(BROKEN) добавлен PingPacket
This commit is contained in:
@@ -18,6 +18,7 @@ import mc.protocol.io.codec.ProtocolSplitter;
|
||||
import mc.server.network.Server;
|
||||
import mc.server.network.netty.handler.HandshakeHandler;
|
||||
import mc.server.network.netty.NettyServer;
|
||||
import mc.server.network.netty.handler.KeepAliveHandler;
|
||||
import mc.server.network.netty.handler.LoginHandler;
|
||||
import mc.server.network.netty.handler.StatusHandler;
|
||||
|
||||
@@ -59,7 +60,8 @@ public class NetworkModule {
|
||||
@Provides
|
||||
Map<String, ChannelHandler> provideChannelHandlerMap(
|
||||
Provider<StatusHandler> statusHandlerProvider,
|
||||
Provider<LoginHandler> loginHandlerProvider
|
||||
Provider<LoginHandler> loginHandlerProvider,
|
||||
Provider<KeepAliveHandler> keepAliveHandlerProvider
|
||||
) {
|
||||
Map<String, ChannelHandler> map = new LinkedHashMap<>();
|
||||
|
||||
@@ -67,7 +69,8 @@ public class NetworkModule {
|
||||
map.put("protocol_splitter", new ProtocolSplitter());
|
||||
map.put("protocol_decoder", new ProtocolDecoder(true));
|
||||
map.put("protocol_encoder", new ProtocolEncoder());
|
||||
map.put("handshake_handler", new HandshakeHandler(statusHandlerProvider, loginHandlerProvider));
|
||||
map.put("handshake_handler", new HandshakeHandler(
|
||||
statusHandlerProvider, loginHandlerProvider, keepAliveHandlerProvider));
|
||||
|
||||
return map;
|
||||
}
|
||||
@@ -81,4 +84,9 @@ public class NetworkModule {
|
||||
LoginHandler provideLoginHandler() {
|
||||
return new LoginHandler();
|
||||
}
|
||||
|
||||
@Provides
|
||||
KeepAliveHandler provideKeepAliveHandler() {
|
||||
return new KeepAliveHandler();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,6 +15,7 @@ public class HandshakeHandler extends AbstractPacketHandler<HandshakePacket> {
|
||||
|
||||
private final Provider<StatusHandler> statusHandlerProvider;
|
||||
private final Provider<LoginHandler> loginHandlerProvider;
|
||||
private final Provider<KeepAliveHandler> keepAliveHandlerProvider;
|
||||
|
||||
@Override
|
||||
protected void channelRead1(ChannelHandlerContext ctx, HandshakePacket packet) {
|
||||
@@ -24,6 +25,7 @@ public class HandshakeHandler extends AbstractPacketHandler<HandshakePacket> {
|
||||
|
||||
if (State.STATUS == packet.getNextState()) {
|
||||
ctx.pipeline().replace("handshake_handler", "status_handler", statusHandlerProvider.get());
|
||||
ctx.pipeline().addAfter("status_handler", "keepalive_handler", keepAliveHandlerProvider.get());
|
||||
} else if (State.LOGIN == packet.getNextState()) {
|
||||
ctx.channel().pipeline().replace("handshake_handler", "login_handler", loginHandlerProvider.get());
|
||||
}
|
||||
|
||||
@@ -0,0 +1,16 @@
|
||||
package mc.server.network.netty.handler;
|
||||
|
||||
import io.netty.channel.ChannelHandlerContext;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import mc.protocol.packets.PingPacket;
|
||||
|
||||
@Slf4j
|
||||
public class KeepAliveHandler extends AbstractPacketHandler<PingPacket> {
|
||||
|
||||
@Override
|
||||
protected void channelRead1(ChannelHandlerContext ctx, PingPacket packet) {
|
||||
log.info("{}", packet);
|
||||
|
||||
ctx.writeAndFlush(packet).channel().disconnect();
|
||||
}
|
||||
}
|
||||
@@ -28,6 +28,6 @@ public class StatusHandler extends AbstractPacketHandler<StatusServerRequest> {
|
||||
" }\n" +
|
||||
"}");
|
||||
|
||||
ctx.channel().writeAndFlush(response).channel().disconnect();
|
||||
ctx.channel().writeAndFlush(response);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user