aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorShane Freeder <[email protected]>2022-04-13 08:27:16 +0100
committerShane Freeder <[email protected]>2022-04-13 08:27:16 +0100
commita9ee1046a50d6ca53b056fa5ef5a0bbb1206964f (patch)
tree3a9fbe4d8d45a7afbcfa2078ef152040aaa2ae2f
parente42d683d754e6f2fdb7581beb68e61d85084cb8f (diff)
downloadPaper-a9ee1046a50d6ca53b056fa5ef5a0bbb1206964f.tar.gz
Paper-a9ee1046a50d6ca53b056fa5ef5a0bbb1206964f.zip
Prevent tile entity copies loading chunks
-rw-r--r--patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch37
1 files changed, 37 insertions, 0 deletions
diff --git a/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch b/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch
new file mode 100644
index 0000000000..8e36eb5cca
--- /dev/null
+++ b/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch
@@ -0,0 +1,37 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Shane Freeder <[email protected]>
+Date: Wed, 13 Apr 2022 08:25:42 +0100
+Subject: [PATCH] Prevent tile entity copies loading chunks
+
+
+diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+index e4d54fdc28b6161e74626f25299b1081e6605e98..3ab4ecb9ee3586cab04da7b500024855892faa3e 100644
+--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
++++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+@@ -1,5 +1,6 @@
+ package net.minecraft.server.network;
+
++import com.destroystokyo.paper.event.player.IllegalPacketEvent;
+ import com.google.common.collect.Lists;
+ import com.google.common.primitives.Floats;
+ import com.mojang.brigadier.ParseResults;
+@@ -2994,8 +2995,17 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
+
+ if (!itemstack.isEmpty() && nbttagcompound != null && nbttagcompound.contains("x") && nbttagcompound.contains("y") && nbttagcompound.contains("z") && this.player.getBukkitEntity().hasPermission("minecraft.nbt.copy")) { // Spigot
+ BlockPos blockposition = BlockEntity.getPosFromTag(nbttagcompound);
+- BlockEntity tileentity = this.player.level.getBlockEntity(blockposition);
+-
++ // Paper start
++ BlockEntity tileentity = null;
++ if (this.player.getLevel().isLoadedAndInBounds(blockposition)) {
++ tileentity = this.player.level.getBlockEntity(blockposition);
++ } else {
++ // failed to find, cleanup
++ nbttagcompound.remove("x");
++ nbttagcompound.remove("y");
++ nbttagcompound.remove("z");
++ }
++ // Paper end
+ if (tileentity != null) {
+ tileentity.saveToItem(itemstack);
+ }