2023-07-05 15:08:19 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Luna <lunahatesgogle@gmail.com>
|
|
|
|
Date: Tue, 4 Jul 2023 18:49:34 -0300
|
|
|
|
Subject: [PATCH] Fix packet-related lag exploits
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2023-09-24 22:01:28 +00:00
|
|
|
index b4213a2f0f8c57b606b1a1a993d352bda200bd63..957c1ec2b6ae60c5de5960a13a2900762b6ffb61 100644
|
2023-07-05 15:08:19 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2023-09-24 22:01:28 +00:00
|
|
|
@@ -858,7 +858,7 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-07-05 15:08:19 +00:00
|
|
|
this.player.sendSystemMessage(Component.translatable("advMode.notEnabled"));
|
|
|
|
} else if (!this.player.canUseGameMasterBlocks() && (!this.player.isCreative() || !this.player.getBukkitEntity().hasPermission("minecraft.commandblock"))) { // Paper - command block permission
|
|
|
|
this.player.sendSystemMessage(Component.translatable("advMode.notAllowed"));
|
|
|
|
- } else {
|
|
|
|
+ } else if (this.player.level().isLoadedAndInBounds(packet.getPos())) { // Scissors
|
|
|
|
BaseCommandBlock commandblocklistenerabstract = null;
|
|
|
|
CommandBlockEntity tileentitycommand = null;
|
|
|
|
BlockPos blockposition = packet.getPos();
|
2023-09-24 22:01:28 +00:00
|
|
|
@@ -1025,7 +1025,7 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-07-05 15:08:19 +00:00
|
|
|
@Override
|
|
|
|
public void handleSetStructureBlock(ServerboundSetStructureBlockPacket packet) {
|
|
|
|
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
|
|
|
|
- if (this.player.canUseGameMasterBlocks()) {
|
|
|
|
+ if (this.player.canUseGameMasterBlocks() && this.player.level().isLoadedAndInBounds(packet.getPos())) { // Scissors
|
|
|
|
BlockPos blockposition = packet.getPos();
|
|
|
|
BlockState iblockdata = this.player.level().getBlockState(blockposition);
|
|
|
|
BlockEntity tileentity = this.player.level().getBlockEntity(blockposition);
|
2023-09-24 22:01:28 +00:00
|
|
|
@@ -1083,7 +1083,7 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-07-05 15:08:19 +00:00
|
|
|
@Override
|
|
|
|
public void handleSetJigsawBlock(ServerboundSetJigsawBlockPacket packet) {
|
|
|
|
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
|
|
|
|
- if (this.player.canUseGameMasterBlocks()) {
|
|
|
|
+ if (this.player.canUseGameMasterBlocks() && this.player.level().isLoadedAndInBounds(packet.getPos())) { // Scissors
|
|
|
|
BlockPos blockposition = packet.getPos();
|
|
|
|
BlockState iblockdata = this.player.level().getBlockState(blockposition);
|
|
|
|
BlockEntity tileentity = this.player.level().getBlockEntity(blockposition);
|
2023-09-24 22:01:28 +00:00
|
|
|
@@ -1106,7 +1106,7 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-07-05 15:08:19 +00:00
|
|
|
@Override
|
|
|
|
public void handleJigsawGenerate(ServerboundJigsawGeneratePacket packet) {
|
|
|
|
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
|
|
|
|
- if (this.player.canUseGameMasterBlocks()) {
|
|
|
|
+ if (this.player.canUseGameMasterBlocks() && this.player.level().isLoadedAndInBounds(packet.getPos())) { // Scissors
|
|
|
|
BlockPos blockposition = packet.getPos();
|
|
|
|
BlockEntity tileentity = this.player.level().getBlockEntity(blockposition);
|
|
|
|
|