mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-06 08:17:44 +01:00
Improve standard messenger logging
This commit is contained in:
parent
23550ec960
commit
f05a7d0a96
@ -0,0 +1,56 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Nassim Jahnke <nassim@njahnke.dev>
|
||||||
|
Date: Mon, 12 Aug 2024 18:38:19 +0200
|
||||||
|
Subject: [PATCH] Improve StandardMessenger exception messages
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java b/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java
|
||||||
|
+++ b/src/main/java/org/bukkit/plugin/messaging/ChannelNameTooLongException.java
|
||||||
|
@@ -0,0 +0,0 @@ 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/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java b/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java
|
||||||
|
+++ b/src/main/java/org/bukkit/plugin/messaging/StandardMessenger.java
|
||||||
|
@@ -0,0 +0,0 @@ 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.
|
@ -25,7 +25,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
|
|
||||||
public void addChannel(String channel) {
|
public void addChannel(String channel) {
|
||||||
- Preconditions.checkState(this.channels.size() < 128, "Cannot register channel '%s'. Too many channels registered!", channel);
|
- Preconditions.checkState(this.channels.size() < 128, "Cannot register channel '%s'. Too many channels registered!", channel);
|
||||||
+ Preconditions.checkState(DISABLE_CHANNEL_LIMIT || this.channels.size() < 128, "Cannot register channel '%s'. Too many channels registered!", channel); // Paper - flag to disable channel limit
|
+ Preconditions.checkState(DISABLE_CHANNEL_LIMIT || this.channels.size() < 128, "Cannot register channel. Too many channels registered!"); // Paper - flag to disable channel limit
|
||||||
channel = StandardMessenger.validateAndCorrectChannel(channel);
|
channel = StandardMessenger.validateAndCorrectChannel(channel);
|
||||||
if (this.channels.add(channel)) {
|
if (this.channels.add(channel)) {
|
||||||
this.server.getPluginManager().callEvent(new PlayerRegisterChannelEvent(this, channel));
|
this.server.getPluginManager().callEvent(new PlayerRegisterChannelEvent(this, channel));
|
||||||
|
Loading…
Reference in New Issue
Block a user