From 5709af5c0ade33aff357650fd4e57f79c4844649 Mon Sep 17 00:00:00 2001 From: Petr Ilin Date: Mon, 23 Jan 2023 22:55:42 +0300 Subject: [PATCH] Ability to deny/allow commands without permission plugins --- VERSION | 2 +- build.gradle | 4 +- .../java/net/elytrium/limboauth/Settings.java | 32 ++++++++++++++++ .../command/ChangePasswordCommand.java | 4 +- .../command/CommandPermissionState.java | 38 +++++++++++++++++++ .../command/DestroySessionCommand.java | 4 +- .../command/ForceChangePasswordCommand.java | 3 +- .../command/ForceUnregisterCommand.java | 3 +- .../limboauth/command/LimboAuthCommand.java | 21 +++++++--- .../limboauth/command/PremiumCommand.java | 4 +- .../limboauth/command/TotpCommand.java | 4 +- .../limboauth/command/UnregisterCommand.java | 4 +- 12 files changed, 103 insertions(+), 20 deletions(-) create mode 100644 src/main/java/net/elytrium/limboauth/command/CommandPermissionState.java diff --git a/VERSION b/VERSION index 0664a8fd..2bf1ca5f 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.1.6 +1.1.7 diff --git a/build.gradle b/build.gradle index 97e5a26d..bd39c53c 100644 --- a/build.gradle +++ b/build.gradle @@ -10,7 +10,7 @@ plugins { } setGroup("net.elytrium") -setVersion("1.1.6") +setVersion("1.1.7") java { setSourceCompatibility(JavaVersion.VERSION_11) @@ -221,4 +221,6 @@ String getCurrentShortRevision() { setStandardOutput(outputStream) } + + return outputStream.toString().trim() } \ No newline at end of file diff --git a/src/main/java/net/elytrium/limboauth/Settings.java b/src/main/java/net/elytrium/limboauth/Settings.java index b83341a3..17d57824 100644 --- a/src/main/java/net/elytrium/limboauth/Settings.java +++ b/src/main/java/net/elytrium/limboauth/Settings.java @@ -28,6 +28,7 @@ import net.elytrium.commons.kyori.serialization.Serializers; import net.elytrium.limboapi.api.chunk.Dimension; import net.elytrium.limboapi.api.player.GameMode; +import net.elytrium.limboauth.command.CommandPermissionState; import net.elytrium.limboauth.dependencies.DatabaseLibrary; import net.elytrium.limboauth.migration.MigrationHash; import net.kyori.adventure.bossbar.BossBar; @@ -286,6 +287,37 @@ public Title.Times toTimes() { } } + @Create + public MAIN.COMMAND_PERMISSION_STATE COMMAND_PERMISSION_STATE; + + @Comment({ + "Available values: FALSE, TRUE, PERMISSION", + " FALSE - the command will be disallowed", + " TRUE - the command will be allowed if player has false permission state", + " PERMISSION - the command will be allowed if player has true permission state" + }) + public static class COMMAND_PERMISSION_STATE { + @Comment("Permission: limboauth.commands.changepassword") + public CommandPermissionState CHANGE_PASSWORD = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.commands.destroysession") + public CommandPermissionState DESTROY_SESSION = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.commands.premium") + public CommandPermissionState PREMIUM = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.commands.totp") + public CommandPermissionState TOTP = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.commands.unregister") + public CommandPermissionState UNREGISTER = CommandPermissionState.PERMISSION; + + @Comment("Permission: limboauth.admin.forcechangepassword") + public CommandPermissionState FORCE_CHANGE_PASSWORD = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.admin.forceunregister") + public CommandPermissionState FORCE_UNREGISTER = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.admin.reload") + public CommandPermissionState RELOAD = CommandPermissionState.PERMISSION; + @Comment("Permission: limboauth.admin.help") + public CommandPermissionState HELP = CommandPermissionState.TRUE; + } + /* @Create public Settings.MAIN.EVENTS_PRIORITIES EVENTS_PRIORITIES; diff --git a/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java b/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java index ebe90323..d903c32e 100644 --- a/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java @@ -21,7 +21,6 @@ import com.j256.ormlite.stmt.UpdateBuilder; import com.velocitypowered.api.command.CommandSource; import com.velocitypowered.api.command.SimpleCommand; -import com.velocitypowered.api.permission.Tristate; import com.velocitypowered.api.proxy.Player; import java.sql.SQLException; import net.elytrium.commons.kyori.serialization.Serializer; @@ -110,6 +109,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().getPermissionValue("limboauth.commands.changepassword") == Tristate.TRUE; + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.CHANGE_PASSWORD + .hasPermission(invocation.source(), "limboauth.commands.changepassword"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/CommandPermissionState.java b/src/main/java/net/elytrium/limboauth/command/CommandPermissionState.java new file mode 100644 index 00000000..47e92085 --- /dev/null +++ b/src/main/java/net/elytrium/limboauth/command/CommandPermissionState.java @@ -0,0 +1,38 @@ +/* + * Copyright (C) 2021 - 2023 Elytrium + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ + +package net.elytrium.limboauth.command; + +import com.velocitypowered.api.permission.PermissionSubject; +import com.velocitypowered.api.permission.Tristate; +import java.util.function.BiFunction; + +public enum CommandPermissionState { + FALSE((source, permission) -> false), + TRUE((source, permission) -> source.getPermissionValue(permission) != Tristate.FALSE), + PERMISSION(PermissionSubject::hasPermission); + + private final BiFunction hasPermissionFunction; + + CommandPermissionState(BiFunction hasPermissionFunction) { + this.hasPermissionFunction = hasPermissionFunction; + } + + public boolean hasPermission(PermissionSubject permissionSubject, String permission) { + return this.hasPermissionFunction.apply(permissionSubject, permission); + } +} diff --git a/src/main/java/net/elytrium/limboauth/command/DestroySessionCommand.java b/src/main/java/net/elytrium/limboauth/command/DestroySessionCommand.java index 604681ca..f796f2e1 100644 --- a/src/main/java/net/elytrium/limboauth/command/DestroySessionCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/DestroySessionCommand.java @@ -19,7 +19,6 @@ import com.velocitypowered.api.command.CommandSource; import com.velocitypowered.api.command.SimpleCommand; -import com.velocitypowered.api.permission.Tristate; import com.velocitypowered.api.proxy.Player; import net.elytrium.commons.kyori.serialization.Serializer; import net.elytrium.limboauth.LimboAuth; @@ -55,6 +54,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().getPermissionValue("limboauth.commands.destroysession") == Tristate.TRUE; + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.DESTROY_SESSION + .hasPermission(invocation.source(), "imboauth.commands.destroysession"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java b/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java index 9e769e86..ed6f292c 100644 --- a/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java @@ -93,6 +93,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().hasPermission("limboauth.admin.forcechangepassword"); + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.FORCE_CHANGE_PASSWORD + .hasPermission(invocation.source(), "limboauth.admin.forcechangepassword"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/ForceUnregisterCommand.java b/src/main/java/net/elytrium/limboauth/command/ForceUnregisterCommand.java index 9d34d82d..fff71208 100644 --- a/src/main/java/net/elytrium/limboauth/command/ForceUnregisterCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/ForceUnregisterCommand.java @@ -88,6 +88,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().hasPermission("limboauth.admin.forceunregister"); + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.FORCE_UNREGISTER + .hasPermission(invocation.source(), "limboauth.admin.forceunregister"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/LimboAuthCommand.java b/src/main/java/net/elytrium/limboauth/command/LimboAuthCommand.java index d55b421d..56a06384 100644 --- a/src/main/java/net/elytrium/limboauth/command/LimboAuthCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/LimboAuthCommand.java @@ -92,6 +92,12 @@ public void execute(SimpleCommand.Invocation invocation) { } } + @Override + public boolean hasPermission(Invocation invocation) { + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.HELP + .hasPermission(invocation.source(), "limboauth.commands.help"); + } + private void showHelp(CommandSource source) { HELP_MESSAGE.forEach(source::sendMessage); @@ -108,23 +114,26 @@ private void showHelp(CommandSource source) { } private enum Subcommand { - RELOAD("Reload config.", (LimboAuthCommand parent, CommandSource source, String[] args) -> { - parent.plugin.reload(); - source.sendMessage(LimboAuth.getSerializer().deserialize(Settings.IMP.MAIN.STRINGS.RELOAD)); - }); + RELOAD("Reload config.", Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.RELOAD, + (LimboAuthCommand parent, CommandSource source, String[] args) -> { + parent.plugin.reload(); + source.sendMessage(LimboAuth.getSerializer().deserialize(Settings.IMP.MAIN.STRINGS.RELOAD)); + }); private final String command; private final String description; + private final CommandPermissionState permissionState; private final SubcommandExecutor executor; - Subcommand(String description, SubcommandExecutor executor) { + Subcommand(String description, CommandPermissionState permissionState, SubcommandExecutor executor) { + this.permissionState = permissionState; this.command = this.name().toLowerCase(Locale.ROOT); this.description = description; this.executor = executor; } public boolean hasPermission(CommandSource source) { - return source.hasPermission("limboauth.admin." + this.command); + return this.permissionState.hasPermission(source, "limboauth.admin." + this.command); } public Component getMessageLine() { diff --git a/src/main/java/net/elytrium/limboauth/command/PremiumCommand.java b/src/main/java/net/elytrium/limboauth/command/PremiumCommand.java index fb42e92e..7cc04cbc 100644 --- a/src/main/java/net/elytrium/limboauth/command/PremiumCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/PremiumCommand.java @@ -20,7 +20,6 @@ import com.j256.ormlite.dao.Dao; import com.velocitypowered.api.command.CommandSource; import com.velocitypowered.api.command.SimpleCommand; -import com.velocitypowered.api.permission.Tristate; import com.velocitypowered.api.proxy.Player; import java.sql.SQLException; import java.util.Locale; @@ -107,6 +106,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().getPermissionValue("limboauth.commands.premium") == Tristate.TRUE; + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.PREMIUM + .hasPermission(invocation.source(), "limboauth.commands.premium"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/TotpCommand.java b/src/main/java/net/elytrium/limboauth/command/TotpCommand.java index b5edb66e..e78dbcc3 100644 --- a/src/main/java/net/elytrium/limboauth/command/TotpCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/TotpCommand.java @@ -21,7 +21,6 @@ import com.j256.ormlite.stmt.UpdateBuilder; import com.velocitypowered.api.command.CommandSource; import com.velocitypowered.api.command.SimpleCommand; -import com.velocitypowered.api.permission.Tristate; import com.velocitypowered.api.proxy.Player; import dev.samstevens.totp.qr.QrData; import dev.samstevens.totp.recovery.RecoveryCodeGenerator; @@ -187,6 +186,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().getPermissionValue("limboauth.commands.totp") == Tristate.TRUE; + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.TOTP + .hasPermission(invocation.source(), "limboauth.commands.totp"); } } diff --git a/src/main/java/net/elytrium/limboauth/command/UnregisterCommand.java b/src/main/java/net/elytrium/limboauth/command/UnregisterCommand.java index 03f0cfcb..fa8334c0 100644 --- a/src/main/java/net/elytrium/limboauth/command/UnregisterCommand.java +++ b/src/main/java/net/elytrium/limboauth/command/UnregisterCommand.java @@ -20,7 +20,6 @@ import com.j256.ormlite.dao.Dao; import com.velocitypowered.api.command.CommandSource; import com.velocitypowered.api.command.SimpleCommand; -import com.velocitypowered.api.permission.Tristate; import com.velocitypowered.api.proxy.Player; import java.sql.SQLException; import java.util.Locale; @@ -102,6 +101,7 @@ public void execute(SimpleCommand.Invocation invocation) { @Override public boolean hasPermission(SimpleCommand.Invocation invocation) { - return invocation.source().getPermissionValue("limboauth.commands.unregister") == Tristate.TRUE; + return Settings.IMP.MAIN.COMMAND_PERMISSION_STATE.UNREGISTER + .hasPermission(invocation.source(), "limboauth.commands.unregister"); } }