diff --git a/paper-api/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java b/paper-api/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java index 80ef8a2a34..ea73d9cd9d 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java +++ b/paper-api/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java @@ -9,7 +9,9 @@ public class ChannelNameTooLongException extends RuntimeException { super("Attempted to send a Plugin Message to a channel that was too large. The maximum length a channel may be is " + Messenger.MAX_CHANNEL_SIZE + " chars."); } - public ChannelNameTooLongException(String channel) { - super("Attempted to send a Plugin Message to a channel that was too large. The maximum length a channel may be is " + Messenger.MAX_CHANNEL_SIZE + " chars (attempted " + channel.length() + " - '" + channel + "."); + // Paper start + public ChannelNameTooLongException(int length, String shortenedChannel) { + super("Attempted to send a Plugin Message to a channel that was too large. The maximum length a channel may be is " + Messenger.MAX_CHANNEL_SIZE + " chars (attempted " + length + " - '" + shortenedChannel + "."); + // Paper end } } diff --git a/paper-api/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java b/paper-api/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java index 8e96be6033..7449d2f787 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java +++ b/paper-api/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java @@ -496,19 +496,26 @@ public class StandardMessenger implements Messenger { if (channel.equals("bungeecord:main")) { return "BungeeCord"; } + // Paper start - improve error message if (channel.length() > Messenger.MAX_CHANNEL_SIZE) { - throw new ChannelNameTooLongException(channel); + throw new ChannelNameTooLongException(channel.length(), shortened(channel)); } if (channel.indexOf(':') == -1) { - throw new IllegalArgumentException("Channel must contain : separator (attempted to use " + channel + ")"); + throw new IllegalArgumentException("Channel must contain : separator (attempted to use " + shortened(channel) + ")"); } if (!channel.toLowerCase(Locale.ROOT).equals(channel)) { // TODO: use NamespacedKey validation here - throw new IllegalArgumentException("Channel must be entirely lowercase (attempted to use " + channel + ")"); + throw new IllegalArgumentException("Channel must be entirely lowercase (attempted to use " + shortened(channel) + ")"); } return channel; } + private static String shortened(String channel) { + channel = org.apache.commons.lang3.StringUtils.normalizeSpace(channel); + return channel.length() > 32 ? channel.substring(0, 32) + "..." : channel; + } + // Paper end - improve error message + /** * Validates the input of a Plugin Message, ensuring the arguments are all * valid.