diff --git a/src/main/java/top/focess/qq/core/commands/PermissionCommand.java b/src/main/java/top/focess/qq/core/commands/PermissionCommand.java index 0eeaf2d..5ba254f 100644 --- a/src/main/java/top/focess/qq/core/commands/PermissionCommand.java +++ b/src/main/java/top/focess/qq/core/commands/PermissionCommand.java @@ -14,18 +14,18 @@ import java.util.List; public class PermissionCommand extends Command { - + public PermissionCommand() { super("permission"); } - + @Override public void init() { this.setExecutorPermission(i -> i.isAdministrator() || i.isConsole()); - this.addExecutor((sender,data,ioHandler)->{ + this.addExecutor((sender, data, ioHandler) -> { Plugin plugin = data.get(Plugin.class); if (plugin.getPluginDescription().getPermissions().isEmpty()) - ioHandler.outputLang("permission-command-no-permission",plugin.getName()); + ioHandler.outputLang("permission-command-no-permission", plugin.getName()); else { StringBuilder stringBuilder = new StringBuilder(); for (Permission permission : plugin.getPluginDescription().getPermissions().keySet()) @@ -34,18 +34,27 @@ public void init() { } return CommandResult.ALLOW; }, CommandArgument.of("get"), CommandArgument.of(PluginDataConverter.PLUGIN_DATA_CONVERTER)); - this.addExecutor((sender,data,ioHandler)->{ + this.addExecutor((sender, data, ioHandler) -> { Plugin plugin = data.get(Plugin.class); Permission permission = data.get(Permission.class); if (plugin.getPluginDescription().addPermission(permission)) - ioHandler.outputLang("permission-command-set-success",plugin.getName(), permission.getName()); - else ioHandler.outputLang("permission-command-set-failed",plugin.getName(),permission.getName()); + ioHandler.outputLang("permission-command-set-success", plugin.getName(), permission.getName()); + else ioHandler.outputLang("permission-command-set-failed", plugin.getName(), permission.getName()); return CommandResult.ALLOW; }, CommandArgument.of("set"), CommandArgument.of(PluginDataConverter.PLUGIN_DATA_CONVERTER), CommandArgument.of(PermissionDataConverter.PERMISSION_DATA_CONVERTER)); + this.addExecutor((sender, dataCollection, ioHandler) -> { + Permission permission = dataCollection.get(Permission.class); + StringBuilder stringBuilder = new StringBuilder(); + for (Plugin plugin : Plugin.getPlugins()) + if (plugin.getPluginDescription().getPermissions().getOrDefault(permission, false)) + stringBuilder.append(' ').append(plugin.getName()); + ioHandler.outputLang("permission-command-list-plugin", permission.getName(), stringBuilder.toString()); + return CommandResult.ALLOW; + }, CommandArgument.of("list"), CommandArgument.of(PermissionDataConverter.PERMISSION_DATA_CONVERTER)); } @Override public @NotNull List usage(CommandSender sender) { - return Lists.newArrayList("Use: permission set ","Use: permission get "); + return Lists.newArrayList("Use: permission set ", "Use: permission get ", "Use: permission list "); } } diff --git a/src/main/resources/lang.yml b/src/main/resources/lang.yml index 227cd67..6344cfe 100644 --- a/src/main/resources/lang.yml +++ b/src/main/resources/lang.yml @@ -219,6 +219,7 @@ debug-prevent-event: "Prevent event: %s to %s" debug-cancel-event: "Cancel event: %s to %s" permission-command-no-permission: "The plugin %s does not have permissions" permission-command-list: "The plugin %s has the following permissions:%s" +permission-command-list-plugin: "Plugins including %s are %s" permission-command-set-success: "The plugin %s set the permission %s successfully" permission-command-set-failed: "The plugin %s set the permission %s failed, it may already have the permission" bot-login-qrcode-state: "Bot %d login qrcode state: %s" \ No newline at end of file