General cleanup
- Moved XSeries to Maven - Updated UpdateManager - New ConfigUpdater
This commit is contained in:
parent
346f9bcb00
commit
4e9ac799a2
23 changed files with 616 additions and 3886 deletions
38
pom.xml
38
pom.xml
|
@ -53,7 +53,30 @@
|
||||||
<pattern>com.zaxxer.hikari</pattern>
|
<pattern>com.zaxxer.hikari</pattern>
|
||||||
<shadedPattern>nl.SBDeveloper.V10Lift.utils.hikari</shadedPattern>
|
<shadedPattern>nl.SBDeveloper.V10Lift.utils.hikari</shadedPattern>
|
||||||
</relocation>
|
</relocation>
|
||||||
|
<relocation>
|
||||||
|
<pattern>com.cryptomorin.xseries</pattern>
|
||||||
|
<shadedPattern>nl.SBDeveloper.V10Lift.utils.xseries</shadedPattern>
|
||||||
|
</relocation>
|
||||||
</relocations>
|
</relocations>
|
||||||
|
<filters>
|
||||||
|
<filter>
|
||||||
|
<artifact>*:*</artifact>
|
||||||
|
<excludes>
|
||||||
|
<exclude>com/cryptomorin/xseries/XPotion*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/XItemStack*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/XEntity*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/XEnchantment*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/XBlock*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/XBiome*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/SkullUtils*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/ReflectionUtils*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/NMSExtras*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/NoteBlockMusic*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/particles/*</exclude>
|
||||||
|
<exclude>com/cryptomorin/xseries/messages/*</exclude>
|
||||||
|
</excludes>
|
||||||
|
</filter>
|
||||||
|
</filters>
|
||||||
</configuration>
|
</configuration>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
|
@ -161,6 +184,14 @@
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- SnakeYAML - Included in Spigot and used for the ConfigUpdater -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.yaml</groupId>
|
||||||
|
<artifactId>snakeyaml</artifactId>
|
||||||
|
<version>1.27</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- Lombok, used for the objects -->
|
<!-- Lombok, used for the objects -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.projectlombok</groupId>
|
<groupId>org.projectlombok</groupId>
|
||||||
|
@ -185,6 +216,13 @@
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- XSeries, used for multi version support -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.github.cryptomorin</groupId>
|
||||||
|
<artifactId>XSeries</artifactId>
|
||||||
|
<version>7.9.1.1</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.google.code.findbugs</groupId>
|
<groupId>com.google.code.findbugs</groupId>
|
||||||
<artifactId>jsr305</artifactId>
|
<artifactId>jsr305</artifactId>
|
||||||
|
|
|
@ -10,15 +10,16 @@ import nl.SBDeveloper.V10Lift.listeners.SignChangeListener;
|
||||||
import nl.SBDeveloper.V10Lift.managers.DBManager;
|
import nl.SBDeveloper.V10Lift.managers.DBManager;
|
||||||
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
||||||
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
||||||
|
import nl.SBDeveloper.V10Lift.sbutils.ConfigUpdater;
|
||||||
import nl.SBDeveloper.V10Lift.sbutils.UpdateManager;
|
import nl.SBDeveloper.V10Lift.sbutils.UpdateManager;
|
||||||
import nl.SBDeveloper.V10Lift.sbutils.YamlFile;
|
import nl.SBDeveloper.V10Lift.sbutils.YamlFile;
|
||||||
import org.bstats.bukkit.Metrics;
|
import org.bstats.bukkit.Metrics;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.time.LocalDate;
|
import java.util.Collections;
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
public class V10LiftPlugin extends JavaPlugin {
|
public class V10LiftPlugin extends JavaPlugin {
|
||||||
|
|
||||||
|
@ -37,6 +38,14 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
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();
|
||||||
|
@ -46,6 +55,7 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
try {
|
try {
|
||||||
dbManager.load();
|
dbManager.load();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
|
Bukkit.getLogger().warning("[V10Lift] Couldn't connect to the SQLite database. Please check the stacktrace below.");
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,10 +63,9 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
api = new V10LiftAPI();
|
api = new V10LiftAPI();
|
||||||
|
|
||||||
//Load vault if found
|
//Load vault if found
|
||||||
if (Bukkit.getServer().getPluginManager().getPlugin("Vault") != null) {
|
if (VaultManager.setupPermissions()) {
|
||||||
Bukkit.getLogger().info("[V10Lift] Loading Vault hook for group whitelist support.");
|
Bukkit.getLogger().info("[V10Lift] Loading Vault hook for group whitelist support.");
|
||||||
vault = true;
|
vault = true;
|
||||||
VaultManager.setupPermissions();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Load the command
|
//Load the command
|
||||||
|
@ -75,27 +84,40 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
metrics.addCustomChart(new Metrics.SingleLineChart("lifts", () -> DataManager.getLifts().size()));
|
metrics.addCustomChart(new Metrics.SingleLineChart("lifts", () -> DataManager.getLifts().size()));
|
||||||
|
|
||||||
//Load the update checker
|
//Load the update checker
|
||||||
if (!getSConfig().getFile().contains("CheckUpdates") || getSConfig().getFile().getBoolean("CheckUpdates")) {
|
if (getSConfig().getFile().getBoolean("UpdateChecker.Enabled")) {
|
||||||
UpdateManager manager = new UpdateManager(this, 72317, UpdateManager.CheckType.SPIGOT);
|
UpdateManager updateManager = new UpdateManager(this, 72317);
|
||||||
|
|
||||||
manager.handleResponse((versionResponse, version) -> {
|
updateManager.handleResponse((versionResponse, version) -> {
|
||||||
if (versionResponse == UpdateManager.VersionResponse.FOUND_NEW) {
|
switch (versionResponse) {
|
||||||
Bukkit.getLogger().warning("[V10Lift] There is a new version available! Current: " + this.getDescription().getVersion() + " New: " + version);
|
case FOUND_NEW:
|
||||||
Bukkit.getLogger().info("[V10Lift] Trying to download...");
|
Bukkit.getLogger().warning("[V10Lift] There is a new version available! Current: " + this.getDescription().getVersion() + " New: " + version.get());
|
||||||
|
if (getSConfig().getFile().getBoolean("UpdateChecker.DownloadOnUpdate")) {
|
||||||
|
Bukkit.getLogger().info("[V10Lift] Trying to download the update. This could take some time...");
|
||||||
|
|
||||||
manager.handleDownloadResponse((downloadResponse, path) -> {
|
updateManager.handleDownloadResponse((downloadResponse, fileName) -> {
|
||||||
if (downloadResponse == UpdateManager.DownloadResponse.DONE) {
|
switch (downloadResponse) {
|
||||||
Bukkit.getLogger().info("[V10Lift] Update done! After a restart, it should be loaded.");
|
case DONE:
|
||||||
} else if (downloadResponse == UpdateManager.DownloadResponse.UNAVAILABLE) {
|
Bukkit.getLogger().info("[V10Lift] Update downloaded! If you restart your server, it will be loaded. Filename: " + fileName);
|
||||||
Bukkit.getLogger().warning("[V10Lift] Couldn't download the update, because it's not a Spigot resource.");
|
break;
|
||||||
} else if (downloadResponse == UpdateManager.DownloadResponse.ERROR) {
|
case ERROR:
|
||||||
Bukkit.getLogger().severe("[V10Lift] Unable to download the newest file.");
|
Bukkit.getLogger().severe("[V10Lift] Something went wrong when trying downloading the latest version.");
|
||||||
|
break;
|
||||||
|
case UNAVAILABLE:
|
||||||
|
Bukkit.getLogger().warning("[V10Lift] Unable to download the latest version.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}).runUpdate();
|
||||||
}
|
}
|
||||||
}).runUpdate();
|
break;
|
||||||
} else if (versionResponse == UpdateManager.VersionResponse.LATEST) {
|
case LATEST:
|
||||||
Bukkit.getLogger().info("[V10Lift] You are running the latest version [" + this.getDescription().getVersion() + "]!");
|
Bukkit.getLogger().info("[V10Lift] You are running the latest version [" + this.getDescription().getVersion() + "]!");
|
||||||
} else if (versionResponse == UpdateManager.VersionResponse.UNAVAILABLE) {
|
break;
|
||||||
Bukkit.getLogger().severe("[V10Lift] Unable to perform an update check.");
|
case THIS_NEWER:
|
||||||
|
Bukkit.getLogger().info("[V10Lift] You are running a newer version [" + this.getDescription().getVersion() + "]! This is probably fine.");
|
||||||
|
break;
|
||||||
|
case UNAVAILABLE:
|
||||||
|
Bukkit.getLogger().severe("[V10Lift] Unable to perform an update check.");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}).check();
|
}).check();
|
||||||
}
|
}
|
||||||
|
@ -105,7 +127,7 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDisable() {
|
public void onDisable() {
|
||||||
V10LiftPlugin.getDBManager().removeFromData();
|
dbManager.removeFromData(); //TODO Find a better way, override?
|
||||||
|
|
||||||
dbManager.save();
|
dbManager.save();
|
||||||
dbManager.closeConnection();
|
dbManager.closeConnection();
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package nl.SBDeveloper.V10Lift.api;
|
package nl.SBDeveloper.V10Lift.api;
|
||||||
|
|
||||||
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.*;
|
import nl.SBDeveloper.V10Lift.api.objects.*;
|
||||||
import nl.SBDeveloper.V10Lift.api.runnables.DoorCloser;
|
import nl.SBDeveloper.V10Lift.api.runnables.DoorCloser;
|
||||||
|
@ -11,7 +12,6 @@ import nl.SBDeveloper.V10Lift.sbutils.LocationSerializer;
|
||||||
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.DirectionUtil;
|
import nl.SBDeveloper.V10Lift.utils.DirectionUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.DoorUtil;
|
import nl.SBDeveloper.V10Lift.utils.DoorUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
|
||||||
import org.bukkit.*;
|
import org.bukkit.*;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.BlockFace;
|
import org.bukkit.block.BlockFace;
|
||||||
|
@ -405,13 +405,7 @@ public class V10LiftAPI {
|
||||||
|
|
||||||
lift.setDoorOpen(f);
|
lift.setDoorOpen(f);
|
||||||
|
|
||||||
if (lift.isRealistic()) {
|
if (lift.isRealistic()) lift.setDoorCloser(new DoorCloser(liftName));
|
||||||
lift.setDoorCloser(new DoorCloser(liftName));
|
|
||||||
long doorCloseTime = V10LiftPlugin.getSConfig().getFile().getLong("DoorCloseTime");
|
|
||||||
|
|
||||||
int pid = Bukkit.getScheduler().scheduleSyncRepeatingTask(V10LiftPlugin.getInstance(), lift.getDoorCloser(), doorCloseTime, doorCloseTime);
|
|
||||||
lift.getDoorCloser().setPid(pid);
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -439,13 +433,7 @@ public class V10LiftAPI {
|
||||||
|
|
||||||
lift.setDoorOpen(f);
|
lift.setDoorOpen(f);
|
||||||
|
|
||||||
if (lift.isRealistic()) {
|
if (lift.isRealistic()) lift.setDoorCloser(new DoorCloser(liftName));
|
||||||
lift.setDoorCloser(new DoorCloser(liftName));
|
|
||||||
long doorCloseTime = V10LiftPlugin.getSConfig().getFile().getLong("DoorCloseTime");
|
|
||||||
|
|
||||||
int pid = Bukkit.getScheduler().scheduleSyncRepeatingTask(V10LiftPlugin.getInstance(), lift.getDoorCloser(), doorCloseTime, doorCloseTime);
|
|
||||||
lift.getDoorCloser().setPid(pid);
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -502,10 +490,12 @@ public class V10LiftAPI {
|
||||||
}
|
}
|
||||||
state.update(true);
|
state.update(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (LiftBlock lb : lift.getDoorOpen().getRealDoorBlocks()) {
|
for (LiftBlock lb : lift.getDoorOpen().getRealDoorBlocks()) {
|
||||||
Block block = Objects.requireNonNull(Bukkit.getWorld(lb.getWorld()), "World is null at closeDoor").getBlockAt(lb.getX(), lb.getY(), lb.getZ());
|
Block block = Objects.requireNonNull(Bukkit.getWorld(lb.getWorld()), "World is null at closeDoor").getBlockAt(lb.getX(), lb.getY(), lb.getZ());
|
||||||
DoorUtil.closeDoor(block);
|
DoorUtil.closeDoor(block);
|
||||||
}
|
}
|
||||||
|
|
||||||
lift.setDoorOpen(null);
|
lift.setDoorOpen(null);
|
||||||
if (lift.getDoorCloser() != null) lift.getDoorCloser().stop();
|
if (lift.getDoorCloser() != null) lift.getDoorCloser().stop();
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,13 +3,14 @@ package nl.SBDeveloper.V10Lift.api.objects;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
/** A floor object, for a floor in the lift. */
|
/** A floor object, for a floor in the lift. */
|
||||||
@Getter @Setter @NoArgsConstructor
|
@Getter @Setter @NoArgsConstructor @ToString
|
||||||
public class Floor {
|
public class Floor {
|
||||||
private String world;
|
private String world;
|
||||||
private int y;
|
private int y;
|
||||||
|
@ -49,16 +50,4 @@ public class Floor {
|
||||||
result = prime * result + y;
|
result = prime * result + y;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Floor{" +
|
|
||||||
"world='" + world + '\'' +
|
|
||||||
", y=" + y +
|
|
||||||
", doorBlocks=" + doorBlocks +
|
|
||||||
", realDoorBlocks=" + realDoorBlocks +
|
|
||||||
", userWhitelist=" + userWhitelist +
|
|
||||||
", groupWhitelist=" + groupWhitelist +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,12 +3,13 @@ package nl.SBDeveloper.V10Lift.api.objects;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
import nl.SBDeveloper.V10Lift.api.runnables.DoorCloser;
|
import nl.SBDeveloper.V10Lift.api.runnables.DoorCloser;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/** A lift object, to create a lift. */
|
/** A lift object, to create a lift. */
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor @ToString
|
||||||
public class Lift {
|
public class Lift {
|
||||||
@Getter @Setter private String worldName;
|
@Getter @Setter private String worldName;
|
||||||
@Getter @Setter private int y;
|
@Getter @Setter private int y;
|
||||||
|
@ -59,30 +60,4 @@ public class Lift {
|
||||||
this.speed = speed;
|
this.speed = speed;
|
||||||
this.realistic = realistic;
|
this.realistic = realistic;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Lift{" +
|
|
||||||
"worldName='" + worldName + '\'' +
|
|
||||||
", y=" + y +
|
|
||||||
", owners=" + owners +
|
|
||||||
", blocks=" + blocks +
|
|
||||||
", floors=" + floors +
|
|
||||||
", signs=" + signs +
|
|
||||||
", inputs=" + inputs +
|
|
||||||
", offlineInputs=" + offlineInputs +
|
|
||||||
", queue=" + queue +
|
|
||||||
", ropes=" + ropes +
|
|
||||||
", toMove=" + toMove +
|
|
||||||
", speed=" + speed +
|
|
||||||
", realistic=" + realistic +
|
|
||||||
", offline=" + offline +
|
|
||||||
", sound=" + sound +
|
|
||||||
", defective=" + defective +
|
|
||||||
", signText='" + signText + '\'' +
|
|
||||||
", counter=" + counter +
|
|
||||||
", doorOpen=" + doorOpen +
|
|
||||||
", doorCloser=" + doorCloser +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +1,19 @@
|
||||||
package nl.SBDeveloper.V10Lift.api.runnables;
|
package nl.SBDeveloper.V10Lift.api.runnables;
|
||||||
|
|
||||||
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
|
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
|
||||||
/** The doorcloser runnable, used for checking if the door can be closed. */
|
/** The DoorCloser runnable, used for checking if the door can be closed. */
|
||||||
public class DoorCloser implements Runnable {
|
public class DoorCloser implements Runnable {
|
||||||
private final String liftName;
|
private final String liftName;
|
||||||
private int pid;
|
private final int taskID;
|
||||||
|
|
||||||
public DoorCloser(String liftName) {
|
public DoorCloser(String liftName) {
|
||||||
this.liftName = liftName;
|
this.liftName = liftName;
|
||||||
|
|
||||||
|
final long doorCloseTime = V10LiftPlugin.getSConfig().getFile().getLong("DoorCloseTime");
|
||||||
|
this.taskID = Bukkit.getScheduler().runTaskTimer(V10LiftPlugin.getInstance(), this, doorCloseTime, doorCloseTime).getTaskId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -18,12 +21,8 @@ public class DoorCloser implements Runnable {
|
||||||
if (V10LiftPlugin.getAPI().closeDoor(liftName)) stop();
|
if (V10LiftPlugin.getAPI().closeDoor(liftName)) stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPid(int pid) {
|
|
||||||
this.pid = pid;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void stop() {
|
public void stop() {
|
||||||
Bukkit.getScheduler().cancelTask(pid);
|
Bukkit.getScheduler().cancelTask(taskID);
|
||||||
if (DataManager.containsLift(liftName)) DataManager.getLift(liftName).setDoorCloser(null);
|
if (DataManager.containsLift(liftName)) DataManager.getLift(liftName).setDoorCloser(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package nl.SBDeveloper.V10Lift.api.runnables;
|
package nl.SBDeveloper.V10Lift.api.runnables;
|
||||||
|
|
||||||
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
|
import com.cryptomorin.xseries.XSound;
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.*;
|
import nl.SBDeveloper.V10Lift.api.objects.*;
|
||||||
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
import nl.SBDeveloper.V10Lift.managers.DataManager;
|
||||||
import nl.SBDeveloper.V10Lift.sbutils.LocationSerializer;
|
import nl.SBDeveloper.V10Lift.sbutils.LocationSerializer;
|
||||||
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.DirectionUtil;
|
import nl.SBDeveloper.V10Lift.utils.DirectionUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
|
||||||
import nl.SBDeveloper.V10Lift.utils.XSound;
|
|
||||||
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;
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package nl.SBDeveloper.V10Lift.commands;
|
package nl.SBDeveloper.V10Lift.commands;
|
||||||
|
|
||||||
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.Floor;
|
import nl.SBDeveloper.V10Lift.api.objects.Floor;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
||||||
|
@ -9,7 +10,6 @@ import nl.SBDeveloper.V10Lift.managers.DataManager;
|
||||||
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
||||||
import nl.SBDeveloper.V10Lift.sbutils.LocationSerializer;
|
import nl.SBDeveloper.V10Lift.sbutils.LocationSerializer;
|
||||||
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
|
||||||
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;
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package nl.SBDeveloper.V10Lift.listeners;
|
package nl.SBDeveloper.V10Lift.listeners;
|
||||||
|
|
||||||
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.Floor;
|
import nl.SBDeveloper.V10Lift.api.objects.Floor;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.LiftBlock;
|
import nl.SBDeveloper.V10Lift.api.objects.LiftBlock;
|
||||||
|
@ -7,8 +9,6 @@ import nl.SBDeveloper.V10Lift.managers.DataManager;
|
||||||
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
import nl.SBDeveloper.V10Lift.managers.VaultManager;
|
||||||
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
import nl.SBDeveloper.V10Lift.utils.ConfigUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.DoorUtil;
|
import nl.SBDeveloper.V10Lift.utils.DoorUtil;
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.GameMode;
|
import org.bukkit.GameMode;
|
||||||
|
@ -29,8 +29,7 @@ import org.bukkit.inventory.ItemStack;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
public class PlayerInteractListener implements Listener {
|
public class PlayerInteractListener implements Listener {
|
||||||
|
private final ArrayList<UUID> rightClicked = new ArrayList<>();
|
||||||
private ArrayList<UUID> rightClicked = new ArrayList<>();
|
|
||||||
|
|
||||||
//BUTTON CLICK
|
//BUTTON CLICK
|
||||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
package nl.SBDeveloper.V10Lift.managers;
|
package nl.SBDeveloper.V10Lift.managers;
|
||||||
|
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
public class AntiCopyBlockManager {
|
public class AntiCopyBlockManager {
|
||||||
private HashSet<XMaterial> antiCopy = new HashSet<>();
|
private static final HashSet<XMaterial> antiCopy = new HashSet<>();
|
||||||
|
|
||||||
public AntiCopyBlockManager() {
|
static {
|
||||||
//TODO Add more anti copy materials
|
//TODO Add more anti copy materials
|
||||||
//TODO Add to config
|
//TODO Add to config
|
||||||
antiCopy.add(XMaterial.REDSTONE_TORCH);
|
antiCopy.add(XMaterial.REDSTONE_TORCH);
|
||||||
|
@ -79,7 +79,7 @@ public class AntiCopyBlockManager {
|
||||||
antiCopy.add(XMaterial.JUKEBOX);
|
antiCopy.add(XMaterial.JUKEBOX);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isAntiCopy(Material mat) {
|
public static boolean isAntiCopy(Material mat) {
|
||||||
XMaterial xmat = XMaterial.matchXMaterial(mat);
|
XMaterial xmat = XMaterial.matchXMaterial(mat);
|
||||||
return antiCopy.contains(xmat);
|
return antiCopy.contains(xmat);
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,6 @@ import java.sql.SQLException;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public class DBManager {
|
public class DBManager {
|
||||||
|
|
||||||
private static SQLiteDB data;
|
private static SQLiteDB data;
|
||||||
private static Connection con;
|
private static Connection con;
|
||||||
|
|
||||||
|
@ -121,5 +120,4 @@ public class DBManager {
|
||||||
public void closeConnection() {
|
public void closeConnection() {
|
||||||
data.closeSource();
|
data.closeSource();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package nl.SBDeveloper.V10Lift.managers;
|
package nl.SBDeveloper.V10Lift.managers;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
import nl.SBDeveloper.V10Lift.api.objects.Lift;
|
||||||
import nl.SBDeveloper.V10Lift.api.objects.LiftBlock;
|
import nl.SBDeveloper.V10Lift.api.objects.LiftBlock;
|
||||||
|
|
||||||
|
@ -7,19 +8,19 @@ import java.util.*;
|
||||||
|
|
||||||
public class DataManager {
|
public class DataManager {
|
||||||
/* A manager for general HashMaps */
|
/* A manager for general HashMaps */
|
||||||
private static LinkedHashMap<String, Lift> lifts = new LinkedHashMap<>();
|
@Getter private static final Map<String, Lift> lifts = new LinkedHashMap<>();
|
||||||
private static LinkedHashMap<UUID, TreeSet<LiftBlock>> builds = new LinkedHashMap<>();
|
private static final Map<UUID, TreeSet<LiftBlock>> builds = new LinkedHashMap<>();
|
||||||
private static LinkedHashMap<UUID, String> editors = new LinkedHashMap<>();
|
@Getter private static final Map<UUID, String> editors = new LinkedHashMap<>();
|
||||||
private static LinkedHashMap<UUID, String> inputEdits = new LinkedHashMap<>();
|
private static final Map<UUID, String> inputEdits = new LinkedHashMap<>();
|
||||||
private static ArrayList<UUID> inputRemoves = new ArrayList<>();
|
private static final List<UUID> inputRemoves = new ArrayList<>();
|
||||||
private static ArrayList<UUID> offlineEdits = new ArrayList<>();
|
private static final List<UUID> offlineEdits = new ArrayList<>();
|
||||||
private static ArrayList<UUID> offlineRemoves = new ArrayList<>();
|
private static final List<UUID> offlineRemoves = new ArrayList<>();
|
||||||
private static ArrayList<UUID> builder = new ArrayList<>();
|
private static final List<UUID> builder = new ArrayList<>();
|
||||||
private static LinkedHashMap<UUID, LiftBlock> ropeEdits = new LinkedHashMap<>();
|
private static final Map<UUID, LiftBlock> ropeEdits = new LinkedHashMap<>();
|
||||||
private static ArrayList<UUID> ropeRemoves = new ArrayList<>();
|
private static final List<UUID> ropeRemoves = new ArrayList<>();
|
||||||
private static HashMap<UUID, String> doorEdits = new HashMap<>();
|
private static final Map<UUID, String> doorEdits = new HashMap<>();
|
||||||
private static ArrayList<UUID> whoisReq = new ArrayList<>();
|
private static final List<UUID> whoisReq = new ArrayList<>();
|
||||||
private static HashMap<String, Integer> movingTasks = new HashMap<>();
|
private static final Map<String, Integer> movingTasks = new HashMap<>();
|
||||||
|
|
||||||
/* HashMap methods */
|
/* HashMap methods */
|
||||||
|
|
||||||
|
@ -40,8 +41,6 @@ public class DataManager {
|
||||||
return lifts.get(liftName);
|
return lifts.get(liftName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static LinkedHashMap<String, Lift> getLifts() { return lifts; }
|
|
||||||
|
|
||||||
// //
|
// //
|
||||||
public static boolean containsPlayer(UUID player) {
|
public static boolean containsPlayer(UUID player) {
|
||||||
return builds.containsKey(player);
|
return builds.containsKey(player);
|
||||||
|
@ -114,8 +113,6 @@ public class DataManager {
|
||||||
return editors.get(player);
|
return editors.get(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static LinkedHashMap<UUID, String> getEditors() { return editors; }
|
|
||||||
|
|
||||||
// //
|
// //
|
||||||
public static void addMovingTask(String liftName, int taskid) {
|
public static void addMovingTask(String liftName, int taskid) {
|
||||||
movingTasks.put(liftName, taskid);
|
movingTasks.put(liftName, taskid);
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
package nl.SBDeveloper.V10Lift.managers;
|
package nl.SBDeveloper.V10Lift.managers;
|
||||||
|
|
||||||
import nl.SBDeveloper.V10Lift.utils.XMaterial;
|
import com.cryptomorin.xseries.XMaterial;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
public class ForbiddenBlockManager {
|
public class ForbiddenBlockManager {
|
||||||
private HashSet<XMaterial> forbidden = new HashSet<>();
|
private static final HashSet<XMaterial> forbidden = new HashSet<>();
|
||||||
|
|
||||||
public ForbiddenBlockManager() {
|
static {
|
||||||
//TODO Add more forbidden materials
|
//TODO Add more forbidden materials
|
||||||
//TODO Add to config
|
//TODO Add to config
|
||||||
forbidden.add(XMaterial.BLACK_BED);
|
forbidden.add(XMaterial.BLACK_BED);
|
||||||
|
@ -41,7 +41,7 @@ public class ForbiddenBlockManager {
|
||||||
forbidden.add(XMaterial.STICKY_PISTON);
|
forbidden.add(XMaterial.STICKY_PISTON);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isForbidden(Material mat) {
|
public static boolean isForbidden(Material mat) {
|
||||||
XMaterial xmat = XMaterial.matchXMaterial(mat);
|
XMaterial xmat = XMaterial.matchXMaterial(mat);
|
||||||
return forbidden.contains(xmat);
|
return forbidden.contains(xmat);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,10 +2,10 @@ package nl.SBDeveloper.V10Lift.managers;
|
||||||
|
|
||||||
import net.milkbowl.vault.permission.Permission;
|
import net.milkbowl.vault.permission.Permission;
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.plugin.RegisteredServiceProvider;
|
import org.bukkit.plugin.RegisteredServiceProvider;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -14,12 +14,14 @@ public class VaultManager {
|
||||||
private static Permission perms = null;
|
private static Permission perms = null;
|
||||||
|
|
||||||
public static boolean setupPermissions() {
|
public static boolean setupPermissions() {
|
||||||
|
if (Bukkit.getServer().getPluginManager().getPlugin("Vault") == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
RegisteredServiceProvider<Permission> rsp = V10LiftPlugin.getInstance().getServer().getServicesManager().getRegistration(Permission.class);
|
RegisteredServiceProvider<Permission> rsp = V10LiftPlugin.getInstance().getServer().getServicesManager().getRegistration(Permission.class);
|
||||||
perms = rsp.getProvider();
|
perms = rsp.getProvider();
|
||||||
return perms != null;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
|
||||||
public static List<String> getGroups() {
|
public static List<String> getGroups() {
|
||||||
return Arrays.asList(perms.getGroups());
|
return Arrays.asList(perms.getGroups());
|
||||||
}
|
}
|
||||||
|
@ -28,7 +30,7 @@ public class VaultManager {
|
||||||
return Arrays.asList(perms.getGroups()).contains(groupName);
|
return Arrays.asList(perms.getGroups()).contains(groupName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean userHasAnyGroup(Player player, @Nonnull HashSet<String> whitelistSet) {
|
public static boolean userHasAnyGroup(Player player, HashSet<String> whitelistSet) {
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
for (String group : whitelistSet) {
|
for (String group : whitelistSet) {
|
||||||
found = Arrays.asList(perms.getPlayerGroups(player)).contains(group);
|
found = Arrays.asList(perms.getPlayerGroups(player)).contains(group);
|
||||||
|
|
|
@ -0,0 +1,331 @@
|
||||||
|
package nl.SBDeveloper.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.toString()).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));
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,7 +7,6 @@ import javax.annotation.Nonnull;
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class LocationSerializer {
|
public class LocationSerializer {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deserialize a serialized location, without {@link Location#getYaw()} and {@link Location#getPitch()}
|
* Deserialize a serialized location, without {@link Location#getYaw()} and {@link Location#getPitch()}
|
||||||
*
|
*
|
||||||
|
@ -77,5 +76,4 @@ public class LocationSerializer {
|
||||||
if (loc.getWorld() == null) return null;
|
if (loc.getWorld() == null) return null;
|
||||||
return loc.getWorld().getName() + "_" + loc.getX() + "_" + loc.getY() + "_" + loc.getZ() + "_" + loc.getYaw() + "_" + loc.getPitch();
|
return loc.getWorld().getName() + "_" + loc.getX() + "_" + loc.getY() + "_" + loc.getZ() + "_" + loc.getYaw() + "_" + loc.getPitch();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -12,8 +12,7 @@ import java.sql.SQLException;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
public class SQLiteDB {
|
public class SQLiteDB {
|
||||||
|
private final String dbName;
|
||||||
private String dbName;
|
|
||||||
private HikariDataSource source;
|
private HikariDataSource source;
|
||||||
private Connection con;
|
private Connection con;
|
||||||
|
|
||||||
|
|
|
@ -1,59 +1,75 @@
|
||||||
package nl.SBDeveloper.V10Lift.sbutils;
|
package nl.SBDeveloper.V10Lift.sbutils;
|
||||||
|
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import com.google.gson.JsonParser;
|
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;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
|
||||||
import javax.annotation.Nullable;
|
|
||||||
import javax.net.ssl.HttpsURLConnection;
|
import javax.net.ssl.HttpsURLConnection;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.net.HttpURLConnection;
|
import java.net.HttpURLConnection;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.nio.channels.Channels;
|
import java.nio.channels.Channels;
|
||||||
|
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 class for SBDevelopment
|
||||||
* @author Stijn [SBDeveloper]
|
* @author Stijn [SBDeveloper]
|
||||||
* @since 05-03-2020
|
* @since 05-03-2020
|
||||||
* @version 1.4
|
* @version 2.0 [26-12-2020] - This class supports the v2 Update API
|
||||||
*
|
*
|
||||||
* © Stijn Bannink <stijnbannink23@gmail.com> - All rights reserved.
|
* <p>© Stijn Bannink [stijnbannink23@gmail.com] - All rights reserved.</p>
|
||||||
*/
|
*/
|
||||||
public class UpdateManager {
|
public class UpdateManager {
|
||||||
|
|
||||||
private static final String SPIGOT_API = "https://api.spigotmc.org/legacy/update.php?resource=%d";
|
private static final String SPIGOT_API = "https://api.spigotmc.org/legacy/update.php?resource=%d";
|
||||||
|
private static final String SPIGOT_DOWNLOAD = "http://api.spiget.org/v2/resources/%s/download";
|
||||||
|
|
||||||
/* Port 4000 is now legacy, 4443 has a SSL cert */
|
private static final String SBDPLUGINS_API = "https://updates.sbdplugins.nl/api/v2/plugins/%d";
|
||||||
/* As of 24-05-2020, using the legacy port because of SSL errors */
|
private static final String SBDPLUGINS_DOWNLOAD = "https://updates.sbdplugins.nl/api/v2/download/%d";
|
||||||
private static final String SBDPLUGINS_API = "http://updates.sbdplugins.nl:4000/api/resources/%d";
|
|
||||||
|
|
||||||
private static final String RESOURCE_DOWNLOAD = "http://api.spiget.org/v2/resources/%s/download";
|
private final Plugin plugin;
|
||||||
|
private final Version currentVersion;
|
||||||
|
private final int resourceID;
|
||||||
|
private final CheckType type;
|
||||||
|
private final String license;
|
||||||
|
|
||||||
private Plugin plugin;
|
|
||||||
private Version currentVersion;
|
|
||||||
private int resourceID;
|
|
||||||
private CheckType type;
|
|
||||||
private BiConsumer<VersionResponse, Version> versionResponse;
|
private BiConsumer<VersionResponse, Version> versionResponse;
|
||||||
private BiConsumer<DownloadResponse, String> downloadResponse;
|
private BiConsumer<DownloadResponse, String> downloadResponse;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new UpdateManager
|
* Construct a new UpdateManager for Spigot
|
||||||
*
|
*
|
||||||
* @param plugin The javaplugin (Main class)
|
* @param plugin The javaplugin (Main class)
|
||||||
* @param resourceID The resourceID on spigot/sbdplugins
|
* @param resourceID The resourceID on spigot/sbdplugins
|
||||||
* @param type The check type
|
|
||||||
*/
|
*/
|
||||||
public UpdateManager(@Nonnull Plugin plugin, int resourceID, CheckType type) {
|
public UpdateManager(Plugin plugin, int resourceID) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.currentVersion = new Version(plugin.getDescription().getVersion());
|
this.currentVersion = new Version(plugin.getDescription().getVersion());
|
||||||
this.resourceID = resourceID;
|
this.resourceID = resourceID;
|
||||||
this.type = type;
|
this.type = CheckType.SPIGOT;
|
||||||
|
this.license = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a new UpdateManager for SBDPlugins
|
||||||
|
*
|
||||||
|
* @param plugin The javaplugin (Main class)
|
||||||
|
* @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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -85,7 +101,7 @@ public class UpdateManager {
|
||||||
|
|
||||||
in = new BufferedReader(new InputStreamReader(con.getInputStream()));
|
in = new BufferedReader(new InputStreamReader(con.getInputStream()));
|
||||||
} else if (type == CheckType.SBDPLUGINS) {
|
} else if (type == CheckType.SBDPLUGINS) {
|
||||||
HttpURLConnection con = (HttpURLConnection) new URL(String.format(SBDPLUGINS_API, this.resourceID)).openConnection();
|
HttpsURLConnection con = (HttpsURLConnection) new URL(String.format(SBDPLUGINS_API, this.resourceID)).openConnection();
|
||||||
con.setRequestMethod("GET");
|
con.setRequestMethod("GET");
|
||||||
con.setRequestProperty("User-Agent", "Mozilla/5.0");
|
con.setRequestProperty("User-Agent", "Mozilla/5.0");
|
||||||
|
|
||||||
|
@ -94,7 +110,7 @@ public class UpdateManager {
|
||||||
|
|
||||||
if (in == null) return;
|
if (in == null) return;
|
||||||
|
|
||||||
String version = null;
|
String version;
|
||||||
|
|
||||||
String inputLine;
|
String inputLine;
|
||||||
StringBuilder response = new StringBuilder();
|
StringBuilder response = new StringBuilder();
|
||||||
|
@ -103,22 +119,25 @@ public class UpdateManager {
|
||||||
}
|
}
|
||||||
in.close();
|
in.close();
|
||||||
|
|
||||||
|
JsonParser parser = new JsonParser();
|
||||||
|
|
||||||
if (type == CheckType.SPIGOT) {
|
if (type == CheckType.SPIGOT) {
|
||||||
version = response.toString();
|
JsonArray array = parser.parse(response.toString()).getAsJsonArray();
|
||||||
} else if (type == CheckType.SBDPLUGINS) {
|
|
||||||
JsonParser parser = new JsonParser();
|
version = array.get(0).getAsJsonObject().get("name").getAsString();
|
||||||
|
} else {
|
||||||
JsonObject object = parser.parse(response.toString()).getAsJsonObject();
|
JsonObject object = parser.parse(response.toString()).getAsJsonObject();
|
||||||
|
|
||||||
version = object.get("data").getAsJsonObject().get("version").getAsString();
|
version = object.get("version").getAsString();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (version == null) return;
|
if (version == null) return;
|
||||||
|
|
||||||
Version onlineVersion = new Version(version);
|
Version onlineVersion = new Version(version);
|
||||||
|
|
||||||
boolean latestVersion = this.currentVersion.compareTo(onlineVersion) < 0;
|
VersionResponse verRes = this.currentVersion.check(onlineVersion);
|
||||||
|
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.versionResponse.accept(latestVersion ? VersionResponse.LATEST : VersionResponse.FOUND_NEW, latestVersion ? this.currentVersion : onlineVersion));
|
Bukkit.getScheduler().runTask(this.plugin, () -> this.versionResponse.accept(verRes, onlineVersion));
|
||||||
} catch (IOException | NullPointerException e) {
|
} catch (IOException | NullPointerException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.versionResponse.accept(VersionResponse.UNAVAILABLE, null));
|
Bukkit.getScheduler().runTask(this.plugin, () -> this.versionResponse.accept(VersionResponse.UNAVAILABLE, null));
|
||||||
|
@ -127,54 +146,108 @@ public class UpdateManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void runUpdate() {
|
public void runUpdate() {
|
||||||
File pluginFile = getPluginFile();// /plugins/XXX.jar
|
File pluginFile = getPluginFile(); // /plugins/XXX.jar
|
||||||
if (pluginFile == null) {
|
if (pluginFile == null) {
|
||||||
this.downloadResponse.accept(DownloadResponse.ERROR, null);
|
this.downloadResponse.accept(DownloadResponse.ERROR, null);
|
||||||
|
Bukkit.getLogger().info("Pluginfile is null");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
File updateFolder = Bukkit.getUpdateFolderFile();
|
File updateFolder = Bukkit.getUpdateFolderFile();
|
||||||
if (!updateFolder.exists()) {
|
if (!updateFolder.exists()) {
|
||||||
if (!updateFolder.mkdirs()) {
|
if (!updateFolder.mkdirs()) {
|
||||||
this.downloadResponse.accept(DownloadResponse.ERROR, null);
|
this.downloadResponse.accept(DownloadResponse.ERROR, null);
|
||||||
|
Bukkit.getLogger().info("Updatefolder doesn't exists, and can't be made");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final File updateFile = new File(updateFolder, pluginFile.getName());
|
final File updateFile = new File(updateFolder, pluginFile.getName());
|
||||||
|
|
||||||
Bukkit.getScheduler().runTaskAsynchronously(this.plugin, () -> {
|
Bukkit.getScheduler().runTaskAsynchronously(this.plugin, () -> {
|
||||||
if (this.type == CheckType.SBDPLUGINS) {
|
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.UNAVAILABLE, null));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
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
|
||||||
HttpURLConnection connection = (HttpURLConnection) new URL(String.format(RESOURCE_DOWNLOAD, this.resourceID)).openConnection();
|
int response;
|
||||||
connection.setRequestProperty("User-Agent", "Mozilla/5.0");
|
InputStream stream;
|
||||||
if (connection.getResponseCode() != 200) {
|
if (type == CheckType.SBDPLUGINS) {
|
||||||
throw new RuntimeException("Download returned status #" + connection.getResponseCode());
|
HttpURLConnection connection = (HttpURLConnection) new URL(String.format(SBDPLUGINS_DOWNLOAD, this.resourceID)).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();
|
||||||
|
|
||||||
|
response = connection.getResponseCode();
|
||||||
|
stream = connection.getInputStream();
|
||||||
|
} else {
|
||||||
|
HttpsURLConnection connection = (HttpsURLConnection) new URL(String.format(SPIGOT_DOWNLOAD, this.resourceID)).openConnection();
|
||||||
|
connection.setRequestProperty("User-Agent", "Mozilla/5.0");
|
||||||
|
|
||||||
|
response = connection.getResponseCode();
|
||||||
|
stream = connection.getInputStream();
|
||||||
}
|
}
|
||||||
channel = Channels.newChannel(connection.getInputStream());
|
|
||||||
|
if (response != 200) {
|
||||||
|
BufferedReader in = new BufferedReader(new InputStreamReader(stream));
|
||||||
|
|
||||||
|
String inputLine;
|
||||||
|
StringBuilder responsestr = new StringBuilder();
|
||||||
|
while ((inputLine = in.readLine()) != null) {
|
||||||
|
responsestr.append(inputLine);
|
||||||
|
}
|
||||||
|
in.close();
|
||||||
|
|
||||||
|
throw new RuntimeException("Download returned status #" + response, new Throwable(responsestr.toString()));
|
||||||
|
}
|
||||||
|
|
||||||
|
channel = Channels.newChannel(stream);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.ERROR, null));
|
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.ERROR, null));
|
||||||
|
e.printStackTrace();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FileChannel fileChannel = null;
|
||||||
try {
|
try {
|
||||||
FileOutputStream output = new FileOutputStream(updateFile);
|
FileOutputStream fosForDownloadedFile = new FileOutputStream(updateFile);
|
||||||
output.getChannel().transferFrom(channel, 0, Long.MAX_VALUE);
|
fileChannel = fosForDownloadedFile.getChannel();
|
||||||
output.flush();
|
|
||||||
output.close();
|
fileChannel.transferFrom(channel, 0, Long.MAX_VALUE);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.ERROR, null));
|
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.ERROR, null));
|
||||||
|
e.printStackTrace();
|
||||||
return;
|
return;
|
||||||
|
} finally {
|
||||||
|
if (channel != null) {
|
||||||
|
try {
|
||||||
|
channel.close();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
System.out.println("Error while closing response body channel");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fileChannel != null) {
|
||||||
|
try {
|
||||||
|
fileChannel.close();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
System.out.println("Error while closing file channel for downloaded file");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.DONE, updateFile.getPath()));
|
Bukkit.getScheduler().runTask(this.plugin, () -> this.downloadResponse.accept(DownloadResponse.DONE, updateFile.getPath()));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
|
||||||
private File getPluginFile() {
|
private File getPluginFile() {
|
||||||
if (!(this.plugin instanceof JavaPlugin)) { return null; }
|
if (!(this.plugin instanceof JavaPlugin)) { return null; }
|
||||||
try {
|
try {
|
||||||
|
@ -186,27 +259,30 @@ public class UpdateManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum CheckType {
|
private enum CheckType {
|
||||||
SPIGOT, SBDPLUGINS
|
SPIGOT, SBDPLUGINS
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum VersionResponse {
|
public enum VersionResponse {
|
||||||
LATEST, FOUND_NEW, UNAVAILABLE
|
LATEST, //Latest version
|
||||||
|
FOUND_NEW, //Newer available
|
||||||
|
THIS_NEWER, //Local version is newer?
|
||||||
|
UNAVAILABLE //Error
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum DownloadResponse {
|
public enum DownloadResponse {
|
||||||
DONE, ERROR, UNAVAILABLE
|
DONE, ERROR, UNAVAILABLE
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Version implements Comparable<Version> {
|
public static class Version {
|
||||||
|
|
||||||
private String version;
|
private final String version;
|
||||||
|
|
||||||
public final String get() {
|
public final String get() {
|
||||||
return this.version;
|
return this.version;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Version(String version) {
|
private Version(String version) {
|
||||||
if(version == null)
|
if(version == null)
|
||||||
throw new IllegalArgumentException("Version can not be null");
|
throw new IllegalArgumentException("Version can not be null");
|
||||||
if(!version.matches("[0-9]+(\\.[0-9]+)*"))
|
if(!version.matches("[0-9]+(\\.[0-9]+)*"))
|
||||||
|
@ -214,8 +290,7 @@ public class UpdateManager {
|
||||||
this.version = version;
|
this.version = version;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private VersionResponse check(Version that) {
|
||||||
public int compareTo(@Nonnull Version that) {
|
|
||||||
String[] thisParts = this.get().split("\\.");
|
String[] thisParts = this.get().split("\\.");
|
||||||
String[] thatParts = that.get().split("\\.");
|
String[] thatParts = that.get().split("\\.");
|
||||||
|
|
||||||
|
@ -224,19 +299,11 @@ public class UpdateManager {
|
||||||
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 -1;
|
return VersionResponse.FOUND_NEW;
|
||||||
if(thisPart > thatPart)
|
if(thisPart > thatPart)
|
||||||
return 1;
|
return VersionResponse.THIS_NEWER;
|
||||||
}
|
}
|
||||||
return 0;
|
return VersionResponse.LATEST;
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object that) {
|
|
||||||
if (this == that) return true;
|
|
||||||
if (that == null) return false;
|
|
||||||
if (this.getClass() != that.getClass()) return false;
|
|
||||||
return this.compareTo((UpdateManager.Version) that) == 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -13,11 +13,9 @@ import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
public class YamlFile {
|
public class YamlFile {
|
||||||
//SBYamlFile file = new SBYamlFile(this, "data");
|
private final String name;
|
||||||
|
|
||||||
private FileConfiguration fileConfiguration;
|
private FileConfiguration fileConfiguration;
|
||||||
private File file;
|
private File file;
|
||||||
private String name;
|
|
||||||
|
|
||||||
public YamlFile(String name) {
|
public YamlFile(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
@ -53,6 +51,10 @@ public class YamlFile {
|
||||||
saveFile();
|
saveFile();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public File getJavaFile() {
|
||||||
|
return this.file;
|
||||||
|
}
|
||||||
|
|
||||||
public FileConfiguration getFile() {
|
public FileConfiguration getFile() {
|
||||||
return this.fileConfiguration;
|
return this.fileConfiguration;
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1,16 +1,35 @@
|
||||||
|
#General sign texts
|
||||||
SignText: "[v10lift]"
|
SignText: "[v10lift]"
|
||||||
DefectText: "&kDefect!"
|
DefectText: "&kDefect!"
|
||||||
DisabledText: "&cDisabled"
|
DisabledText: "&cDisabled"
|
||||||
MaintenanceText: "&cMaintenance"
|
MaintenanceText: "&cMaintenance"
|
||||||
UpText: "&aup"
|
UpText: "&aup"
|
||||||
DownText: "&adown"
|
DownText: "&adown"
|
||||||
|
|
||||||
|
#The change for a lift to get defective. Disabled by default.
|
||||||
DefectRate: 0.0
|
DefectRate: 0.0
|
||||||
|
|
||||||
|
#The repair item and amount required
|
||||||
RepairItem: REDSTONE
|
RepairItem: REDSTONE
|
||||||
RepairAmount: 5
|
RepairAmount: 5
|
||||||
|
|
||||||
|
#The master repair item and amount required
|
||||||
MasterRepairItem: DIAMOND
|
MasterRepairItem: DIAMOND
|
||||||
MasterRepairAmount: 10
|
MasterRepairAmount: 10
|
||||||
|
|
||||||
|
#The default speed of a lift
|
||||||
DefaultSpeed: 16
|
DefaultSpeed: 16
|
||||||
|
|
||||||
|
#Create lifts with realistic mode enabled default?
|
||||||
DefaultRealistic: true
|
DefaultRealistic: true
|
||||||
|
|
||||||
|
#The time for the door to close, in ticks. 20 ticks = 1 sec
|
||||||
DoorCloseTime: 100
|
DoorCloseTime: 100
|
||||||
CheckUpdates: true
|
|
||||||
|
#Teleport with packets (no Bukkit events will be fired then)
|
||||||
PacketTeleport: false
|
PacketTeleport: false
|
||||||
|
|
||||||
|
#The updater checker - It will check for new versions, and install automatically if found.
|
||||||
|
UpdateChecker:
|
||||||
|
Enabled: true
|
||||||
|
DownloadOnUpdate: true
|
|
@ -1,22 +1,18 @@
|
||||||
General:
|
General:
|
||||||
#General
|
|
||||||
NoPermission: '&cYou don''t have the permission to do this.'
|
NoPermission: '&cYou don''t have the permission to do this.'
|
||||||
PlayerOnly: '&cOnly players can do this.'
|
PlayerOnly: '&cOnly players can do this.'
|
||||||
IncorrectUsage: '&cPlease use %Command% instead'
|
IncorrectUsage: '&cPlease use %Command% instead'
|
||||||
InternalError: '&cSomething went wrong internally.'
|
InternalError: '&cSomething went wrong internally.'
|
||||||
|
|
||||||
#Lift general
|
|
||||||
DoesntExists: '&cThere are no lifts with that name.'
|
DoesntExists: '&cThere are no lifts with that name.'
|
||||||
AlreadyExists: '&cA lift with that name already exists.'
|
AlreadyExists: '&cA lift with that name already exists.'
|
||||||
SwitchOnEdit: '&cEnable editor mode before doing this.'
|
SwitchOnEdit: '&cEnable editor mode before doing this.'
|
||||||
DetectionFailed: '&cAutomatic floor detection failed!'
|
DetectionFailed: '&cAutomatic floor detection failed!'
|
||||||
FloorDoesntExists: '&cThe floor %Name% doesn''t exists!'
|
FloorDoesntExists: '&cThe floor %Name% doesn''t exists!'
|
||||||
|
|
||||||
#Lift control
|
|
||||||
NoWhitelistPermission: '&cYou can''t go to that floor!'
|
NoWhitelistPermission: '&cYou can''t go to that floor!'
|
||||||
NoFloors: '&cThis elevator has no floors!'
|
NoFloors: '&cThis elevator has no floors!'
|
||||||
|
|
||||||
#Protection
|
|
||||||
RemoveLiftFirst: '&cYou can''t do this! Remove the lift first.'
|
RemoveLiftFirst: '&cYou can''t do this! Remove the lift first.'
|
||||||
RemoveRopeFirst: '&cYou can''t do this! Remove the rope first.'
|
RemoveRopeFirst: '&cYou can''t do this! Remove the rope first.'
|
||||||
RemoveDoorFirst: '&cYou can''t do this! Remove the door first.'
|
RemoveDoorFirst: '&cYou can''t do this! Remove the door first.'
|
||||||
|
|
Loading…
Reference in a new issue