2022-06-08 13:12:28 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2022-08-01 14:01:20 +00:00
From: Nassim Jahnke <nassim@njahnke.dev>
2022-06-08 13:12:28 +00:00
Date: Mon, 17 Jan 2022 19:47:19 +0100
2022-06-12 01:11:18 +00:00
Subject: [PATCH] Kick on main for illegal chat
2022-06-08 13:12:28 +00:00
2022-06-12 01:11:18 +00:00
Makes the PlayerKickEvent fire on the main thread for
illegal characters or chat out-of-order errors.
2022-06-08 13:12:28 +00:00
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
2022-08-29 13:21:45 +00:00
index 5c9d7320536be70100f7e1d843e8c4e0c0802a19..26402aa8879e4e50c619c1e9d8e30ef49c3b8a34 100644
2022-06-08 13:12:28 +00:00
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
2022-08-29 13:21:45 +00:00
@@ -2174,7 +2174,9 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
2022-06-08 13:12:28 +00:00
}
// CraftBukkit end
2022-07-27 21:32:15 +00:00
if (ServerGamePacketListenerImpl.isChatMessageIllegal(packet.message())) {
2022-06-08 13:12:28 +00:00
+ this.server.scheduleOnMain(() -> { // Paper - push to main for event firing
this.disconnect(Component.translatable("multiplayer.disconnect.illegal_characters"), org.bukkit.event.player.PlayerKickEvent.Cause.ILLEGAL_CHARACTERS); // Paper - add cause
+ }); // Paper - push to main for event firing
} else {
2022-07-27 21:32:15 +00:00
if (this.tryHandleChat(packet.message(), packet.timeStamp(), packet.lastSeenMessages())) {
// this.server.submit(() -> { // CraftBukkit - async chat
2022-08-29 13:21:45 +00:00
@@ -2202,7 +2204,9 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
2022-06-08 13:12:28 +00:00
@Override
public void handleChatCommand(ServerboundChatCommandPacket packet) {
if (ServerGamePacketListenerImpl.isChatMessageIllegal(packet.command())) {
+ this.server.scheduleOnMain(() -> { // Paper - push to main for event firing
2022-07-29 16:31:02 +00:00
this.disconnect(Component.translatable("multiplayer.disconnect.illegal_characters"), org.bukkit.event.player.PlayerKickEvent.Cause.ILLEGAL_CHARACTERS); // Paper
2022-06-08 13:12:28 +00:00
+ }); // Paper - push to main for event firing
} else {
2022-07-27 21:32:15 +00:00
if (this.tryHandleChat(packet.command(), packet.timeStamp(), packet.lastSeenMessages())) {
this.server.submit(() -> {
2022-08-29 13:21:45 +00:00
@@ -2288,7 +2292,9 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
2022-08-05 22:58:34 +00:00
private boolean tryHandleChat(String message, Instant timestamp, LastSeenMessages.Update acknowledgment) {
2022-07-27 21:32:15 +00:00
if (!this.updateChatOrder(timestamp)) {
ServerGamePacketListenerImpl.LOGGER.warn("{} sent out-of-order chat: '{}'", this.player.getName().getString(), message);
2022-06-12 01:11:18 +00:00
+ this.server.scheduleOnMain(() -> { // Paper - push to main
2022-07-29 16:31:02 +00:00
this.disconnect(Component.translatable("multiplayer.disconnect.out_of_order_chat"), org.bukkit.event.player.PlayerKickEvent.Cause.OUT_OF_ORDER_CHAT); // Paper - kick event cause
2022-06-12 01:11:18 +00:00
+ }); // Paper - push to main
return false;
2022-07-27 21:32:15 +00:00
} else if (this.player.isRemoved() || this.player.getChatVisibility() == ChatVisiblity.HIDDEN) { // CraftBukkit - dead men tell no tales
this.send(new ClientboundSystemChatPacket(Component.translatable("chat.disabled.options").withStyle(ChatFormatting.RED), false));