mirror of
https://github.com/TotalFreedomMC/TF-PlotSquared.git
synced 2024-12-22 16:05:02 +00:00
Merge pull request #2890 from MeFisto94/fix-1-16-worldserver-regression
Fixes an OfflinePlayerUtil breakaged caused by NMS Changes
This commit is contained in:
commit
28fc29c3ab
2 changed files with 48 additions and 5 deletions
|
@ -69,6 +69,7 @@ import com.plotsquared.core.util.MainUtil;
|
|||
import com.plotsquared.core.util.MathMan;
|
||||
import com.plotsquared.core.util.Permissions;
|
||||
import com.plotsquared.core.util.PremiumVerification;
|
||||
import com.plotsquared.core.util.ReflectionUtils;
|
||||
import com.plotsquared.core.util.RegExUtil;
|
||||
import com.plotsquared.core.util.entity.EntityCategories;
|
||||
import com.plotsquared.core.util.task.TaskManager;
|
||||
|
@ -139,6 +140,7 @@ import java.util.HashSet;
|
|||
import java.util.List;
|
||||
import java.util.Set;
|
||||
import java.util.UUID;
|
||||
import java.util.function.Predicate;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
/**
|
||||
|
@ -153,7 +155,15 @@ public class PlayerEventListener extends PlotListener implements Listener {
|
|||
private PlayerMoveEvent moveTmp;
|
||||
private String internalVersion;
|
||||
|
||||
private final Predicate<Player> isRealPlayerCheck;
|
||||
|
||||
{
|
||||
Class<?> playerImplementation = ReflectionUtils.getCbClass("entity.CraftPlayer");
|
||||
if (playerImplementation == null) {
|
||||
isRealPlayerCheck = p -> true;
|
||||
} else {
|
||||
isRealPlayerCheck = p -> p.getClass() == playerImplementation;
|
||||
}
|
||||
try {
|
||||
fieldPlayer = PlayerEvent.class.getDeclaredField("player");
|
||||
fieldPlayer.setAccessible(true);
|
||||
|
@ -346,6 +356,9 @@ public class PlayerEventListener extends PlotListener implements Listener {
|
|||
|
||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||
public void onTeleport(PlayerTeleportEvent event) {
|
||||
if (!isRealPlayerCheck.test(event.getPlayer())) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
BukkitPlayer pp = BukkitUtil.getPlayer(player);
|
||||
Plot lastPlot = pp.getMeta(PlotPlayer.META_LAST_PLOT);
|
||||
|
@ -452,6 +465,9 @@ public class PlayerEventListener extends PlotListener implements Listener {
|
|||
|
||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||
public void playerMove(PlayerMoveEvent event) {
|
||||
if (!isRealPlayerCheck.test(event.getPlayer())) {
|
||||
return;
|
||||
}
|
||||
org.bukkit.Location from = event.getFrom();
|
||||
org.bukkit.Location to = event.getTo();
|
||||
int x2;
|
||||
|
@ -643,6 +659,9 @@ public class PlayerEventListener extends PlotListener implements Listener {
|
|||
|
||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||
public void onWorldChanged(PlayerChangedWorldEvent event) {
|
||||
if (!isRealPlayerCheck.test(event.getPlayer())) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
BukkitPlayer pp = BukkitUtil.getPlayer(player);
|
||||
// Delete last location
|
||||
|
|
|
@ -63,11 +63,11 @@ public class OfflinePlayerUtil {
|
|||
Object profile = newGameProfile(id, name);
|
||||
Class<?> entityPlayerClass = getNmsClass("EntityPlayer");
|
||||
Constructor entityPlayerConstructor =
|
||||
makeConstructor(entityPlayerClass, getNmsClass("MinecraftServer"),
|
||||
getNmsClass("WorldServer"), getUtilClass("com.mojang.authlib.GameProfile"),
|
||||
getNmsClass("PlayerInteractManager"));
|
||||
makeConstructor(entityPlayerClass, getNmsClass("MinecraftServer"),
|
||||
getNmsClass("WorldServer"), getUtilClass("com.mojang.authlib.GameProfile"),
|
||||
getNmsClass("PlayerInteractManager"));
|
||||
Object entityPlayer =
|
||||
callConstructor(entityPlayerConstructor, server, worldServer, profile, interactManager);
|
||||
callConstructor(entityPlayerConstructor, server, worldServer, profile, interactManager);
|
||||
return (Player) getBukkitEntity(entityPlayer);
|
||||
}
|
||||
|
||||
|
@ -97,6 +97,26 @@ public class OfflinePlayerUtil {
|
|||
return callConstructor(c, worldServer);
|
||||
}
|
||||
|
||||
public static Object getWorldServer116() {
|
||||
Object server = getMinecraftServer();
|
||||
Class<?> minecraftServerClass = getNmsClass("MinecraftServer");
|
||||
Class<?> genericResourceKey = getNmsClass("ResourceKey");
|
||||
Class<?> minecraftKey = getNmsClass("MinecraftKey");
|
||||
// MinecraftKey + MinecraftKey -> ResourceKey
|
||||
Method constructResourceKey = makeMethod(genericResourceKey, "a", minecraftKey, minecraftKey);
|
||||
// MinecraftKey(String)
|
||||
Constructor<Object> minecraftKeyConstructor = makeConstructor(minecraftKey, String.class);
|
||||
// minecraft:overworld
|
||||
Object overworldKey = callConstructor(minecraftKeyConstructor, "overworld");
|
||||
// minecraft:dimension
|
||||
Object dimensionKey = callConstructor(minecraftKeyConstructor, "dimension");
|
||||
// ResourceKey[minecraft:dimension / minecraft:overworld]
|
||||
Object resourceKey = callMethod(constructResourceKey, null, dimensionKey, overworldKey);
|
||||
Method getWorldServer =
|
||||
makeMethod(minecraftServerClass, "getWorldServer", genericResourceKey);
|
||||
return callMethod(getWorldServer, server, resourceKey);
|
||||
}
|
||||
|
||||
public static Object getWorldServerNew() {
|
||||
Object server = getMinecraftServer();
|
||||
Class<?> minecraftServerClass = getNmsClass("MinecraftServer");
|
||||
|
@ -115,7 +135,11 @@ public class OfflinePlayerUtil {
|
|||
try {
|
||||
o = callMethod(getWorldServer, server, 0);
|
||||
} catch (final RuntimeException e) {
|
||||
o = getWorldServerNew();
|
||||
try {
|
||||
o = getWorldServerNew();
|
||||
} catch (final RuntimeException f) {
|
||||
o = getWorldServer116();
|
||||
}
|
||||
}
|
||||
return o;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue