2022-07-28 03:57:50 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Allink <arclicious@vivaldi.net>
|
|
|
|
Date: Sun, 10 Jul 2022 02:55:01 +0100
|
|
|
|
Subject: [PATCH] Prevent invalid container events
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2022-08-18 02:42:45 +00:00
|
|
|
index 728ded5c2aff87a4087ef99515a5787500b97fef..5dfd4ed57a92632a19a7109d6ac0b093f8e20aa3 100644
|
2022-07-28 03:57:50 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2022-07-30 01:48:11 +00:00
|
|
|
@@ -29,6 +29,8 @@ import java.util.function.UnaryOperator;
|
2022-07-28 03:57:50 +00:00
|
|
|
import java.util.stream.Collectors;
|
|
|
|
import java.util.stream.Stream;
|
|
|
|
import javax.annotation.Nullable;
|
|
|
|
+
|
|
|
|
+import net.kyori.adventure.text.format.NamedTextColor;
|
|
|
|
import net.minecraft.ChatFormatting;
|
|
|
|
import net.minecraft.CrashReport;
|
|
|
|
import net.minecraft.CrashReportCategory;
|
2022-08-18 02:42:45 +00:00
|
|
|
@@ -3103,6 +3105,7 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
|
2022-07-28 03:57:50 +00:00
|
|
|
public void handleContainerClick(ServerboundContainerClickPacket packet) {
|
|
|
|
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.getLevel());
|
|
|
|
if (this.player.isImmobile()) return; // CraftBukkit
|
|
|
|
+
|
|
|
|
this.player.resetLastActionTime();
|
|
|
|
if (this.player.containerMenu.containerId == packet.getContainerId() && this.player.containerMenu.stillValid(this.player)) { // CraftBukkit
|
|
|
|
boolean cancelled = this.player.isSpectator(); // CraftBukkit - see below if
|
2022-08-18 02:42:45 +00:00
|
|
|
@@ -3124,6 +3127,18 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
|
2022-07-28 03:57:50 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Scissors start - Do not call events when the slot/button number is invalid
|
|
|
|
+ final int sentSlotNum = packet.getSlotNum();
|
|
|
|
+ if((Mth.clamp(sentSlotNum, -1, this.player.containerMenu.slots.size() - 1) != sentSlotNum) && sentSlotNum != -999)
|
|
|
|
+ {
|
|
|
|
+ this.getCraftPlayer().kick(
|
|
|
|
+ net.kyori.adventure.text.Component.text("Invalid container click slot (Hacking?)")
|
|
|
|
+ .color(NamedTextColor.RED)
|
|
|
|
+ );
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Scissors end
|
|
|
|
+
|
|
|
|
InventoryView inventory = this.player.containerMenu.getBukkitView();
|
|
|
|
SlotType type = inventory.getSlotType(packet.getSlotNum());
|
|
|
|
|