Added list permission, added setoffline command, closes #65

This commit is contained in:
Stijn Bannink 2023-08-13 18:32:46 +02:00
parent a1b1deaafe
commit 6662f74d4f
3 changed files with 53 additions and 6 deletions

View file

@ -5,6 +5,8 @@ import org.bukkit.*;
import org.bukkit.block.Block; import org.bukkit.block.Block;
import org.bukkit.block.BlockState; import org.bukkit.block.BlockState;
import org.bukkit.block.Sign; 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.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
@ -12,10 +14,7 @@ import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import tech.sbdevelopment.v10lift.V10LiftPlugin; import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.V10LiftAPI; import tech.sbdevelopment.v10lift.api.V10LiftAPI;
import tech.sbdevelopment.v10lift.api.objects.Floor; import tech.sbdevelopment.v10lift.api.objects.*;
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.managers.DataManager; import tech.sbdevelopment.v10lift.managers.DataManager;
import tech.sbdevelopment.v10lift.managers.VaultManager; import tech.sbdevelopment.v10lift.managers.VaultManager;
import tech.sbdevelopment.v10lift.sbutils.LocationSerializer; import tech.sbdevelopment.v10lift.sbutils.LocationSerializer;
@ -37,7 +36,11 @@ public class V10LiftCommand implements CommandExecutor {
return infoCommand(sender); return infoCommand(sender);
} else if (args[0].equalsIgnoreCase("list") && args.length == 1) { } else if (args[0].equalsIgnoreCase("list") && args.length == 1) {
//v10lift list //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)) { } else if (args[0].equalsIgnoreCase("create") && (args.length == 1 || args.length == 2)) {
//v10lift create || v10lift create <Name> //v10lift create || v10lift create <Name>
if (!(sender instanceof Player)) { if (!(sender instanceof Player)) {
@ -231,6 +234,13 @@ public class V10LiftCommand implements CommandExecutor {
} else { } else {
ConfigUtil.sendMessage(sender, "General.NoPermission"); ConfigUtil.sendMessage(sender, "General.NoPermission");
} }
} else if (args[0].equalsIgnoreCase("setoffline") && args.length == 3) {
//v10lift setoffline <Name> <State>
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")) { } else if (args[0].equalsIgnoreCase("start")) {
//v10lift start <Name> <Floor> //v10lift start <Name> <Floor>
if (sender.hasPermission("v10lift.start") || sender.hasPermission("v10lift.admin")) { if (sender.hasPermission("v10lift.start") || sender.hasPermission("v10lift.admin")) {
@ -265,6 +275,35 @@ public class V10LiftCommand implements CommandExecutor {
return true; 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) { private boolean disableCommand(CommandSender sender, @Nonnull String[] args) {
String liftName = args[1]; String liftName = args[1];
if (!DataManager.containsLift(liftName)) { if (!DataManager.containsLift(liftName)) {

View file

@ -164,3 +164,7 @@ List:
NoLifts: '&cThere are no lifts!' NoLifts: '&cThere are no lifts!'
Header: '&6Lifts:' Header: '&6Lifts:'
Lift: '&6- %Name%' Lift: '&6- %Name%'
SetOffline:
Disabled: '&aThe lift is now offline!'
Enabled: '&aThe lift is now online!'

View file

@ -23,3 +23,7 @@ permissions:
description: Start a lift description: Start a lift
v10lift.stop: v10lift.stop:
description: Stop a lift description: Stop a lift
v10lift.list:
description: List all lifts
v10lift.setoffline:
description: Set a lift offline / online