aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorSpottedleaf <[email protected]>2022-05-07 14:59:20 -0700
committerSpottedleaf <[email protected]>2022-05-07 14:59:20 -0700
commite3997543203bc1d86b58b6f1e751b0593228ca7b (patch)
tree179f8f1409893f4a5e4d0c500bd4699bdf71f9dd
parent87d2eb2d3b3e51683fb8467a64a9fb15cdaaefcc (diff)
downloadPaper-e3997543203bc1d86b58b6f1e751b0593228ca7b.tar.gz
Paper-e3997543203bc1d86b58b6f1e751b0593228ca7b.zip
Do not accept invalid client settings
-rw-r--r--patches/server/0855-Replace-player-chunk-loader-system.patch6
-rw-r--r--patches/server/0906-Do-not-accept-invalid-client-settings.patch24
2 files changed, 27 insertions, 3 deletions
diff --git a/patches/server/0855-Replace-player-chunk-loader-system.patch b/patches/server/0855-Replace-player-chunk-loader-system.patch
index 52c3526e22..6775e3163a 100644
--- a/patches/server/0855-Replace-player-chunk-loader-system.patch
+++ b/patches/server/0855-Replace-player-chunk-loader-system.patch
@@ -84,7 +84,7 @@ index 309dbf5fce3ce940d5e1b57d267b9d6b2c5ff5b6..5ba64e1083b7cb1eec64d1925095c6ca
}));
diff --git a/src/main/java/com/destroystokyo/paper/PaperConfig.java b/src/main/java/com/destroystokyo/paper/PaperConfig.java
-index 432db841f4b25ab219078501942bcfb586645be1..b6ada92f426c545801b6f0e5b44206f533aca39a 100644
+index 318e28b5e93b6842d48745ec53bcc25dbfeaff72..66d360b2c4ae9e380ec6c452a263c04bd3aef4ff 100644
--- a/src/main/java/com/destroystokyo/paper/PaperConfig.java
+++ b/src/main/java/com/destroystokyo/paper/PaperConfig.java
@@ -652,4 +652,35 @@ public class PaperConfig {
@@ -125,7 +125,7 @@ index 432db841f4b25ab219078501942bcfb586645be1..b6ada92f426c545801b6f0e5b44206f5
}
diff --git a/src/main/java/io/papermc/paper/chunk/PlayerChunkLoader.java b/src/main/java/io/papermc/paper/chunk/PlayerChunkLoader.java
new file mode 100644
-index 0000000000000000000000000000000000000000..0f62a766a3249d8651a11dce6e9051b162693716
+index 0000000000000000000000000000000000000000..12bcf96ec1ba4314c7ea2eab9f3d140559f1dc08
--- /dev/null
+++ b/src/main/java/io/papermc/paper/chunk/PlayerChunkLoader.java
@@ -0,0 +1,1128 @@
@@ -1066,7 +1066,7 @@ index 0000000000000000000000000000000000000000..0f62a766a3249d8651a11dce6e9051b1
+ }
+
+ protected int getClientViewDistance() {
-+ return this.player.clientViewDistance == null ? -1 : this.player.clientViewDistance.intValue();
++ return this.player.clientViewDistance == null ? -1 : Math.max(0, this.player.clientViewDistance.intValue());
+ }
+
+ public void update() {
diff --git a/patches/server/0906-Do-not-accept-invalid-client-settings.patch b/patches/server/0906-Do-not-accept-invalid-client-settings.patch
new file mode 100644
index 0000000000..1381f89d0b
--- /dev/null
+++ b/patches/server/0906-Do-not-accept-invalid-client-settings.patch
@@ -0,0 +1,24 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Spottedleaf <[email protected]>
+Date: Sat, 7 May 2022 14:58:53 -0700
+Subject: [PATCH] Do not accept invalid client settings
+
+
+diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+index 1a87f61d534ed531132fb43a9d2a45a4b604a6fc..1a1f3664554ae1f2b0110f615e79fa0568407d17 100644
+--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
++++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+@@ -3169,6 +3169,13 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
+ @Override
+ public void handleClientInformation(ServerboundClientInformationPacket packet) {
+ PacketUtils.ensureRunningOnSameThread(packet, this, this.player.getLevel());
++ // Paper start - do not accept invalid information
++ if (packet.viewDistance() < 0) {
++ LOGGER.warn("Disconnecting " + this.player.getScoreboardName() + " for invalid view distance: " + packet.viewDistance());
++ this.disconnect("Invalid client settings", PlayerKickEvent.Cause.ILLEGAL_ACTION);
++ return;
++ }
++ // Paper end - do not accept invalid information
+ this.player.updateOptions(packet);
+ }
+