340 lines
13 KiB
Diff
340 lines
13 KiB
Diff
|
From 69614650662d3da7f61f0399a01094ad6ed16ad9 Mon Sep 17 00:00:00 2001
|
||
|
From: md_5 <md_5@live.com.au>
|
||
|
Date: Sat, 28 Sep 2013 18:35:51 +1000
|
||
|
Subject: [PATCH] Snapshot Protocol
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
index 36eca0f..c90c65e 100644
|
||
|
--- a/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
+++ b/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
@@ -63,6 +63,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen
|
||
|
protected float bL = 0.02F;
|
||
|
private int h;
|
||
|
public EntityFishingHook hookedFish;
|
||
|
+ public String playerUUID; // Spigot
|
||
|
|
||
|
public EntityHuman(World world, String s) {
|
||
|
super(world);
|
||
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||
|
index fb8bc87..5651bd0 100644
|
||
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
||
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||
|
@@ -764,7 +764,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo
|
||
|
}
|
||
|
|
||
|
public String getVersion() {
|
||
|
- return "1.6.4";
|
||
|
+ return org.spigotmc.SpigotConfig.gameVersion; // Spigot
|
||
|
}
|
||
|
|
||
|
public int A() {
|
||
|
diff --git a/src/main/java/net/minecraft/server/Packet200Statistic.java b/src/main/java/net/minecraft/server/Packet200Statistic.java
|
||
|
new file mode 100644
|
||
|
index 0000000..a850473
|
||
|
--- /dev/null
|
||
|
+++ b/src/main/java/net/minecraft/server/Packet200Statistic.java
|
||
|
@@ -0,0 +1,49 @@
|
||
|
+package net.minecraft.server;
|
||
|
+
|
||
|
+import java.io.DataInput;
|
||
|
+import java.io.DataOutput;
|
||
|
+import java.io.IOException;
|
||
|
+
|
||
|
+public class Packet200Statistic extends Packet {
|
||
|
+
|
||
|
+ public int a;
|
||
|
+ public int b;
|
||
|
+
|
||
|
+ public Packet200Statistic() {}
|
||
|
+
|
||
|
+ public Packet200Statistic(int i, int j) {
|
||
|
+ this.a = i;
|
||
|
+ this.b = j;
|
||
|
+ }
|
||
|
+
|
||
|
+ public void handle(Connection connection) {
|
||
|
+ connection.a(this);
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataInput datainput) throws IOException {
|
||
|
+ this.a = datainput.readInt();
|
||
|
+ this.b = datainput.readInt();
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataOutput dataoutput) throws IOException {
|
||
|
+ // Spigot Start
|
||
|
+ if ( org.spigotmc.SpigotConfig.snapshotProtocol )
|
||
|
+ {
|
||
|
+ dataoutput.writeInt( 1 );
|
||
|
+ a( ( (Statistic) StatisticList.a.get( this.a ) ).g, dataoutput );
|
||
|
+ dataoutput.writeInt( this.b );
|
||
|
+ return;
|
||
|
+ }
|
||
|
+ // Spigot End
|
||
|
+ dataoutput.writeInt(this.a);
|
||
|
+ dataoutput.writeInt(this.b);
|
||
|
+ }
|
||
|
+
|
||
|
+ public int a() {
|
||
|
+ return 6;
|
||
|
+ }
|
||
|
+
|
||
|
+ public boolean a_() {
|
||
|
+ return true;
|
||
|
+ }
|
||
|
+}
|
||
|
diff --git a/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java b/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java
|
||
|
index 1843d9c..aeb42bb 100644
|
||
|
--- a/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java
|
||
|
+++ b/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java
|
||
|
@@ -8,6 +8,7 @@ import java.io.IOException; // CraftBukkit
|
||
|
|
||
|
public class Packet20NamedEntitySpawn extends Packet {
|
||
|
|
||
|
+ public String playerUUID; // Spigot
|
||
|
public int a;
|
||
|
public String b;
|
||
|
public int c;
|
||
|
@@ -23,6 +24,7 @@ public class Packet20NamedEntitySpawn extends Packet {
|
||
|
|
||
|
public Packet20NamedEntitySpawn(EntityHuman entityhuman) {
|
||
|
this.a = entityhuman.id;
|
||
|
+ this.playerUUID = entityhuman.playerUUID; // Spigot
|
||
|
|
||
|
// CraftBukkit start - Limit name length to 16 characters
|
||
|
if (entityhuman.name.length() > 16) {
|
||
|
@@ -58,6 +60,7 @@ public class Packet20NamedEntitySpawn extends Packet {
|
||
|
|
||
|
public void a(DataOutput dataoutput) throws IOException { // CraftBukkit
|
||
|
dataoutput.writeInt(this.a);
|
||
|
+ if ( this.playerUUID != null ) a( playerUUID, dataoutput ); // Spigot
|
||
|
a(this.b, dataoutput);
|
||
|
dataoutput.writeInt(this.c);
|
||
|
dataoutput.writeInt(this.d);
|
||
|
diff --git a/src/main/java/net/minecraft/server/Packet62NamedSoundEffect.java b/src/main/java/net/minecraft/server/Packet62NamedSoundEffect.java
|
||
|
new file mode 100644
|
||
|
index 0000000..9b64483
|
||
|
--- /dev/null
|
||
|
+++ b/src/main/java/net/minecraft/server/Packet62NamedSoundEffect.java
|
||
|
@@ -0,0 +1,60 @@
|
||
|
+package net.minecraft.server;
|
||
|
+
|
||
|
+import java.io.DataInput;
|
||
|
+import java.io.DataOutput;
|
||
|
+import java.io.IOException;
|
||
|
+
|
||
|
+public class Packet62NamedSoundEffect extends Packet {
|
||
|
+
|
||
|
+ private String a;
|
||
|
+ private int b;
|
||
|
+ private int c = Integer.MAX_VALUE;
|
||
|
+ private int d;
|
||
|
+ private float e;
|
||
|
+ private int f;
|
||
|
+
|
||
|
+ public Packet62NamedSoundEffect() {}
|
||
|
+
|
||
|
+ public Packet62NamedSoundEffect(String s, double d0, double d1, double d2, float f, float f1) {
|
||
|
+ this.a = s;
|
||
|
+ this.b = (int) (d0 * 8.0D);
|
||
|
+ this.c = (int) (d1 * 8.0D);
|
||
|
+ this.d = (int) (d2 * 8.0D);
|
||
|
+ this.e = f;
|
||
|
+ this.f = (int) (f1 * 63.0F);
|
||
|
+ if (this.f < 0) {
|
||
|
+ this.f = 0;
|
||
|
+ }
|
||
|
+
|
||
|
+ if (this.f > 255) {
|
||
|
+ this.f = 255;
|
||
|
+ }
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataInput datainput) throws IOException {
|
||
|
+ this.a = a(datainput, 256);
|
||
|
+ this.b = datainput.readInt();
|
||
|
+ this.c = datainput.readInt();
|
||
|
+ this.d = datainput.readInt();
|
||
|
+ this.e = datainput.readFloat();
|
||
|
+ this.f = datainput.readUnsignedByte();
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataOutput dataoutput) throws IOException {
|
||
|
+ a(this.a, dataoutput);
|
||
|
+ dataoutput.writeInt(this.b);
|
||
|
+ dataoutput.writeInt(this.c);
|
||
|
+ dataoutput.writeInt(this.d);
|
||
|
+ dataoutput.writeFloat(this.e);
|
||
|
+ dataoutput.writeByte(this.f);
|
||
|
+ if ( org.spigotmc.SpigotConfig.snapshotProtocol ) dataoutput.writeByte( 0 ); // Spigot
|
||
|
+ }
|
||
|
+
|
||
|
+ public void handle(Connection connection) {
|
||
|
+ connection.a(this);
|
||
|
+ }
|
||
|
+
|
||
|
+ public int a() {
|
||
|
+ return 24;
|
||
|
+ }
|
||
|
+}
|
||
|
diff --git a/src/main/java/net/minecraft/server/Packet70Bed.java b/src/main/java/net/minecraft/server/Packet70Bed.java
|
||
|
new file mode 100644
|
||
|
index 0000000..ff89531
|
||
|
--- /dev/null
|
||
|
+++ b/src/main/java/net/minecraft/server/Packet70Bed.java
|
||
|
@@ -0,0 +1,37 @@
|
||
|
+package net.minecraft.server;
|
||
|
+
|
||
|
+import java.io.DataInput;
|
||
|
+import java.io.DataOutput;
|
||
|
+import java.io.IOException;
|
||
|
+
|
||
|
+public class Packet70Bed extends Packet {
|
||
|
+
|
||
|
+ public static final String[] a = new String[] { "tile.bed.notValid", null, null, "gameMode.changed"};
|
||
|
+ public int b;
|
||
|
+ public int c;
|
||
|
+
|
||
|
+ public Packet70Bed() {}
|
||
|
+
|
||
|
+ public Packet70Bed(int i, int j) {
|
||
|
+ this.b = i;
|
||
|
+ this.c = j;
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataInput datainput) throws IOException {
|
||
|
+ this.b = datainput.readByte();
|
||
|
+ this.c = datainput.readByte();
|
||
|
+ }
|
||
|
+
|
||
|
+ public void a(DataOutput dataoutput) throws IOException {
|
||
|
+ dataoutput.writeByte(this.b);
|
||
|
+ if ( org.spigotmc.SpigotConfig.snapshotProtocol ) dataoutput.writeFloat(this.c); else dataoutput.writeByte(this.c); // Spigot
|
||
|
+ }
|
||
|
+
|
||
|
+ public void handle(Connection connection) {
|
||
|
+ connection.a(this);
|
||
|
+ }
|
||
|
+
|
||
|
+ public int a() {
|
||
|
+ return 2;
|
||
|
+ }
|
||
|
+}
|
||
|
diff --git a/src/main/java/net/minecraft/server/PendingConnection.java b/src/main/java/net/minecraft/server/PendingConnection.java
|
||
|
index 358cba4..a86fbbc 100644
|
||
|
--- a/src/main/java/net/minecraft/server/PendingConnection.java
|
||
|
+++ b/src/main/java/net/minecraft/server/PendingConnection.java
|
||
|
@@ -25,6 +25,7 @@ public class PendingConnection extends Connection {
|
||
|
private boolean j;
|
||
|
private SecretKey k;
|
||
|
public String hostname = ""; // CraftBukkit - add field
|
||
|
+ public String playerUUID;
|
||
|
|
||
|
public PendingConnection(MinecraftServer minecraftserver, org.spigotmc.netty.NettyNetworkManager networkManager) {
|
||
|
this.server = minecraftserver;
|
||
|
@@ -78,8 +79,8 @@ public class PendingConnection extends Connection {
|
||
|
} else {
|
||
|
PublicKey publickey = this.server.H().getPublic();
|
||
|
|
||
|
- if (packet2handshake.d() != 78) {
|
||
|
- if (packet2handshake.d() > 78) {
|
||
|
+ if (packet2handshake.d() != org.spigotmc.SpigotConfig.protocolVersion) { // Spigot
|
||
|
+ if (packet2handshake.d() > org.spigotmc.SpigotConfig.protocolVersion) { // Spigot
|
||
|
this.disconnect(org.spigotmc.SpigotConfig.outdatedServerMessage); // Spigot
|
||
|
} else {
|
||
|
this.disconnect(org.spigotmc.SpigotConfig.outdatedClientMessage); // Spigot
|
||
|
@@ -133,6 +134,7 @@ public class PendingConnection extends Connection {
|
||
|
// CraftBukkit end
|
||
|
} else {
|
||
|
EntityPlayer entityplayer = this.server.getPlayerList().processLogin(s); // CraftBukkit - this.g -> s
|
||
|
+ entityplayer.playerUUID = this.playerUUID; // Spigot
|
||
|
|
||
|
if (entityplayer != null) {
|
||
|
this.server.getPlayerList().a((INetworkManager) this.networkManager, entityplayer);
|
||
|
@@ -159,7 +161,7 @@ public class PendingConnection extends Connection {
|
||
|
s = pingEvent.getMotd() + "\u00A7" + playerlist.getPlayerCount() + "\u00A7" + pingEvent.getMaxPlayers();
|
||
|
} else {
|
||
|
// CraftBukkit start - Don't create a list from an array
|
||
|
- Object[] list = new Object[] { 1, 78, this.server.getVersion(), pingEvent.getMotd(), playerlist.getPlayerCount(), pingEvent.getMaxPlayers() };
|
||
|
+ Object[] list = new Object[] { 1, org.spigotmc.SpigotConfig.protocolVersion, this.server.getVersion(), pingEvent.getMotd(), playerlist.getPlayerCount(), pingEvent.getMaxPlayers() }; // Spigot
|
||
|
|
||
|
StringBuilder builder = new StringBuilder();
|
||
|
for (Object object : list) {
|
||
|
diff --git a/src/main/java/net/minecraft/server/ThreadLoginVerifier.java b/src/main/java/net/minecraft/server/ThreadLoginVerifier.java
|
||
|
index 70f9fea..2d0c1f9 100644
|
||
|
--- a/src/main/java/net/minecraft/server/ThreadLoginVerifier.java
|
||
|
+++ b/src/main/java/net/minecraft/server/ThreadLoginVerifier.java
|
||
|
@@ -26,9 +26,39 @@ class ThreadLoginVerifier extends Thread {
|
||
|
// CraftBukkit end
|
||
|
this.pendingConnection = pendingconnection;
|
||
|
}
|
||
|
+
|
||
|
+ // Spigot Start
|
||
|
+ public static class NewResponse
|
||
|
+ {
|
||
|
|
||
|
- private boolean auth() throws java.io.IOException {
|
||
|
- String s = (new BigInteger(MinecraftEncryption.a(PendingConnection.a(this.pendingConnection), PendingConnection.b(this.pendingConnection).H().getPublic(), PendingConnection.c(this.pendingConnection)))).toString(16);
|
||
|
+ private String id;
|
||
|
+ }
|
||
|
+ // Spigot End
|
||
|
+
|
||
|
+ private boolean auth() throws java.io.IOException
|
||
|
+ {
|
||
|
+ // Spigot Start
|
||
|
+ if ( org.spigotmc.SpigotConfig.snapshotProtocol )
|
||
|
+ {
|
||
|
+ String url = "https://sessionserver.mojang.com/session/minecraft/hasJoined?username=" + URLEncoder.encode( PendingConnection.d( this.pendingConnection ), "UTF-8" ) + "&serverId=" + URLEncoder.encode( PendingConnection.a( pendingConnection ), "UTF-8" );
|
||
|
+ BufferedReader br = new BufferedReader( new InputStreamReader( new URL( url ).openConnection( PendingConnection.b( this.pendingConnection ).ap() ).getInputStream() ) );
|
||
|
+ String s = br.readLine();
|
||
|
+ br.close();
|
||
|
+ NewResponse response = new com.google.gson.Gson().fromJson( s, NewResponse.class );
|
||
|
+ if ( response != null )
|
||
|
+ {
|
||
|
+ if ( response.id != null )
|
||
|
+ {
|
||
|
+ this.pendingConnection.playerUUID = response.id;
|
||
|
+ return true;
|
||
|
+ }
|
||
|
+ }
|
||
|
+ this.pendingConnection.disconnect( "Failed to verify username!" );
|
||
|
+ return false;
|
||
|
+ }
|
||
|
+ // Spigot End
|
||
|
+
|
||
|
+ String s = ( new BigInteger( MinecraftEncryption.a( PendingConnection.a(this.pendingConnection), PendingConnection.b(this.pendingConnection).H().getPublic(), PendingConnection.c(this.pendingConnection)))).toString(16);
|
||
|
URL url = new URL("http://session.minecraft.net/game/checkserver.jsp?user=" + URLEncoder.encode(PendingConnection.d(this.pendingConnection), "UTF-8") + "&serverId=" + URLEncoder.encode(s, "UTF-8"));
|
||
|
BufferedReader bufferedreader = new BufferedReader(new InputStreamReader(url.openConnection(PendingConnection.b(this.pendingConnection).ap()).getInputStream()));
|
||
|
String s1 = bufferedreader.readLine();
|
||
|
diff --git a/src/main/java/org/spigotmc/SpigotConfig.java b/src/main/java/org/spigotmc/SpigotConfig.java
|
||
|
index 296c581..a49b275 100644
|
||
|
--- a/src/main/java/org/spigotmc/SpigotConfig.java
|
||
|
+++ b/src/main/java/org/spigotmc/SpigotConfig.java
|
||
|
@@ -290,4 +290,22 @@ public class SpigotConfig
|
||
|
|
||
|
Bukkit.getLogger().setFilter( new LogFilter() );
|
||
|
}
|
||
|
+
|
||
|
+ public static boolean snapshotProtocol;
|
||
|
+ public static String gameVersion;
|
||
|
+ public static byte protocolVersion;
|
||
|
+ private static void snapshotProtocol()
|
||
|
+ {
|
||
|
+ snapshotProtocol = getBoolean( "settings.snapshot-protocol", false );
|
||
|
+
|
||
|
+ gameVersion = ( snapshotProtocol ) ? "13w39b" : "1.6.4";
|
||
|
+ protocolVersion = (byte) ( ( snapshotProtocol ) ? 80 : 78 );
|
||
|
+ if ( snapshotProtocol )
|
||
|
+ {
|
||
|
+ Bukkit.getLogger().severe( "================ [Snapshot Protocol] ================" );
|
||
|
+ Bukkit.getLogger().severe( "Initialised Snapshot Protocol for " + gameVersion + " (" + protocolVersion + ")" );
|
||
|
+ Bukkit.getLogger().severe( "Features may NOT be implemented! Use at your own risk!" );
|
||
|
+ Bukkit.getLogger().severe( "================ ====================================" );
|
||
|
+ }
|
||
|
+ }
|
||
|
}
|
||
|
--
|
||
|
1.8.1.2
|
||
|
|