2019-05-14 10:00:00 +10:00
From ff4fd6591cc3dab65da1b45c11645b3829ec6dee Mon Sep 17 00:00:00 2001
2014-04-12 14:18:37 +10:00
From: md_5 <md_5@live.com.au>
Date: Sun, 1 Dec 2013 18:18:41 +1100
Subject: [PATCH] BungeeCord Support
Provides support for IP forwarding via BungeeCord.
diff --git a/src/main/java/net/minecraft/server/HandshakeListener.java b/src/main/java/net/minecraft/server/HandshakeListener.java
2019-04-25 12:00:00 +10:00
index f72d4cf15..1ef8e8653 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/net/minecraft/server/HandshakeListener.java
+++ b/src/main/java/net/minecraft/server/HandshakeListener.java
2015-02-28 11:36:22 +00:00
@@ -7,6 +7,7 @@ import java.util.HashMap;
2014-04-12 14:38:17 +10:00
public class HandshakeListener implements PacketHandshakingInListener {
2015-02-28 11:36:22 +00:00
2014-04-14 11:41:45 +10:00
+ private static final com.google.gson.Gson gson = new com.google.gson.Gson(); // Spigot
// CraftBukkit start - add fields
private static final HashMap<InetAddress, Long> throttleTracker = new HashMap<InetAddress, Long>();
private static int throttleCounter = 0;
2019-04-23 12:00:00 +10:00
@@ -72,6 +73,26 @@ public class HandshakeListener implements PacketHandshakingInListener {
2017-05-30 21:24:00 +10:00
this.b.close(chatmessage);
2014-04-12 14:18:37 +10:00
} else {
2016-03-01 08:33:06 +11:00
this.b.setPacketListener(new LoginListener(this.a, this.b));
2014-04-12 14:18:37 +10:00
+ // Spigot Start
+ if (org.spigotmc.SpigotConfig.bungee) {
2015-07-30 17:22:16 +10:00
+ String[] split = packethandshakinginsetprotocol.hostname.split("\00");
2014-04-14 11:41:45 +10:00
+ if ( split.length == 3 || split.length == 4 ) {
2015-07-30 17:22:16 +10:00
+ packethandshakinginsetprotocol.hostname = split[0];
2018-12-13 11:00:00 +11:00
+ b.socketAddress = new java.net.InetSocketAddress(split[1], ((java.net.InetSocketAddress) b.getSocketAddress()).getPort());
2014-11-26 08:27:08 +11:00
+ b.spoofedUUID = com.mojang.util.UUIDTypeAdapter.fromString( split[2] );
2014-04-12 14:18:37 +10:00
+ } else
+ {
2017-05-30 21:24:00 +10:00
+ chatmessage = new ChatMessage("If you wish to use IP forwarding, please enable it in your BungeeCord config as well!");
+ this.b.sendPacket(new PacketLoginOutDisconnect(chatmessage));
+ this.b.close(chatmessage);
2014-04-12 14:18:37 +10:00
+ return;
+ }
2014-04-14 11:41:45 +10:00
+ if ( split.length == 4 )
+ {
2014-11-26 08:27:08 +11:00
+ b.spoofedProfile = gson.fromJson(split[3], com.mojang.authlib.properties.Property[].class);
2014-04-14 11:41:45 +10:00
+ }
2014-04-12 14:18:37 +10:00
+ }
+ // Spigot End
2016-03-01 08:33:06 +11:00
((LoginListener) this.b.i()).hostname = packethandshakinginsetprotocol.hostname + ":" + packethandshakinginsetprotocol.port; // CraftBukkit - set hostname
2014-04-12 14:18:37 +10:00
}
break;
diff --git a/src/main/java/net/minecraft/server/LoginListener.java b/src/main/java/net/minecraft/server/LoginListener.java
2019-04-25 12:00:00 +10:00
index 11a18196d..b85b048ac 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/net/minecraft/server/LoginListener.java
+++ b/src/main/java/net/minecraft/server/LoginListener.java
2019-04-23 12:00:00 +10:00
@@ -95,9 +95,24 @@ public class LoginListener implements PacketLoginInListener {
2014-04-12 14:18:37 +10:00
// Spigot start
public void initUUID()
{
2018-07-15 10:00:00 +10:00
- UUID uuid = EntityHuman.getOfflineUUID( this.i.getName() );
2014-04-12 14:38:17 +10:00
+ UUID uuid;
2014-04-12 14:18:37 +10:00
+ if ( networkManager.spoofedUUID != null )
+ {
+ uuid = networkManager.spoofedUUID;
+ } else
+ {
2018-07-15 10:00:00 +10:00
+ uuid = EntityHuman.getOfflineUUID( this.i.getName() );
2014-04-12 14:18:37 +10:00
+ }
2014-04-12 14:38:17 +10:00
2014-04-12 14:18:37 +10:00
this.i = new GameProfile( uuid, this.i.getName() );
2014-04-14 11:41:45 +10:00
+
+ if (networkManager.spoofedProfile != null)
+ {
2014-11-26 08:27:08 +11:00
+ for ( com.mojang.authlib.properties.Property property : networkManager.spoofedProfile )
2014-04-14 11:41:45 +10:00
+ {
+ this.i.getProperties().put( property.getName(), property );
+ }
+ }
2014-04-12 14:18:37 +10:00
}
2014-04-14 11:41:45 +10:00
// Spigot end
2014-04-12 14:18:37 +10:00
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
2019-04-25 12:00:00 +10:00
index 1b46c7d97..374749b16 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/net/minecraft/server/NetworkManager.java
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
2018-12-26 08:00:00 +11:00
@@ -47,6 +47,10 @@ public class NetworkManager extends SimpleChannelInboundHandler<Packet<?>> {
2015-02-28 11:36:22 +00:00
private final ReentrantReadWriteLock j = new ReentrantReadWriteLock();
2015-06-06 19:47:02 +10:00
public Channel channel;
2018-12-13 11:00:00 +11:00
public SocketAddress socketAddress;
+ // Spigot Start
2014-04-14 11:41:45 +10:00
+ public java.util.UUID spoofedUUID;
2014-11-26 08:27:08 +11:00
+ public com.mojang.authlib.properties.Property[] spoofedProfile;
2014-04-14 11:41:45 +10:00
+ // Spigot End
2018-12-13 11:00:00 +11:00
private PacketListener packetListener;
2015-02-28 11:36:22 +00:00
private IChatBaseComponent n;
private boolean o;
2019-04-23 12:00:00 +10:00
@@ -333,4 +337,11 @@ public class NetworkManager extends SimpleChannelInboundHandler<Packet<?>> {
2018-07-15 10:00:00 +10:00
this.b = genericfuturelistener;
2015-02-28 11:36:22 +00:00
}
2014-04-12 14:18:37 +10:00
}
+
+ // Spigot Start
+ public SocketAddress getRawAddress()
+ {
2015-05-09 21:23:26 +01:00
+ return this.channel.remoteAddress();
2014-04-12 14:18:37 +10:00
+ }
+ // Spigot End
}
2014-04-14 11:41:45 +10:00
diff --git a/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java b/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
2019-04-25 12:00:00 +10:00
index 6aeea22ae..4f008e472 100644
2014-04-14 11:41:45 +10:00
--- a/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
+++ b/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
2019-04-23 12:00:00 +10:00
@@ -14,7 +14,7 @@ public class PacketHandshakingInSetProtocol implements Packet<PacketHandshakingI
@Override
2015-02-28 11:36:22 +00:00
public void a(PacketDataSerializer packetdataserializer) throws IOException {
2019-04-23 12:00:00 +10:00
this.a = packetdataserializer.i();
2016-03-30 22:20:25 +01:00
- this.hostname = packetdataserializer.e(255);
+ this.hostname = packetdataserializer.e(Short.MAX_VALUE); // Spigot
2015-07-30 17:22:16 +10:00
this.port = packetdataserializer.readUnsignedShort();
2019-04-23 12:00:00 +10:00
this.d = EnumProtocol.a(packetdataserializer.i());
2014-04-14 11:41:45 +10:00
}
2014-04-12 14:18:37 +10:00
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
2019-05-14 10:00:00 +10:00
index b5af4da99..bcbb718b6 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/net/minecraft/server/PlayerList.java
+++ b/src/main/java/net/minecraft/server/PlayerList.java
2019-05-12 11:18:39 +10:00
@@ -458,7 +458,7 @@ public abstract class PlayerList {
2014-04-12 14:18:37 +10:00
2018-08-26 12:00:00 +10:00
EntityPlayer entity = new EntityPlayer(this.server, this.server.getWorldServer(DimensionManager.OVERWORLD), gameprofile, new PlayerInteractManager(this.server.getWorldServer(DimensionManager.OVERWORLD)));
2014-04-12 14:18:37 +10:00
Player player = entity.getBukkitEntity();
- PlayerLoginEvent event = new PlayerLoginEvent(player, hostname, ((java.net.InetSocketAddress) socketaddress).getAddress());
+ PlayerLoginEvent event = new PlayerLoginEvent(player, hostname, ((java.net.InetSocketAddress) socketaddress).getAddress(), ((java.net.InetSocketAddress) loginlistener.networkManager.getRawAddress()).getAddress());
2014-11-26 08:27:08 +11:00
if (getProfileBans().isBanned(gameprofile) && !getProfileBans().get(gameprofile).hasExpired()) {
2018-07-15 10:00:00 +10:00
GameProfileBanEntry gameprofilebanentry = (GameProfileBanEntry) this.k.get(gameprofile);
2014-05-06 16:10:35 +10:00
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2019-05-14 10:00:00 +10:00
index d49592467..7f10ff02f 100644
2014-05-06 16:10:35 +10:00
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2019-04-24 10:12:26 +10:00
@@ -620,7 +620,13 @@ public final class CraftServer implements Server {
2014-05-06 16:10:35 +10:00
2014-06-27 20:49:31 +10:00
@Override
2014-05-06 16:10:35 +10:00
public long getConnectionThrottle() {
- return this.configuration.getInt("settings.connection-throttle");
+ // Spigot Start - Automatically set connection throttle for bungee configurations
+ if (org.spigotmc.SpigotConfig.bungee) {
+ return -1;
+ } else {
+ return this.configuration.getInt("settings.connection-throttle");
+ }
+ // Spigot End
}
2014-06-27 20:49:31 +10:00
@Override
2014-04-12 14:18:37 +10:00
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
2019-05-12 11:18:39 +10:00
index 79a500934..13cb7f8a4 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
2019-04-28 11:41:06 +10:00
@@ -1644,6 +1644,12 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
2017-11-07 17:30:57 +11:00
private final Player.Spigot spigot = new Player.Spigot()
2014-04-12 14:18:37 +10:00
{
2017-11-07 17:30:57 +11:00
+ @Override
2014-04-12 14:18:37 +10:00
+ public InetSocketAddress getRawAddress()
+ {
+ return (InetSocketAddress) getHandle().playerConnection.networkManager.getRawAddress();
+ }
+
2017-11-07 17:30:57 +11:00
@Override
2016-03-27 20:36:54 +11:00
public boolean getCollidesWithEntities() {
return CraftPlayer.this.isCollidable();
2014-04-12 14:18:37 +10:00
diff --git a/src/main/java/org/spigotmc/SpigotConfig.java b/src/main/java/org/spigotmc/SpigotConfig.java
2019-04-30 21:46:22 +10:00
index 37bf0cec0..642f3a39a 100644
2014-04-12 14:18:37 +10:00
--- a/src/main/java/org/spigotmc/SpigotConfig.java
+++ b/src/main/java/org/spigotmc/SpigotConfig.java
2018-07-16 20:30:51 +10:00
@@ -214,4 +214,14 @@ public class SpigotConfig
2014-04-12 14:18:37 +10:00
commands.put( "restart", new RestartCommand( "restart" ) );
WatchdogThread.doStart( timeoutTime, restartOnCrash );
}
+
+ public static boolean bungee;
+ private static void bungee() {
+ if ( version < 4 )
+ {
+ set( "settings.bungeecord", false );
+ System.out.println( "Oudated config, disabling BungeeCord support!" );
+ }
+ bungee = getBoolean( "settings.bungeecord", false );
+ }
}
--
2019-04-23 09:33:25 +10:00
2.20.1
2014-04-12 14:18:37 +10:00