mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-25 01:25:03 +01:00
30e4583dbe
By: Initial Source <noreply+automated@papermc.io>
45 lines
2.9 KiB
Diff
45 lines
2.9 KiB
Diff
--- a/net/minecraft/server/network/LegacyQueryHandler.java
|
|
+++ b/net/minecraft/server/network/LegacyQueryHandler.java
|
|
@@ -35,10 +35,11 @@
|
|
SocketAddress socketaddress = channelhandlercontext.channel().remoteAddress();
|
|
int i = bytebuf.readableBytes();
|
|
String s;
|
|
+ org.bukkit.event.server.ServerListPingEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callServerListPingEvent(socketaddress, this.server.getMotd(), this.server.getPlayerCount(), this.server.getMaxPlayers()); // CraftBukkit
|
|
|
|
if (i == 0) {
|
|
LegacyQueryHandler.LOGGER.debug("Ping: (<1.3.x) from {}", socketaddress);
|
|
- s = LegacyQueryHandler.createVersion0Response(this.server);
|
|
+ s = LegacyQueryHandler.createVersion0Response(this.server, event); // CraftBukkit
|
|
LegacyQueryHandler.sendFlushAndClose(channelhandlercontext, LegacyQueryHandler.createLegacyDisconnectPacket(channelhandlercontext.alloc(), s));
|
|
} else {
|
|
if (bytebuf.readUnsignedByte() != 1) {
|
|
@@ -55,7 +56,7 @@
|
|
LegacyQueryHandler.LOGGER.debug("Ping: (1.4-1.5.x) from {}", socketaddress);
|
|
}
|
|
|
|
- s = LegacyQueryHandler.createVersion1Response(this.server);
|
|
+ s = LegacyQueryHandler.createVersion1Response(this.server, event); // CraftBukkit
|
|
LegacyQueryHandler.sendFlushAndClose(channelhandlercontext, LegacyQueryHandler.createLegacyDisconnectPacket(channelhandlercontext.alloc(), s));
|
|
}
|
|
|
|
@@ -106,12 +107,16 @@
|
|
}
|
|
}
|
|
|
|
- private static String createVersion0Response(ServerInfo server) {
|
|
- return String.format(Locale.ROOT, "%s\u00a7%d\u00a7%d", server.getMotd(), server.getPlayerCount(), server.getMaxPlayers());
|
|
+ // CraftBukkit start
|
|
+ private static String createVersion0Response(ServerInfo serverinfo, org.bukkit.event.server.ServerListPingEvent event) {
|
|
+ return String.format(Locale.ROOT, "%s\u00a7%d\u00a7%d", event.getMotd(), event.getNumPlayers(), event.getMaxPlayers());
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
- private static String createVersion1Response(ServerInfo server) {
|
|
- return String.format(Locale.ROOT, "\u00a71\u0000%d\u0000%s\u0000%s\u0000%d\u0000%d", 127, server.getServerVersion(), server.getMotd(), server.getPlayerCount(), server.getMaxPlayers());
|
|
+ // CraftBukkit start
|
|
+ private static String createVersion1Response(ServerInfo serverinfo, org.bukkit.event.server.ServerListPingEvent event) {
|
|
+ return String.format(Locale.ROOT, "\u00a71\u0000%d\u0000%s\u0000%s\u0000%d\u0000%d", 127, serverinfo.getServerVersion(), event.getMotd(), event.getNumPlayers(), event.getMaxPlayers());
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
private static void sendFlushAndClose(ChannelHandlerContext context, ByteBuf buf) {
|