From e5ce64266f1aaf5bc745cfb33e3cd3a1dbe3da32 Mon Sep 17 00:00:00 2001 From: Luck Date: Mon, 11 Dec 2017 19:40:39 +0000 Subject: [PATCH] Add option to pull server setting from the server.properties file --- .../me/lucko/luckperms/bukkit/LPBukkitPlugin.java | 7 ++++++- bukkit/src/main/resources/config.yml | 4 ++++ .../me/lucko/luckperms/bungee/LPBungeePlugin.java | 2 +- .../common/commands/impl/misc/InfoCommand.java | 2 +- .../lucko/luckperms/common/config/ConfigKeys.java | 11 ++++++++++- .../luckperms/common/plugin/LuckPermsPlugin.java | 13 +++++++++++-- .../me/lucko/luckperms/sponge/LPSpongePlugin.java | 2 +- 7 files changed, 34 insertions(+), 7 deletions(-) diff --git a/bukkit/src/main/java/me/lucko/luckperms/bukkit/LPBukkitPlugin.java b/bukkit/src/main/java/me/lucko/luckperms/bukkit/LPBukkitPlugin.java index d0fa3d54..7e5379ab 100644 --- a/bukkit/src/main/java/me/lucko/luckperms/bukkit/LPBukkitPlugin.java +++ b/bukkit/src/main/java/me/lucko/luckperms/bukkit/LPBukkitPlugin.java @@ -434,7 +434,7 @@ public class LPBukkitPlugin extends JavaPlugin implements LuckPermsPlugin { } @Override - public String getServerName() { + public String getServerBrand() { return getServer().getName(); } @@ -443,6 +443,11 @@ public class LPBukkitPlugin extends JavaPlugin implements LuckPermsPlugin { return getServer().getVersion() + " - " + getServer().getBukkitVersion(); } + @Override + public String getServerName() { + return getServer().getServerName(); + } + @Override public File getDataDirectory() { return super.getDataFolder(); diff --git a/bukkit/src/main/resources/config.yml b/bukkit/src/main/resources/config.yml index 58c965eb..ffb0047c 100644 --- a/bukkit/src/main/resources/config.yml +++ b/bukkit/src/main/resources/config.yml @@ -70,6 +70,10 @@ use-server-uuids: true # in the LuckPerms cache. use-server-uuid-cache: false +# If LuckPerms should use the "server-name" property from the "server.properties" +# file as the "server" option within LuckPerms. +use-server-properties-name: false + # If set to true, LuckPerms will allow usernames with non alphanumeric characters. # # Note that due to the design of the storage implementation, usernames must still be diff --git a/bungee/src/main/java/me/lucko/luckperms/bungee/LPBungeePlugin.java b/bungee/src/main/java/me/lucko/luckperms/bungee/LPBungeePlugin.java index 6cf07f46..7ec5bf6e 100644 --- a/bungee/src/main/java/me/lucko/luckperms/bungee/LPBungeePlugin.java +++ b/bungee/src/main/java/me/lucko/luckperms/bungee/LPBungeePlugin.java @@ -266,7 +266,7 @@ public class LPBungeePlugin extends Plugin implements LuckPermsPlugin { } @Override - public String getServerName() { + public String getServerBrand() { return getProxy().getName(); } diff --git a/common/src/main/java/me/lucko/luckperms/common/commands/impl/misc/InfoCommand.java b/common/src/main/java/me/lucko/luckperms/common/commands/impl/misc/InfoCommand.java index e5fc8c1f..39681d13 100644 --- a/common/src/main/java/me/lucko/luckperms/common/commands/impl/misc/InfoCommand.java +++ b/common/src/main/java/me/lucko/luckperms/common/commands/impl/misc/InfoCommand.java @@ -55,7 +55,7 @@ public class InfoCommand extends SingleCommand { Message.INFO_TOP.send(sender, plugin.getVersion(), plugin.getServerType().getFriendlyName(), - plugin.getServerName(), + plugin.getServerBrand(), plugin.getServerVersion() ); diff --git a/common/src/main/java/me/lucko/luckperms/common/config/ConfigKeys.java b/common/src/main/java/me/lucko/luckperms/common/config/ConfigKeys.java index aa84e02d..e57c5de5 100644 --- a/common/src/main/java/me/lucko/luckperms/common/config/ConfigKeys.java +++ b/common/src/main/java/me/lucko/luckperms/common/config/ConfigKeys.java @@ -68,7 +68,16 @@ public class ConfigKeys { /** * The name of the server */ - public static final ConfigKey SERVER = LowercaseStringKey.of("server", "global"); + public static final ConfigKey SERVER = AbstractKey.of(c -> { + if (c.getBoolean("use-server-properties-name", false)) { + String serverName = c.getPlugin().getServerName(); + if (serverName != null && !serverName.equals("Unknown Server")) { + return serverName.toLowerCase(); + } + } + + return c.getString("server", "global").toLowerCase(); + }); /** * How many minutes to wait between syncs. A value <= 0 will disable syncing. diff --git a/common/src/main/java/me/lucko/luckperms/common/plugin/LuckPermsPlugin.java b/common/src/main/java/me/lucko/luckperms/common/plugin/LuckPermsPlugin.java index dc05397b..d945cdd1 100644 --- a/common/src/main/java/me/lucko/luckperms/common/plugin/LuckPermsPlugin.java +++ b/common/src/main/java/me/lucko/luckperms/common/plugin/LuckPermsPlugin.java @@ -230,7 +230,7 @@ public interface LuckPermsPlugin { * * @return the server brand */ - String getServerName(); + String getServerBrand(); /** * Gets the version of the running platform @@ -239,6 +239,15 @@ public interface LuckPermsPlugin { */ String getServerVersion(); + /** + * Gets the name associated with this server + * + * @return the server name + */ + default String getServerName() { + return null; + } + /** * Gets the time when the plugin first started in millis. * @@ -394,7 +403,7 @@ public interface LuckPermsPlugin { sender.sendMessage(CommandUtils.color("&b | | | / ` |__/ &3|__) |__ |__) |\\/| /__` ")); sender.sendMessage(CommandUtils.color("&b |___ \\__/ \\__, | \\ &3| |___ | \\ | | .__/ ")); sender.sendMessage(CommandUtils.color(" ")); - sender.sendMessage(CommandUtils.color("&2 Loading version &bv" + plugin.getVersion() + "&2 on " + plugin.getServerType().getFriendlyName() + " - " + plugin.getServerName())); + sender.sendMessage(CommandUtils.color("&2 Loading version &bv" + plugin.getVersion() + "&2 on " + plugin.getServerType().getFriendlyName() + " - " + plugin.getServerBrand())); sender.sendMessage(CommandUtils.color("&8 Running on server version " + plugin.getServerVersion())); sender.sendMessage(CommandUtils.color(" ")); } diff --git a/sponge/src/main/java/me/lucko/luckperms/sponge/LPSpongePlugin.java b/sponge/src/main/java/me/lucko/luckperms/sponge/LPSpongePlugin.java index 7e568a1f..636b3fe0 100644 --- a/sponge/src/main/java/me/lucko/luckperms/sponge/LPSpongePlugin.java +++ b/sponge/src/main/java/me/lucko/luckperms/sponge/LPSpongePlugin.java @@ -411,7 +411,7 @@ public class LPSpongePlugin implements LuckPermsPlugin { } @Override - public String getServerName() { + public String getServerBrand() { return getGame().getPlatform().getContainer(Platform.Component.IMPLEMENTATION).getName(); }