From 6662f74d4f84c7662b7ef8abd34148a91d1eaddc Mon Sep 17 00:00:00 2001 From: Stijn Bannink Date: Sun, 13 Aug 2023 18:32:46 +0200 Subject: [PATCH] Added list permission, added setoffline command, closes #65 --- .../v10lift/commands/V10LiftCommand.java | 49 +++++++++++++++++-- src/main/resources/messages.yml | 6 ++- src/main/resources/plugin.yml | 4 ++ 3 files changed, 53 insertions(+), 6 deletions(-) diff --git a/src/main/java/tech/sbdevelopment/v10lift/commands/V10LiftCommand.java b/src/main/java/tech/sbdevelopment/v10lift/commands/V10LiftCommand.java index feac92f..03c1fdc 100644 --- a/src/main/java/tech/sbdevelopment/v10lift/commands/V10LiftCommand.java +++ b/src/main/java/tech/sbdevelopment/v10lift/commands/V10LiftCommand.java @@ -5,6 +5,8 @@ import org.bukkit.*; import org.bukkit.block.Block; import org.bukkit.block.BlockState; import org.bukkit.block.Sign; +import org.bukkit.block.data.BlockData; +import org.bukkit.block.data.Powerable; import org.bukkit.command.Command; import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandSender; @@ -12,10 +14,7 @@ import org.bukkit.entity.Player; import org.bukkit.inventory.ItemStack; import tech.sbdevelopment.v10lift.V10LiftPlugin; import tech.sbdevelopment.v10lift.api.V10LiftAPI; -import tech.sbdevelopment.v10lift.api.objects.Floor; -import tech.sbdevelopment.v10lift.api.objects.Lift; -import tech.sbdevelopment.v10lift.api.objects.LiftBlock; -import tech.sbdevelopment.v10lift.api.objects.LiftSign; +import tech.sbdevelopment.v10lift.api.objects.*; import tech.sbdevelopment.v10lift.managers.DataManager; import tech.sbdevelopment.v10lift.managers.VaultManager; import tech.sbdevelopment.v10lift.sbutils.LocationSerializer; @@ -37,7 +36,11 @@ public class V10LiftCommand implements CommandExecutor { return infoCommand(sender); } else if (args[0].equalsIgnoreCase("list") && args.length == 1) { //v10lift list - return listCommand(sender); + if (sender.hasPermission("v10lift.list") || sender.hasPermission("v10lift.admin")) { + return listCommand(sender); + } else { + ConfigUtil.sendMessage(sender, "General.NoPermission"); + } } else if (args[0].equalsIgnoreCase("create") && (args.length == 1 || args.length == 2)) { //v10lift create || v10lift create if (!(sender instanceof Player)) { @@ -231,6 +234,13 @@ public class V10LiftCommand implements CommandExecutor { } else { ConfigUtil.sendMessage(sender, "General.NoPermission"); } + } else if (args[0].equalsIgnoreCase("setoffline") && args.length == 3) { + //v10lift setoffline + if (sender.hasPermission("v10lift.setoffline") || sender.hasPermission("v10lift.admin")) { + return setOfflineCommand(sender, args); + } else { + ConfigUtil.sendMessage(sender, "General.NoPermission"); + } } else if (args[0].equalsIgnoreCase("start")) { //v10lift start if (sender.hasPermission("v10lift.start") || sender.hasPermission("v10lift.admin")) { @@ -265,6 +275,35 @@ public class V10LiftCommand implements CommandExecutor { return true; } + private boolean setOfflineCommand(CommandSender sender, @Nonnull String[] args) { + String liftName = args[1]; + boolean newState = Boolean.parseBoolean(args[2]); + if (!DataManager.containsLift(liftName)) { + ConfigUtil.sendMessage(sender, "General.DoesntExists"); + return true; + } + + Lift lift = DataManager.getLift(liftName); + + lift.setOffline(newState); + + //Update all offline inputs + for (LiftInput li : lift.getOfflineInputs()) { + Block b = Bukkit.getWorld(li.getWorld()).getBlockAt(li.getX(), li.getY(), li.getZ()); + BlockData bd = b.getBlockData(); + if (!(bd instanceof Powerable)) continue; + ((Powerable) bd).setPowered(newState); + b.setBlockData(bd); + } + + if (lift.isOffline()) { + ConfigUtil.sendMessage(sender, "SetOffline.Disabled"); + } else { + ConfigUtil.sendMessage(sender, "SetOffline.Enabled"); + } + return true; + } + private boolean disableCommand(CommandSender sender, @Nonnull String[] args) { String liftName = args[1]; if (!DataManager.containsLift(liftName)) { diff --git a/src/main/resources/messages.yml b/src/main/resources/messages.yml index 26ebaf1..6f6e6d3 100644 --- a/src/main/resources/messages.yml +++ b/src/main/resources/messages.yml @@ -163,4 +163,8 @@ LiftSign: List: NoLifts: '&cThere are no lifts!' Header: '&6Lifts:' - Lift: '&6- %Name%' \ No newline at end of file + Lift: '&6- %Name%' + +SetOffline: + Disabled: '&aThe lift is now offline!' + Enabled: '&aThe lift is now online!' \ No newline at end of file diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml index 856f725..dab432b 100644 --- a/src/main/resources/plugin.yml +++ b/src/main/resources/plugin.yml @@ -23,3 +23,7 @@ permissions: description: Start a lift v10lift.stop: description: Stop a lift + v10lift.list: + description: List all lifts + v10lift.setoffline: + description: Set a lift offline / online \ No newline at end of file