geforkt von Mirrors/Paper
Add skin forwarding support for BungeeCord.
Dieser Commit ist enthalten in:
Ursprung
5483861924
Commit
eff9004f15
@ -1,4 +1,4 @@
|
|||||||
From 326665012cc6ce86d73c955b8a61c7880b734c49 Mon Sep 17 00:00:00 2001
|
From 969ea97d8abf9fb99e0a647371546068db211211 Mon Sep 17 00:00:00 2001
|
||||||
From: md_5 <md_5@live.com.au>
|
From: md_5 <md_5@live.com.au>
|
||||||
Date: Sun, 1 Dec 2013 18:18:41 +1100
|
Date: Sun, 1 Dec 2013 18:18:41 +1100
|
||||||
Subject: [PATCH] BungeeCord Support
|
Subject: [PATCH] BungeeCord Support
|
||||||
@ -6,10 +6,15 @@ Subject: [PATCH] BungeeCord Support
|
|||||||
Provides support for IP forwarding via BungeeCord.
|
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
|
diff --git a/src/main/java/net/minecraft/server/HandshakeListener.java b/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
index b98079c..c738ab5 100644
|
index b98079c..ee24038 100644
|
||||||
--- a/src/main/java/net/minecraft/server/HandshakeListener.java
|
--- a/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
+++ b/src/main/java/net/minecraft/server/HandshakeListener.java
|
+++ b/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
@@ -5,6 +5,7 @@ import net.minecraft.util.io.netty.util.concurrent.GenericFutureListener;
|
@@ -1,14 +1,17 @@
|
||||||
|
package net.minecraft.server;
|
||||||
|
|
||||||
|
+import net.minecraft.util.com.mojang.authlib.properties.Property; // Spigot
|
||||||
|
import net.minecraft.util.io.netty.util.concurrent.GenericFutureListener;
|
||||||
|
|
||||||
// CraftBukkit start
|
// CraftBukkit start
|
||||||
import java.net.InetAddress;
|
import java.net.InetAddress;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -17,14 +22,19 @@ index b98079c..c738ab5 100644
|
|||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
|
||||||
public class HandshakeListener implements PacketHandshakingInListener {
|
public class HandshakeListener implements PacketHandshakingInListener {
|
||||||
@@ -73,6 +74,22 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
|
||||||
|
+ 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;
|
||||||
|
@@ -73,6 +76,26 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
||||||
this.b.close(chatcomponenttext);
|
this.b.close(chatcomponenttext);
|
||||||
} else {
|
} else {
|
||||||
this.b.a((PacketListener) (new LoginListener(this.a, this.b)));
|
this.b.a((PacketListener) (new LoginListener(this.a, this.b)));
|
||||||
+ // Spigot Start
|
+ // Spigot Start
|
||||||
+ if (org.spigotmc.SpigotConfig.bungee) {
|
+ if (org.spigotmc.SpigotConfig.bungee) {
|
||||||
+ String[] split = packethandshakinginsetprotocol.b.split("\00");
|
+ String[] split = packethandshakinginsetprotocol.b.split("\00");
|
||||||
+ if ( split.length == 3 ) {
|
+ if ( split.length == 3 || split.length == 4 ) {
|
||||||
+ packethandshakinginsetprotocol.b = split[0];
|
+ packethandshakinginsetprotocol.b = split[0];
|
||||||
+ b.n = new java.net.InetSocketAddress(split[1], ((java.net.InetSocketAddress) b.getSocketAddress()).getPort());
|
+ b.n = new java.net.InetSocketAddress(split[1], ((java.net.InetSocketAddress) b.getSocketAddress()).getPort());
|
||||||
+ b.spoofedUUID = UUIDTypeAdapter.fromString( split[2] );
|
+ b.spoofedUUID = UUIDTypeAdapter.fromString( split[2] );
|
||||||
@ -35,16 +45,28 @@ index b98079c..c738ab5 100644
|
|||||||
+ this.b.close(chatcomponenttext);
|
+ this.b.close(chatcomponenttext);
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
|
+ if ( split.length == 4 )
|
||||||
|
+ {
|
||||||
|
+ b.spoofedProfile = gson.fromJson(split[3], Property[].class);
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ // Spigot End
|
+ // Spigot End
|
||||||
((LoginListener) this.b.getPacketListener()).hostname = packethandshakinginsetprotocol.b + ":" + packethandshakinginsetprotocol.c; // CraftBukkit - set hostname
|
((LoginListener) this.b.getPacketListener()).hostname = packethandshakinginsetprotocol.b + ":" + packethandshakinginsetprotocol.c; // CraftBukkit - set hostname
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
diff --git a/src/main/java/net/minecraft/server/LoginListener.java b/src/main/java/net/minecraft/server/LoginListener.java
|
diff --git a/src/main/java/net/minecraft/server/LoginListener.java b/src/main/java/net/minecraft/server/LoginListener.java
|
||||||
index 0755d36..990dbef 100644
|
index 0755d36..e380a70 100644
|
||||||
--- a/src/main/java/net/minecraft/server/LoginListener.java
|
--- a/src/main/java/net/minecraft/server/LoginListener.java
|
||||||
+++ b/src/main/java/net/minecraft/server/LoginListener.java
|
+++ b/src/main/java/net/minecraft/server/LoginListener.java
|
||||||
@@ -62,7 +62,14 @@ public class LoginListener implements PacketLoginInListener {
|
@@ -9,6 +9,7 @@ import javax.crypto.SecretKey;
|
||||||
|
|
||||||
|
import net.minecraft.util.com.google.common.base.Charsets;
|
||||||
|
import net.minecraft.util.com.mojang.authlib.GameProfile;
|
||||||
|
+import net.minecraft.util.com.mojang.authlib.properties.Property;
|
||||||
|
import net.minecraft.util.io.netty.util.concurrent.GenericFutureListener;
|
||||||
|
import net.minecraft.util.org.apache.commons.lang3.Validate;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
@@ -62,9 +63,24 @@ public class LoginListener implements PacketLoginInListener {
|
||||||
// Spigot start
|
// Spigot start
|
||||||
public void initUUID()
|
public void initUUID()
|
||||||
{
|
{
|
||||||
@ -59,22 +81,43 @@ index 0755d36..990dbef 100644
|
|||||||
+ }
|
+ }
|
||||||
|
|
||||||
this.i = new GameProfile( uuid, this.i.getName() );
|
this.i = new GameProfile( uuid, this.i.getName() );
|
||||||
|
+
|
||||||
|
+ if (networkManager.spoofedProfile != null)
|
||||||
|
+ {
|
||||||
|
+ for ( Property property : networkManager.spoofedProfile )
|
||||||
|
+ {
|
||||||
|
+ this.i.getProperties().put( property.getName(), property );
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
}
|
}
|
||||||
|
// Spigot end
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
index 1dd2227..6789ca8 100644
|
index 1dd2227..e8e20fd 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
@@ -36,7 +36,8 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
@@ -6,6 +6,7 @@ import javax.crypto.SecretKey;
|
||||||
|
|
||||||
|
import net.minecraft.util.com.google.common.collect.Queues;
|
||||||
|
import net.minecraft.util.com.google.common.util.concurrent.ThreadFactoryBuilder;
|
||||||
|
+import net.minecraft.util.com.mojang.authlib.properties.Property;
|
||||||
|
import net.minecraft.util.io.netty.channel.Channel;
|
||||||
|
import net.minecraft.util.io.netty.channel.ChannelFutureListener;
|
||||||
|
import net.minecraft.util.io.netty.channel.ChannelHandlerContext;
|
||||||
|
@@ -36,7 +37,11 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
||||||
private final Queue k = Queues.newConcurrentLinkedQueue();
|
private final Queue k = Queues.newConcurrentLinkedQueue();
|
||||||
private final Queue l = Queues.newConcurrentLinkedQueue();
|
private final Queue l = Queues.newConcurrentLinkedQueue();
|
||||||
private Channel m;
|
private Channel m;
|
||||||
- private SocketAddress n;
|
- private SocketAddress n;
|
||||||
+ public SocketAddress n; // Spigot
|
+ // Spigot Start
|
||||||
+ public java.util.UUID spoofedUUID; // Spigot
|
+ public SocketAddress n;
|
||||||
|
+ public java.util.UUID spoofedUUID;
|
||||||
|
+ public Property[] spoofedProfile;
|
||||||
|
+ // Spigot End
|
||||||
private PacketListener o;
|
private PacketListener o;
|
||||||
private EnumProtocol p;
|
private EnumProtocol p;
|
||||||
private IChatBaseComponent q;
|
private IChatBaseComponent q;
|
||||||
@@ -198,4 +199,11 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
@@ -198,4 +203,11 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
||||||
static Channel a(NetworkManager networkmanager) {
|
static Channel a(NetworkManager networkmanager) {
|
||||||
return networkmanager.m;
|
return networkmanager.m;
|
||||||
}
|
}
|
||||||
@ -86,6 +129,19 @@ index 1dd2227..6789ca8 100644
|
|||||||
+ }
|
+ }
|
||||||
+ // Spigot End
|
+ // Spigot End
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java b/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
|
||||||
|
index 16d4765..39692ee 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/PacketHandshakingInSetProtocol.java
|
||||||
|
@@ -13,7 +13,7 @@ public class PacketHandshakingInSetProtocol extends Packet {
|
||||||
|
|
||||||
|
public void a(PacketDataSerializer packetdataserializer) throws IOException { // CraftBukkit - added throws
|
||||||
|
this.a = packetdataserializer.a();
|
||||||
|
- this.b = packetdataserializer.c(255);
|
||||||
|
+ this.b = packetdataserializer.c(Short.MAX_VALUE); // Spigot
|
||||||
|
this.c = packetdataserializer.readUnsignedShort();
|
||||||
|
this.d = EnumProtocol.a(packetdataserializer.a());
|
||||||
|
}
|
||||||
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
||||||
index 9c98a62..d2a378e 100644
|
index 9c98a62..d2a378e 100644
|
||||||
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
From 1b286e686b378ca461c3a8dbdb2af6aeeabdda96 Mon Sep 17 00:00:00 2001
|
From d599a3be18665b9ca05fd1eabde7b0e2e3e5ff23 Mon Sep 17 00:00:00 2001
|
||||||
From: md_5 <git@md-5.net>
|
From: md_5 <git@md-5.net>
|
||||||
Date: Sat, 12 Apr 2014 15:11:15 +1000
|
Date: Sat, 12 Apr 2014 15:11:15 +1000
|
||||||
Subject: [PATCH] Old / New Version Support.
|
Subject: [PATCH] Old / New Version Support.
|
||||||
@ -7,10 +7,10 @@ This adds support for newer / older Minecraft versions.
|
|||||||
At present it supports protocol versions 4 and 5 (1.7.2-1.7.8).
|
At present it supports protocol versions 4 and 5 (1.7.2-1.7.8).
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/HandshakeListener.java b/src/main/java/net/minecraft/server/HandshakeListener.java
|
diff --git a/src/main/java/net/minecraft/server/HandshakeListener.java b/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
index c738ab5..ec44fe3 100644
|
index ee24038..2ef286e 100644
|
||||||
--- a/src/main/java/net/minecraft/server/HandshakeListener.java
|
--- a/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
+++ b/src/main/java/net/minecraft/server/HandshakeListener.java
|
+++ b/src/main/java/net/minecraft/server/HandshakeListener.java
|
||||||
@@ -24,6 +24,7 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
@@ -26,6 +26,7 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void a(PacketHandshakingInSetProtocol packethandshakinginsetprotocol) {
|
public void a(PacketHandshakingInSetProtocol packethandshakinginsetprotocol) {
|
||||||
@ -18,7 +18,7 @@ index c738ab5..ec44fe3 100644
|
|||||||
switch (ProtocolOrdinalWrapper.a[packethandshakinginsetprotocol.c().ordinal()]) {
|
switch (ProtocolOrdinalWrapper.a[packethandshakinginsetprotocol.c().ordinal()]) {
|
||||||
case 1:
|
case 1:
|
||||||
this.b.a(EnumProtocol.LOGIN);
|
this.b.a(EnumProtocol.LOGIN);
|
||||||
@@ -68,7 +69,7 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
@@ -70,7 +71,7 @@ public class HandshakeListener implements PacketHandshakingInListener {
|
||||||
chatcomponenttext = new ChatComponentText( org.spigotmc.SpigotConfig.outdatedServerMessage ); // Spigot
|
chatcomponenttext = new ChatComponentText( org.spigotmc.SpigotConfig.outdatedServerMessage ); // Spigot
|
||||||
this.b.handle(new PacketLoginOutDisconnect(chatcomponenttext), new GenericFutureListener[0]);
|
this.b.handle(new PacketLoginOutDisconnect(chatcomponenttext), new GenericFutureListener[0]);
|
||||||
this.b.close(chatcomponenttext);
|
this.b.close(chatcomponenttext);
|
||||||
@ -28,10 +28,10 @@ index c738ab5..ec44fe3 100644
|
|||||||
this.b.handle(new PacketLoginOutDisconnect(chatcomponenttext), new GenericFutureListener[0]);
|
this.b.handle(new PacketLoginOutDisconnect(chatcomponenttext), new GenericFutureListener[0]);
|
||||||
this.b.close(chatcomponenttext);
|
this.b.close(chatcomponenttext);
|
||||||
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
index 6789ca8..9842440 100644
|
index e8e20fd..8514dd6 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
@@ -42,6 +42,19 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
@@ -46,6 +46,19 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
||||||
private EnumProtocol p;
|
private EnumProtocol p;
|
||||||
private IChatBaseComponent q;
|
private IChatBaseComponent q;
|
||||||
private boolean r;
|
private boolean r;
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
From a1f6b5f98344b9a8c16ccd4bf63a363621efa362 Mon Sep 17 00:00:00 2001
|
From 4a54acd0c4fcf31b83a4b9ee83b7dfb78be93b0d Mon Sep 17 00:00:00 2001
|
||||||
From: md_5 <git@md-5.net>
|
From: md_5 <git@md-5.net>
|
||||||
Date: Sun, 13 Apr 2014 09:00:59 +1000
|
Date: Sun, 13 Apr 2014 09:00:59 +1000
|
||||||
Subject: [PATCH] Print Stack on InternalException
|
Subject: [PATCH] Print Stack on InternalException
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
index 9842440..214f071 100644
|
index 8514dd6..8825258 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
--- a/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
+++ b/src/main/java/net/minecraft/server/NetworkManager.java
|
||||||
@@ -81,6 +81,7 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
@@ -85,6 +85,7 @@ public class NetworkManager extends SimpleChannelInboundHandler {
|
||||||
|
|
||||||
public void exceptionCaught(ChannelHandlerContext channelhandlercontext, Throwable throwable) {
|
public void exceptionCaught(ChannelHandlerContext channelhandlercontext, Throwable throwable) {
|
||||||
this.close(new ChatMessage("disconnect.genericReason", new Object[] { "Internal Exception: " + throwable}));
|
this.close(new ChatMessage("disconnect.genericReason", new Object[] { "Internal Exception: " + throwable}));
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren