From 10860c2ef552bbd25b950e7a3e72431d7af01dcb Mon Sep 17 00:00:00 2001 From: "Josiah (Gaming32) Glosson" Date: Tue, 14 May 2024 19:03:57 -0500 Subject: [PATCH] Fix race condition --- .../github/gaming32/worldhost/proxy/ProxyClient.java | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/main/java/io/github/gaming32/worldhost/proxy/ProxyClient.java b/src/main/java/io/github/gaming32/worldhost/proxy/ProxyClient.java index 0b6e74d..4b00020 100644 --- a/src/main/java/io/github/gaming32/worldhost/proxy/ProxyClient.java +++ b/src/main/java/io/github/gaming32/worldhost/proxy/ProxyClient.java @@ -13,6 +13,7 @@ import io.netty.channel.local.LocalChannel; import net.minecraft.server.network.ServerConnectionListener; +import java.io.ByteArrayOutputStream; import java.io.IOException; import java.net.InetAddress; import java.util.function.Supplier; @@ -24,6 +25,7 @@ public final class ProxyClient extends SimpleChannelInboundHandler { private final long connectionId; private final Supplier proxy; + private ByteArrayOutputStream preActiveBuffer = new ByteArrayOutputStream(); private Channel channel; private boolean closed; @@ -41,9 +43,11 @@ public ProxyClient( } @Override - public void channelActive(ChannelHandlerContext ctx) throws Exception { + public synchronized void channelActive(ChannelHandlerContext ctx) throws Exception { super.channelActive(ctx); channel = ctx.channel(); + send(preActiveBuffer.toByteArray()); + preActiveBuffer = null; WorldHost.LOGGER.info("Started proxy client from {}", remoteAddress); } @@ -107,7 +111,11 @@ public void close() { } } - public void send(byte[] message) { + public synchronized void send(byte[] message) { + if (channel == null) { + preActiveBuffer.writeBytes(message); + return; + } if (channel.eventLoop().inEventLoop()) { doSend(message); } else {