From 002dcc2745437c45805de92237d131ed404c4879 Mon Sep 17 00:00:00 2001 From: Ryan Jones <10679776+wordandahalf@users.noreply.github.com> Date: Sun, 28 Jan 2024 18:24:26 -0500 Subject: [PATCH] More safely handle offline authentication servers. (#124) --- .../server/listener/preplay/LoginListener.java | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/src/main/java/net/minestom/server/listener/preplay/LoginListener.java b/src/main/java/net/minestom/server/listener/preplay/LoginListener.java index c14c02beb..d05c6569e 100644 --- a/src/main/java/net/minestom/server/listener/preplay/LoginListener.java +++ b/src/main/java/net/minestom/server/listener/preplay/LoginListener.java @@ -123,8 +123,13 @@ public final class LoginListener { final HttpClient client = HttpClient.newHttpClient(); final HttpRequest request = HttpRequest.newBuilder(URI.create(url)).GET().build(); client.sendAsync(request, HttpResponse.BodyHandlers.ofString()).whenComplete((response, throwable) -> { - if (throwable != null) { - MinecraftServer.getExceptionManager().handleException(throwable); + final boolean ok = throwable == null && response.statusCode() == 200 && response.body() != null && !response.body().isEmpty(); + + if (!ok) { + if (throwable != null) { + MinecraftServer.getExceptionManager().handleException(throwable); + } + if (socketConnection.getPlayer() != null) { socketConnection.getPlayer().kick(Component.text("Failed to contact Mojang's Session Servers (Are they down?)")); } else { @@ -134,15 +139,6 @@ public final class LoginListener { } try { final JsonObject gameProfile = GSON.fromJson(response.body(), JsonObject.class); - if (gameProfile == null) { - // Invalid response - if (socketConnection.getPlayer() != null) { - socketConnection.getPlayer().kick(Component.text("Failed to get data from Mojang's Session Servers (Are they down?)")); - } else { - socketConnection.disconnect(); - } - return; - } socketConnection.setEncryptionKey(getSecretKey(packet.sharedSecret())); UUID profileUUID = java.util.UUID.fromString(gameProfile.get("id").getAsString() .replaceFirst("(\\w{8})(\\w{4})(\\w{4})(\\w{4})(\\w{12})", "$1-$2-$3-$4-$5"));