mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-03 23:07:40 +01:00
Add Channel initialization listeners
This commit is contained in:
parent
639cb2d6aa
commit
3ab2001afb
@ -29,7 +29,7 @@
|
|||||||
@Nullable
|
@Nullable
|
||||||
private volatile PacketListener disconnectListener;
|
private volatile PacketListener disconnectListener;
|
||||||
@Nullable
|
@Nullable
|
||||||
@@ -114,7 +119,25 @@
|
@@ -114,6 +119,24 @@
|
||||||
private volatile DisconnectionDetails delayedDisconnect;
|
private volatile DisconnectionDetails delayedDisconnect;
|
||||||
@Nullable
|
@Nullable
|
||||||
BandwidthDebugMonitor bandwidthDebugMonitor;
|
BandwidthDebugMonitor bandwidthDebugMonitor;
|
||||||
@ -39,7 +39,7 @@
|
|||||||
+ public java.net.InetSocketAddress virtualHost;
|
+ public java.net.InetSocketAddress virtualHost;
|
||||||
+ private static boolean enableExplicitFlush = Boolean.getBoolean("paper.explicit-flush"); // Paper - Disable explicit network manager flushing
|
+ private static boolean enableExplicitFlush = Boolean.getBoolean("paper.explicit-flush"); // Paper - Disable explicit network manager flushing
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
+
|
||||||
+ // Paper start - add utility methods
|
+ // Paper start - add utility methods
|
||||||
+ public final net.minecraft.server.level.ServerPlayer getPlayer() {
|
+ public final net.minecraft.server.level.ServerPlayer getPlayer() {
|
||||||
+ if (this.packetListener instanceof net.minecraft.server.network.ServerGamePacketListenerImpl impl) {
|
+ if (this.packetListener instanceof net.minecraft.server.network.ServerGamePacketListenerImpl impl) {
|
||||||
@ -51,10 +51,9 @@
|
|||||||
+ return null;
|
+ return null;
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end - add utility methods
|
+ // Paper end - add utility methods
|
||||||
+
|
|
||||||
public Connection(PacketFlow side) {
|
public Connection(PacketFlow side) {
|
||||||
this.receiving = side;
|
this.receiving = side;
|
||||||
}
|
|
||||||
@@ -123,6 +146,9 @@
|
@@ -123,6 +146,9 @@
|
||||||
super.channelActive(channelhandlercontext);
|
super.channelActive(channelhandlercontext);
|
||||||
this.channel = channelhandlercontext.channel();
|
this.channel = channelhandlercontext.channel();
|
||||||
@ -163,7 +162,23 @@
|
|||||||
public void write(ChannelHandlerContext channelhandlercontext, Object object, ChannelPromise channelpromise) throws Exception {
|
public void write(ChannelHandlerContext channelhandlercontext, Object object, ChannelPromise channelpromise) throws Exception {
|
||||||
super.write(channelhandlercontext, object, channelpromise);
|
super.write(channelhandlercontext, object, channelpromise);
|
||||||
}
|
}
|
||||||
@@ -661,6 +708,27 @@
|
@@ -633,6 +680,7 @@
|
||||||
|
} else {
|
||||||
|
this.channel.pipeline().addAfter("prepender", "compress", new CompressionEncoder(compressionThreshold));
|
||||||
|
}
|
||||||
|
+ this.channel.pipeline().fireUserEventTriggered(io.papermc.paper.network.ConnectionEvent.COMPRESSION_THRESHOLD_SET); // Paper - Add Channel initialization listeners
|
||||||
|
} else {
|
||||||
|
if (this.channel.pipeline().get("decompress") instanceof CompressionDecoder) {
|
||||||
|
this.channel.pipeline().remove("decompress");
|
||||||
|
@@ -641,6 +689,7 @@
|
||||||
|
if (this.channel.pipeline().get("compress") instanceof CompressionEncoder) {
|
||||||
|
this.channel.pipeline().remove("compress");
|
||||||
|
}
|
||||||
|
+ this.channel.pipeline().fireUserEventTriggered(io.papermc.paper.network.ConnectionEvent.COMPRESSION_DISABLED); // Paper - Add Channel initialization listeners
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
@@ -661,6 +710,27 @@
|
||||||
|
|
||||||
packetlistener1.onDisconnect(disconnectiondetails);
|
packetlistener1.onDisconnect(disconnectiondetails);
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
public ServerConnectionListener(MinecraftServer server) {
|
public ServerConnectionListener(MinecraftServer server) {
|
||||||
this.server = server;
|
this.server = server;
|
||||||
@@ -100,16 +109,27 @@
|
@@ -100,16 +109,28 @@
|
||||||
|
|
||||||
Connection.configureSerialization(channelpipeline, PacketFlow.SERVERBOUND, false, (BandwidthDebugMonitor) null);
|
Connection.configureSerialization(channelpipeline, PacketFlow.SERVERBOUND, false, (BandwidthDebugMonitor) null);
|
||||||
int j = ServerConnectionListener.this.server.getRateLimitPacketsPerSecond();
|
int j = ServerConnectionListener.this.server.getRateLimitPacketsPerSecond();
|
||||||
@ -39,6 +39,7 @@
|
|||||||
+ pending.add(object); // Paper - prevent blocking on adding a new connection while the server is ticking
|
+ pending.add(object); // Paper - prevent blocking on adding a new connection while the server is ticking
|
||||||
((Connection) object).configurePacketHandler(channelpipeline);
|
((Connection) object).configurePacketHandler(channelpipeline);
|
||||||
((Connection) object).setListenerForServerboundHandshake(new ServerHandshakePacketListenerImpl(ServerConnectionListener.this.server, (Connection) object));
|
((Connection) object).setListenerForServerboundHandshake(new ServerHandshakePacketListenerImpl(ServerConnectionListener.this.server, (Connection) object));
|
||||||
|
+ io.papermc.paper.network.ChannelInitializeListenerHolder.callListeners(channel); // Paper - Add Channel initialization listeners
|
||||||
}
|
}
|
||||||
- }).group(eventloopgroup).localAddress(address, port)).bind().syncUninterruptibly());
|
- }).group(eventloopgroup).localAddress(address, port)).bind().syncUninterruptibly());
|
||||||
+ }).group(eventloopgroup).localAddress(address, port)).option(ChannelOption.AUTO_READ, false).bind().syncUninterruptibly()); // CraftBukkit
|
+ }).group(eventloopgroup).localAddress(address, port)).option(ChannelOption.AUTO_READ, false).bind().syncUninterruptibly()); // CraftBukkit
|
||||||
@ -58,7 +59,7 @@
|
|||||||
public SocketAddress startMemoryChannel() {
|
public SocketAddress startMemoryChannel() {
|
||||||
List list = this.channels;
|
List list = this.channels;
|
||||||
ChannelFuture channelfuture;
|
ChannelFuture channelfuture;
|
||||||
@@ -153,6 +173,14 @@
|
@@ -153,6 +174,14 @@
|
||||||
List list = this.connections;
|
List list = this.connections;
|
||||||
|
|
||||||
synchronized (this.connections) {
|
synchronized (this.connections) {
|
||||||
@ -73,7 +74,7 @@
|
|||||||
Iterator<Connection> iterator = this.connections.iterator();
|
Iterator<Connection> iterator = this.connections.iterator();
|
||||||
|
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
@@ -176,6 +204,10 @@
|
@@ -176,6 +205,10 @@
|
||||||
networkmanager.setReadOnly();
|
networkmanager.setReadOnly();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -0,0 +1,15 @@
|
|||||||
|
package io.papermc.paper.network;
|
||||||
|
|
||||||
|
import io.netty.channel.Channel;
|
||||||
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal API to register channel initialization listeners.
|
||||||
|
* <p>
|
||||||
|
* This is not officially supported API and we make no guarantees to the existence or state of this interface.
|
||||||
|
*/
|
||||||
|
@FunctionalInterface
|
||||||
|
public interface ChannelInitializeListener {
|
||||||
|
|
||||||
|
void afterInitChannel(@NonNull Channel channel);
|
||||||
|
}
|
@ -0,0 +1,74 @@
|
|||||||
|
package io.papermc.paper.network;
|
||||||
|
|
||||||
|
import io.netty.channel.Channel;
|
||||||
|
import net.kyori.adventure.key.Key;
|
||||||
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
import org.checkerframework.checker.nullness.qual.Nullable;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal API to register channel initialization listeners.
|
||||||
|
* <p>
|
||||||
|
* This is not officially supported API and we make no guarantees to the existence or state of this class.
|
||||||
|
*/
|
||||||
|
public final class ChannelInitializeListenerHolder {
|
||||||
|
|
||||||
|
private static final Map<Key, ChannelInitializeListener> LISTENERS = new HashMap<>();
|
||||||
|
private static final Map<Key, ChannelInitializeListener> IMMUTABLE_VIEW = Collections.unmodifiableMap(LISTENERS);
|
||||||
|
|
||||||
|
private ChannelInitializeListenerHolder() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers whether an initialization listener is registered under the given key.
|
||||||
|
*
|
||||||
|
* @param key key
|
||||||
|
* @return whether an initialization listener is registered under the given key
|
||||||
|
*/
|
||||||
|
public static boolean hasListener(@NonNull Key key) {
|
||||||
|
return LISTENERS.containsKey(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers a channel initialization listener called after ServerConnection is initialized.
|
||||||
|
*
|
||||||
|
* @param key key
|
||||||
|
* @param listener initialization listeners
|
||||||
|
*/
|
||||||
|
public static void addListener(@NonNull Key key, @NonNull ChannelInitializeListener listener) {
|
||||||
|
LISTENERS.put(key, listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes and returns an initialization listener registered by the given key if present.
|
||||||
|
*
|
||||||
|
* @param key key
|
||||||
|
* @return removed initialization listener if present
|
||||||
|
*/
|
||||||
|
public static @Nullable ChannelInitializeListener removeListener(@NonNull Key key) {
|
||||||
|
return LISTENERS.remove(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an immutable map of registered initialization listeners.
|
||||||
|
*
|
||||||
|
* @return immutable map of registered initialization listeners
|
||||||
|
*/
|
||||||
|
public static @NonNull Map<Key, ChannelInitializeListener> getListeners() {
|
||||||
|
return IMMUTABLE_VIEW;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calls the registered listeners with the given channel.
|
||||||
|
*
|
||||||
|
* @param channel channel
|
||||||
|
*/
|
||||||
|
public static void callListeners(@NonNull Channel channel) {
|
||||||
|
for (ChannelInitializeListener listener : LISTENERS.values()) {
|
||||||
|
listener.afterInitChannel(channel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
package io.papermc.paper.network;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal connection pipeline events.
|
||||||
|
*/
|
||||||
|
public enum ConnectionEvent {
|
||||||
|
|
||||||
|
COMPRESSION_THRESHOLD_SET,
|
||||||
|
COMPRESSION_DISABLED
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user