55 lines
3.4 KiB
Diff
55 lines
3.4 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Aikar <aikar@aikar.co>
|
||
|
Date: Wed, 27 Feb 2019 22:18:40 -0500
|
||
|
Subject: [PATCH] Limit Client Sign length more
|
||
|
|
||
|
modified clients can send more data from the client
|
||
|
to the server and it would get stored on the sign as sent.
|
||
|
|
||
|
Mojang has a limit of 384 which is much higher than reasonable.
|
||
|
|
||
|
the client can barely render around 16 characters as-is, but formatting
|
||
|
codes can get it to be more than 16 actual length.
|
||
|
|
||
|
Set a limit of 80 which should give an average of 16 characters 2
|
||
|
sets of legacy formatting codes which should be plenty for all uses.
|
||
|
|
||
|
This does not strip any existing data from the NBT as plugins
|
||
|
may use this for storing data out of the rendered area.
|
||
|
|
||
|
it only impacts data sent from the client.
|
||
|
|
||
|
Set -DPaper.maxSignLength=XX to change limit or -1 to disable
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||
|
index 276773e17149f57038cd21485fd9d9061670ff2d..d6d8d83bc16572474d56a278dd119eacc2c52476 100644
|
||
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||
|
@@ -254,6 +254,7 @@ public class ServerGamePacketListenerImpl implements ServerGamePacketListener {
|
||
|
private int aboveGroundVehicleTickCount;
|
||
|
private int receivedMovePacketCount;
|
||
|
private int knownMovePacketCount;
|
||
|
+ private static final int MAX_SIGN_LINE_LENGTH = Integer.getInteger("Paper.maxSignLength", 80);
|
||
|
private static final long KEEPALIVE_LIMIT = Long.getLong("paper.playerconnection.keepalive", 30) * 1000; // Paper - provide property to set keepalive limit
|
||
|
|
||
|
public ServerGamePacketListenerImpl(MinecraftServer server, Connection connection, ServerPlayer player) {
|
||
|
@@ -2860,7 +2861,17 @@ public class ServerGamePacketListenerImpl implements ServerGamePacketListener {
|
||
|
List<net.kyori.adventure.text.Component> lines = new java.util.ArrayList<>();
|
||
|
|
||
|
for (int i = 0; i < list.size(); ++i) {
|
||
|
- lines.add(net.kyori.adventure.text.Component.text(SharedConstants.filterAllowedChatCharacters(list.get(i)))); // Paper - Replaced with anvil color stripping method to stop exploits that allow colored signs to be created.
|
||
|
+ // Paper start - cap line length - modified clients can send longer data than normal
|
||
|
+ String currentLine = list.get(i);
|
||
|
+ if (MAX_SIGN_LINE_LENGTH > 0 && currentLine.length() > MAX_SIGN_LINE_LENGTH) {
|
||
|
+ // This handles multibyte characters as 1
|
||
|
+ int offset = currentLine.codePoints().limit(MAX_SIGN_LINE_LENGTH).map(Character::charCount).sum();
|
||
|
+ if (offset < currentLine.length()) {
|
||
|
+ list.set(i, currentLine = currentLine.substring(0, offset));
|
||
|
+ }
|
||
|
+ }
|
||
|
+ // Paper end
|
||
|
+ lines.add(net.kyori.adventure.text.Component.text(SharedConstants.filterAllowedChatCharacters(currentLine))); // Paper - Replaced with anvil color stripping method to stop exploits that allow colored signs to be created.
|
||
|
}
|
||
|
SignChangeEvent event = new SignChangeEvent(org.bukkit.craftbukkit.block.CraftBlock.at(worldserver, blockposition), this.getPlayer(), lines);
|
||
|
this.craftServer.getPluginManager().callEvent(event);
|