2018-07-22 12:00:00 +10:00
From a3883ae11de748a8f4482a557fe68d93dd109a9b 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
2018-07-22 12:00:00 +10:00
index 387d8a09f..5b784002f 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;
2016-05-10 21:48:25 +10:00
@@ -71,6 +72,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];
2015-02-28 11:36:22 +00:00
+ b.l = 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
2018-07-22 12:00:00 +10:00
index 0cf9d4bde..a22f4c55e 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
2018-07-15 10:00:00 +10:00
@@ -96,9 +96,24 @@ public class LoginListener implements PacketLoginInListener, ITickable {
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
2018-07-22 12:00:00 +10:00
index 8a9b5046c..f3f77aebe 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-07-15 10:00:00 +10:00
@@ -47,7 +47,11 @@ public class NetworkManager extends SimpleChannelInboundHandler<Packet<?>> {
2015-02-28 11:36:22 +00:00
private final Queue<NetworkManager.QueuedPacket> i = Queues.newConcurrentLinkedQueue();
private final ReentrantReadWriteLock j = new ReentrantReadWriteLock();
2015-06-06 19:47:02 +10:00
public Channel channel;
2015-02-28 11:36:22 +00:00
- private SocketAddress l;
2015-06-06 19:47:02 +10:00
+ // Spigot Start // PAIL
2015-02-28 11:36:22 +00:00
+ public SocketAddress l;
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
2015-02-28 11:36:22 +00:00
private PacketListener m;
private IChatBaseComponent n;
private boolean o;
2018-07-15 10:00:00 +10:00
@@ -334,4 +338,11 @@ public class NetworkManager extends SimpleChannelInboundHandler<Packet<?>> {
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
2018-07-22 12:00:00 +10:00
index 47b871dfc..7acdac55e 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
2015-02-28 11:36:22 +00:00
@@ -13,7 +13,7 @@ public class PacketHandshakingInSetProtocol implements Packet<PacketHandshakingI
2014-04-14 11:41:45 +10:00
2015-02-28 11:36:22 +00:00
public void a(PacketDataSerializer packetdataserializer) throws IOException {
2016-03-01 08:33:06 +11:00
this.a = packetdataserializer.g();
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();
2016-03-01 08:33:06 +11:00
this.d = EnumProtocol.a(packetdataserializer.g());
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
2018-07-22 12:00:00 +10:00
index 668452809..9d0e29df7 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
2018-07-15 10:00:00 +10:00
@@ -479,7 +479,7 @@ public abstract class PlayerList {
2014-04-12 14:18:37 +10:00
2018-07-15 10:00:00 +10:00
EntityPlayer entity = new EntityPlayer(this.server, this.server.a(DimensionManager.OVERWORLD), gameprofile, new PlayerInteractManager(this.server.a(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
2018-07-22 12:00:00 +10:00
index 2ef172a4e..eb4ba4c40 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
2018-07-16 12:16:51 +10:00
@@ -606,7 +606,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
2018-07-22 12:00:00 +10:00
index 3ce1218a4..6290c9374 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
2018-07-15 10:00:00 +10:00
@@ -1581,6 +1581,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
2018-07-22 12:00:00 +10:00
index d8145db91..06081dc64 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 );
+ }
}
--
2018-07-15 10:00:00 +10:00
2.17.1
2014-04-12 14:18:37 +10:00