2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
|
|
Date: Sat, 12 Nov 2016 23:25:22 -0600
|
|
|
|
Subject: [PATCH] Filter bad data from ArmorStand and SpawnEgg items
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-03-11 21:13:46 +01:00
|
|
|
index d7734fbc6b684b14bc32c94e65947fb41aae126a..7320f07beffee60fe3c49016daf7a98658879a27 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-03-11 21:13:46 +01:00
|
|
|
@@ -347,4 +347,12 @@ public class PaperWorldConfig {
|
|
|
|
preventTntFromMovingInWater = getBoolean("prevent-tnt-from-moving-in-water", false);
|
|
|
|
log("Prevent TNT from moving in water: " + preventTntFromMovingInWater);
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public boolean filterNBTFromSpawnEgg = true;
|
|
|
|
+ private void fitlerNBTFromSpawnEgg() {
|
|
|
|
+ filterNBTFromSpawnEgg = getBoolean("filter-nbt-data-from-spawn-eggs-and-related", true);
|
|
|
|
+ if (!filterNBTFromSpawnEgg) {
|
|
|
|
+ Bukkit.getLogger().warning("Spawn Egg and Armor Stand NBT filtering disabled, this is a potential security risk");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
2022-03-11 21:13:46 +01:00
|
|
|
index 16b029f08d5c9dfd3bc4ad304ab9d339ad20b232..2723816204ee61ea3fda9279369df030b8d70a13 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
2022-03-01 06:43:03 +01:00
|
|
|
@@ -309,6 +309,18 @@ public class FallingBlockEntity extends Entity {
|
2021-06-11 14:02:28 +02:00
|
|
|
@Override
|
2021-06-12 08:24:50 +02:00
|
|
|
protected void readAdditionalSaveData(CompoundTag nbt) {
|
|
|
|
this.blockState = NbtUtils.readBlockState(nbt.getCompound("BlockState"));
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start - Block FallingBlocks with Command Blocks
|
|
|
|
+ final Block b = this.blockState.getBlock();
|
2021-06-12 08:24:50 +02:00
|
|
|
+ if (this.level.paperConfig.filterNBTFromSpawnEgg
|
|
|
|
+ && (b == Blocks.COMMAND_BLOCK
|
|
|
|
+ || b == Blocks.REPEATING_COMMAND_BLOCK
|
|
|
|
+ || b == Blocks.CHAIN_COMMAND_BLOCK
|
|
|
|
+ || b == Blocks.JIGSAW
|
|
|
|
+ || b == Blocks.STRUCTURE_BLOCK
|
|
|
|
+ || b instanceof net.minecraft.world.level.block.GameMasterBlock)) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ this.blockState = Blocks.STONE.defaultBlockState();
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-12 08:24:50 +02:00
|
|
|
this.time = nbt.getInt("Time");
|
|
|
|
if (nbt.contains("HurtEntities", 99)) {
|
|
|
|
this.hurtEntities = nbt.getBoolean("HurtEntities");
|