RpcPeer.java revision 46e1faa3
1420c9859SShuo Chenpackage muduo.rpc;
2420c9859SShuo Chen
3420c9859SShuo Chenimport java.util.Collections;
4420c9859SShuo Chenimport java.util.Map;
5420c9859SShuo Chenimport java.util.concurrent.ConcurrentHashMap;
6420c9859SShuo Chen
7420c9859SShuo Chenimport org.jboss.netty.channel.Channel;
8420c9859SShuo Chen
9420c9859SShuo Chenimport com.google.protobuf.Service;
10420c9859SShuo Chen
11420c9859SShuo Chenpublic abstract class RpcPeer {
12420c9859SShuo Chen
13420c9859SShuo Chen    protected NewChannelCallback newChannelCallback;
14420c9859SShuo Chen    protected Map<String, Service> services = new ConcurrentHashMap<String, Service>();
15420c9859SShuo Chen
16420c9859SShuo Chen    public void registerService(Service service) {
17420c9859SShuo Chen        services.put(service.getDescriptorForType().getFullName(), service);
18420c9859SShuo Chen    }
19420c9859SShuo Chen
20420c9859SShuo Chen    public void setNewChannelCallback(NewChannelCallback newChannelCallback) {
21420c9859SShuo Chen        this.newChannelCallback = newChannelCallback;
22420c9859SShuo Chen    }
2346e1faa3SShuo Chen
24420c9859SShuo Chen    protected void setupNewChannel(RpcChannel rpcChannel) {
25420c9859SShuo Chen        Channel channel = rpcChannel.getChannel();
26420c9859SShuo Chen        RpcMessageHandler handler = (RpcMessageHandler) channel.getPipeline().get("handler");
27420c9859SShuo Chen        handler.setChannel(rpcChannel);
28420c9859SShuo Chen        rpcChannel.setServiceMap(Collections.unmodifiableMap(services));
29420c9859SShuo Chen        if (newChannelCallback != null) {
30420c9859SShuo Chen            newChannelCallback.run(rpcChannel);
31420c9859SShuo Chen        }
32420c9859SShuo Chen    }
3346e1faa3SShuo Chen
34420c9859SShuo Chen    public abstract void channelConnected(Channel channel);
35420c9859SShuo Chen}
36