SPIGOT-6803: Fix ServerPing not using the new logic for show players in 1.18

By: Doc <nachito94@msn.com>
This commit is contained in:
CraftBukkit/Spigot 2021-11-24 07:28:22 +11:00
parent c8802f0a64
commit 34c3a49371

View file

@ -19,13 +19,13 @@
public class PacketStatusListener implements PacketStatusInListener { public class PacketStatusListener implements PacketStatusInListener {
private static final IChatBaseComponent DISCONNECT_REASON = new ChatMessage("multiplayer.status.request_handled"); private static final IChatBaseComponent DISCONNECT_REASON = new ChatMessage("multiplayer.status.request_handled");
@@ -36,7 +48,95 @@ @@ -36,7 +48,102 @@
this.connection.disconnect(PacketStatusListener.DISCONNECT_REASON); this.connection.disconnect(PacketStatusListener.DISCONNECT_REASON);
} else { } else {
this.hasRequestedStatus = true; this.hasRequestedStatus = true;
- this.connection.send(new PacketStatusOutServerInfo(this.server.getStatus())); - this.connection.send(new PacketStatusOutServerInfo(this.server.getStatus()));
+ // CraftBukkit start + // CraftBukkit start
+ // this.networkManager.sendPacket(new PacketStatusOutServerInfo(this.minecraftServer.getServerPing())); + // this.connection.send(new PacketStatusOutServerInfo(this.server.getStatus()));
+ final Object[] players = server.getPlayerList().players.toArray(); + final Object[] players = server.getPlayerList().players.toArray();
+ class ServerListPingEvent extends org.bukkit.event.server.ServerListPingEvent { + class ServerListPingEvent extends org.bukkit.event.server.ServerListPingEvent {
+ +
@ -97,12 +97,19 @@
+ java.util.List<GameProfile> profiles = new java.util.ArrayList<GameProfile>(players.length); + java.util.List<GameProfile> profiles = new java.util.ArrayList<GameProfile>(players.length);
+ for (Object player : players) { + for (Object player : players) {
+ if (player != null) { + if (player != null) {
+ profiles.add(((EntityPlayer) player).getGameProfile()); + EntityPlayer entityPlayer = ((EntityPlayer) player);
+ if (entityPlayer.allowsListing()) {
+ profiles.add(entityPlayer.getGameProfile());
+ } else {
+ profiles.add(MinecraftServer.ANONYMOUS_PLAYER_PROFILE);
+ }
+ } + }
+ } + }
+ +
+ ServerPing.ServerPingPlayerSample playerSample = new ServerPing.ServerPingPlayerSample(event.getMaxPlayers(), profiles.size()); + ServerPing.ServerPingPlayerSample playerSample = new ServerPing.ServerPingPlayerSample(event.getMaxPlayers(), profiles.size());
+ playerSample.setSample(profiles.toArray(new GameProfile[profiles.size()])); + if (!this.server.hidesOnlinePlayers()) {
+ playerSample.setSample(profiles.toArray(new GameProfile[profiles.size()]));
+ }
+ +
+ ServerPing ping = new ServerPing(); + ServerPing ping = new ServerPing();
+ ping.setFavicon(event.icon.value); + ping.setFavicon(event.icon.value);