From aeb072c35d6d5bae66c2dd858385c549b3429c25 Mon Sep 17 00:00:00 2001 From: MD <1917406+mdcfe@users.noreply.github.com> Date: Wed, 7 Jul 2021 16:12:58 +0100 Subject: [PATCH] Route sign run_command click events through normal chat logic (#6109) This patch changes sign command logic so that `run_command` click events are routed through the standard chat/command logic used for inbound chat messages. This fixes numerous issues related to sign click commands: - Signs with a `run_command` value of "/" would fail and show the "Unknown command" warning. This prevents usage of commands like `//wand` from WorldEdit in sign click events entirely and requires users to drop the leading slash from other plugins' commands. This patch now executes the plugin commands as would be expected, adding a leading slash if necessary. - Signs with a `run_command` value that doesn't match an existing command could fail silently. This patch causes these to *always* show "Unknown command" instead. - Plugins listening to `PlayerCommandPreprocessEvent` would not be able to intercept any command executions from sign click events. This patch allows plugins to intercept player commands when fired by a click event, in the same manner as commands executed by the player typing or clicking on a chat message. - Commands executed from signs would not be logged to the console. This patch fixes this. This patch also prepends a leading slash if the `run_command` value lacks one, which matches vanilla behaviour (old code would strip this slash away) while also ensuring `PlayerCommandPreprocessEvent#getMessage` remains consistent with other command executions from chat (which always include the leading slash). --- ...ommand-click-events-through-normal-c.patch | 40 +++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 patches/server/Route-sign-run_command-click-events-through-normal-c.patch diff --git a/patches/server/Route-sign-run_command-click-events-through-normal-c.patch b/patches/server/Route-sign-run_command-click-events-through-normal-c.patch new file mode 100644 index 0000000000..78a4226955 --- /dev/null +++ b/patches/server/Route-sign-run_command-click-events-through-normal-c.patch @@ -0,0 +1,40 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: MD <1917406+mdcfe@users.noreply.github.com> +Date: Wed, 7 Jul 2021 12:29:48 +0100 +Subject: [PATCH] Route sign run_command click events through normal chat logic + +This patch changes sign command logic so that `run_command` click events are routed through the standard chat/command +logic used for inbound chat messages. + +This fixes numerous issues related to sign click commands: + - Signs with a `run_command` value of "/" would fail and show the "Unknown command" warning. This + prevents usage of commands like `//wand` from WorldEdit in sign click events entirely and requires users to drop + the leading slash from other plugins' commands. This patch now executes the plugin commands as would be expected, + adding a leading slash if necessary. + - Signs with a `run_command` value that doesn't match an existing command could fail silently. This patch causes + these to *always* show "Unknown command" instead. + - Plugins listening to `PlayerCommandPreprocessEvent` would not be able to intercept any command executions from + sign click events. This patch allows plugins to intercept player commands when fired by a click event, in the same + manner as commands executed by the player typing or clicking on a chat message. + - Commands executed from signs would not be logged to the console. This patch fixes this. + +This patch also prepends a leading slash if the `run_command` value lacks one, which matches vanilla behaviour (old +code would strip this slash away) while also ensuring `PlayerCommandPreprocessEvent#getMessage` remains consistent +with other command executions from chat (which always include the leading slash). + +diff --git a/src/main/java/net/minecraft/world/level/block/entity/SignBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/SignBlockEntity.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/world/level/block/entity/SignBlockEntity.java ++++ b/src/main/java/net/minecraft/world/level/block/entity/SignBlockEntity.java +@@ -0,0 +0,0 @@ public class SignBlockEntity extends BlockEntity implements CommandSource { // C + ClickEvent chatclickable = chatmodifier.getClickEvent(); + + if (chatclickable != null && chatclickable.getAction() == ClickEvent.Action.RUN_COMMAND) { +- player.getServer().getCommands().performCommand(this.createCommandSourceStack(player), chatclickable.getValue()); ++ // Paper start - route through standard chat/command logic ++ final String command = chatclickable.getValue().startsWith("/") ? chatclickable.getValue() : "/" + chatclickable.getValue(); ++ player.connection.chat(command, false); ++ // Paper end + } + } +