Migrated to storm
Some checks failed
Java 11 CI / build (push) Has been cancelled
Java 17 CI / build (push) Has been cancelled

This commit is contained in:
Stijn Bannink 2024-08-23 14:12:19 +02:00
parent e5f31385d5
commit fdd34cbe31
Signed by: SBDeveloper
GPG key ID: B730712F2C3A9D7A
25 changed files with 850 additions and 1409 deletions

18
pom.xml
View file

@ -150,6 +150,10 @@
<id>enginehub-maven</id> <id>enginehub-maven</id>
<url>https://maven.enginehub.org/repo/</url> <url>https://maven.enginehub.org/repo/</url>
</repository> </repository>
<repository>
<id>aikar</id>
<url>https://repo.aikar.co/content/groups/aikar/</url>
</repository>
</repositories> </repositories>
<dependencies> <dependencies>
@ -208,5 +212,19 @@
<version>7.2.9</version> <version>7.2.9</version>
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<!-- STORM, framework for HikariCP data storage -->
<dependency>
<groupId>com.github.jensjeflensje</groupId>
<artifactId>storm</artifactId>
<version>4e84a5205f</version>
</dependency>
<!-- Aikar command framework -->
<dependency>
<groupId>co.aikar</groupId>
<artifactId>acf-paper</artifactId>
<version>0.5.1-SNAPSHOT</version>
</dependency>
</dependencies> </dependencies>
</project> </project>

View file

@ -6,20 +6,17 @@ import org.bstats.charts.SingleLineChart;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import tech.sbdevelopment.v10lift.api.V10LiftAPI; import tech.sbdevelopment.v10lift.api.V10LiftAPI;
import tech.sbdevelopment.v10lift.commands.V10LiftCommand;
import tech.sbdevelopment.v10lift.commands.V10LiftTabCompleter;
import tech.sbdevelopment.v10lift.listeners.BlockBreakListener; import tech.sbdevelopment.v10lift.listeners.BlockBreakListener;
import tech.sbdevelopment.v10lift.listeners.EntityDamageListener; import tech.sbdevelopment.v10lift.listeners.EntityDamageListener;
import tech.sbdevelopment.v10lift.listeners.PlayerInteractListener; import tech.sbdevelopment.v10lift.listeners.PlayerInteractListener;
import tech.sbdevelopment.v10lift.listeners.SignChangeListener; import tech.sbdevelopment.v10lift.listeners.SignChangeListener;
import tech.sbdevelopment.v10lift.managers.*; import tech.sbdevelopment.v10lift.managers.*;
import tech.sbdevelopment.v10lift.sbutils.ConfigUpdater;
import tech.sbdevelopment.v10lift.sbutils.UpdateManager; import tech.sbdevelopment.v10lift.sbutils.UpdateManager;
import tech.sbdevelopment.v10lift.sbutils.YamlFile; import tech.sbdevelopment.v10lift.sbutils.YamlFile;
import java.io.IOException; import java.io.IOException;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.Collections; import java.util.logging.Level;
public class V10LiftPlugin extends JavaPlugin { public class V10LiftPlugin extends JavaPlugin {
@Getter @Getter
@ -39,21 +36,20 @@ public class V10LiftPlugin extends JavaPlugin {
public void onEnable() { public void onEnable() {
instance = this; instance = this;
getLogger().info("-------------------------------");
getLogger().info("V10Lift v" + getDescription().getVersion());
getLogger().info("Made by SBDeveloper");
getLogger().info(" ");
//Load the API //Load the API
getLogger().info("Loading API...");
api = new V10LiftAPI(); api = new V10LiftAPI();
//Load the config //Load the config
getLogger().info("Loading configs...");
config = new YamlFile("config"); config = new YamlFile("config");
config.loadDefaults(); config.loadDefaults();
//And update config
try {
ConfigUpdater.update(this, "config.yml", config.getJavaFile(), Collections.emptyList());
} catch (IOException e) {
Bukkit.getLogger().warning("[V10Lift] Couldn't update the config.yml. Please check the stacktrace below.");
e.printStackTrace();
}
//Load the messages //Load the messages
messages = new YamlFile("messages"); messages = new YamlFile("messages");
messages.loadDefaults(); messages.loadDefaults();
@ -65,88 +61,101 @@ public class V10LiftPlugin extends JavaPlugin {
ForbiddenBlockManager.init(); ForbiddenBlockManager.init();
//Load the database //Load the database
dbManager = new DBManager("data"); getLogger().info("Loading lifts from storage...");
dbManager = new DBManager(this, "data");
try { try {
dbManager.load(); dbManager.load();
} catch (SQLException e) { } catch (Exception e) {
Bukkit.getLogger().warning("[V10Lift] Couldn't connect to the SQLite database. Please check the stacktrace below."); getLogger().log(Level.SEVERE, "Couldn't load lifts from data storage.", e);
e.printStackTrace();
} }
//Load vault if found //Load vault if found
if (VaultManager.setupPermissions()) { if (VaultManager.setupPermissions()) {
Bukkit.getLogger().info("[V10Lift] Loading Vault hook for group whitelist support."); getLogger().info("Loading Vault hook for group whitelist support.");
vault = true; vault = true;
} }
//Load worldedit if found //Load worldedit if found
if (Bukkit.getPluginManager().getPlugin("WorldEdit") != null) { if (Bukkit.getPluginManager().getPlugin("WorldEdit") != null) {
Bukkit.getLogger().info("[V10Lift] Loading WorldEdit hook for selection support."); getLogger().info("Loading WorldEdit hook for selection support.");
worldEdit = true; worldEdit = true;
} }
//Load the command //Load the command
getCommand("v10lift").setExecutor(new V10LiftCommand()); getLogger().info("Registering commands...");
getCommand("v10lift").setTabCompleter(new V10LiftTabCompleter()); try {
ACFHandler.init(this);
} catch (IOException e) {
getLogger().log(Level.SEVERE, "Couldn't load commands.", e);
}
//Register the listeners //Register the listeners
getLogger().info("Registering events...");
Bukkit.getPluginManager().registerEvents(new PlayerInteractListener(), this); Bukkit.getPluginManager().registerEvents(new PlayerInteractListener(), this);
Bukkit.getPluginManager().registerEvents(new BlockBreakListener(), this); Bukkit.getPluginManager().registerEvents(new BlockBreakListener(), this);
Bukkit.getPluginManager().registerEvents(new SignChangeListener(), this); Bukkit.getPluginManager().registerEvents(new SignChangeListener(), this);
Bukkit.getPluginManager().registerEvents(new EntityDamageListener(), this); Bukkit.getPluginManager().registerEvents(new EntityDamageListener(), this);
//Load metrics //Load metrics
Bukkit.getLogger().info("[V10Lift] Loading metrics. Can be disabled in the global bStats config."); getLogger().info("Loading metrics. Can be disabled in the global bStats config.");
Metrics metrics = new Metrics(this, 6564); Metrics metrics = new Metrics(this, 6564);
metrics.addCustomChart(new SingleLineChart("lifts", () -> DataManager.getLifts().size())); metrics.addCustomChart(new SingleLineChart("lifts", () -> api.getLifts().size()));
//Load the update checker //Load the update checker
if (getSConfig().getFile().getBoolean("UpdateChecker.Enabled")) { if (getSConfig().getFile().getBoolean("UpdateChecker.Enabled")) {
UpdateManager updateManager = new UpdateManager(this, 72317); UpdateManager updateManager = new UpdateManager(this, UpdateManager.CheckType.SPIGOT);
updateManager.handleResponse((versionResponse, version) -> { updateManager.handleResponse((versionResponse, version) -> {
switch (versionResponse) { switch (versionResponse) {
case FOUND_NEW: case FOUND_NEW:
Bukkit.getLogger().warning("[V10Lift] There is a new version available! Current: " + this.getDescription().getVersion() + " New: " + version.get()); getLogger().warning("There is a new version available! Current: " + this.getDescription().getVersion() + " New: " + version.get());
if (getSConfig().getFile().getBoolean("UpdateChecker.DownloadOnUpdate")) { if (getSConfig().getFile().getBoolean("UpdateChecker.DownloadOnUpdate")) {
Bukkit.getLogger().info("[V10Lift] Trying to download the update. This could take some time..."); getLogger().info("Trying to download the update. This could take some time...");
updateManager.handleDownloadResponse((downloadResponse, fileName) -> { updateManager.handleDownloadResponse((downloadResponse, fileName) -> {
switch (downloadResponse) { switch (downloadResponse) {
case DONE: case DONE:
Bukkit.getLogger().info("[V10Lift] Update downloaded! If you restart your server, it will be loaded. Filename: " + fileName); getLogger().info("Update downloaded! If you restart your server, it will be loaded. Filename: " + fileName);
break; break;
case ERROR: case ERROR:
Bukkit.getLogger().severe("[V10Lift] Something went wrong when trying downloading the latest version."); getLogger().severe("Something went wrong when trying downloading the latest version.");
break; break;
case UNAVAILABLE: case UNAVAILABLE:
Bukkit.getLogger().warning("[V10Lift] Unable to download the latest version."); getLogger().warning("Unable to download the latest version.");
break; break;
} }
}).runUpdate(); }).runUpdate();
} }
break; break;
case LATEST: case LATEST:
Bukkit.getLogger().info("[V10Lift] You are running the latest version [" + this.getDescription().getVersion() + "]!"); getLogger().info("You are running the latest version [" + this.getDescription().getVersion() + "]!");
break; break;
case THIS_NEWER: case THIS_NEWER:
Bukkit.getLogger().info("[V10Lift] You are running a newer version [" + this.getDescription().getVersion() + "]! This is probably fine."); getLogger().info("You are running a newer version [" + this.getDescription().getVersion() + "]! This is probably fine.");
break; break;
case UNAVAILABLE: case UNAVAILABLE:
Bukkit.getLogger().severe("[V10Lift] Unable to perform an update check."); getLogger().severe("Unable to perform an update check.");
break; break;
} }
}).check(); }).check();
} }
Bukkit.getLogger().info("[V10Lift] Plugin loaded successfully!"); getLogger().info("Plugin loaded successfully!");
getLogger().info("-------------------------------");
} }
@Override @Override
public void onDisable() { public void onDisable() {
dbManager.save(); getLogger().info("Saving lifts...");
try {
dbManager.save();
} catch (SQLException e) {
//We can't do anything about it here, just inform the user
getLogger().log(Level.WARNING, "Couldn't save lifts to data storage.", e);
}
dbManager.closeConnection(); dbManager.closeConnection();
getLogger().info("Plugin disabled!");
instance = null; instance = null;
} }

View file

@ -13,6 +13,8 @@ import tech.sbdevelopment.v10lift.api.objects.LiftSign;
import tech.sbdevelopment.v10lift.managers.DataManager; import tech.sbdevelopment.v10lift.managers.DataManager;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.sql.SQLException;
import java.util.*; import java.util.*;
/** /**
@ -20,37 +22,36 @@ import java.util.*;
*/ */
public class V10LiftAPI { public class V10LiftAPI {
@Getter @Getter
private static final List<Lift> lifts = new ArrayList<>(); private final List<Lift> lifts = new ArrayList<>();
/** /**
* Create a new Lift * Create a new Lift
* *
* @param p The player [owner] of the lift * @param p The player [owner] of the lift
* @param liftName The name of the lift * @param liftName The name of the lift
* @return true if created, false if null or already exists * @return The lift object, or null if already exists
*/ */
public boolean createLift(@Nonnull Player p, @Nonnull String liftName) { @Nullable
if (isLift(liftName)) return false; public Lift createLift(@Nonnull Player p, @Nonnull String liftName) {
if (isLift(liftName)) return null;
lifts.add(new Lift(p.getUniqueId(), V10LiftPlugin.getSConfig().getFile().getInt("DefaultSpeed"), V10LiftPlugin.getSConfig().getFile().getBoolean("DefaultRealistic"))); Lift lift = new Lift(p.getUniqueId(), V10LiftPlugin.getSConfig().getFile().getInt("DefaultSpeed"), V10LiftPlugin.getSConfig().getFile().getBoolean("DefaultRealistic"));
return true; lifts.add(lift);
return lift;
} }
/** /**
* Remove a lift * Remove a lift
* *
* @param liftName The name of the lift * @param lift The lift
* @return true if removed, false if null or doesn't exists * @return true if removed, false if failure (check console)
*/ */
public boolean deleteLift(@Nonnull String liftName) { public boolean deleteLift(Lift lift) {
Optional<Lift> liftOpt = getLift(liftName);
if (liftOpt.isEmpty()) return false;
Iterator<Map.Entry<UUID, String>> iter = DataManager.getEditors().entrySet().iterator(); Iterator<Map.Entry<UUID, String>> iter = DataManager.getEditors().entrySet().iterator();
HashSet<UUID> activeEdits = new HashSet<>(); HashSet<UUID> activeEdits = new HashSet<>();
while (iter.hasNext()) { while (iter.hasNext()) {
Map.Entry<UUID, String> entry = iter.next(); Map.Entry<UUID, String> entry = iter.next();
if (entry.getValue().equals(liftName)) { if (entry.getValue().equals(lift.getName())) {
activeEdits.add(entry.getKey()); activeEdits.add(entry.getKey());
iter.remove(); iter.remove();
} }
@ -67,13 +68,18 @@ public class V10LiftAPI {
DataManager.removeDoorEditPlayer(puuid); DataManager.removeDoorEditPlayer(puuid);
} }
if (DataManager.containsMovingTask(liftName)) { if (DataManager.containsMovingTask(lift.getName())) {
Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(liftName)); Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(lift.getName()));
DataManager.removeMovingTask(liftName); DataManager.removeMovingTask(lift.getName());
} }
lifts.remove(liftOpt.get()); lifts.remove(lift);
V10LiftPlugin.getDBManager().remove(liftName); try {
V10LiftPlugin.getDBManager().remove(lift);
} catch (SQLException e) {
e.printStackTrace();
return false;
}
return true; return true;
} }

View file

@ -3,6 +3,7 @@ package tech.sbdevelopment.v10lift.api.lists;
import lombok.Setter; import lombok.Setter;
import tech.sbdevelopment.v10lift.api.objects.Floor; import tech.sbdevelopment.v10lift.api.objects.Floor;
import java.util.Iterator;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.Map; import java.util.Map;
@ -12,6 +13,10 @@ public class LiftQueue {
@Setter @Setter
private LiftQueueListener listener; private LiftQueueListener listener;
public void empty() {
queue.clear();
}
public interface LiftQueueListener { public interface LiftQueueListener {
void onQueueChange(); void onQueueChange();
} }
@ -26,6 +31,10 @@ public class LiftQueue {
} }
} }
public Iterator<Map.Entry<String, Floor>> iterator() {
return queue.entrySet().iterator();
}
public boolean hasRequests() { public boolean hasRequests() {
return !queue.isEmpty(); return !queue.isEmpty();
} }

View file

@ -1,5 +1,8 @@
package tech.sbdevelopment.v10lift.api.objects; package tech.sbdevelopment.v10lift.api.objects;
import com.craftmend.storm.api.StormModel;
import com.craftmend.storm.api.markers.Column;
import com.craftmend.storm.api.markers.Table;
import lombok.Getter; import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.Setter; import lombok.Setter;
@ -27,35 +30,56 @@ import java.util.*;
@Getter @Getter
@NoArgsConstructor @NoArgsConstructor
@ToString @ToString
public class Lift { @Table(name = "lifts")
public class Lift extends StormModel {
@Column
@Setter @Setter
private String name; private String name;
@Column
@Setter @Setter
private String worldName; private String worldName;
@Column
@Setter @Setter
private int y; private int y;
@Column
private HashSet<UUID> owners; private HashSet<UUID> owners;
@Column
private final TreeSet<LiftBlock> blocks = new TreeSet<>(); private final TreeSet<LiftBlock> blocks = new TreeSet<>();
@Column
private final LinkedHashMap<String, Floor> floors = new LinkedHashMap<>(); private final LinkedHashMap<String, Floor> floors = new LinkedHashMap<>();
@Column
private final HashSet<LiftSign> signs = new HashSet<>(); private final HashSet<LiftSign> signs = new HashSet<>();
@Column
private final HashSet<LiftInput> inputs = new HashSet<>(); private final HashSet<LiftInput> inputs = new HashSet<>();
@Column
private final HashSet<LiftInput> offlineInputs = new HashSet<>(); private final HashSet<LiftInput> offlineInputs = new HashSet<>();
//transient
private final LiftQueue queue = new LiftQueue(); private final LiftQueue queue = new LiftQueue();
@Column
private final HashSet<LiftRope> ropes = new HashSet<>(); private final HashSet<LiftRope> ropes = new HashSet<>();
@Column
@Setter @Setter
private int speed; private int speed;
@Column
@Setter @Setter
private boolean realistic; private boolean realistic;
@Column
private boolean offline = false; private boolean offline = false;
@Column
@Setter @Setter
private boolean sound = true; private boolean sound = true;
@Column
private boolean defective = false; private boolean defective = false;
@Column
@Setter @Setter
private String signText = null; private String signText = null;
//transient
@Setter @Setter
private int counter = 0; private int counter = 0;
//transient
@Setter @Setter
private Floor doorOpen = null; private Floor doorOpen = null;
//transient
@Setter @Setter
private DoorCloser doorCloser = null; private DoorCloser doorCloser = null;

View file

@ -1,6 +1,5 @@
package tech.sbdevelopment.v10lift.api.runnables; package tech.sbdevelopment.v10lift.api.runnables;
import com.cryptomorin.xseries.XMaterial;
import com.cryptomorin.xseries.XSound; import com.cryptomorin.xseries.XSound;
import org.bukkit.*; import org.bukkit.*;
import org.bukkit.block.Block; import org.bukkit.block.Block;
@ -11,14 +10,13 @@ import org.bukkit.entity.Entity;
import org.bukkit.inventory.Inventory; import org.bukkit.inventory.Inventory;
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.enums.LiftDirection; import tech.sbdevelopment.v10lift.api.enums.LiftDirection;
import tech.sbdevelopment.v10lift.api.objects.*; import tech.sbdevelopment.v10lift.api.objects.*;
import tech.sbdevelopment.v10lift.managers.AntiCopyBlockManager; import tech.sbdevelopment.v10lift.managers.AntiCopyBlockManager;
import tech.sbdevelopment.v10lift.managers.DataManager; import tech.sbdevelopment.v10lift.managers.DataManager;
import tech.sbdevelopment.v10lift.sbutils.LocationSerializer; import tech.sbdevelopment.v10lift.sbutils.LocationSerializer;
import tech.sbdevelopment.v10lift.utils.ConfigUtil;
import tech.sbdevelopment.v10lift.utils.BlockStateUtil; import tech.sbdevelopment.v10lift.utils.BlockStateUtil;
import tech.sbdevelopment.v10lift.utils.ConfigUtil;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.*; import java.util.*;
@ -67,15 +65,16 @@ public class MoveLift implements Runnable {
@Override @Override
public void run() { public void run() {
//Check if lift exists //Check if lift exists
Lift lift = DataManager.getLift(liftName); Optional<Lift> liftOpt = V10LiftPlugin.getApi().getLift(liftName);
if (lift == null) { if (liftOpt.isEmpty()) {
stop(); stop();
return; return;
} }
Lift lift = liftOpt.get();
//If the queue is NOT empty and the lift is NOT offline //If the queue is NOT empty and the lift is offline
if (lift.getQueue().isEmpty() || lift.isOffline()) { if (lift.getQueue().hasRequests() || lift.isOffline()) {
lift.setQueue(null); lift.getQueue().empty();
stop(); stop();
return; return;
} }
@ -122,12 +121,12 @@ public class MoveLift implements Runnable {
if (changeOfDefect > 0.0D) { if (changeOfDefect > 0.0D) {
double chance = ThreadLocalRandom.current().nextDouble(100); double chance = ThreadLocalRandom.current().nextDouble(100);
if (chance < changeOfDefect) { if (chance < changeOfDefect) {
V10LiftAPI.getInstance().setDefective(liftName, true); lift.setDefective(true);
return; return;
} }
} }
Iterator<Map.Entry<String, Floor>> queueIterator = lift.getQueue().entrySet().iterator(); Iterator<Map.Entry<String, Floor>> queueIterator = lift.getQueue().iterator();
Map.Entry<String, Floor> floor = queueIterator.next(); Map.Entry<String, Floor> floor = queueIterator.next();
String floorName = floor.getKey(); String floorName = floor.getKey();
Floor floorTo = floor.getValue(); Floor floorTo = floor.getValue();
@ -144,7 +143,7 @@ public class MoveLift implements Runnable {
List<LiftBlock> antiCopyBlocks = new ArrayList<>(); List<LiftBlock> antiCopyBlocks = new ArrayList<>();
if (direction == LiftDirection.UP || direction == LiftDirection.DOWN) { if (direction == LiftDirection.UP || direction == LiftDirection.DOWN) {
if (!V10LiftAPI.getInstance().closeDoor(liftName)) return; if (!lift.closeDoor()) return;
if (direction == LiftDirection.UP) { if (direction == LiftDirection.UP) {
//MOVE ROPES //MOVE ROPES
@ -152,7 +151,7 @@ public class MoveLift implements Runnable {
if (rope.getCurrently() > rope.getMaxY()) { if (rope.getCurrently() > rope.getMaxY()) {
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!"); Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!");
V10LiftAPI.getInstance().setDefective(liftName, true); lift.setDefective(true);
queueIterator.remove(); queueIterator.remove();
return; return;
} }
@ -305,7 +304,7 @@ public class MoveLift implements Runnable {
if (rope.getCurrently() < rope.getMinY()) { if (rope.getCurrently() < rope.getMinY()) {
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!"); Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!");
V10LiftAPI.getInstance().setDefective(liftName, true); lift.setDefective(true);
queueIterator.remove(); queueIterator.remove();
stopAfter = true; stopAfter = true;
@ -388,7 +387,7 @@ public class MoveLift implements Runnable {
ls.setState((byte) 0); ls.setState((byte) 0);
} }
V10LiftAPI.getInstance().openDoor(lift, liftName, floorTo); lift.openDoor(floorTo);
if (lift.isRealistic()) lift.setCounter(ft); if (lift.isRealistic()) lift.setCounter(ft);

View file

@ -1,15 +1,15 @@
package tech.sbdevelopment.v10lift.commands; package tech.sbdevelopment.v10lift.commands;
import co.aikar.commands.BaseCommand;
import co.aikar.commands.CommandHelp;
import co.aikar.commands.annotation.*;
import com.cryptomorin.xseries.XMaterial; import com.cryptomorin.xseries.XMaterial;
import com.ibm.icu.impl.Pair;
import org.bukkit.*; 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.BlockData;
import org.bukkit.block.data.Powerable; import org.bukkit.block.data.Powerable;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
@ -25,285 +25,102 @@ import tech.sbdevelopment.v10lift.utils.ConfigUtil;
import tech.sbdevelopment.v10lift.utils.WorldEditUtil; import tech.sbdevelopment.v10lift.utils.WorldEditUtil;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import java.sql.SQLException; import java.util.Optional;
import java.util.*; import java.util.*;
public class V10LiftCommand implements CommandExecutor { @CommandAlias("v10lift|v10l")
@Description("The main command for V10Lift")
@Override public class V10LiftCommand extends BaseCommand {
public boolean onCommand(@Nonnull CommandSender sender, @Nonnull Command cmd, @Nonnull String label, @Nonnull String[] args) { @HelpCommand
if (args.length == 0) { @CatchUnknown
//v10lift @Default
return helpCommand(sender); public static void onHelp(CommandSender sender, CommandHelp help) {
} else if (args[0].equalsIgnoreCase("info") && args.length == 1) { help.showHelp();
//v10lift info
return infoCommand(sender);
} else if (args[0].equalsIgnoreCase("list") && args.length == 1) {
//v10lift list
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 <Name>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return createCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("delete") && args.length == 2) {
//v10lift delete <Name>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return deleteCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("edit") && (args.length == 1 || args.length == 2)) {
//v10lift edit <Name>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return editCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("floor") && (args.length == 3 || args.length == 4)) {
//v10lift floor add <Name> || v10lift floor del <Name> || v10lift floor rename <Old> <New>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return floorCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("input") && (args.length == 2 || args.length == 3)) {
//v10lift input add <Floor name> || v10lift input del
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return inputCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("offline") && args.length == 2) {
//v10lift offline add || v10lift offline del
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return offlineCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("rename") && args.length == 2) {
//v10lift rename <New name>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return renameCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("build") && args.length == 1) {
//v10lift build
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return buildCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("build") && args.length == 2 && args[1].equalsIgnoreCase("worldedit")) {
//v10lift build worldedit
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
if (!V10LiftPlugin.isWorldEditEnabled()) {
ConfigUtil.sendMessage(sender, "Build.WorldEditNotEnabled");
return true;
}
return buildWorldEditCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("rope") && args.length == 2) {
//v10lift rope add || v10lift rope del
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return ropeCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("door") && (args.length == 1 || args.length == 2)) {
//v10lift door <Name> || v10lift door
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return doorCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("whitelist") && (args.length == 3 || args.length == 4)) {
//v10lift whitelist add <Player> <Floor> || v10lift whitelist del <Player> <Floor>
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return whitelistCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("whois") && (args.length == 1 || args.length == 2)) {
//v10lift whois || v10lift whois <Name>
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return whoisCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("speed") && (args.length == 2 || args.length == 3)) {
//v10lift speed <Speed> [Name]
if (args.length == 2 && !(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return speedCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("sound") && args.length == 1) {
//v10lift sound
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return soundCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("realistic") && args.length == 1) {
//v10lift realistic
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return realisticCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("abort") && args.length == 1) {
//v10lift abort
if (!(sender instanceof Player)) {
ConfigUtil.sendMessage(sender, "General.PlayerOnly");
return true;
}
if (sender.hasPermission("v10lift.build") || sender.hasPermission("v10lift.admin")) {
return abortCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("reload") && args.length == 1) {
//v10lift reload
if (sender.hasPermission("v10lift.reload") || sender.hasPermission("v10lift.admin")) {
return reloadCommand(sender);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("repair") && args.length == 2) {
//v10lift repair <Name>
if (sender.hasPermission("v10lift.repair") || sender.hasPermission("v10lift.admin")) {
return repairCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("disable") && args.length == 2) {
//v10lift disable <Name>
if (sender.hasPermission("v10lift.disable") || sender.hasPermission("v10lift.admin")) {
return disableCommand(sender, args);
} else {
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")) {
//v10lift start <Name> <Floor>
if (sender.hasPermission("v10lift.start") || sender.hasPermission("v10lift.admin")) {
return startCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else if (args[0].equalsIgnoreCase("stop")) {
//v10lift stop <Name>
if (sender.hasPermission("v10lift.stop") || sender.hasPermission("v10lift.admin")) {
return stopCommand(sender, args);
} else {
ConfigUtil.sendMessage(sender, "General.NoPermission");
}
} else {
return helpCommand(sender);
}
return true;
} }
private boolean listCommand(CommandSender sender) { @Subcommand("info")
@Description("Get information about the plugin")
public void infoCommand(CommandSender sender) {
sender.sendMessage(ChatColor.DARK_GREEN + "V10Lift v" + V10LiftPlugin.getInstance().getDescription().getVersion());
sender.sendMessage(ChatColor.GREEN + "Made by SBDeveloper");
sender.sendMessage(ChatColor.GREEN + " ");
sender.sendMessage(ChatColor.GREEN + "Type /v10lift help for more information!");
}
@Subcommand("list")
@Description("List all lifts")
@CommandPermission("v10lift.list")
public void listCommand(CommandSender sender) {
//Send list of all lifts //Send list of all lifts
Map<String, Lift> lifts = DataManager.getLifts(); List<Lift> lifts = V10LiftPlugin.getApi().getLifts();
if (lifts.isEmpty()) { if (lifts.isEmpty()) {
ConfigUtil.sendMessage(sender, "List.NoLifts"); ConfigUtil.sendMessage(sender, "List.NoLifts");
return true; return;
} }
ConfigUtil.sendMessage(sender, "List.Header"); ConfigUtil.sendMessage(sender, "List.Header");
for (String liftName : lifts.keySet()) { for (Lift lift : lifts) {
ConfigUtil.sendMessage(sender, "List.Lift", Map.of("%Name%", liftName)); ConfigUtil.sendMessage(sender, "List.Lift", Map.of("%Name%", lift.getName()));
} }
return true; }
@Subcommand("create")
@Description("Create a lift")
@CommandPermission("v10lift.admin")
@CommandCompletion("@nothing")
public void createCommand(Player p, @co.aikar.commands.annotation.Optional String name) {
if (DataManager.containsPlayer(p.getUniqueId())) {
//Already building!!
if (name == null) {
ConfigUtil.sendMessage(p, "General.IncorrectUsage", Collections.singletonMap("%Command%", "/v10lift create <Name>"));
return;
}
TreeSet<LiftBlock> blocks = DataManager.getPlayer(p.getUniqueId());
if (blocks.isEmpty()) {
ConfigUtil.sendMessage(p, "Create.NoBlocks");
return;
}
Lift lift = V10LiftPlugin.getApi().createLift(p, name);
if (lift == null) {
ConfigUtil.sendMessage(p, "General.AlreadyExists");
return;
}
blocks.forEach(block -> lift.addBlock(lift.getBlocks(), block));
lift.sortLiftBlocks();
DataManager.removePlayer(p.getUniqueId());
ConfigUtil.sendMessage(p, "Create.Created", Collections.singletonMap("%Name%", name));
p.performCommand("v10lift edit " + name);
} else {
//Not building yet!!
DataManager.addPlayer(p.getUniqueId());
ConfigUtil.sendMessage(p, "Create.AddBlocks");
}
}
@Subcommand("delete")
@Description("Delete a lift")
@CommandPermission("v10lift.admin")
@CommandCompletion("@lifts")
public void deleteCommand(Player p, Lift lift) {
if (!V10LiftPlugin.getApi().deleteLift(lift)) {
ConfigUtil.sendMessage(p, "Delete.NotRemoved", Collections.singletonMap("%Name%", lift.getName()));
return;
}
ConfigUtil.sendMessage(p, "Delete.Removed", Collections.singletonMap("%Name%", lift.getName()));
} }
private boolean setOfflineCommand(CommandSender sender, @Nonnull String[] args) { private boolean setOfflineCommand(CommandSender sender, @Nonnull String[] args) {
String liftName = args[1]; String liftName = args[1];
boolean newState = Boolean.parseBoolean(args[2]); boolean newState = Boolean.parseBoolean(args[2]);
if (!DataManager.containsLift(liftName)) { Optional<Lift> liftOpt = V10LiftPlugin.getApi().getLift(liftName);
if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(liftName);
lift.setOffline(newState); lift.setOffline(newState);
@ -326,74 +143,73 @@ public class V10LiftCommand implements CommandExecutor {
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)) { Optional<Lift> liftOpt = V10LiftPlugin.getApi().getLift(liftName);
if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(liftName);
if (lift.isDefective()) { if (lift.isDefective()) {
ConfigUtil.sendMessage(sender, "Disable.AlreadyDefective"); ConfigUtil.sendMessage(sender, "Disable.AlreadyDefective");
return true; return true;
} }
V10LiftAPI.getInstance().setDefective(liftName, true); lift.setDefective(true);
ConfigUtil.sendMessage(sender, "Disable.Disabled"); ConfigUtil.sendMessage(sender, "Disable.Disabled");
return true; return true;
} }
private boolean stopCommand(CommandSender sender, @Nonnull String[] args) { private boolean stopCommand(CommandSender sender, @Nonnull String[] args) {
String liftName; Optional<Lift> liftOpt;
if (args.length == 1 && sender instanceof Player) { if (args.length == 1 && sender instanceof Player) {
//v10lift stop -> Get liftName from loc and floorName from sign //v10lift stop -> Get liftName from loc and floorName from sign
Player p = (Player) sender; Player p = (Player) sender;
liftName = V10LiftAPI.getInstance().getLiftByLocation(p.getLocation()); liftOpt = V10LiftPlugin.getApi().getLift(p.getLocation());
} else if (args.length == 1) { } else if (args.length == 1) {
ConfigUtil.sendMessage(sender, "Stop.NonPlayer"); ConfigUtil.sendMessage(sender, "Stop.NonPlayer");
return true; return true;
} else { } else {
liftName = args[1]; liftOpt = V10LiftPlugin.getApi().getLift(args[1]);
} }
if (liftName == null || !DataManager.containsLift(liftName)) { if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(liftName); if (lift.getQueue().hasRequests()) lift.getQueue().empty();
if (!lift.getQueue().isEmpty()) lift.getQueue().clear();
if (!DataManager.containsMovingTask(liftName)) { if (!DataManager.containsMovingTask(lift.getName())) {
ConfigUtil.sendMessage(sender, "Stop.NoMovingTasks", Collections.singletonMap("%Name%", liftName)); ConfigUtil.sendMessage(sender, "Stop.NoMovingTasks", Collections.singletonMap("%Name%", lift.getName()));
return true; return true;
} }
Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(liftName)); Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(lift.getName()));
DataManager.removeMovingTask(liftName); DataManager.removeMovingTask(lift.getName());
ConfigUtil.sendMessage(sender, "Stop.Stopped", Collections.singletonMap("%Name%", liftName)); ConfigUtil.sendMessage(sender, "Stop.Stopped", Collections.singletonMap("%Name%", lift.getName()));
return true; return true;
} }
private boolean startCommand(CommandSender sender, @Nonnull String[] args) { private boolean startCommand(CommandSender sender, @Nonnull String[] args) {
String liftName; Optional<Lift> liftOpt;
if (args.length == 1 && sender instanceof Player) { if (args.length == 1 && sender instanceof Player) {
//v10lift start -> Get liftName from loc and floorName from sign //v10lift stop -> Get liftName from loc and floorName from sign
Player p = (Player) sender; Player p = (Player) sender;
liftName = V10LiftAPI.getInstance().getLiftByLocation(p.getLocation()); liftOpt = V10LiftPlugin.getApi().getLift(p.getLocation());
} else if (args.length == 1) { } else if (args.length == 1) {
ConfigUtil.sendMessage(sender, "Start.NonPlayer"); ConfigUtil.sendMessage(sender, "Start.NonPlayer");
return true; return true;
} else { } else {
liftName = args[1]; liftOpt = V10LiftPlugin.getApi().getLift(args[1]);
} }
if (liftName == null || !DataManager.containsLift(liftName)) { if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(liftName);
String floorName = null; String floorName = null;
if (args.length == 1 || args.length == 2) { if (args.length == 1 || args.length == 2) {
@ -418,20 +234,19 @@ public class V10LiftCommand implements CommandExecutor {
} }
Floor f = lift.getFloors().get(floorName); Floor f = lift.getFloors().get(floorName);
V10LiftAPI.getInstance().addToQueue(liftName, f, floorName); lift.getQueue().requestFloor(floorName, f);
ConfigUtil.sendMessage(sender, "Start.Started", Collections.singletonMap("%Name%", liftName)); ConfigUtil.sendMessage(sender, "Start.Started", Collections.singletonMap("%Name%", lift.getName()));
return true; return true;
} }
private boolean reloadCommand(CommandSender sender) { private boolean reloadCommand(CommandSender sender) {
for (Map.Entry<String, Lift> e : DataManager.getLifts().entrySet()) { for (Lift lift : V10LiftPlugin.getApi().getLifts()) {
String lift = e.getKey(); if (DataManager.containsMovingTask(lift.getName())) {
if (DataManager.containsMovingTask(lift)) { Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(lift.getName()));
Bukkit.getScheduler().cancelTask(DataManager.getMovingTask(lift));
} }
e.getValue().setQueue(null); lift.getQueue().empty();
V10LiftAPI.getInstance().sortLiftBlocks(lift); lift.sortLiftBlocks();
} }
DataManager.clearMovingTasks(); DataManager.clearMovingTasks();
@ -439,7 +254,7 @@ public class V10LiftCommand implements CommandExecutor {
try { try {
V10LiftPlugin.getDBManager().save(); V10LiftPlugin.getDBManager().save();
V10LiftPlugin.getDBManager().load(); V10LiftPlugin.getDBManager().load();
} catch (SQLException e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -486,7 +301,7 @@ public class V10LiftCommand implements CommandExecutor {
if (DataManager.containsBuilderPlayer(p.getUniqueId())) { if (DataManager.containsBuilderPlayer(p.getUniqueId())) {
DataManager.removeBuilderPlayer(p.getUniqueId()); DataManager.removeBuilderPlayer(p.getUniqueId());
V10LiftAPI.getInstance().sortLiftBlocks(DataManager.getEditPlayer(p.getUniqueId())); V10LiftPlugin.getApi().getLift(DataManager.getEditPlayer(p.getUniqueId())).get().sortLiftBlocks();
abort = true; abort = true;
} }
@ -515,12 +330,12 @@ public class V10LiftCommand implements CommandExecutor {
private boolean repairCommand(CommandSender sender, @Nonnull String[] args) { private boolean repairCommand(CommandSender sender, @Nonnull String[] args) {
String liftName = args[1]; String liftName = args[1];
if (!DataManager.containsLift(liftName)) { Optional<Lift> liftOpt = V10LiftPlugin.getApi().getLift(liftName);
if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(liftName);
if (!lift.isDefective()) { if (!lift.isDefective()) {
ConfigUtil.sendMessage(sender, "Repair.NotDefective"); ConfigUtil.sendMessage(sender, "Repair.NotDefective");
@ -553,7 +368,7 @@ public class V10LiftCommand implements CommandExecutor {
} }
} }
} }
V10LiftAPI.getInstance().setDefective(liftName, false); lift.setDefective(false);
ConfigUtil.sendMessage(sender, "Repair.Repaired"); ConfigUtil.sendMessage(sender, "Repair.Repaired");
return true; return true;
} }
@ -565,7 +380,7 @@ public class V10LiftCommand implements CommandExecutor {
return true; return true;
} }
Lift lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId())); Lift lift = V10LiftPlugin.getApi().getLift(DataManager.getEditPlayer(p.getUniqueId())).get();
lift.setRealistic(!lift.isRealistic()); lift.setRealistic(!lift.isRealistic());
if (lift.isRealistic()) { if (lift.isRealistic()) {
ConfigUtil.sendMessage(sender, "Realistic.TurnedOn"); ConfigUtil.sendMessage(sender, "Realistic.TurnedOn");
@ -582,7 +397,7 @@ public class V10LiftCommand implements CommandExecutor {
return true; return true;
} }
Lift lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId())); Lift lift = V10LiftPlugin.getApi().getLift(DataManager.getEditPlayer(p.getUniqueId())).get();
lift.setSound(!lift.isSound()); lift.setSound(!lift.isSound());
if (lift.isSound()) { if (lift.isSound()) {
ConfigUtil.sendMessage(sender, "Sound.TurnedOn"); ConfigUtil.sendMessage(sender, "Sound.TurnedOn");
@ -595,11 +410,11 @@ public class V10LiftCommand implements CommandExecutor {
private boolean speedCommand(CommandSender sender, @Nonnull String[] args) { private boolean speedCommand(CommandSender sender, @Nonnull String[] args) {
Lift lift; Lift lift;
if (args.length == 3) { if (args.length == 3) {
if (!DataManager.containsLift(args[2])) { if (!V10LiftPlugin.getApi().isLift(args[2])) {
ConfigUtil.sendMessage(sender, "General.DoesntExists"); ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true; return true;
} }
lift = DataManager.getLift(args[2]); lift = V10LiftPlugin.getApi().getLift(args[2]).get();
} else { } else {
Player p = (Player) sender; Player p = (Player) sender;
if (!DataManager.containsEditPlayer(p.getUniqueId())) { if (!DataManager.containsEditPlayer(p.getUniqueId())) {
@ -607,7 +422,7 @@ public class V10LiftCommand implements CommandExecutor {
return true; return true;
} }
lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId())); lift = V10LiftPlugin.getApi().getLift(DataManager.getEditPlayer(p.getUniqueId())).get();
} }
try { try {
@ -634,10 +449,10 @@ public class V10LiftCommand implements CommandExecutor {
ConfigUtil.sendMessage(sender, "Whois.WithoutName"); ConfigUtil.sendMessage(sender, "Whois.WithoutName");
} else { } else {
String liftName = args[1]; String liftName = args[1];
if (!DataManager.containsLift(liftName)) { if (!V10LiftPlugin.getApi().isLift(liftName)) {
ConfigUtil.sendMessage(sender, "Whois.DoesntExists"); ConfigUtil.sendMessage(sender, "Whois.DoesntExists");
} else { } else {
V10LiftAPI.getInstance().sendLiftInfo(sender, liftName); V10LiftPlugin.getApi().getLift(liftName).get().sendInfo(sender);
} }
} }
return true; return true;
@ -1145,100 +960,4 @@ public class V10LiftCommand implements CommandExecutor {
} }
return true; return true;
} }
private boolean deleteCommand(@Nonnull CommandSender sender, @Nonnull String[] args) {
Player p = (Player) sender;
if (!DataManager.containsLift(args[1])) {
ConfigUtil.sendMessage(sender, "General.DoesntExists");
return true;
}
Lift lift = DataManager.getLift(args[1]);
if (!lift.getOwners().contains(p.getUniqueId()) && !p.hasPermission("v10lift.admin")) {
ConfigUtil.sendMessage(sender, "General.NoPermission");
return true;
}
if (!V10LiftAPI.getInstance().removeLift(args[1])) {
ConfigUtil.sendMessage(sender, "Delete.NotRemoved", Collections.singletonMap("%Name%", args[1]));
return true;
}
ConfigUtil.sendMessage(sender, "Delete.Removed", Collections.singletonMap("%Name%", args[1]));
return true;
}
private boolean createCommand(@Nonnull CommandSender sender, @Nonnull String[] args) {
Player p = (Player) sender;
if (DataManager.containsPlayer(p.getUniqueId())) {
//Already building!!
if (args.length < 2) {
ConfigUtil.sendMessage(sender, "General.IncorrectUsage", Collections.singletonMap("%Command%", "/v10lift create <Name>"));
return true;
}
TreeSet<LiftBlock> blocks = DataManager.getPlayer(p.getUniqueId());
if (blocks.isEmpty()) {
ConfigUtil.sendMessage(sender, "Create.NoBlocks");
return true;
}
if (!V10LiftAPI.getInstance().createLift(p, args[1])) {
ConfigUtil.sendMessage(sender, "General.AlreadyExists");
return true;
}
TreeSet<LiftBlock> blcks = DataManager.getLift(args[1]).getBlocks();
blocks.forEach(block -> V10LiftAPI.getInstance().addBlockToLift(blcks, block));
V10LiftAPI.getInstance().sortLiftBlocks(args[1]);
DataManager.removePlayer(p.getUniqueId());
ConfigUtil.sendMessage(p, "Create.Created", Collections.singletonMap("%Name%", args[1]));
p.performCommand("v10lift edit " + args[1]);
} else {
//Not building yet!!
DataManager.addPlayer(p.getUniqueId());
ConfigUtil.sendMessage(p, "Create.AddBlocks");
}
return true;
}
private boolean infoCommand(@Nonnull CommandSender sender) {
sender.sendMessage("§1==================================");
sender.sendMessage("§6V10Lift plugin made by §aSBDeveloper");
sender.sendMessage("§6Version: " + V10LiftPlugin.getInstance().getDescription().getVersion());
sender.sendMessage("§6Type /v10lift help for more information!");
sender.sendMessage("§1==================================");
return true;
}
private boolean helpCommand(@Nonnull CommandSender sender) {
sender.sendMessage("§8V10Lift commands:");
sender.sendMessage("§6/v10lift info§f: Gives you information about the plugin.");
sender.sendMessage("§6/v10lift help§f: Gives you this help page.");
sender.sendMessage("§6/v10lift reload§f: Reload the plugin.");
sender.sendMessage("§6/v10lift create [Name]§f: Create a lift.");
sender.sendMessage("§6/v10lift delete <Name>§f: Delete a lift.");
sender.sendMessage("§6/v10lift rename <New name>§f: Rename a lift.");
sender.sendMessage("§6/v10lift abort§f: Abort your action.");
sender.sendMessage("§6/v10lift whois [Name]§f: See information about a lift.");
sender.sendMessage("§6/v10lift edit [Name]§f: Edit a lift.");
sender.sendMessage("§6/v10lift floor <add/del/rename> <Name> [New name]§f: Add/remove/rename a floor.");
sender.sendMessage("§6/v10lift input <add/del> [Floorname]§f: Add/remove an input.");
sender.sendMessage("§6/v10lift offline <add/del>§f: Add/remove an offline input.");
sender.sendMessage("§6/v10lift build§f: Add/remove blocks to/from a cab.");
sender.sendMessage("§6/v10lift rope <add/del>§f: Add/remove a rope.");
sender.sendMessage("§6/v10lift door§f: Add doors to a lift.");
sender.sendMessage("§6/v10lift speed <New speed>§f: Change the speed of a lift.");
sender.sendMessage("§6/v10lift realistic§f: Toggle realistic mode.");
sender.sendMessage("§6/v10lift repair§f: Repair a lift.");
sender.sendMessage("§6/v10lift whitelist <add/del> <Player/Group> [Floorname]§f: Add/remove someone of the whitelist. Use g:<Groupname> for a group.");
sender.sendMessage("§6/v10lift start [Name] [Floor]§f: Start a lift to a floor.");
sender.sendMessage("§6/v10lift stop [Name]§f: Stop a lift.");
sender.sendMessage("§6/v10lift disable <Name>§f: Disable a lift.");
sender.sendMessage("§6/v10lift repair <Name>§f: Repair a lift.");
return true;
}
} }

View file

@ -1,98 +0,0 @@
package tech.sbdevelopment.v10lift.commands;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
import org.bukkit.command.TabCompleter;
import org.bukkit.entity.Player;
import org.bukkit.util.StringUtil;
import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.managers.DataManager;
import tech.sbdevelopment.v10lift.managers.VaultManager;
import javax.annotation.Nonnull;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class V10LiftTabCompleter implements TabCompleter {
private static final List<String> COMMANDS = Arrays.asList("create", "delete", "rename", "abort", "whois", "edit", "floor", "input", "build", "rope", "door", "speed", "realistic", "repair", "disable", "whitelist", "reload", "help", "start", "stop", "offline", "list", "setoffline");
private static final List<String> SUBRENAME = Arrays.asList("add", "del", "rename");
private static final List<String> SUB = Arrays.asList("add", "del");
private static final List<String> BOOL = Arrays.asList("true", "false");
@Override
public List<String> onTabComplete(@Nonnull CommandSender commandSender, @Nonnull Command cmd, @Nonnull String label, @Nonnull String[] args) {
if (label.equalsIgnoreCase("v10lift")) {
if (args.length == 1) {
return StringUtil.copyPartialMatches(args[0], COMMANDS, new ArrayList<>());
} else if (args.length == 2) {
//Command based sub-commands
if (args[0].equalsIgnoreCase("delete")
|| args[0].equalsIgnoreCase("edit")
|| args[0].equalsIgnoreCase("whois")
|| args[0].equalsIgnoreCase("repair")
|| args[0].equalsIgnoreCase("disable")
|| args[0].equalsIgnoreCase("start")
|| args[0].equalsIgnoreCase("stop")) {
return StringUtil.copyPartialMatches(args[1], DataManager.getLifts().keySet(), new ArrayList<>());
} else if (args[0].equalsIgnoreCase("floor")) {
return StringUtil.copyPartialMatches(args[1], SUBRENAME, new ArrayList<>());
} else if (args[0].equalsIgnoreCase("input")
|| args[0].equalsIgnoreCase("offline")
|| args[0].equalsIgnoreCase("whitelist")
|| args[0].equalsIgnoreCase("rope")) {
return StringUtil.copyPartialMatches(args[1], SUB, new ArrayList<>());
} else if (args[0].equalsIgnoreCase("setoffline")) {
return StringUtil.copyPartialMatches(args[1], BOOL, new ArrayList<>());
} else if (args[0].equalsIgnoreCase("build") && V10LiftPlugin.isWorldEditEnabled()) {
return StringUtil.copyPartialMatches(args[1], List.of("worldedit"), new ArrayList<>());
}
} else if (args.length == 3) {
//Command based arguments
if (args[0].equalsIgnoreCase("floor") && (args[1].equalsIgnoreCase("del") || args[1].equalsIgnoreCase("rename"))) {
if (commandSender instanceof Player) {
Player p = (Player) commandSender;
if (DataManager.containsEditPlayer(p.getUniqueId())) {
Lift lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId()));
return StringUtil.copyPartialMatches(args[2], lift.getFloors().keySet(), new ArrayList<>());
}
}
} else if ((args[0].equalsIgnoreCase("input")
|| args[0].equalsIgnoreCase("offline")) && args[1].equalsIgnoreCase("del")) {
if (commandSender instanceof Player) {
Player p = (Player) commandSender;
if (DataManager.containsEditPlayer(p.getUniqueId())) {
Lift lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId()));
return StringUtil.copyPartialMatches(args[2], lift.getFloors().keySet(), new ArrayList<>());
}
}
} else if (args[0].equalsIgnoreCase("whitelist")) {
ArrayList<String> playerOrGroupNames = new ArrayList<>();
for (Player p : Bukkit.getOnlinePlayers()) {
playerOrGroupNames.add(p.getName());
}
if (V10LiftPlugin.isVaultEnabled()) {
playerOrGroupNames.addAll(VaultManager.getGroups());
}
return StringUtil.copyPartialMatches(args[2], playerOrGroupNames, new ArrayList<>());
}
} else if (args.length == 4) {
//Command based arguments
if (args[0].equalsIgnoreCase("whitelist")) {
if (commandSender instanceof Player) {
Player p = (Player) commandSender;
if (DataManager.containsEditPlayer(p.getUniqueId())) {
Lift lift = DataManager.getLift(DataManager.getEditPlayer(p.getUniqueId()));
return StringUtil.copyPartialMatches(args[3], lift.getFloors().keySet(), new ArrayList<>());
}
}
}
}
}
return null;
}
}

View file

@ -7,31 +7,27 @@ import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority; import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.block.BlockBreakEvent; import org.bukkit.event.block.BlockBreakEvent;
import tech.sbdevelopment.v10lift.api.V10LiftAPI; import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.objects.Floor; import tech.sbdevelopment.v10lift.api.objects.Floor;
import tech.sbdevelopment.v10lift.api.objects.Lift; import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.api.objects.LiftBlock; import tech.sbdevelopment.v10lift.api.objects.LiftBlock;
import tech.sbdevelopment.v10lift.api.objects.LiftInput;
import tech.sbdevelopment.v10lift.managers.DataManager;
import tech.sbdevelopment.v10lift.utils.ConfigUtil; import tech.sbdevelopment.v10lift.utils.ConfigUtil;
import tech.sbdevelopment.v10lift.utils.DoorUtil; import tech.sbdevelopment.v10lift.utils.DoorUtil;
import java.util.Map;
import java.util.Objects; import java.util.Objects;
public class BlockBreakListener implements Listener { public class BlockBreakListener implements Listener {
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true) @EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
public void onBlockBreak(BlockBreakEvent e) { public void onBlockBreak(BlockBreakEvent e) {
Block b = e.getBlock(); Block b = e.getBlock();
if (V10LiftAPI.getInstance().isRope(b)) { if (V10LiftPlugin.getApi().isRope(b)) {
ConfigUtil.sendMessage(e.getPlayer(), "General.RemoveRopeFirst"); ConfigUtil.sendMessage(e.getPlayer(), "General.RemoveRopeFirst");
e.setCancelled(true); e.setCancelled(true);
return; return;
} }
LiftBlock tlb = new LiftBlock(b); LiftBlock tlb = new LiftBlock(b);
for (Map.Entry<String, Lift> entry : DataManager.getLifts().entrySet()) { for (Lift lift : V10LiftPlugin.getApi().getLifts()) {
Lift lift = entry.getValue();
if (lift.getBlocks().contains(tlb)) { if (lift.getBlocks().contains(tlb)) {
ConfigUtil.sendMessage(e.getPlayer(), "General.RemoveLiftFirst"); ConfigUtil.sendMessage(e.getPlayer(), "General.RemoveLiftFirst");
e.setCancelled(true); e.setCancelled(true);

View file

@ -7,6 +7,8 @@ import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority; import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageEvent; import org.bukkit.event.entity.EntityDamageEvent;
import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.V10LiftAPI;
import tech.sbdevelopment.v10lift.api.objects.Lift; import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.api.objects.LiftBlock; import tech.sbdevelopment.v10lift.api.objects.LiftBlock;
import tech.sbdevelopment.v10lift.managers.DataManager; import tech.sbdevelopment.v10lift.managers.DataManager;
@ -31,7 +33,7 @@ public class EntityDamageListener implements Listener {
int y = loc.getBlockY(); int y = loc.getBlockY();
int z = loc.getBlockZ(); int z = loc.getBlockZ();
for (Lift lift : DataManager.getLifts().values()) { for (Lift lift : V10LiftPlugin.getApi().getLifts()) {
for (LiftBlock lb : lift.getBlocks()) { for (LiftBlock lb : lift.getBlocks()) {
if (world.equals(lb.getWorld()) && x == lb.getX() && y == lb.getY() && z == lb.getZ()) { if (world.equals(lb.getWorld()) && x == lb.getX() && y == lb.getY() && z == lb.getZ()) {
e.setCancelled(true); e.setCancelled(true);

View file

@ -7,11 +7,13 @@ import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority; import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.block.SignChangeEvent; import org.bukkit.event.block.SignChangeEvent;
import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.objects.Lift; import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.api.objects.LiftSign; import tech.sbdevelopment.v10lift.api.objects.LiftSign;
import tech.sbdevelopment.v10lift.managers.DataManager;
import tech.sbdevelopment.v10lift.utils.ConfigUtil; import tech.sbdevelopment.v10lift.utils.ConfigUtil;
import java.util.Optional;
public class SignChangeListener implements Listener { public class SignChangeListener implements Listener {
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true) @EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
@ -25,12 +27,13 @@ public class SignChangeListener implements Listener {
return; return;
} }
if (!DataManager.containsLift(lines[1])) { Optional<Lift> liftOpt = V10LiftPlugin.getApi().getLift(lines[1]);
if (liftOpt.isEmpty()) {
ConfigUtil.sendMessage(e.getPlayer(), "General.DoesntExists"); ConfigUtil.sendMessage(e.getPlayer(), "General.DoesntExists");
return; return;
} }
Lift lift = liftOpt.get();
Lift lift = DataManager.getLift(lines[1]);
if (!lift.getOwners().contains(p.getUniqueId()) && !p.hasPermission("v10lift.admin")) { if (!lift.getOwners().contains(p.getUniqueId()) && !p.hasPermission("v10lift.admin")) {
ConfigUtil.sendMessage(e.getPlayer(), "General.NoPermission"); ConfigUtil.sendMessage(e.getPlayer(), "General.NoPermission");
e.setCancelled(true); e.setCancelled(true);

View file

@ -0,0 +1,66 @@
package tech.sbdevelopment.v10lift.locale;
import co.aikar.commands.MessageType;
import co.aikar.locales.MessageKey;
import net.md_5.bungee.api.ChatColor;
import tech.sbdevelopment.v10lift.managers.ACFHandler;
import java.util.Map;
public class Locale {
private Locale() {
}
/**
* Get a translated message
*
* @param key the key to the message
* @return the translated message string
*/
public static String getMessage(Message key) {
return getMessage(key.getMessageKey());
}
/**
* Get a translated message
*
* @param msg the key to the message
* @return the translated message string
*/
public static String getMessage(MessageKey msg) {
String message = ACFHandler.getManager().formatMessage(null, MessageType.INFO, msg);
return ChatColor.translateAlternateColorCodes('&', message);
}
/**
* Get a translated message
*
* @param key the key to the message
* @param args the arguments to the message
* @return the translated message string
*/
public static String getMessage(Message key, Map<String, String> args) {
return getMessage(key.getMessageKey(), args);
}
/**
* Get a translated message
*
* @param msg the key to the message
* @param args the arguments to the message
* @return the translated message string
*/
public static String getMessage(MessageKey msg, Map<String, String> args) {
//Turn map into array (key, value, key, value, etc.)
String[] argsArray = new String[args.size() * 2];
int i = 0;
for (Map.Entry<String, String> entry : args.entrySet()) {
argsArray[i] = entry.getKey();
argsArray[i + 1] = entry.getValue();
i += 2;
}
String message = ACFHandler.getManager().formatMessage(null, MessageType.INFO, msg, argsArray);
return ChatColor.translateAlternateColorCodes('&', message);
}
}

View file

@ -0,0 +1,144 @@
package tech.sbdevelopment.v10lift.locale;
import co.aikar.locales.MessageKey;
import co.aikar.locales.MessageKeyProvider;
public enum Message implements MessageKeyProvider {
GENERAL_NOPERMISSION,
GENERAL_PLAYERONLY,
GENERAL_INCORRECTUSAGE,
GENERAL_INTERNALERROR,
GENERAL_DOESNTEXISTS,
GENERAL_ALREADYEXISTS,
GENERAL_SWITCHONEDIT,
GENERAL_DETECTIONFAILED,
GENERAL_FLOORDOESNTEXISTS,
GENERAL_NOWHITELISTPERMISSION,
GENERAL_NOFLOORS,
GENERAL_REMOVELIFFTFIRST,
GENERAL_REMOVEROPEFIRST,
GENERAL_REMOVEDOORFIRST,
CREATE_ADDBLOCKS,
CREATE_NOBLOCKS,
CREATE_CREATED,
DELETE_NOTREMOVED,
DELETE_REMOVED,
RENAME_RENAMED,
EDIT_STILLINEDITMODE,
EDIT_TURNEDON,
EDIT_TURNEDOFF,
FLOOR_TOHIGH,
FLOOR_ALREADYEXISTS,
FLOOR_DOESNTEXISTS,
FLOOR_ADDED,
FLOOR_REMOVED,
FLOOR_RENAMED,
INPUT_STILLADJUSTING,
INPUT_NOTHINGTOREMOVE,
INPUT_ALREADYADDED,
INPUT_NOINPUT,
INPUT_RIGHTCLICK,
INPUT_CREATED,
INPUT_REMOVED,
OFFLINEINPUT_STILLADJUSTING,
OFFLINEINPUT_NOTHINGTOREMOVE,
OFFLINEINPUT_ALREADYADDED,
OFFLINEINPUT_NOINPUT,
OFFLINEINPUT_RIGHTCLICK,
OFFLINEINPUT_CREATED,
OFFLINEINPUT_REMOVED,
BUILD_DISABLED,
BUILD_ENABLED,
BUILD_BLOCKADDED,
BUILD_BLOCKREMOVED,
BUILD_BLACKLISTEDMATERIAL,
BUILD_NOSELECTION,
BUILD_UNSUPPORTEDSELECTION,
BUILD_BLOCKSADDED,
BUILD_BLOCKSFAILED,
BUILD_WORLDEDITNOTENABLED,
ROPE_STILLADJUSTING,
ROPE_ONLYUP,
ROPE_ONLYONEMATERIAL,
ROPE_ALREADYAROPE,
ROPE_NOTAROPE,
ROPE_BLACKLISTEDMATERIAL,
ROPE_ADD,
ROPE_DELETE,
ROPE_CLICKONEND,
ROPE_PARTREMOVED,
ROPE_CREATED,
ROPE_REMOVED,
DOOR_BLACKLISTEDMATERIAL,
DOOR_DISABLED,
DOOR_ENABLED,
DOOR_CREATED,
DOOR_REMOVED,
WHITELIST_GROUP_VAULTNOTFOUND,
WHITELIST_GROUP_NOTFOUND,
WHITELIST_GROUP_ALREADYCONTAINS,
WHITELIST_GROUP_DOESNTCONTAINS,
WHITELIST_GROUP_ADDED,
WHITELIST_GROUP_REMOVED,
WHITELIST_PLAYER_NOTFOUND,
WHITELIST_PLAYER_ALREADYCONTAINS,
WHITELIST_PLAYER_DOESNTCONTAINS,
WHITELIST_PLAYER_ADDED,
WHITELIST_PLAYER_REMOVED,
WHOIS_USEWITHOUTNAME,
WHOIS_NOTALIFT,
WHOIS_WITHOUTNAME,
SPEED_WRONGSPEED,
SPEED_CHANGED,
SOUND_TURNEDON,
SOUND_TURNEDOFF,
REALISTIC_TURNEDON,
REALISTIC_TURNEDOFF,
DISABLE_ALREADYDEFECTIVE,
DISABLE_DISABLED,
REPAIR_NOTDEFECTIVE,
REPAIR_ITEMSNEEDED,
REPAIR_REPAIRED,
ABORT_NOTHINGTOCANCEL,
ABORT_CANCELLED,
RELOAD_RELOADED,
START_NONPLAYER,
START_STARTED,
STOP_NONPLAYER,
STOP_NOMOVINGTASKS,
STOP_STOPPED,
LIFTSIGN_NONAME,
LIFTSIGN_CREATED,
LIFTSIGN_REMOVED,
LIST_NOLIFTS,
LIST_HEADER,
LIST_LIFT,
SETOFFLINE_DISABLED,
SETOFFLINE_ENABLED;
private final MessageKey key;
Message() {
this.key = MessageKey.of(convertConstantToLanguageKey("v10lift." + this.name()));
}
@Override
public MessageKey getMessageKey() {
return this.key;
}
private static String convertConstantToLanguageKey(String constant) {
StringBuilder languageKey = new StringBuilder();
String[] words = constant.split("_");
for (int i = 0; i < words.length; i++) {
String word = words[i].toLowerCase();
if (i > 0) {
languageKey.append(".");
}
languageKey.append(word);
}
return languageKey.toString();
}
}

View file

@ -0,0 +1,4 @@
/**
* All the event listeners of V10Lift
*/
package tech.sbdevelopment.v10lift.locale;

View file

@ -0,0 +1,61 @@
package tech.sbdevelopment.v10lift.managers;
import co.aikar.commands.PaperCommandManager;
import org.bukkit.configuration.InvalidConfigurationException;
import org.bukkit.plugin.java.JavaPlugin;
import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.commands.V10LiftCommand;
import tech.sbdevelopment.v10lift.sbutils.YamlFile;
import java.io.File;
import java.io.IOException;
import java.util.Locale;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.stream.Collectors;
public class ACFHandler {
private static final String[] defaultLanguages = new String[]{"en"};
private static final Pattern pattern = Pattern.compile("^lang_([a-z]{2})\\.yml$");
private ACFHandler() {
}
private static PaperCommandManager manager;
public static void init(JavaPlugin plugin) throws IOException {
manager = new PaperCommandManager(plugin);
manager.getCommandContexts().registerContext(Lift.class, c -> V10LiftPlugin.getApi().getLift(c.popFirstArg().toLowerCase()).orElse(null));
manager.getCommandCompletions().registerCompletion("lifts", c -> V10LiftPlugin.getApi().getLifts().stream().map(Lift::getName).collect(Collectors.toList()));
manager.registerCommand(new V10LiftCommand());
manager.enableUnstableAPI("help");
manager.getLocales().setDefaultLocale(Locale.forLanguageTag(V10LiftPlugin.getSConfig().getFile().getString("Locale")));
File localeDir = new File(plugin.getDataFolder(), "locale");
localeDir.mkdirs();
for (String lang : defaultLanguages) {
YamlFile file = new YamlFile("locale/lang_" + lang);
file.loadDefaults();
}
for (File file : localeDir.listFiles((dir, name) -> name.startsWith("lang_") && name.endsWith(".yml"))) {
Matcher matcher = pattern.matcher(file.getName());
if (!matcher.matches()) continue;
try {
manager.getLocales().loadYamlLanguageFile(file, Locale.forLanguageTag(matcher.group(1)));
} catch (IOException | InvalidConfigurationException e) {
plugin.getLogger().severe("Couldn't load the language file " + file.getName() + "!");
}
}
}
public static PaperCommandManager getManager() {
return manager;
}
}

View file

@ -1,147 +1,64 @@
package tech.sbdevelopment.v10lift.managers; package tech.sbdevelopment.v10lift.managers;
import com.google.gson.Gson; import org.bukkit.plugin.java.JavaPlugin;
import org.bukkit.Bukkit;
import tech.sbdevelopment.v10lift.V10LiftPlugin; import tech.sbdevelopment.v10lift.V10LiftPlugin;
import tech.sbdevelopment.v10lift.api.objects.Lift; import tech.sbdevelopment.v10lift.api.objects.Lift;
import tech.sbdevelopment.v10lift.sbutils.SQLiteDB; import tech.sbdevelopment.v10lift.sbutils.StormSQLiteDB;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.Map; import java.util.Collection;
/** /**
* The DBManager manages the database * The DBManager manages the database
*/ */
public class DBManager { public class DBManager {
private static final Gson gson = new Gson(); private final StormSQLiteDB data;
private static SQLiteDB data;
private static Connection con;
/** /**
* Construct the database manager * Construct the database manager
* *
* @param name The name of the sqlite database file * @param plugin The plugin instance
* @param dbName The name of the sqlite database file
*/ */
public DBManager(String name) { public DBManager(JavaPlugin plugin, String dbName) {
data = new SQLiteDB(name);
try { try {
con = data.getConnection(); data = new StormSQLiteDB(plugin, dbName);
String query = "CREATE TABLE IF NOT EXISTS lifts (liftName varchar(255) NOT NULL, liftData blob NOT NULL, UNIQUE (liftName))";
PreparedStatement statement = con.prepareStatement(query);
statement.execute();
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); throw new RuntimeException("Couldn't connect to the database!", e);
} }
} }
/** /**
* Load the database from data * Load the database from data
* *
* @throws SQLException If the SQL SELECT fails * @throws Exception If the data couldn't be loaded
*/ */
public void load() throws SQLException { public void load() throws Exception {
String query = "SELECT * FROM lifts"; Collection<Lift> lifts = data.getStorm().buildQuery(Lift.class)
PreparedStatement statement = con.prepareStatement(query); .execute()
ResultSet liftSet = statement.executeQuery(); .join();
while (liftSet.next()) { V10LiftPlugin.getApi().getLifts().addAll(lifts);
//Loading a lift...
/*
* @todo Fix migrating from 1.12.2- to 1.13+
* - byte to Facing for signs
* - Facing opposite for ropes
* - New materials
*/
byte[] blob = liftSet.getBytes("liftData");
String json = new String(blob);
Lift lift = gson.fromJson(json, Lift.class);
DataManager.addLift(liftSet.getString("liftName"), lift);
Bukkit.getLogger().info("[V10Lift] Loading lift " + liftSet.getString("liftName") + " from data...");
}
} }
/** /**
* Remove a lift from data * Save the data to the database
* *
* @param liftName The name of the lift * @throws SQLException If the data couldn't be saved
*/ */
public void remove(String liftName) { public void save() throws SQLException {
if (!DataManager.containsLift(liftName)) { for (Lift lift : V10LiftPlugin.getApi().getLifts()) {
Bukkit.getLogger().info("[V10Lift] Removing lift " + liftName + " to data..."); data.getStorm().save(lift);
Bukkit.getScheduler().runTaskAsynchronously(V10LiftPlugin.getInstance(), () -> {
try {
String query = "DELETE FROM lifts WHERE liftName = ?";
PreparedStatement statement = con.prepareStatement(query);
statement.setString(1, liftName);
statement.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
});
} }
} }
/** /**
* Save all lifts to data * Remove a lift from the database
*/
public void save() {
for (Map.Entry<String, Lift> entry : DataManager.getLifts().entrySet()) {
saveLift(entry.getKey(), entry.getValue(), true);
}
}
/**
* Save a lift to data
* *
* @param liftName The name of the lift * @param lift The lift to remove
* @param lift The lift itself * @throws SQLException If the lift couldn't be removed
*/ */
public void saveLift(String liftName, Lift lift, boolean sync) { public void remove(Lift lift) throws SQLException {
Bukkit.getLogger().info("[V10Lift] Saving lift " + liftName + " to data..."); data.getStorm().delete(lift);
byte[] blob = gson.toJson(lift).getBytes();
if (sync) {
updateLift(liftName, blob);
} else {
Bukkit.getScheduler().runTaskAsynchronously(V10LiftPlugin.getInstance(), () -> updateLift(liftName, blob));
}
}
/**
* Update a lift in data
*
* @param liftName The name of the lift
* @param liftData The JSON blob of the lift object
*/
private void updateLift(String liftName, byte[] liftData) {
try {
String query = "INSERT INTO lifts (liftName, liftData) VALUES (?, ?)";
PreparedStatement statement = con.prepareStatement(query);
statement.setString(1, liftName);
statement.setBytes(2, liftData);
statement.executeUpdate();
} catch (SQLException ignored) {
}
try {
String query2 = "UPDATE lifts SET liftData = ? WHERE liftName = ?";
PreparedStatement statement2 = con.prepareStatement(query2);
statement2.setBytes(1, liftData);
statement2.setString(2, liftName);
statement2.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
} }
/** /**

View file

@ -1,335 +0,0 @@
package tech.sbdevelopment.v10lift.sbutils;
import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.configuration.serialization.ConfigurationSerializable;
import org.bukkit.plugin.Plugin;
import org.yaml.snakeyaml.DumperOptions;
import org.yaml.snakeyaml.Yaml;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.*;
import java.util.stream.Collectors;
/**
* A class to update/add new sections/keys to your config while keeping your current values and keeping your comments
* Algorithm:
* Read the new file and scan for comments and ignored sections, if ignored section is found it is treated as a comment.
* Read and write each line of the new config, if the old config has value for the given key it writes that value in the new config.
* If a key has an attached comment above it, it is written first.
*
* @author tchristofferson
*/
public class ConfigUpdater {
/**
* Update a yaml file from a resource inside your plugin jar
*
* @param plugin You plugin
* @param resourceName The yaml file name to update from, typically config.yml
* @param toUpdate The yaml file to update
* @param ignoredSections List of sections to ignore and copy from the current config
* @throws IOException If an IOException occurs
*/
public static void update(Plugin plugin, String resourceName, File toUpdate, List<String> ignoredSections) throws IOException {
BufferedReader newReader = new BufferedReader(new InputStreamReader(plugin.getResource(resourceName), StandardCharsets.UTF_8));
List<String> newLines = newReader.lines().collect(Collectors.toList());
newReader.close();
FileConfiguration oldConfig = YamlConfiguration.loadConfiguration(toUpdate);
FileConfiguration newConfig = YamlConfiguration.loadConfiguration(new InputStreamReader(plugin.getResource(resourceName)));
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(toUpdate), StandardCharsets.UTF_8));
List<String> ignoredSectionsArrayList = new ArrayList<>(ignoredSections);
//ignoredSections can ONLY contain configurations sections
ignoredSectionsArrayList.removeIf(ignoredSection -> !newConfig.isConfigurationSection(ignoredSection));
DumperOptions options = new DumperOptions();
options.setSplitLines(false);
Yaml yaml = new Yaml(options);
Map<String, String> comments = parseComments(newLines, ignoredSectionsArrayList, oldConfig, yaml);
write(newConfig, oldConfig, comments, ignoredSectionsArrayList, writer, yaml);
}
//Write method doing the work.
//It checks if key has a comment associated with it and writes comment then the key and value
private static void write(FileConfiguration newConfig, FileConfiguration oldConfig, Map<String, String> comments, List<String> ignoredSections, BufferedWriter writer, Yaml yaml) throws IOException {
outer:
for (String key : newConfig.getKeys(true)) {
String[] keys = key.split("\\.");
String actualKey = keys[keys.length - 1];
String comment = comments.remove(key);
StringBuilder prefixBuilder = new StringBuilder();
int indents = keys.length - 1;
appendPrefixSpaces(prefixBuilder, indents);
String prefixSpaces = prefixBuilder.toString();
if (comment != null) {
writer.write(comment);//No \n character necessary, new line is automatically at end of comment
}
for (String ignoredSection : ignoredSections) {
if (key.startsWith(ignoredSection)) {
continue outer;
}
}
Object newObj = newConfig.get(key);
Object oldObj = oldConfig.get(key);
if (newObj instanceof ConfigurationSection && oldObj instanceof ConfigurationSection) {
//write the old section
writeSection(writer, actualKey, prefixSpaces, (ConfigurationSection) oldObj);
} else if (newObj instanceof ConfigurationSection) {
//write the new section, old value is no more
writeSection(writer, actualKey, prefixSpaces, (ConfigurationSection) newObj);
} else if (oldObj != null) {
//write the old object
write(oldObj, actualKey, prefixSpaces, yaml, writer);
} else {
//write new object
write(newObj, actualKey, prefixSpaces, yaml, writer);
}
}
String danglingComments = comments.get(null);
if (danglingComments != null) {
writer.write(danglingComments);
}
writer.close();
}
//Doesn't work with configuration sections, must be an actual object
//Auto checks if it is serializable and writes to file
private static void write(Object obj, String actualKey, String prefixSpaces, Yaml yaml, BufferedWriter writer) throws IOException {
if (obj instanceof ConfigurationSerializable) {
writer.write(prefixSpaces + actualKey + ": " + yaml.dump(((ConfigurationSerializable) obj).serialize()));
} else if (obj instanceof String || obj instanceof Character) {
if (obj instanceof String) {
String s = (String) obj;
obj = s.replace("\n", "\\n");
}
writer.write(prefixSpaces + actualKey + ": " + yaml.dump(obj));
} else if (obj instanceof List) {
writeList((List<?>) obj, actualKey, prefixSpaces, yaml, writer);
} else {
writer.write(prefixSpaces + actualKey + ": " + yaml.dump(obj));
}
}
//Writes a configuration section
private static void writeSection(BufferedWriter writer, String actualKey, String prefixSpaces, ConfigurationSection section) throws IOException {
if (section.getKeys(false).isEmpty()) {
writer.write(prefixSpaces + actualKey + ": {}");
} else {
writer.write(prefixSpaces + actualKey + ":");
}
writer.write("\n");
}
//Writes a list of any object
private static void writeList(List<?> list, String actualKey, String prefixSpaces, Yaml yaml, BufferedWriter writer) throws IOException {
writer.write(getListAsString(list, actualKey, prefixSpaces, yaml));
}
private static String getListAsString(List<?> list, String actualKey, String prefixSpaces, Yaml yaml) {
StringBuilder builder = new StringBuilder(prefixSpaces).append(actualKey).append(":");
if (list.isEmpty()) {
builder.append(" []\n");
return builder.toString();
}
builder.append("\n");
for (int i = 0; i < list.size(); i++) {
Object o = list.get(i);
if (o instanceof String || o instanceof Character) {
builder.append(prefixSpaces).append("- '").append(o).append("'");
} else if (o instanceof List) {
builder.append(prefixSpaces).append("- ").append(yaml.dump(o));
} else {
builder.append(prefixSpaces).append("- ").append(o);
}
if (i != list.size()) {
builder.append("\n");
}
}
return builder.toString();
}
//Key is the config key, value = comment and/or ignored sections
//Parses comments, blank lines, and ignored sections
private static Map<String, String> parseComments(List<String> lines, List<String> ignoredSections, FileConfiguration oldConfig, Yaml yaml) {
Map<String, String> comments = new HashMap<>();
StringBuilder builder = new StringBuilder();
StringBuilder keyBuilder = new StringBuilder();
int lastLineIndentCount = 0;
outer:
for (int i = 0; i < lines.size(); i++) {
String line = lines.get(i);
if (line != null && line.trim().startsWith("-"))
continue;
if (line == null || line.trim().equals("") || line.trim().startsWith("#")) {
builder.append(line).append("\n");
} else {
lastLineIndentCount = setFullKey(keyBuilder, i, lines, lastLineIndentCount);
for (String ignoredSection : ignoredSections) {
if (keyBuilder.toString().equals(ignoredSection)) {
Object value = oldConfig.get(keyBuilder.toString());
if (value instanceof ConfigurationSection)
appendSection(builder, (ConfigurationSection) value, new StringBuilder(getPrefixSpaces(lastLineIndentCount)), yaml);
continue outer;
}
}
if (keyBuilder.length() > 0) {
comments.put(keyBuilder.toString(), builder.toString());
builder.setLength(0);
}
}
}
if (builder.length() > 0) {
comments.put(null, builder.toString());
}
return comments;
}
private static void appendSection(StringBuilder builder, ConfigurationSection section, StringBuilder prefixSpaces, Yaml yaml) {
builder.append(prefixSpaces).append(getKeyFromFullKey(section.getCurrentPath())).append(":");
Set<String> keys = section.getKeys(false);
if (keys.isEmpty()) {
builder.append(" {}\n");
return;
}
builder.append("\n");
prefixSpaces.append(" ");
for (String key : keys) {
Object value = section.get(key);
String actualKey = getKeyFromFullKey(key);
if (value instanceof ConfigurationSection) {
appendSection(builder, (ConfigurationSection) value, prefixSpaces, yaml);
prefixSpaces.setLength(prefixSpaces.length() - 2);
} else if (value instanceof List) {
builder.append(getListAsString((List<?>) value, actualKey, prefixSpaces.toString(), yaml));
} else {
builder.append(prefixSpaces).append(actualKey).append(": ").append(yaml.dump(value));
}
}
}
//Check how many times spaces make a jump of at least two
private static int countIndents(int index, List<String> lines) {
int currentSpaces = getSpaces(lines.get(index));
int indents = 0;
for (int i = index - 1; i >= 0; i--) {
String line = lines.get(i);
if (line == null || line.trim().equals("")) continue;
int newSpaces = getSpaces(lines.get(i));
// differs at least two
if (newSpaces < currentSpaces - 1) {
indents++;
currentSpaces = newSpaces;
}
if (currentSpaces <= 1) break;
}
return indents;
}
private static int getSpaces(String line) {
int spaces = 0;
for (char c : line.toCharArray()) {
if (c == ' ') {
spaces += 1;
} else {
break;
}
}
return spaces;
}
//Ex. keyBuilder = key1.key2.key3 --> key1.key2
private static void removeLastKey(StringBuilder keyBuilder) {
String temp = keyBuilder.toString();
String[] keys = temp.split("\\.");
if (keys.length == 1) {
keyBuilder.setLength(0);
return;
}
temp = temp.substring(0, temp.length() - keys[keys.length - 1].length() - 1);
keyBuilder.setLength(temp.length());
}
private static String getKeyFromFullKey(String fullKey) {
String[] keys = fullKey.split("\\.");
return keys[keys.length - 1];
}
//Updates the keyBuilder and returns configLines number of indents
private static int setFullKey(StringBuilder keyBuilder, int index, List<String> configLines, int lastLineIndentCount) {
int currentIndents = countIndents(index, configLines);
String key = configLines.get(index).trim().split(":")[0];
if (keyBuilder.length() == 0) {
keyBuilder.append(key);
} else if (currentIndents == lastLineIndentCount) {
//Replace the last part of the key with current key
removeLastKey(keyBuilder);
if (keyBuilder.length() > 0) {
keyBuilder.append(".");
}
keyBuilder.append(key);
} else if (currentIndents > lastLineIndentCount) {
//Append current key to the keyBuilder
keyBuilder.append(".").append(key);
} else {
int difference = lastLineIndentCount - currentIndents;
for (int i = 0; i < difference + 1; i++) {
removeLastKey(keyBuilder);
}
if (keyBuilder.length() > 0) {
keyBuilder.append(".");
}
keyBuilder.append(key);
}
return currentIndents;
}
private static String getPrefixSpaces(int indents) {
return new String(new char[Math.max(0, indents)]).replace("\0", " ");
}
private static void appendPrefixSpaces(StringBuilder builder, int indents) {
builder.append(getPrefixSpaces(indents));
}
}

View file

@ -1,89 +0,0 @@
package tech.sbdevelopment.v10lift.sbutils;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import org.bukkit.Bukkit;
import tech.sbdevelopment.v10lift.V10LiftPlugin;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
public class SQLiteDB {
private final String dbName;
private HikariDataSource source;
private Connection con;
/**
* Initialize a new connection
*
* @param dbName The database name
*/
public SQLiteDB(String dbName) {
this.dbName = dbName;
File dbFile = new File(V10LiftPlugin.getInstance().getDataFolder(), dbName + ".db");
if (!dbFile.exists()) {
try {
Bukkit.getLogger().info("[V10Lift] Generating the " + dbName + ".db!");
if (!dbFile.createNewFile()) {
Bukkit.getLogger().severe("[V10Lift] Couldn't generate the " + dbName + ".db!");
return;
}
} catch (IOException e) {
Bukkit.getLogger().info("[V10Lift] Couldn't generate the " + dbName + ".db!");
return;
}
}
HikariConfig config = new HikariConfig();
config.setPoolName("V10Lift");
config.setUsername(null);
config.setPassword(null);
config.setDriverClassName("org.sqlite.JDBC");
config.setConnectionTestQuery("SELECT 1");
config.setMaximumPoolSize(1);
Properties prop = new Properties();
prop.setProperty("date_string_format", "yyyy-MM-dd HH:mm:ss");
config.setJdbcUrl("jdbc:sqlite:" + dbFile.getAbsolutePath());
config.setDataSourceProperties(prop);
this.source = new HikariDataSource(config);
try {
this.con = this.source.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* Get the connection, to execute queries
* <p>
* CREATE TABLE - execute()
* SELECT - executeQuery()
* UPDATE - executeUpdate()
*
* @return Connection
*/
public Connection getConnection() {
return this.con;
}
/**
* Close the connection
*/
public void closeSource() {
Bukkit.getLogger().info("[V10Lift] Closing the database connection for " + dbName + ".db!");
try {
this.con.close();
} catch (SQLException e) {
e.printStackTrace();
}
this.source.close();
}
}

View file

@ -0,0 +1,72 @@
package tech.sbdevelopment.v10lift.sbutils;
import com.craftmend.storm.Storm;
import com.craftmend.storm.connection.hikaricp.HikariDriver;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import org.bukkit.plugin.java.JavaPlugin;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
public class StormSQLiteDB {
private final JavaPlugin plugin;
private final String dbName;
private final Storm storm;
/**
* Initialize a new database source
*
* @param dbName The database name
*/
public StormSQLiteDB(JavaPlugin plugin, String dbName) throws SQLException {
this.plugin = plugin;
this.dbName = dbName;
File dbFile = new File(plugin.getDataFolder(), dbName + ".db");
if (!dbFile.exists()) {
try {
plugin.getLogger().info("Generating the " + dbName + ".db...");
if (!dbFile.createNewFile()) {
throw new IOException("Couldn't generate the " + dbName + ".db!");
}
} catch (IOException e) {
throw new RuntimeException("Couldn't generate the " + dbName + ".db!", e);
}
}
HikariConfig config = new HikariConfig();
config.setPoolName(plugin.getName());
config.setJdbcUrl("jdbc:sqlite:" + dbFile.getAbsolutePath());
config.setUsername(null);
config.setPassword(null);
config.setDriverClassName("org.sqlite.JDBC");
config.setConnectionTestQuery("SELECT 1");
config.setMaxLifetime(60000);
config.setIdleTimeout(45000);
config.setMinimumIdle(10);
config.setMaximumPoolSize(50);
this.storm = new Storm(new HikariDriver(config));
}
/**
* Close the connection
*/
public void closeSource() {
plugin.getLogger().info("Closing the database connection for " + dbName + ".db...");
this.storm.getDriver().close();
}
/**
* Get the database connection
*
* @return The database connection
*/
public Storm getStorm() {
return storm;
}
}

View file

@ -1,6 +1,5 @@
package tech.sbdevelopment.v10lift.sbutils; package tech.sbdevelopment.v10lift.sbutils;
import com.google.gson.JsonParser;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
@ -12,68 +11,62 @@ import java.net.URL;
import java.nio.channels.Channels; import java.nio.channels.Channels;
import java.nio.channels.FileChannel; import java.nio.channels.FileChannel;
import java.nio.channels.ReadableByteChannel; import java.nio.channels.ReadableByteChannel;
import java.nio.charset.StandardCharsets;
import java.util.function.BiConsumer; import java.util.function.BiConsumer;
/** /**
* Update class for SBDevelopment * Update checker class
* *
* @author Stijn [SBDeveloper] * @author Stijn [SBDeveloper]
* @version 2.1 [19-11-2021] - This class supports both the v2 Spiget and v2 SBDUpdate API
*
* <p>&copy; Stijn Bannink [stijnbannink23@gmail.com] - All rights reserved.</p>
* @since 05-03-2020 * @since 05-03-2020
* @version 2.2 [17-04-2022] - Added Polymart support
*/ */
public class UpdateManager { public class UpdateManager {
private static final JsonParser parser = new JsonParser(); private static final String SPIGOT_API = "https://api.spigotmc.org/legacy/update.php?resource=%d";
private static final String SPIGOT_API = "https://api.spiget.org/v2/resources/%s/versions/latest";
private static final String SPIGOT_DOWNLOAD = "https://api.spiget.org/v2/resources/%s/download"; private static final String SPIGOT_DOWNLOAD = "https://api.spiget.org/v2/resources/%s/download";
private static final String SBDPLUGINS_API = "https://updates.sbdplugins.nl/api/v2/plugins/%d"; private static final String POLYMART_API = "https://api.polymart.org/v1/getResourceInfoSimple/?resource_id=%d&key=version";
private static final String SBDPLUGINS_DOWNLOAD = "https://updates.sbdplugins.nl/api/v2/download/%d"; private static final String POLYMART_DOWNLOAD = "https://api.polymart.org/v1/requestUpdateURL/?inject_version=%d&resource_id=%d&user_id=%d&nonce=%d&download_agent=%d&download_time=%d&download_token=%s";
private final Plugin plugin; private final Plugin plugin;
private final Version currentVersion; private final Version currentVersion;
private final int resourceID;
private final CheckType type; private final CheckType type;
private final String license;
//Spigot & Polymart
private final int resourceID;
//Polymart only
private int injector_version;
private int user_id;
private int nonce;
private int download_agent;
private int download_time;
private String download_token;
private BiConsumer<VersionResponse, Version> versionResponse; private BiConsumer<VersionResponse, Version> versionResponse;
private BiConsumer<DownloadResponse, String> downloadResponse; private BiConsumer<DownloadResponse, String> downloadResponse;
/** /**
* Construct a new UpdateManager for Spigot * Construct a new UpdateManager
* *
* @param plugin The javaplugin (Main class) * @param plugin The plugin instance
* @param resourceID The resourceID on spigot/sbdplugins
*/ */
public UpdateManager(Plugin plugin, int resourceID) { public UpdateManager(Plugin plugin, CheckType type) {
this.plugin = plugin; this.plugin = plugin;
this.currentVersion = new Version(plugin.getDescription().getVersion()); this.currentVersion = new Version(plugin.getDescription().getVersion());
this.resourceID = resourceID; this.type = type;
this.type = CheckType.SPIGOT; this.resourceID = Integer.parseInt("%%__RESOURCE__%%");
this.license = null; if (type == CheckType.POLYMART_PAID) {
} this.injector_version = Integer.parseInt("%%__INJECT_VER__%%");
this.user_id = Integer.parseInt("%%__USER__%%");
/** this.nonce = Integer.parseInt("%%__NONCE__%%");
* Construct a new UpdateManager for SBDPlugins this.download_agent = Integer.parseInt("%%__AGENT__%%");
* this.download_time = Integer.parseInt("%%__TIMESTAMP__%%");
* @param plugin The javaplugin (Main class) this.download_token = "%%__VERIFY_TOKEN__%%";
* @param resourceID The resourceID on spigot/sbdplugins }
* @param license The license for the download
*/
public UpdateManager(Plugin plugin, int resourceID, String license) {
this.plugin = plugin;
this.currentVersion = new Version(plugin.getDescription().getVersion());
this.resourceID = resourceID;
this.type = CheckType.SBDPLUGINS;
this.license = license;
} }
/** /**
* Handle the response given by check(); * Handle the response given by check();
*
* @param versionResponse The response * @param versionResponse The response
* @return The updatemanager * @return The updatemanager
*/ */
@ -93,23 +86,16 @@ public class UpdateManager {
public void check() { public void check() {
Bukkit.getScheduler().runTaskAsynchronously(this.plugin, () -> { Bukkit.getScheduler().runTaskAsynchronously(this.plugin, () -> {
try { try {
BufferedReader in = null; HttpsURLConnection con;
if (type == CheckType.SPIGOT) { if (type == CheckType.POLYMART_PAID) {
HttpsURLConnection con = (HttpsURLConnection) new URL(String.format(SPIGOT_API, this.resourceID)).openConnection(); con = (HttpsURLConnection) new URL(String.format(POLYMART_API, this.resourceID)).openConnection();
con.setRequestMethod("GET"); } else {
con.setRequestProperty("User-Agent", "Mozilla/5.0"); con = (HttpsURLConnection) new URL(String.format(SPIGOT_API, this.resourceID)).openConnection();
in = new BufferedReader(new InputStreamReader(con.getInputStream()));
} else if (type == CheckType.SBDPLUGINS) {
HttpsURLConnection con = (HttpsURLConnection) new URL(String.format(SBDPLUGINS_API, this.resourceID)).openConnection();
con.setRequestMethod("GET");
con.setRequestProperty("User-Agent", "Mozilla/5.0");
in = new BufferedReader(new InputStreamReader(con.getInputStream()));
} }
con.setRequestMethod("GET");
con.setRequestProperty("User-Agent", "SBDChecker/2.1");
if (in == null) return; BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
String inputLine; String inputLine;
StringBuilder response = new StringBuilder(); StringBuilder response = new StringBuilder();
while ((inputLine = in.readLine()) != null) { while ((inputLine = in.readLine()) != null) {
@ -117,10 +103,7 @@ public class UpdateManager {
} }
in.close(); in.close();
String version = parser.parse(response.toString()).getAsJsonObject().get(type == CheckType.SPIGOT ? "name" : "version").getAsString(); Version onlineVersion = new Version(response.toString());
if (version == null) return;
Version onlineVersion = new Version(version);
VersionResponse verRes = this.currentVersion.check(onlineVersion); VersionResponse verRes = this.currentVersion.check(onlineVersion);
@ -153,35 +136,16 @@ public class UpdateManager {
ReadableByteChannel channel; ReadableByteChannel channel;
try { try {
//https://stackoverflow.com/questions/921262/how-to-download-and-save-a-file-from-internet-using-java //https://stackoverflow.com/questions/921262/how-to-download-and-save-a-file-from-internet-using-java
int response;
InputStream stream;
HttpsURLConnection connection; HttpsURLConnection connection;
if (type == CheckType.SBDPLUGINS) { if (type == CheckType.POLYMART_PAID) {
connection = (HttpsURLConnection) new URL(String.format(SBDPLUGINS_DOWNLOAD, this.resourceID)).openConnection(); connection = (HttpsURLConnection) new URL(String.format(POLYMART_DOWNLOAD, this.injector_version, this.resourceID, this.user_id, this.nonce, this.download_agent, this.download_time, this.download_token)).openConnection();
String urlParameters = "license=" + license + "&port=" + Bukkit.getPort();
byte[] postData = urlParameters.getBytes(StandardCharsets.UTF_8);
int postDataLength = postData.length;
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
connection.setRequestProperty("charset", "utf-8");
connection.setRequestProperty("Content-Length", Integer.toString(postDataLength));
connection.setRequestProperty("User-Agent", "Mozilla/5.0");
connection.setDoOutput(true);
DataOutputStream wr = new DataOutputStream(connection.getOutputStream());
wr.write(postData);
wr.close();
} else { } else {
connection = (HttpsURLConnection) new URL(String.format(SPIGOT_DOWNLOAD, this.resourceID)).openConnection(); connection = (HttpsURLConnection) new URL(String.format(SPIGOT_DOWNLOAD, this.resourceID)).openConnection();
connection.setRequestProperty("User-Agent", "Mozilla/5.0");
} }
connection.setRequestProperty("User-Agent", "Mozilla/5.0");
response = connection.getResponseCode(); InputStream stream = connection.getInputStream();
stream = connection.getInputStream(); if (connection.getResponseCode() != 200) {
if (response != 200) {
BufferedReader in = new BufferedReader(new InputStreamReader(stream)); BufferedReader in = new BufferedReader(new InputStreamReader(stream));
String inputLine; String inputLine;
@ -191,7 +155,7 @@ public class UpdateManager {
} }
in.close(); in.close();
throw new RuntimeException("Download returned status #" + response, new Throwable(responsestr.toString())); throw new RuntimeException("Download returned status #" + connection.getResponseCode(), new Throwable(responsestr.toString()));
} }
channel = Channels.newChannel(stream); channel = Channels.newChannel(stream);
@ -234,9 +198,7 @@ public class UpdateManager {
} }
private File getPluginFile() { private File getPluginFile() {
if (!(this.plugin instanceof JavaPlugin)) { if (!(this.plugin instanceof JavaPlugin)) { return null; }
return null;
}
try { try {
Method method = JavaPlugin.class.getDeclaredMethod("getFile"); Method method = JavaPlugin.class.getDeclaredMethod("getFile");
method.setAccessible(true); method.setAccessible(true);
@ -246,8 +208,8 @@ public class UpdateManager {
} }
} }
private enum CheckType { public enum CheckType {
SPIGOT, SBDPLUGINS SPIGOT, POLYMART_PAID
} }
public enum VersionResponse { public enum VersionResponse {
@ -265,18 +227,18 @@ public class UpdateManager {
private final String version; private final String version;
private Version(String version) {
if (version == null)
throw new IllegalArgumentException("Version can not be null");
if (!version.matches("[0-9]+(\\.[0-9]+)*"))
throw new IllegalArgumentException("Invalid version format");
this.version = version;
}
public final String get() { public final String get() {
return this.version; return this.version;
} }
private Version(String version) {
if(version == null)
throw new IllegalArgumentException("Version can not be null");
if(!version.matches("[0-9]+(\\.[0-9]+)*"))
throw new IllegalArgumentException("Invalid version format");
this.version = version;
}
private VersionResponse check(Version that) { private VersionResponse check(Version that) {
String[] thisParts = this.get().split("\\."); String[] thisParts = this.get().split("\\.");
String[] thatParts = that.get().split("\\."); String[] thatParts = that.get().split("\\.");
@ -285,9 +247,9 @@ public class UpdateManager {
for (int i = 0; i < length; i++) { for (int i = 0; i < length; i++) {
int thisPart = i < thisParts.length ? Integer.parseInt(thisParts[i]) : 0; int thisPart = i < thisParts.length ? Integer.parseInt(thisParts[i]) : 0;
int thatPart = i < thatParts.length ? Integer.parseInt(thatParts[i]) : 0; int thatPart = i < thatParts.length ? Integer.parseInt(thatParts[i]) : 0;
if (thisPart < thatPart) if(thisPart < thatPart)
return VersionResponse.FOUND_NEW; return VersionResponse.FOUND_NEW;
if (thisPart > thatPart) if(thisPart > thatPart)
return VersionResponse.THIS_NEWER; return VersionResponse.THIS_NEWER;
} }
return VersionResponse.LATEST; return VersionResponse.LATEST;

View file

@ -26,14 +26,14 @@ public class ConfigUtil {
} }
/** /**
* Send a message from the messages.yml without variables * Send a message from the lang_en.yml without variables
* *
* @param p The commandsender to send it to * @param p The commandsender to send it to
* @param path The path to look for * @param path The path to look for
*/ */
public static void sendMessage(CommandSender p, @Nonnull String path) { public static void sendMessage(CommandSender p, @Nonnull String path) {
if (V10LiftPlugin.getMessages().getFile().get(path) == null) { if (V10LiftPlugin.getMessages().getFile().get(path) == null) {
throw new NullPointerException("Message " + path + " not found in messages.yml!"); throw new NullPointerException("Message " + path + " not found in lang_en.yml!");
} }
if (V10LiftPlugin.getMessages().getFile().isList(path)) { if (V10LiftPlugin.getMessages().getFile().isList(path)) {
@ -48,7 +48,7 @@ public class ConfigUtil {
} }
/** /**
* Get a message from the messages.yml with variables * Get a message from the lang_en.yml with variables
* *
* @param p The commandsender to send it to * @param p The commandsender to send it to
* @param path The path to look for * @param path The path to look for
@ -56,7 +56,7 @@ public class ConfigUtil {
*/ */
public static void sendMessage(CommandSender p, @Nonnull String path, Map<String, String> replacement) { public static void sendMessage(CommandSender p, @Nonnull String path, Map<String, String> replacement) {
if (V10LiftPlugin.getMessages().getFile().get(path) == null) { if (V10LiftPlugin.getMessages().getFile().get(path) == null) {
throw new NullPointerException("Message " + path + " not found in messages.yml!"); throw new NullPointerException("Message " + path + " not found in lang_en.yml!");
} }
if (V10LiftPlugin.getMessages().getFile().isList(path)) { if (V10LiftPlugin.getMessages().getFile().isList(path)) {

View file

@ -1,3 +1,6 @@
# The language to use for the messages
Locale: en
# Generic sign texts # Generic sign texts
SignText: "[v10lift]" SignText: "[v10lift]"
DefectText: "&kDefect!" DefectText: "&kDefect!"

View file

@ -0,0 +1,147 @@
v10lift:
general:
nopermission: '&cYou don''t have the permission to do this.'
playeronly: '&cOnly players can do this.'
incorrectusage: '&cPlease use %Command% instead'
internalerror: '&cSomething went wrong internally.'
doesntexists: '&cThere are no lifts with that name.'
alreadyexists: '&cA lift with that name already exists.'
switchonedit: '&cEnable editor mode before doing this.'
detectionfailed: '&cAutomatic floor detection failed!'
floordoesntexists: '&cThe floor %Name% doesn''t exists!'
nowhitelistpermission: '&cYou can''t go to that floor!'
nofloors: '&cThis elevator has no floors!'
removeliftfirst: '&cYou can''t do this! Remove the lift first.'
removeropefirst: '&cYou can''t do this! Remove the rope first.'
removedoorfirst: '&cYou can''t do this! Remove the door first.'
create:
addblocks: >
&aOkay, now add all the blocks from the cab by right-clicking them.
&awhen finished, type: /v10lift create <Name>
noblocks: '&cYou must add blocks first.'
created: '&aSuccessfully created lift %Name%.'
delete:
notremoved: '&cThe lift %Name% couldn''t be removed.'
removed: '&aSuccessfully removed lift %Name%.'
rename:
renamed: '&aLift successfully renamed!'
edit:
stillineditmode: '&cYou are still in editor mode.'
turnedon: '&aEnabled editor.'
turnedoff: '&aDisabled editor.'
floor:
tohigh: '&cThat floor is too high!'
alreadyexists: '&cThat floor already exists!'
doesntexists: '&cThat floor doesn''t exists!'
added: '&aFloor successfully added!'
removed: '&aFloor successfully removed!'
renamed: '&aFloor successfully renamed!'
input:
stilladjusting: '&cYou are still adjusting an input!'
nothingtoremove: '&cThere is no input to remove!'
alreadyadded: '&cThis block has already been chosen as an input. Choose another block!'
noinput: '&cThis block is not an input. Choose another block!'
rightclick: '&aNow right click on the input block!'
created: '&aInput created!'
removed: '&aInput removed!'
offlineinput:
stilladjusting: '&cYou are still adjusting an offline input!'
nothingtoremove: '&cThere is no offline input to remove!'
alreadyadded: '&cThis block has already been chosen as an offline input. Choose another block!'
noinput: '&cThis block is not an offline input. Choose another block!'
rightclick: '&aNow right click on the offline input block!'
created: '&aOffline input created!'
removed: '&aOffline input removed!'
build:
disabled: '&aConstruction mode disabled!'
enabled: >
&aNow right-click on the elevator blocks!
&aThen do /v10lift build to save it!
blockadded: '&aBlock added to the elevator.'
blockremoved: '&6Block removed from the elevator.'
blacklistedmaterial: '&cThe material %Name% cannot be used!'
noselection: '&cYou must select a region with the WorldEdit wand first!'
unsupportedselection: '&cThe selection must be cuboid or polygonal!'
blocksadded: '&aBlocks added to the elevator.'
blocksfailed: '&cNot all blocks could be added to the elevator. Failure amount: %Failed%'
worldeditnotenabled: '&cWorldEdit is not enabled on this server!'
rope:
stilladjusting: '&cYou are still adjusting a rope.'
onlyup: '&cA rope can only go up!'
onlyonematerial: '&cThe rope must be of the same material!'
alreadyarope: '&cPart of the rope is already part of another rope!'
notarope: '&cThis block is not part of the rope.'
blacklistedmaterial: '&cThe rope is built of blacklisted blocks!'
add: '&aNow right-click on the beginning and the end of the rope.'
delete: '&aNow right-click on the rope.'
clickonend: '&6Now right-click on the end of the rope!'
partremoved: >
&6Start removed!
&6Now right-click on the end of the rope!
created: '&aRope created.'
removed: '&aRope removed.'
door:
blacklistedmaterial: '&cThe material %Name% is currently not supported!'
disabled: '&aDoor editor mode disabled!'
enabled: >
&aNow right-click on the door blocks! (If they are real doors, click on the bottom block)
&aThen do /v10lift door to save it.
created: '&aDoor created.'
removed: '&6Door removed.'
whitelist:
group:
vaultnotfound: '&cYou can''t add a group when Vault is not found.'
notfound: '&cThe group %Name% is not found.'
alreadycontains: '&cThe whitelist already contains this group!'
doesntcontains: '&cThe whitelist doesn''t contain this group!'
added: '&aGroup added to whitelist!'
removed: '&aGroup removed from whitelist!'
player:
notfound: '&cThe player %Name% could not be found.'
alreadycontains: '&cThis user is already on the whitelist'
doesntcontains: '&cThis user isn''t on the whitelist'
added: '&aUser added to whitelist!'
removed: '&aUser removed from whitelist!'
whois:
usewithoutname: '&cYou need to be a player to use this command without a name.'
notalift: '&cThis block is not part of a lift.'
withoutname: '&aNow right-click on the block you want to check.'
speed:
wrongspeed: '&cThe speed %Speed% is incorrect.'
changed: '&aUpdated lift speed!'
sound:
turnedon: '&aSounds are now turned on!'
turnedoff: '&aSounds are now turned off!'
realistic:
turnedon: '&aRealistic mode turned on!'
turnedoff: '&aRealistic mode turned off!'
disable:
alreadydefective: '&cThis lift is already defective!'
disabled: '&aLift disabled!'
repair:
notdefective: '&cThis lift isn''t defective!'
itemsneeded: '&cYou need %Amount%x %ItemName%!'
repaired: '&aYou successfully repaired the lift!'
abort:
nothingtocancel: '&cOops! You can''t cancel anything.'
cancelled: '&6Cancelled.'
reload:
reloaded: '&6Plugin reloaded successfully!'
start:
nonplayer: '&cPlease give a name as a non-player!'
started: '&aLift %Name% started.'
stop:
nonplayer: '&cPlease give a name as a non-player!'
nomovingtasks: '&cLift %Name% doesn''t contain any moving tasks!'
started: '&aLift %Name% stopped.'
liftsign:
noname: '&cNo lift name given!'
created: '&aLift sign created!'
removed: '&6Lift sign removed!'
list:
nolifts: '&cThere are no lifts!'
header: '&6Lifts:'
lift: '&6- %Name%'
setoffline:
disabled: '&aThe lift is now offline!'
enabled: '&aThe lift is now online!'

View file

@ -1,175 +0,0 @@
General:
NoPermission: '&cYou don''t have the permission to do this.'
PlayerOnly: '&cOnly players can do this.'
IncorrectUsage: '&cPlease use %Command% instead'
InternalError: '&cSomething went wrong internally.'
DoesntExists: '&cThere are no lifts with that name.'
AlreadyExists: '&cA lift with that name already exists.'
SwitchOnEdit: '&cEnable editor mode before doing this.'
DetectionFailed: '&cAutomatic floor detection failed!'
FloorDoesntExists: '&cThe floor %Name% doesn''t exists!'
NoWhitelistPermission: '&cYou can''t go to that floor!'
NoFloors: '&cThis elevator has no floors!'
RemoveLiftFirst: '&cYou can''t do this! Remove the lift first.'
RemoveRopeFirst: '&cYou can''t do this! Remove the rope first.'
RemoveDoorFirst: '&cYou can''t do this! Remove the door first.'
Create:
AddBlocks: |-
&aOkay, now add all the blocks from the cab by right-clicking them.
&awhen finished, type: /v10lift create <Name>
NoBlocks: '&cYou must add blocks first.'
Created: '&aSuccessfully created lift %Name%.'
Delete:
NotRemoved: '&cThe lift %Name% couldn''t be removed.'
Removed: '&aSuccessfully removed lift %Name%.'
Rename:
Renamed: '&aLift successfully renamed!'
Edit:
StillInEditMode: '&cYou are still in editor mode.'
TurnedOn: '&aEnabled editor.'
TurnedOff: '&aDisabled editor.'
Floor:
ToHigh: '&cThat floor is too high!'
AlreadyExists: '&cThat floor already exists!'
DoesntExists: '&cThat floor doesn''t exists!'
Added: '&aFloor successfully added!'
Removed: '&aFloor successfully removed!'
Renamed: '&aFloor successfully renamed!'
Input:
StillAdjusting: '&cYou are still adjusting an input!'
NothingToRemove: '&cThere is no input to remove!'
AlreadyAdded: '&cThis block has already been chosen as an input. Choose another
block!'
NoInput: '&cThis block is not an input. Choose another block!'
RightClick: '&aNow right click on the input block!'
Created: '&aInput created!'
Removed: '&aInput removed!'
OfflineInput:
StillAdjusting: '&cYou are still adjusting an offline input!'
NothingToRemove: '&cThere is no offline input to remove!'
AlreadyAdded: '&cThis block has already been chosen as an offline input. Choose
another block!'
NoInput: '&cThis block is not an offline input. Choose another block!'
RightClick: '&aNow right click on the offline input block!'
Created: '&aOffline input created!'
Removed: '&aOffline input removed!'
Build:
Disabled: '&aConstruction mode disabled!'
Enabled: |-
&aNow right-click on the elevator blocks!
&aThen do /v10lift build to save it!
BlockAdded: '&aBlock added to the elevator.'
BlockRemoved: '&6Block removed from the elevator.'
BlacklistedMaterial: '&cThe material %Name% cannot be used!'
NoSelection: '&cYou must select a region with the WorldEdit wand first!'
UnsupportedSelection: '&cThe selection must be cuboid or polygonal!'
BlocksAdded: '&aBlocks added to the elevator.'
BlocksFailed: '&cNot all blocks could be added to the elevator. Failure amount: %Failed%'
WorldEditNotEnabled: '&cWorldEdit is not enabled on this server!'
Rope:
StillAdjusting: '&cYou are still adjusting a rope.'
OnlyUp: '&cA rope can only go up!'
OnlyOneMaterial: '&cThe rope must be of the same material!'
AlreadyARope: '&cPart of the rope is already part of another rope!'
NotARope: '&cThis block is not part of the rope.'
BlacklistedMaterial: '&cThe rope is build of blacklisted blocks!'
Add: '&aNow right-click on the beginning and the end of the rope.'
Delete: '&aNow right-click on the rope.'
ClickOnEnd: '&6Now right-click on the end of the rope!'
PartRemoved: |-
&6Start removed!
&6Now right-click on the end of the rope!
Created: '&aRope created.'
Removed: '&aRope removed.'
Door:
BlacklistedMaterial: '&cThe material %Name% is currently not supported!'
Disabled: '&aDoor editor mode disabled!'
Enabled: |-
&aNow right-click on the door blocks! (If it are real doors, click on the bottom block)
&aThen do /v10lift door to save it.
Created: '&aDoor created.'
Removed: '&6Door removed.'
Whitelist:
Group:
VaultNotFound: '&cYou can''t add a group when Vault is not found.'
NotFound: '&cThe group %Name% is not found.'
AlreadyContains: '&cThe whitelist already contains this group!'
DoesntContains: '&cThe whitelist doesn''t contain this group!'
Added: '&aGroup added to whitelist!'
Removed: '&aGroup removed from whitelist!'
Player:
NotFound: '&cThe player %Name% could not be found.'
AlreadyContains: '&cThis user is already on the whitelist'
DoesntContains: '&cThis user isn''t on the whitelist'
Added: '&aUser added to whitelist!'
Removed: '&aUser removed from whitelist!'
Whois:
UseWithoutName: '&cYou need to be a player to use this command without name.'
NotALift: '&cThis block is not part of a lift.'
WithoutName: '&aNow right-click on the block you want to check.'
Speed:
WrongSpeed: '&cThe speed %Speed% is incorrect.'
Changed: '&aUpdated lift speed!'
Sound:
TurnedOn: '&aSounds are now turned on!'
TurnedOff: '&aSounds are now turned off!'
Realistic:
TurnedOn: '&aRealistic mode turned on!'
TurnedOff: '&aRealistic mode turned off!'
Disable:
AlreadyDefective: '&cThis lift is already defective!'
Disabled: '&aLift disabled!'
Repair:
NotDefective: '&cThis lift isn''t defective!'
ItemsNeeded: '&cYou need %Amount%x %ItemName%!'
Repaired: '&aYou successfully repaired the lift!'
Abort:
NothingToCancel: '&cOops! You can''t cancel anything.'
Cancelled: '&6Cancelled.'
Reload:
Reloaded: '&6Plugin reloaded successfully!'
Start:
NonPlayer: '&cPlease give a name as non-player!'
Started: '&aLift %Name% started.'
Stop:
NonPlayer: '&cPlease give a name as non-player!'
NoMovingTasks: '&cLift %Name% doesn''t contain any movingtasks!'
Started: '&aLift %Name% stopped.'
LiftSign:
NoName: '&cNo lift name given!'
Created: '&aLift sign created!'
Removed: '&6Lift sign removed!'
List:
NoLifts: '&cThere are no lifts!'
Header: '&6Lifts:'
Lift: '&6- %Name%'
SetOffline:
Disabled: '&aThe lift is now offline!'
Enabled: '&aThe lift is now online!'

View file

@ -4,26 +4,3 @@ version: ${project.version}
api-version: "1.13" api-version: "1.13"
author: SBDeveloper author: SBDeveloper
softdepend: ["Vault", "WorldEdit"] softdepend: ["Vault", "WorldEdit"]
commands:
v10lift:
description: The V10Lift Command
permissions:
v10lift.admin:
description: The full power admin permission
default: op
v10lift.build:
description: The permission to build a lift
v10lift.reload:
description: Reload the plugin
v10lift.repair:
description: Repair a lift
v10lift.disable:
description: Disable a lift
v10lift.start:
description: Start a lift
v10lift.stop:
description: Stop a lift
v10lift.list:
description: List all lifts
v10lift.setoffline:
description: Set a lift offline / online