From c4591f4fc397311352286f65ef86d333d61aad08 Mon Sep 17 00:00:00 2001 From: IzzelAliz Date: Sat, 2 Dec 2023 21:01:02 +0800 Subject: [PATCH] Add an option that allows non ascii username to login (#1139) --- .../mixin/core/network/ServerLoginNetHandlerMixin.java | 8 +++++++- .../main/java/io/izzel/arclight/i18n/conf/CompatSpec.java | 7 +++++++ i18n-config/src/main/resources/META-INF/arclight.conf | 1 + i18n-config/src/main/resources/META-INF/i18n/en_us.conf | 7 +++++++ i18n-config/src/main/resources/META-INF/i18n/zh_cn.conf | 7 +++++++ 5 files changed, 29 insertions(+), 1 deletion(-) diff --git a/arclight-common/src/main/java/io/izzel/arclight/common/mixin/core/network/ServerLoginNetHandlerMixin.java b/arclight-common/src/main/java/io/izzel/arclight/common/mixin/core/network/ServerLoginNetHandlerMixin.java index c7518944e..0d34a95ec 100644 --- a/arclight-common/src/main/java/io/izzel/arclight/common/mixin/core/network/ServerLoginNetHandlerMixin.java +++ b/arclight-common/src/main/java/io/izzel/arclight/common/mixin/core/network/ServerLoginNetHandlerMixin.java @@ -5,6 +5,7 @@ import io.izzel.arclight.common.bridge.core.network.NetworkManagerBridge; import io.izzel.arclight.common.bridge.core.server.MinecraftServerBridge; import io.izzel.arclight.common.bridge.core.server.management.PlayerListBridge; +import io.izzel.arclight.i18n.ArclightConfig; import net.minecraft.DefaultUncaughtExceptionHandler; import net.minecraft.core.UUIDUtil; import net.minecraft.network.Connection; @@ -132,6 +133,11 @@ public void handleAcceptedLogin() { } } + private static boolean arclight$validUsernameCheck(String name) { + var regex = ArclightConfig.spec().getCompat().getValidUsernameRegex(); + return !regex.isBlank() && name.matches(regex); + } + /** * @author IzzelAliz * @reason @@ -140,7 +146,7 @@ public void handleAcceptedLogin() { public void handleHello(ServerboundHelloPacket packetIn) { Validate.validState(this.state == ServerLoginPacketListenerImpl.State.HELLO, "Unexpected hello packet"); Validate.validState(this.state == ServerLoginPacketListenerImpl.State.HELLO, "Unexpected hello packet"); - Validate.validState(isValidUsername(packetIn.name()), "Invalid characters in username"); + Validate.validState(arclight$validUsernameCheck(packetIn.name()) || isValidUsername(packetIn.name()), "Invalid characters in username"); this.profilePublicKeyData = packetIn.publicKey().orElse(null); GameProfile gameprofile = this.server.getSingleplayerProfile(); if (gameprofile != null && packetIn.name().equalsIgnoreCase(gameprofile.getName())) { diff --git a/i18n-config/src/main/java/io/izzel/arclight/i18n/conf/CompatSpec.java b/i18n-config/src/main/java/io/izzel/arclight/i18n/conf/CompatSpec.java index 4977af997..2c8f01436 100644 --- a/i18n-config/src/main/java/io/izzel/arclight/i18n/conf/CompatSpec.java +++ b/i18n-config/src/main/java/io/izzel/arclight/i18n/conf/CompatSpec.java @@ -26,6 +26,9 @@ public class CompatSpec { @Setting("forward-permission") private String forwardPermission; + @Setting("valid-username-regex") + private String validUsernameRegex; + public Map getMaterials() { return materials; } @@ -57,4 +60,8 @@ public boolean isForwardPermission() { public boolean isForwardPermissionReverse() { return Objects.equals(forwardPermission, "reverse"); } + + public String getValidUsernameRegex() { + return validUsernameRegex; + } } diff --git a/i18n-config/src/main/resources/META-INF/arclight.conf b/i18n-config/src/main/resources/META-INF/arclight.conf index 45356e0aa..92f64a942 100644 --- a/i18n-config/src/main/resources/META-INF/arclight.conf +++ b/i18n-config/src/main/resources/META-INF/arclight.conf @@ -18,6 +18,7 @@ compatibility { "com.example.mod.ExtraLogicWorld" ] forward-permission = true + valid-username-regex = "" } async-catcher { dump = true diff --git a/i18n-config/src/main/resources/META-INF/i18n/en_us.conf b/i18n-config/src/main/resources/META-INF/i18n/en_us.conf index b00ad32b0..cbea50795 100644 --- a/i18n-config/src/main/resources/META-INF/i18n/en_us.conf +++ b/i18n-config/src/main/resources/META-INF/i18n/en_us.conf @@ -119,5 +119,12 @@ comments { "false - Disable permission forward" "reverse - Forward Bukkit player perimission query to Forge" ] + valid-username-regex.comment = [ + "Regex for valid username check. Leave it blank will fallback to vanilla check" + "Following allows Chinese characters:" + "valid-username-regex = \"^[ -~\\\\p{sc=Han}]{1,16}$\"" + "Following allows any username to login:" + "valid-username-regex = \".+\"" + ] } } diff --git a/i18n-config/src/main/resources/META-INF/i18n/zh_cn.conf b/i18n-config/src/main/resources/META-INF/i18n/zh_cn.conf index e30feee6f..c365c364b 100644 --- a/i18n-config/src/main/resources/META-INF/i18n/zh_cn.conf +++ b/i18n-config/src/main/resources/META-INF/i18n/zh_cn.conf @@ -123,5 +123,12 @@ comments { "false - 不启用权限转发" "reverse - 将 Bukkit 玩家权限查询请求转发至 Forge" ] + valid-username-regex.comment = [ + "用户名合法检查正则表达式,留空为使用原版检查" + "如果需要允许中文字符可以使用" + "valid-username-regex = \"^[ -~\\p{sc=Han}]{1,16}$\"" + "如果允许任何用户名可以使用" + "valid-username-regex = \".+\"" + ] } }