From d6fb3a210e11e76ec32c0a51e80f58f05ae276b3 Mon Sep 17 00:00:00 2001 From: Andrew Steinborn Date: Thu, 4 Oct 2018 10:09:03 -0400 Subject: [PATCH] Shorten connection errors to a more reasonable length. Fixes #58 --- .../proxy/connection/client/ConnectedPlayer.java | 14 ++++++++++---- .../velocitypowered/proxy/util/ThrowableUtils.java | 2 +- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/proxy/src/main/java/com/velocitypowered/proxy/connection/client/ConnectedPlayer.java b/proxy/src/main/java/com/velocitypowered/proxy/connection/client/ConnectedPlayer.java index b36203c5d..7d87aba2a 100644 --- a/proxy/src/main/java/com/velocitypowered/proxy/connection/client/ConnectedPlayer.java +++ b/proxy/src/main/java/com/velocitypowered/proxy/connection/client/ConnectedPlayer.java @@ -51,6 +51,7 @@ import java.util.List; import java.util.Optional; import java.util.UUID; import java.util.concurrent.CompletableFuture; +import java.util.concurrent.CompletionException; public class ConnectedPlayer implements MinecraftConnectionAssociation, Player { private static final PlainComponentSerializer PASS_THRU_TRANSLATE = new PlainComponentSerializer((c) -> "", TranslatableComponent::key); @@ -258,13 +259,18 @@ public class ConnectedPlayer implements MinecraftConnectionAssociation, Player { } public void handleConnectionException(RegisteredServer server, Throwable throwable) { - String error = ThrowableUtils.briefDescription(throwable); + Throwable wrapped = throwable; + if (throwable instanceof CompletionException) { + wrapped = throwable.getCause(); + } + + String error = ThrowableUtils.briefDescription(wrapped); String userMessage; if (connectedServer != null && connectedServer.getServerInfo().equals(server.getServerInfo())) { userMessage = "Exception in server " + server.getServerInfo().getName(); } else { - logger.error("{}: unable to connect to server {}", this, server.getServerInfo().getName(), throwable); - userMessage = "Exception connecting to server " + server.getServerInfo().getName(); + logger.error("{}: unable to connect to server {}", this, server.getServerInfo().getName(), wrapped); + userMessage = "Can't connect to server " + server.getServerInfo().getName(); } handleConnectionException(server, null, TextComponent.builder() .content(userMessage + ": ") @@ -286,7 +292,7 @@ public class ConnectedPlayer implements MinecraftConnectionAssociation, Player { } else { logger.error("{}: disconnected while connecting to {}: {}", this, server.getServerInfo().getName(), plainTextReason); handleConnectionException(server, disconnectReason, TextComponent.builder() - .content("Unable to connect to " + server.getServerInfo().getName() + ": ") + .content("Can't connect to server " + server.getServerInfo().getName() + ": ") .color(TextColor.RED) .append(disconnectReason) .build()); diff --git a/proxy/src/main/java/com/velocitypowered/proxy/util/ThrowableUtils.java b/proxy/src/main/java/com/velocitypowered/proxy/util/ThrowableUtils.java index ffb445a73..7bd578d7e 100644 --- a/proxy/src/main/java/com/velocitypowered/proxy/util/ThrowableUtils.java +++ b/proxy/src/main/java/com/velocitypowered/proxy/util/ThrowableUtils.java @@ -4,6 +4,6 @@ public enum ThrowableUtils { ; public static String briefDescription(Throwable throwable) { - return throwable.getClass().getName() + ": " + throwable.getMessage(); + return throwable.getClass().getSimpleName() + ": " + throwable.getMessage(); } }