From ed223f0e4e3874587b165ad637adc453e8919305 Mon Sep 17 00:00:00 2001
From: Luck
Date: Mon, 15 Jan 2018 20:06:20 +0000
Subject: [PATCH] Don't allow empty context keys/values (#688)
---
.../api/context/AbstractContextSet.java | 26 +++++++++++++++++--
.../luckperms/api/context/ContextSet.java | 4 ++-
.../common/commands/utils/ArgumentUtils.java | 4 +--
3 files changed, 29 insertions(+), 5 deletions(-)
diff --git a/api/src/main/java/me/lucko/luckperms/api/context/AbstractContextSet.java b/api/src/main/java/me/lucko/luckperms/api/context/AbstractContextSet.java
index b9c0334c..03074a35 100644
--- a/api/src/main/java/me/lucko/luckperms/api/context/AbstractContextSet.java
+++ b/api/src/main/java/me/lucko/luckperms/api/context/AbstractContextSet.java
@@ -122,11 +122,33 @@ abstract class AbstractContextSet implements ContextSet {
}
static String sanitizeKey(String key) {
- return Objects.requireNonNull(key, "key is null").toLowerCase().intern();
+ Objects.requireNonNull(key, "key is null");
+ if (stringIsEmpty(key)) {
+ throw new IllegalArgumentException("key is (effectively) empty");
+ }
+
+ return key.toLowerCase().intern();
}
static String sanitizeValue(String value) {
- return Objects.requireNonNull(value, "value is null").intern();
+ Objects.requireNonNull(value, "value is null");
+ if (stringIsEmpty(value)) {
+ throw new IllegalArgumentException("value is (effectively) empty");
+ }
+
+ return value.intern();
+ }
+
+ private static boolean stringIsEmpty(String s) {
+ if (s.isEmpty()) {
+ return true;
+ }
+ for (char c : s.toCharArray()) {
+ if (c != ' ') {
+ return false;
+ }
+ }
+ return true;
}
}
diff --git a/api/src/main/java/me/lucko/luckperms/api/context/ContextSet.java b/api/src/main/java/me/lucko/luckperms/api/context/ContextSet.java
index 0ede2d2e..e4f15fe7 100644
--- a/api/src/main/java/me/lucko/luckperms/api/context/ContextSet.java
+++ b/api/src/main/java/me/lucko/luckperms/api/context/ContextSet.java
@@ -51,7 +51,9 @@ import javax.annotation.Nonnull;
* {@link String#toLowerCase() lowercase} by all implementations.
* Values however are case-sensitive.
*
- * Context keys and values may not be null.
+ * Context keys and values may not be null or empty. A key/value will be
+ * deemed empty if it's length is zero, or if it consists of only space
+ * characters.
*
* Two default ContextSet implementations are provided.
* {@link MutableContextSet} allows the addition and removal of context keys
diff --git a/common/src/main/java/me/lucko/luckperms/common/commands/utils/ArgumentUtils.java b/common/src/main/java/me/lucko/luckperms/common/commands/utils/ArgumentUtils.java
index 9dc037d5..5834e7c6 100644
--- a/common/src/main/java/me/lucko/luckperms/common/commands/utils/ArgumentUtils.java
+++ b/common/src/main/java/me/lucko/luckperms/common/commands/utils/ArgumentUtils.java
@@ -134,12 +134,12 @@ public class ArgumentUtils {
}
String key = pair.substring(0, index);
- if (key.equals("")) {
+ if (key.equals("") || key.trim().isEmpty()) {
continue;
}
String value = pair.substring(index + 1);
- if (value.equals("")) {
+ if (value.equals("") || value.trim().isEmpty()) {
continue;
}