Fix BanList API

This commit is contained in:
Jake Potrebic 2023-07-04 11:27:10 -07:00
parent 61ff05d0d5
commit 5b7b25844e
5 changed files with 144 additions and 29 deletions

View File

@ -115,17 +115,17 @@ public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializa
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Date expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Date expires, String source) { // Paper - fix ban list API
return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source); return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Instant expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Instant expires, String source) { // Paper - fix ban list API
return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source); return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Duration duration, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Duration duration, String source) { // Paper - fix ban list API
return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, duration, source); return ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, duration, source);
} }

View File

@ -9,7 +9,7 @@ import org.bukkit.BanEntry;
import org.bukkit.craftbukkit.profile.CraftPlayerProfile; import org.bukkit.craftbukkit.profile.CraftPlayerProfile;
import org.bukkit.profile.PlayerProfile; import org.bukkit.profile.PlayerProfile;
public final class CraftProfileBanEntry implements BanEntry<PlayerProfile> { public final class CraftProfileBanEntry implements BanEntry<com.destroystokyo.paper.profile.PlayerProfile> { // Paper
private static final Date minorDate = Date.from(Instant.parse("1899-12-31T04:00:00Z")); private static final Date minorDate = Date.from(Instant.parse("1899-12-31T04:00:00Z"));
private final UserBanList list; private final UserBanList list;
private final GameProfile profile; private final GameProfile profile;
@ -33,8 +33,8 @@ public final class CraftProfileBanEntry implements BanEntry<PlayerProfile> {
} }
@Override @Override
public PlayerProfile getBanTarget() { public com.destroystokyo.paper.profile.PlayerProfile getBanTarget() { // Paper
return new CraftPlayerProfile(this.profile); return new com.destroystokyo.paper.profile.CraftPlayerProfile(this.profile); // Paper
} }
@Override @Override

View File

@ -24,42 +24,80 @@ public class CraftProfileBanList implements ProfileBanList {
} }
@Override @Override
public BanEntry<PlayerProfile> getBanEntry(String target) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> getBanEntry(String target) { // Paper
Preconditions.checkArgument(target != null, "Target cannot be null"); Preconditions.checkArgument(target != null, "Target cannot be null");
return this.getBanEntry(CraftProfileBanList.getProfile(target)); return this.getBanEntry(CraftProfileBanList.getProfile(target));
} }
@Override @Override
public BanEntry<PlayerProfile> getBanEntry(PlayerProfile target) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> getBanEntry(PlayerProfile target) { // Paper
Preconditions.checkArgument(target != null, "Target cannot be null"); Preconditions.checkArgument(target != null, "Target cannot be null");
return this.getBanEntry(((CraftPlayerProfile) target).buildGameProfile()); return this.getBanEntry(((com.destroystokyo.paper.profile.SharedPlayerProfile) target).buildGameProfile()); // Paper
}
// Paper start - fix ban list API
@Override
public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> getBanEntry(final com.destroystokyo.paper.profile.PlayerProfile target) {
Preconditions.checkArgument(target != null, "target cannot be null");
return this.getBanEntry(((com.destroystokyo.paper.profile.SharedPlayerProfile) target).buildGameProfile());
} }
@Override @Override
public BanEntry<PlayerProfile> addBan(String target, String reason, Date expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(final com.destroystokyo.paper.profile.PlayerProfile target, final String reason, final Date expires, final String source) {
Preconditions.checkArgument(target != null, "PlayerProfile cannot be null");
Preconditions.checkArgument(target.getId() != null, "The PlayerProfile UUID cannot be null");
return this.addBan(((com.destroystokyo.paper.profile.SharedPlayerProfile) target).buildGameProfile(), reason, expires, source);
}
@Override
public boolean isBanned(final com.destroystokyo.paper.profile.PlayerProfile target) {
return this.isBanned((com.destroystokyo.paper.profile.SharedPlayerProfile) target);
}
@Override
public void pardon(final com.destroystokyo.paper.profile.PlayerProfile target) {
this.pardon((com.destroystokyo.paper.profile.SharedPlayerProfile) target);
}
@Override
public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(final com.destroystokyo.paper.profile.PlayerProfile target, final String reason, final Instant expires, final String source) {
Date date = expires != null ? Date.from(expires) : null;
return this.addBan(target, reason, date, source);
}
@Override
public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(final com.destroystokyo.paper.profile.PlayerProfile target, final String reason, final Duration duration, final String source) {
Instant instant = duration != null ? Instant.now().plus(duration) : null;
return this.addBan(target, reason, instant, source);
}
// Paper end - fix ban list API
@Override
public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(String target, String reason, Date expires, String source) { // Paper - fix ban list API
Preconditions.checkArgument(target != null, "Ban target cannot be null"); Preconditions.checkArgument(target != null, "Ban target cannot be null");
return this.addBan(CraftProfileBanList.getProfileByName(target), reason, expires, source); return this.addBan(CraftProfileBanList.getProfileByName(target), reason, expires, source);
} }
@Override @Override
public BanEntry<PlayerProfile> addBan(PlayerProfile target, String reason, Date expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(PlayerProfile target, String reason, Date expires, String source) { // Paper - fix ban list API
Preconditions.checkArgument(target != null, "PlayerProfile cannot be null"); Preconditions.checkArgument(target != null, "PlayerProfile cannot be null");
Preconditions.checkArgument(target.getUniqueId() != null, "The PlayerProfile UUID cannot be null"); Preconditions.checkArgument(target.getUniqueId() != null, "The PlayerProfile UUID cannot be null");
return this.addBan(((CraftPlayerProfile) target).buildGameProfile(), reason, expires, source); return this.addBan(((com.destroystokyo.paper.profile.SharedPlayerProfile) target).buildGameProfile(), reason, expires, source); // Paper
} }
@Override @Override
public BanEntry<PlayerProfile> addBan(PlayerProfile target, String reason, Instant expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(PlayerProfile target, String reason, Instant expires, String source) { // Paper - fix ban list API
Date date = expires != null ? Date.from(expires) : null; Date date = expires != null ? Date.from(expires) : null;
return this.addBan(target, reason, date, source); return this.addBan(target, reason, date, source);
} }
@Override @Override
public BanEntry<PlayerProfile> addBan(PlayerProfile target, String reason, Duration duration, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(PlayerProfile target, String reason, Duration duration, String source) { // Paper - fix ban list API
Instant instant = duration != null ? Instant.now().plus(duration) : null; Instant instant = duration != null ? Instant.now().plus(duration) : null;
return this.addBan(target, reason, instant, source); return this.addBan(target, reason, instant, source);
} }
@ -76,8 +114,8 @@ public class CraftProfileBanList implements ProfileBanList {
} }
@Override @Override
public Set<BanEntry<PlayerProfile>> getEntries() { public Set<BanEntry<com.destroystokyo.paper.profile.PlayerProfile>> getEntries() { // Paper
ImmutableSet.Builder<BanEntry<PlayerProfile>> builder = ImmutableSet.builder(); ImmutableSet.Builder<BanEntry<com.destroystokyo.paper.profile.PlayerProfile>> builder = ImmutableSet.builder(); // Paper
for (UserBanListEntry entry : this.list.getEntries()) { for (UserBanListEntry entry : this.list.getEntries()) {
GameProfile profile = entry.getUser(); GameProfile profile = entry.getUser();
builder.add(new CraftProfileBanEntry(profile, entry, this.list)); builder.add(new CraftProfileBanEntry(profile, entry, this.list));
@ -88,9 +126,14 @@ public class CraftProfileBanList implements ProfileBanList {
@Override @Override
public boolean isBanned(PlayerProfile target) { public boolean isBanned(PlayerProfile target) {
// Paper start
return this.isBanned((com.destroystokyo.paper.profile.SharedPlayerProfile) target);
}
private boolean isBanned(com.destroystokyo.paper.profile.SharedPlayerProfile target) {
// Paper end
Preconditions.checkArgument(target != null, "Target cannot be null"); Preconditions.checkArgument(target != null, "Target cannot be null");
return this.isBanned(((CraftPlayerProfile) target).buildGameProfile()); return this.isBanned(target.buildGameProfile()); // Paper
} }
@Override @Override
@ -102,9 +145,14 @@ public class CraftProfileBanList implements ProfileBanList {
@Override @Override
public void pardon(PlayerProfile target) { public void pardon(PlayerProfile target) {
// Paper start
this.pardon((com.destroystokyo.paper.profile.SharedPlayerProfile) target);
}
private void pardon(com.destroystokyo.paper.profile.SharedPlayerProfile target) {
// Paper end
Preconditions.checkArgument(target != null, "Target cannot be null"); Preconditions.checkArgument(target != null, "Target cannot be null");
this.pardon(((CraftPlayerProfile) target).buildGameProfile()); this.pardon(target.buildGameProfile()); // Paper
} }
@Override @Override
@ -114,7 +162,7 @@ public class CraftProfileBanList implements ProfileBanList {
this.pardon(CraftProfileBanList.getProfile(target)); this.pardon(CraftProfileBanList.getProfile(target));
} }
public BanEntry<PlayerProfile> getBanEntry(GameProfile profile) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> getBanEntry(GameProfile profile) { // Paper
if (profile == null) { if (profile == null) {
return null; return null;
} }
@ -127,7 +175,7 @@ public class CraftProfileBanList implements ProfileBanList {
return new CraftProfileBanEntry(profile, entry, this.list); return new CraftProfileBanEntry(profile, entry, this.list);
} }
public BanEntry<PlayerProfile> addBan(GameProfile profile, String reason, Date expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> addBan(GameProfile profile, String reason, Date expires, String source) { // Paper
if (profile == null) { if (profile == null) {
return null; return null;
} }

View File

@ -1759,23 +1759,23 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Date expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Date expires, String source) { // Paper - fix ban list API
return this.ban(reason, expires, source, true); return this.ban(reason, expires, source, true);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Instant expires, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Instant expires, String source) { // Paper - fix ban list API
return this.ban(reason, expires != null ? Date.from(expires) : null, source); return this.ban(reason, expires != null ? Date.from(expires) : null, source);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Duration duration, String source) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Duration duration, String source) { // Paper - fix ban list API
return this.ban(reason, duration != null ? Instant.now().plus(duration) : null, source); return this.ban(reason, duration != null ? Instant.now().plus(duration) : null, source);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Date expires, String source, boolean kickPlayer) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Date expires, String source, boolean kickPlayer) { // Paper - fix ban list API
BanEntry<PlayerProfile> banEntry = ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source); BanEntry<com.destroystokyo.paper.profile.PlayerProfile> banEntry = ((ProfileBanList) this.server.getBanList(BanList.Type.PROFILE)).addBan(this.getPlayerProfile(), reason, expires, source); // Paper - fix ban list API
if (kickPlayer) { if (kickPlayer) {
this.kickPlayer(reason); this.kickPlayer(reason);
} }
@ -1783,12 +1783,12 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Instant instant, String source, boolean kickPlayer) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Instant instant, String source, boolean kickPlayer) { // Paper - fix ban list API
return this.ban(reason, instant != null ? Date.from(instant) : null, source, kickPlayer); return this.ban(reason, instant != null ? Date.from(instant) : null, source, kickPlayer);
} }
@Override @Override
public BanEntry<PlayerProfile> ban(String reason, Duration duration, String source, boolean kickPlayer) { public BanEntry<com.destroystokyo.paper.profile.PlayerProfile> ban(String reason, Duration duration, String source, boolean kickPlayer) { // Paper - fix ban list API
return this.ban(reason, duration != null ? Instant.now().plus(duration) : null, source, kickPlayer); return this.ban(reason, duration != null ? Instant.now().plus(duration) : null, source, kickPlayer);
} }

View File

@ -31,7 +31,7 @@ import org.bukkit.profile.PlayerTextures;
import org.jetbrains.annotations.ApiStatus; import org.jetbrains.annotations.ApiStatus;
@SerializableAs("PlayerProfile") @SerializableAs("PlayerProfile")
public final class CraftPlayerProfile implements PlayerProfile, com.destroystokyo.paper.profile.SharedPlayerProfile { // Paper public final class CraftPlayerProfile implements PlayerProfile, com.destroystokyo.paper.profile.SharedPlayerProfile, com.destroystokyo.paper.profile.PlayerProfile { // Paper
@Nonnull @Nonnull
public static GameProfile validateSkullProfile(@Nonnull GameProfile gameProfile) { public static GameProfile validateSkullProfile(@Nonnull GameProfile gameProfile) {
@ -162,7 +162,7 @@ public final class CraftPlayerProfile implements PlayerProfile, com.destroystoky
} }
@Override @Override
public CompletableFuture<PlayerProfile> update() { public CompletableFuture update() { // Paper - have to remove generic to avoid clashing between bukkit.PlayerProfile and paper.PlayerProfile
return CompletableFuture.supplyAsync(this::getUpdatedProfile, Util.PROFILE_EXECUTOR); // Paper - don't submit BLOCKING PROFILE LOOKUPS to the world gen thread return CompletableFuture.supplyAsync(this::getUpdatedProfile, Util.PROFILE_EXECUTOR); // Paper - don't submit BLOCKING PROFILE LOOKUPS to the world gen thread
} }
@ -321,4 +321,71 @@ public final class CraftPlayerProfile implements PlayerProfile, com.destroystoky
// Paper - diff on change // Paper - diff on change
return profile; return profile;
} }
// Paper start - This must implement our PlayerProfile so generic casts succeed from cb.CraftPlayerProfile to paper.PlayerProfile
// The methods don't actually have to be implemented, because the profile should immediately be cast to SharedPlayerProfile
@Override
public String setName(final String name) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public UUID getId() {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public UUID setId(final UUID uuid) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public java.util.Set<com.destroystokyo.paper.profile.ProfileProperty> getProperties() {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean hasProperty(final String property) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public void setProperty(final com.destroystokyo.paper.profile.ProfileProperty property) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public void setProperties(final java.util.Collection<com.destroystokyo.paper.profile.ProfileProperty> properties) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public void clearProperties() {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean completeFromCache() {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean completeFromCache(final boolean onlineMode) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean completeFromCache(final boolean lookupUUID, final boolean onlineMode) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean complete(final boolean textures) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
@Override
public boolean complete(final boolean textures, final boolean onlineMode) {
throw new UnsupportedOperationException("Do not cast to com.destroystokyo.paper.profile.PlayerProfile");
}
} }