2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: kashike <kashike@vq.lc>
|
|
|
|
Date: Wed, 13 Apr 2016 20:21:38 -0700
|
|
|
|
Subject: [PATCH] Add handshake event to allow plugins to handle client
|
|
|
|
handshaking logic themselves
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
2023-09-22 19:31:02 +02:00
|
|
|
index a12d23b03d64aacaf1f231039333aec94245a89a..c1eb9f999c1042da804a3560d12c14f5d67b7953 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
2023-03-14 19:36:39 +01:00
|
|
|
@@ -89,9 +89,36 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
|
2022-06-07 21:55:39 +02:00
|
|
|
this.connection.disconnect(ichatmutablecomponent);
|
2021-06-11 14:02:28 +02:00
|
|
|
} else {
|
|
|
|
this.connection.setListener(new ServerLoginPacketListenerImpl(this.server, this.connection));
|
|
|
|
+ // Paper start - handshake event
|
|
|
|
+ boolean proxyLogicEnabled = org.spigotmc.SpigotConfig.bungee;
|
|
|
|
+ boolean handledByEvent = false;
|
|
|
|
+ // Try and handle the handshake through the event
|
|
|
|
+ if (com.destroystokyo.paper.event.player.PlayerHandshakeEvent.getHandlerList().getRegisteredListeners().length != 0) { // Hello? Can you hear me?
|
2021-06-12 06:38:04 +02:00
|
|
|
+ java.net.SocketAddress socketAddress = this.connection.address;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ String hostnameOfRemote = socketAddress instanceof java.net.InetSocketAddress ? ((java.net.InetSocketAddress) socketAddress).getHostString() : InetAddress.getLoopbackAddress().getHostAddress();
|
2023-09-22 19:31:02 +02:00
|
|
|
+ com.destroystokyo.paper.event.player.PlayerHandshakeEvent event = new com.destroystokyo.paper.event.player.PlayerHandshakeEvent(packet.hostName(), hostnameOfRemote, !proxyLogicEnabled);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ if (event.callEvent()) {
|
|
|
|
+ // If we've failed somehow, let the client know so and go no further.
|
|
|
|
+ if (event.isFailed()) {
|
2022-03-05 21:20:52 +01:00
|
|
|
+ Component component = io.papermc.paper.adventure.PaperAdventure.asVanilla(event.failMessage());
|
|
|
|
+ this.connection.send(new ClientboundLoginDisconnectPacket(component));
|
|
|
|
+ this.connection.disconnect(component);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (event.getServerHostname() != null) packet.hostName = event.getServerHostname();
|
2021-06-12 06:38:04 +02:00
|
|
|
+ if (event.getSocketAddressHostname() != null) this.connection.address = new java.net.InetSocketAddress(event.getSocketAddressHostname(), socketAddress instanceof java.net.InetSocketAddress ? ((java.net.InetSocketAddress) socketAddress).getPort() : 0);
|
|
|
|
+ this.connection.spoofedUUID = event.getUniqueId();
|
|
|
|
+ this.connection.spoofedProfile = gson.fromJson(event.getPropertiesJson(), com.mojang.authlib.properties.Property[].class);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ handledByEvent = true; // Hooray, we did it!
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
// Spigot Start
|
2023-09-21 22:14:58 +02:00
|
|
|
String[] split = packet.hostName().split("\00");
|
2021-06-11 14:02:28 +02:00
|
|
|
- if (org.spigotmc.SpigotConfig.bungee) {
|
2021-12-02 21:21:33 +01:00
|
|
|
+ // Don't try and handle default logic if it's been handled by the event.
|
|
|
|
+ if (!handledByEvent && proxyLogicEnabled) {
|
|
|
|
+ // Paper end
|
|
|
|
+ // if (org.spigotmc.SpigotConfig.bungee) { // Paper - comment out, we check above!
|
2021-06-12 06:38:04 +02:00
|
|
|
if ( ( split.length == 3 || split.length == 4 ) && ( ServerHandshakePacketListenerImpl.HOST_PATTERN.matcher( split[1] ).matches() ) ) {
|
2023-09-21 22:14:58 +02:00
|
|
|
connection.hostname = split[0];
|
2021-12-02 21:21:33 +01:00
|
|
|
connection.address = new java.net.InetSocketAddress(split[1], ((java.net.InetSocketAddress) this.connection.getRemoteAddress()).getPort());
|