2021-12-01 12:32:36 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Noah van der Aa <ndvdaa@gmail.com>
|
|
|
|
Date: Tue, 3 Aug 2021 17:28:27 +0200
|
|
|
|
Subject: [PATCH] Hide unnecessary itemmeta from clients
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/level/ServerEntity.java b/src/main/java/net/minecraft/server/level/ServerEntity.java
|
2024-02-01 09:15:57 +00:00
|
|
|
index 86f6e5bad325dd3d817b643388b196121624b8c7..062225ac8b5fbc44290352d78b215640691f3c23 100644
|
2021-12-01 12:32:36 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/level/ServerEntity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/level/ServerEntity.java
|
2023-09-22 14:58:35 +00:00
|
|
|
@@ -337,7 +337,7 @@ public class ServerEntity {
|
2021-12-01 12:32:36 +00:00
|
|
|
if (!itemstack.isEmpty()) {
|
|
|
|
// Paper start - prevent oversized data
|
|
|
|
final ItemStack sanitized = LivingEntity.sanitizeItemStack(itemstack.copy(), false);
|
|
|
|
- list.add(Pair.of(enumitemslot, sanitized));
|
2024-01-18 21:00:40 +00:00
|
|
|
+ list.add(Pair.of(enumitemslot, ((LivingEntity) this.entity).stripMeta(sanitized, false))); // Paper - Hide unnecessary item meta
|
|
|
|
// Paper end - prevent oversized data
|
2021-12-01 12:32:36 +00:00
|
|
|
}
|
|
|
|
}
|
2022-08-14 08:03:13 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2024-02-22 16:23:15 +00:00
|
|
|
index ace2cab310aa7d89e1b76bf5fdc9fd64f56b6cc7..cf173a2315f3a97a89dc2aabe81be285abe73603 100644
|
2022-08-14 08:03:13 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2024-02-22 16:23:15 +00:00
|
|
|
@@ -2565,8 +2565,8 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2022-12-07 21:35:34 +00:00
|
|
|
// Refresh the current entity metadata
|
2023-10-26 23:34:58 +00:00
|
|
|
entity.getEntityData().refresh(ServerGamePacketListenerImpl.this.player);
|
2022-12-07 21:35:34 +00:00
|
|
|
// SPIGOT-7136 - Allays
|
|
|
|
- if (entity instanceof Allay) {
|
2023-10-26 23:34:58 +00:00
|
|
|
- ServerGamePacketListenerImpl.this.send(new ClientboundSetEquipmentPacket(entity.getId(), Arrays.stream(net.minecraft.world.entity.EquipmentSlot.values()).map((slot) -> Pair.of(slot, ((LivingEntity) entity).getItemBySlot(slot).copy())).collect(Collectors.toList())));
|
2024-01-18 21:00:40 +00:00
|
|
|
+ if (entity instanceof Allay allay) { // Paper - Hide unnecessary item meta
|
|
|
|
+ ServerGamePacketListenerImpl.this.send(new ClientboundSetEquipmentPacket(entity.getId(), Arrays.stream(net.minecraft.world.entity.EquipmentSlot.values()).map((slot) -> Pair.of(slot, allay.stripMeta(allay.getItemBySlot(slot), true))).collect(Collectors.toList()))); // Paper - Hide unnecessary item meta
|
2023-10-26 23:34:58 +00:00
|
|
|
ServerGamePacketListenerImpl.this.player.containerMenu.sendAllDataToRemote();
|
2022-12-07 21:35:34 +00:00
|
|
|
}
|
2022-08-14 08:03:13 +00:00
|
|
|
}
|
2021-12-01 12:32:36 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
2024-02-22 16:23:15 +00:00
|
|
|
index bd2449fd82a2415b9a0c1f588cd1815155a5d300..5c566576703a22bca9ab2cde7e201d893faece03 100644
|
2021-12-01 12:32:36 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
Updated Upstream (Bukkit/CraftBukkit) (#10242)
* Updated Upstream (Bukkit/CraftBukkit)
Upstream has released updates that appear to apply and compile correctly.
This update has not been tested by PaperMC and as with ANY update, please do your own testing
Bukkit Changes:
a6a9d2a4 Remove some old ApiStatus.Experimental annotations
be72314c SPIGOT-7300, PR-829: Add new DamageSource API providing enhanced information about entity damage
b252cf05 SPIGOT-7576, PR-970: Add methods in MushroomCow to change stew effects
b1c689bd PR-902: Add Server#isLoggingIPs to get log-ips configuration
08f86d1c PR-971: Add Player methods for client-side potion effects
2e3024a9 PR-963: Add API for in-world structures
a23292a7 SPIGOT-7530, PR-948: Improve Resource Pack API with new 1.20.3 functionality
1851857b SPIGOT-3071, PR-969: Add entity spawn method with spawn reason
cde4c52a SPIGOT-5553, PR-964: Add EntityKnockbackEvent
CraftBukkit Changes:
38fd4bd50 Fix accidentally renamed internal damage method
80f0ce4be SPIGOT-7300, PR-1180: Add new DamageSource API providing enhanced information about entity damage
7e43f3b16 SPIGOT-7581: Fix typo in BlockMushroom
ea14b7d90 SPIGOT-7576, PR-1347: Add methods in MushroomCow to change stew effects
4c687f243 PR-1259: Add Server#isLoggingIPs to get log-ips configuration
22a541a29 Improve support for per-world game rules
cb7dccce2 PR-1348: Add Player methods for client-side potion effects
b8d6109f0 PR-1335: Add API for in-world structures
4398a1b5b SPIGOT-7577: Make CraftWindCharge#explode discard the entity
e74107678 Fix Crafter maximum stack size
0bb0f4f6a SPIGOT-7530, PR-1314: Improve Resource Pack API with new 1.20.3 functionality
4949f556d SPIGOT-3071, PR-1345: Add entity spawn method with spawn reason
20ac73ca2 PR-1353: Fix Structure#place not working as documented with 0 palette
3c1b77871 SPIGOT-6911, PR-1349: Change max book length in CraftMetaBook
333701839 SPIGOT-7572: Bee nests generated without bees
f48f4174c SPIGOT-5553, PR-1336: Add EntityKnockbackEvent
2024-02-11 21:28:00 +00:00
|
|
|
@@ -3202,7 +3202,7 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
2021-12-01 12:32:36 +00:00
|
|
|
|
|
|
|
// Paper start - prevent oversized data
|
|
|
|
ItemStack toSend = sanitizeItemStack(itemstack1, true);
|
|
|
|
- list.add(Pair.of(enumitemslot, toSend));
|
2024-01-18 21:00:40 +00:00
|
|
|
+ list.add(Pair.of(enumitemslot, stripMeta(toSend, toSend == itemstack1))); // Paper - Hide unnecessary item meta
|
|
|
|
// Paper end - prevent oversized data
|
2021-12-01 12:32:36 +00:00
|
|
|
switch (enumitemslot.getType()) {
|
|
|
|
case HAND:
|
Updated Upstream (Bukkit/CraftBukkit) (#10242)
* Updated Upstream (Bukkit/CraftBukkit)
Upstream has released updates that appear to apply and compile correctly.
This update has not been tested by PaperMC and as with ANY update, please do your own testing
Bukkit Changes:
a6a9d2a4 Remove some old ApiStatus.Experimental annotations
be72314c SPIGOT-7300, PR-829: Add new DamageSource API providing enhanced information about entity damage
b252cf05 SPIGOT-7576, PR-970: Add methods in MushroomCow to change stew effects
b1c689bd PR-902: Add Server#isLoggingIPs to get log-ips configuration
08f86d1c PR-971: Add Player methods for client-side potion effects
2e3024a9 PR-963: Add API for in-world structures
a23292a7 SPIGOT-7530, PR-948: Improve Resource Pack API with new 1.20.3 functionality
1851857b SPIGOT-3071, PR-969: Add entity spawn method with spawn reason
cde4c52a SPIGOT-5553, PR-964: Add EntityKnockbackEvent
CraftBukkit Changes:
38fd4bd50 Fix accidentally renamed internal damage method
80f0ce4be SPIGOT-7300, PR-1180: Add new DamageSource API providing enhanced information about entity damage
7e43f3b16 SPIGOT-7581: Fix typo in BlockMushroom
ea14b7d90 SPIGOT-7576, PR-1347: Add methods in MushroomCow to change stew effects
4c687f243 PR-1259: Add Server#isLoggingIPs to get log-ips configuration
22a541a29 Improve support for per-world game rules
cb7dccce2 PR-1348: Add Player methods for client-side potion effects
b8d6109f0 PR-1335: Add API for in-world structures
4398a1b5b SPIGOT-7577: Make CraftWindCharge#explode discard the entity
e74107678 Fix Crafter maximum stack size
0bb0f4f6a SPIGOT-7530, PR-1314: Improve Resource Pack API with new 1.20.3 functionality
4949f556d SPIGOT-3071, PR-1345: Add entity spawn method with spawn reason
20ac73ca2 PR-1353: Fix Structure#place not working as documented with 0 palette
3c1b77871 SPIGOT-6911, PR-1349: Change max book length in CraftMetaBook
333701839 SPIGOT-7572: Bee nests generated without bees
f48f4174c SPIGOT-5553, PR-1336: Add EntityKnockbackEvent
2024-02-11 21:28:00 +00:00
|
|
|
@@ -3216,6 +3216,77 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
2023-06-08 07:20:03 +00:00
|
|
|
((ServerLevel) this.level()).getChunkSource().broadcast(this, new ClientboundSetEquipmentPacket(this.getId(), list));
|
2021-12-01 12:32:36 +00:00
|
|
|
}
|
|
|
|
|
2024-01-18 21:00:40 +00:00
|
|
|
+ // Paper start - Hide unnecessary item meta
|
2021-12-01 12:32:36 +00:00
|
|
|
+ public ItemStack stripMeta(final ItemStack itemStack, final boolean copyItemStack) {
|
|
|
|
+ if (itemStack.isEmpty() || (!itemStack.hasTag() && itemStack.getCount() < 2)) {
|
|
|
|
+ return itemStack;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ final ItemStack copy = copyItemStack ? itemStack.copy() : itemStack;
|
2023-06-08 19:00:58 +00:00
|
|
|
+ if (this.level().paperConfig().anticheat.obfuscation.items.hideDurability) {
|
2021-12-01 12:32:36 +00:00
|
|
|
+ // Only show damage values for elytra's, since they show a different texture when broken.
|
|
|
|
+ if (!copy.is(Items.ELYTRA) || copy.getDamageValue() < copy.getMaxDamage() - 1) {
|
|
|
|
+ copy.setDamageValue(0);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
2022-11-19 21:41:09 +00:00
|
|
|
+ final CompoundTag tag = copy.getTag();
|
2023-06-08 19:00:58 +00:00
|
|
|
+ if (this.level().paperConfig().anticheat.obfuscation.items.hideItemmeta) {
|
2021-12-01 12:32:36 +00:00
|
|
|
+ // Some resource packs show different textures when there is more than one item. Since this shouldn't provide a big advantage,
|
|
|
|
+ // we'll tell the client if there's one or (more than) two items.
|
|
|
|
+ copy.setCount(copy.getCount() > 1 ? 2 : 1);
|
|
|
|
+ // We can't just strip out display, leather helmets still use the display.color tag.
|
|
|
|
+ if (tag != null) {
|
|
|
|
+ if (tag.get("display") instanceof CompoundTag displayTag) {
|
|
|
|
+ displayTag.remove("Lore");
|
|
|
|
+ displayTag.remove("Name");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (tag.get("Enchantments") instanceof ListTag enchantmentsTag && !enchantmentsTag.isEmpty()) {
|
|
|
|
+ // The client still renders items with the enchantment glow if the enchantments tag contains at least one (empty) child.
|
|
|
|
+ ListTag enchantments = new ListTag();
|
2022-01-01 23:26:53 +00:00
|
|
|
+ CompoundTag fakeEnchantment = new CompoundTag();
|
|
|
|
+ // Soul speed boots generate client side particles.
|
|
|
|
+ if (EnchantmentHelper.getItemEnchantmentLevel(Enchantments.SOUL_SPEED, itemStack) > 0) {
|
|
|
|
+ fakeEnchantment.putString("id", org.bukkit.enchantments.Enchantment.SOUL_SPEED.getKey().asString());
|
|
|
|
+ fakeEnchantment.putInt("lvl", 1);
|
|
|
|
+ }
|
|
|
|
+ enchantments.add(fakeEnchantment);
|
2021-12-01 12:32:36 +00:00
|
|
|
+ tag.put("Enchantments", enchantments);
|
|
|
|
+ }
|
|
|
|
+ tag.remove("AttributeModifiers");
|
2023-10-14 21:41:15 +00:00
|
|
|
+ tag.remove("Unbreakable");
|
|
|
|
+ tag.remove("PublicBukkitValues"); // Persistent data container1
|
2022-04-18 10:23:37 +00:00
|
|
|
+
|
|
|
|
+ // Books
|
|
|
|
+ tag.remove("author");
|
|
|
|
+ tag.remove("filtered_title");
|
|
|
|
+ tag.remove("pages");
|
|
|
|
+ tag.remove("filtered_pages");
|
|
|
|
+ tag.remove("title");
|
|
|
|
+ tag.remove("generation");
|
2023-10-14 21:41:15 +00:00
|
|
|
+
|
|
|
|
+ // Filled maps
|
|
|
|
+ tag.remove("map");
|
|
|
|
+ tag.remove("map_scale_direction");
|
|
|
|
+ tag.remove("map_to_lock");
|
2021-12-01 12:32:36 +00:00
|
|
|
+ }
|
|
|
|
+ }
|
2022-11-19 21:41:09 +00:00
|
|
|
+
|
2023-06-08 19:00:58 +00:00
|
|
|
+ if (this.level().paperConfig().anticheat.obfuscation.items.hideItemmetaWithVisualEffects && tag != null) {
|
2022-11-19 21:41:09 +00:00
|
|
|
+ // Lodestone compasses
|
|
|
|
+ tag.remove("LodestonePos");
|
|
|
|
+ if (tag.contains("LodestoneDimension")) {
|
|
|
|
+ // The client shows the glint if either the position or the dimension is present, so we just wipe
|
|
|
|
+ // the position and fake the dimension
|
|
|
|
+ tag.putString("LodestoneDimension", "paper:paper");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
2021-12-01 12:32:36 +00:00
|
|
|
+ return copy;
|
|
|
|
+ }
|
2024-01-18 21:00:40 +00:00
|
|
|
+ // Paper end - Hide unnecessary item meta
|
2021-12-01 12:32:36 +00:00
|
|
|
+
|
2022-01-01 23:26:53 +00:00
|
|
|
// Paper start - prevent oversized data
|
2021-12-01 12:32:36 +00:00
|
|
|
public static ItemStack sanitizeItemStack(final ItemStack itemStack, final boolean copyItemStack) {
|
|
|
|
if (itemStack.isEmpty() || !itemStack.hasTag()) {
|