/* * (C) Copyright 2015-2016 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Contributors: * ohun@live.cn (夜色) */ package com.mpush.client.connect; import com.google.common.eventbus.Subscribe; import com.mpush.api.event.ConnectionCloseEvent; import com.mpush.netty.client.NettyTCPClient; import com.mpush.tools.event.EventBus; import io.netty.channel.ChannelHandler; public class ConnectClient extends NettyTCPClient { private final ConnClientChannelHandler handler; public ConnectClient(String host, int port, ClientConfig config) { handler = new ConnClientChannelHandler(config); EventBus.I.register(this); } @Override public ChannelHandler getChannelHandler() { return handler; } @Subscribe void on(ConnectionCloseEvent event) { this.stop(); } @Override protected int getWorkThreadNum() { return 1; } }