2021-06-11 12:02:28 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Spottedleaf <spottedleaf@users.noreply.github.com>
|
|
|
|
Date: Fri, 4 Jun 2021 17:06:52 -0400
|
|
|
|
Subject: [PATCH] Fix dangerous end portal logic
|
|
|
|
|
|
|
|
End portals could teleport entities during move calls. Stupid
|
|
|
|
logic given the caller will never expect that kind of thing,
|
|
|
|
and will result in all kinds of dupes.
|
|
|
|
|
|
|
|
Move the tick logic into the post tick, where portaling was
|
|
|
|
designed to happen in the first place.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/java/net/minecraft/world/entity/Entity.java
|
2023-07-04 08:22:56 +00:00
|
|
|
index 5f93c2fa9be835825d9a3c5fbd85ab285eced34d..205be31a06f97678aea0da06bc13f5a18b6eb903 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
2023-06-08 23:21:20 +00:00
|
|
|
@@ -515,6 +515,36 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
|
|
|
return chunkMap.playerEntityTrackerTrackMaps[type.ordinal()].getObjectsInRange(MCUtil.getCoordinateKey(this));
|
|
|
|
}
|
|
|
|
// Paper end - optimise entity tracking
|
2021-06-11 12:02:28 +00:00
|
|
|
+ // Paper start - make end portalling safe
|
|
|
|
+ public BlockPos portalBlock;
|
|
|
|
+ public ServerLevel portalWorld;
|
|
|
|
+ public void tickEndPortal() {
|
|
|
|
+ BlockPos pos = this.portalBlock;
|
|
|
|
+ ServerLevel world = this.portalWorld;
|
|
|
|
+ this.portalBlock = null;
|
|
|
|
+ this.portalWorld = null;
|
|
|
|
+
|
|
|
|
+ if (pos == null || world == null || world != this.level) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
2021-06-15 04:16:18 +00:00
|
|
|
+ if (this.isPassenger() || this.isVehicle() || !this.canChangeDimensions() || this.isRemoved() || !this.valid || !this.isAlive()) {
|
2021-06-11 12:02:28 +00:00
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
2021-11-24 23:26:29 +00:00
|
|
|
+ ResourceKey<Level> resourcekey = world.getTypeKey() == LevelStem.END ? Level.OVERWORLD : Level.END; // CraftBukkit - SPIGOT-6152: send back to main overworld in custom ends
|
2021-06-11 12:02:28 +00:00
|
|
|
+ ServerLevel worldserver = world.getServer().getLevel(resourcekey);
|
|
|
|
+
|
|
|
|
+ org.bukkit.event.entity.EntityPortalEnterEvent event = new org.bukkit.event.entity.EntityPortalEnterEvent(this.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
|
|
|
|
+ event.callEvent();
|
|
|
|
+
|
|
|
|
+ if (this instanceof ServerPlayer) {
|
|
|
|
+ ((ServerPlayer)this).changeDimension(worldserver, PlayerTeleportEvent.TeleportCause.END_PORTAL);
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ this.teleportTo(worldserver, null);
|
|
|
|
+ }
|
|
|
|
+ // Paper end - make end portalling safe
|
2023-06-08 05:21:04 +00:00
|
|
|
|
2021-06-11 12:02:28 +00:00
|
|
|
public Entity(EntityType<?> type, Level world) {
|
|
|
|
this.id = Entity.ENTITY_COUNTER.incrementAndGet();
|
2023-07-04 08:22:56 +00:00
|
|
|
@@ -2839,6 +2869,7 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
2021-06-11 12:02:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
this.processPortalCooldown();
|
|
|
|
+ this.tickEndPortal(); // Paper - make end portalling safe
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
2023-03-14 20:25:13 +00:00
|
|
|
index 45b427f314da778cc13da9ad6e4e1316790bf1b1..41d7cff39fc37955877668337689b4b26cd8c7cf 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
2021-06-15 03:50:26 +00:00
|
|
|
@@ -53,16 +53,10 @@ public class EndPortalBlock extends BaseEntityBlock {
|
2021-06-11 12:02:28 +00:00
|
|
|
// return; // CraftBukkit - always fire event in case plugins wish to change it
|
|
|
|
}
|
|
|
|
|
|
|
|
- // CraftBukkit start - Entity in portal
|
|
|
|
- EntityPortalEnterEvent event = new EntityPortalEnterEvent(entity.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
|
|
|
|
- world.getCraftServer().getPluginManager().callEvent(event);
|
|
|
|
-
|
|
|
|
- if (entity instanceof ServerPlayer) {
|
2021-06-15 03:50:26 +00:00
|
|
|
- ((ServerPlayer) entity).changeDimension(worldserver, PlayerTeleportEvent.TeleportCause.END_PORTAL);
|
2021-06-11 12:02:28 +00:00
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
- // CraftBukkit end
|
|
|
|
- entity.changeDimension(worldserver);
|
|
|
|
+ // Paper start - move all of this logic into portal tick
|
|
|
|
+ entity.portalWorld = ((ServerLevel)world);
|
|
|
|
+ entity.portalBlock = pos.immutable();
|
|
|
|
+ // Paper end - move all of this logic into portal tick
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|