mirror of
https://github.com/GeorgH93/Minepacks.git
synced 2024-12-10 15:03:30 +01:00
Start the clean up for V2
This commit is contained in:
parent
512b39038f
commit
b07809939d
@ -7,4 +7,4 @@
|
|||||||
[Spigot](https://www.spigotmc.org/resources/minepacks.19286/)</br>
|
[Spigot](https://www.spigotmc.org/resources/minepacks.19286/)</br>
|
||||||
[Dev Bukkit](http://dev.bukkit.org/bukkit-plugins/minepacks/)</br>
|
[Dev Bukkit](http://dev.bukkit.org/bukkit-plugins/minepacks/)</br>
|
||||||
[Issue tracker](https://github.com/GeorgH93/Bukkit_Minepacks/issues)</br>
|
[Issue tracker](https://github.com/GeorgH93/Bukkit_Minepacks/issues)</br>
|
||||||
[Build Server ![Build Status](http://ci.pcgamingfreaks.at/job/Minepacks/badge/icon)](http://ci.pcgamingfreaks.at/job/Minepacks/)
|
[Build Server ![Build Status](http://ci.pcgamingfreaks.at/job/Minepacks/badge/icon)](http://ci.pcgamingfreaks.at/job/Minepacks%20V2/)
|
38
pom.xml
38
pom.xml
@ -3,7 +3,7 @@
|
|||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>at.pcgamingfreaks</groupId>
|
<groupId>at.pcgamingfreaks</groupId>
|
||||||
<artifactId>MinePacks</artifactId>
|
<artifactId>MinePacks</artifactId>
|
||||||
<version>1.16.3</version>
|
<version>2.0-SNAPSHOT</version>
|
||||||
|
|
||||||
<scm>
|
<scm>
|
||||||
<connection>scm:git:git@github.com:GeorgH93/Bukkit_Minepacks.git</connection>
|
<connection>scm:git:git@github.com:GeorgH93/Bukkit_Minepacks.git</connection>
|
||||||
@ -31,27 +31,27 @@
|
|||||||
</licenses>
|
</licenses>
|
||||||
|
|
||||||
<repositories>
|
<repositories>
|
||||||
<repository>
|
|
||||||
<id>spigot-repo</id>
|
|
||||||
<url>https://hub.spigotmc.org/nexus/content/groups/public/</url>
|
|
||||||
</repository>
|
|
||||||
<repository>
|
<repository>
|
||||||
<id>pcgf-repo</id>
|
<id>pcgf-repo</id>
|
||||||
<url>http://repo.pcgamingfreaks.at/repository/everything/</url>
|
<url>http://repo.pcgamingfreaks.at/repository/everything/</url>
|
||||||
</repository>
|
</repository>
|
||||||
|
<repository>
|
||||||
|
<id>spigot-nexus</id>
|
||||||
|
<url>https://hub.spigotmc.org/nexus/content/groups/public/</url>
|
||||||
|
</repository>
|
||||||
</repositories>
|
</repositories>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.bukkit</groupId>
|
<groupId>org.bukkit</groupId>
|
||||||
<artifactId>bukkit</artifactId>
|
<artifactId>bukkit</artifactId>
|
||||||
<version>LATEST</version>
|
<version>1.10.2-R0.1-SNAPSHOT</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>at.pcgamingfreaks</groupId>
|
<groupId>at.pcgamingfreaks</groupId>
|
||||||
<artifactId>Bukkit_Bungee_PluginLib</artifactId>
|
<artifactId>Bukkit_Bungee_PluginLib</artifactId>
|
||||||
<version>LATEST</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.zaxxer</groupId>
|
<groupId>com.zaxxer</groupId>
|
||||||
@ -91,30 +91,6 @@
|
|||||||
<target>1.7</target>
|
<target>1.7</target>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-shade-plugin</artifactId>
|
|
||||||
<version>2.3</version>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>package</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>shade</goal>
|
|
||||||
</goals>
|
|
||||||
<configuration>
|
|
||||||
<createDependencyReducedPom>false</createDependencyReducedPom>
|
|
||||||
<minimizeJar>true</minimizeJar>
|
|
||||||
<artifactSet>
|
|
||||||
<includes>
|
|
||||||
<include>at.pcgamingfreaks:Bukkit_Bungee_PluginLib</include>
|
|
||||||
<include>com.zaxxer:HikariCP</include>
|
|
||||||
<include>org.slf4j:*</include>
|
|
||||||
</includes>
|
|
||||||
</artifactSet>
|
|
||||||
</configuration>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
|
@ -1,24 +1,18 @@
|
|||||||
Language:
|
Language:
|
||||||
Console:
|
NotFromConsole: "&cDieser Befehl kann nicht in der Console ausgeführt werden."
|
||||||
Enabled: MinePacks wurde aktiviert.
|
|
||||||
Disabled: MinePacks wurde deaktiviert.
|
|
||||||
NotFromConsole: Dieser Befehl kann nicht in der Console ausgeführt werden.
|
|
||||||
LangUpdated: Die Sprachdatei wurde aktualisiert.
|
|
||||||
UpdateUUIDs: Beginne die Spielernamen in UUIDs umzuwandeln...
|
|
||||||
UpdatedUUIDs: 'Es wurden %d Spielernamen in UUIDs umgewandelt.'
|
|
||||||
MinecraftVersionNotCompatible: "Deine Minecraft Version (MC %1$s) ist mit der Version des Plugins (%2$s) nicht kompatibel! Bitte prüfe ob ein update verfügbar ist!"
|
|
||||||
Ingame:
|
Ingame:
|
||||||
NoPermission: 'Dir fehlen die Rechte dafür.'
|
NoPermission: "Dir fehlen die Rechte dafür."
|
||||||
OwnBackPackClose: 'Rucksack geschlossen.'
|
OwnBackPackClose: "Rucksack geschlossen."
|
||||||
PlayerBackPackClose: "%s's Rucksack geschlossen."
|
PlayerBackPackClose: "%s's Rucksack geschlossen."
|
||||||
InvalidBackpack: Rucksack fehlerhaft.
|
InvalidBackpack: "Rucksack fehlerhaft."
|
||||||
BackpackCleaned: Rucksack gelehrt.
|
BackpackCleaned: "Rucksack gelehrt."
|
||||||
Cooldown: 'Bitte warte kurz bis du deinen Rucksack wieder öffnest.'
|
Cooldown: "&2Bitte warte kurz bis du deinen Rucksack wieder öffnest."
|
||||||
Description:
|
Commands:
|
||||||
Backpack: Öffent deinen Rucksack.
|
Description:
|
||||||
Clean: Leert deinen Rucksack.
|
Backpack: "Öffent deinen Rucksack."
|
||||||
CleanOther: Leert den Rucksack eines anderen Spielers.
|
Clean: "Leert deinen Rucksack."
|
||||||
View: Öffnet den Rucksack eines anderen Spielers.
|
CleanOther: "Leert den Rucksack eines anderen Spielers."
|
||||||
|
View: "Öffnet den Rucksack eines anderen Spielers."
|
||||||
|
|
||||||
# Language file version. Don't touch it!
|
# Language file version. Don't touch it!
|
||||||
Version: 4
|
Version: 10
|
@ -1,24 +1,18 @@
|
|||||||
Language:
|
Language:
|
||||||
Console:
|
NotFromConsole: "&cCommand not useable from console."
|
||||||
Enabled: MinePacks has been enabled!
|
|
||||||
Disabled: MinePacks has been disabled.
|
|
||||||
NotFromConsole: Command not useable from console.
|
|
||||||
LangUpdated: Language File has been updated.
|
|
||||||
UpdateUUIDs: Start updating database to UUIDs ...
|
|
||||||
UpdatedUUIDs: 'Updated %s accounts to UUIDs.'
|
|
||||||
MinecraftVersionNotCompatible: "Your minecraft version (MC %1$s) is currently not compatible with this plugins version (%2$s). Please check for updates!"
|
|
||||||
Ingame:
|
Ingame:
|
||||||
NoPermission: You don't have the Permission to do that.
|
NoPermission: "&cYou don't have the Permission to do that."
|
||||||
OwnBackPackClose: 'Backpack closed!'
|
OwnBackPackClose: "Backpack closed!"
|
||||||
PlayerBackPackClose: "%s's backpack closed!"
|
PlayerBackPackClose: "%s's backpack closed!"
|
||||||
InvalidBackpack: Invalid backpack.
|
InvalidBackpack: "Invalid backpack."
|
||||||
BackpackCleaned: Backpack cleaned.
|
BackpackCleaned: "Backpack cleaned."
|
||||||
Cooldown: "Please wait till you reopen your backpack."
|
Cooldown: "&2Please wait till you reopen your backpack."
|
||||||
Description:
|
Commands:
|
||||||
Backpack: Opens your backpack.
|
Description:
|
||||||
Clean: Cleans your backpack.
|
Backpack: "Opens your backpack."
|
||||||
CleanOther: Cleans the backpack of other players.
|
Clean: "Cleans your backpack."
|
||||||
View: Shows the backpack of other player.
|
CleanOther: "Cleans the backpack of other players."
|
||||||
|
View: "Shows the backpack of other player."
|
||||||
|
|
||||||
# Language file version. Don't touch it!
|
# Language file version. Don't touch it!
|
||||||
Version: 4
|
Version: 10
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-2015 GeorgH93
|
* Copyright (C) 2014-2016 GeorgH93
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -18,7 +18,7 @@
|
|||||||
package at.pcgamingfreaks.MinePacks;
|
package at.pcgamingfreaks.MinePacks;
|
||||||
|
|
||||||
import at.pcgamingfreaks.Bukkit.NMSReflection;
|
import at.pcgamingfreaks.Bukkit.NMSReflection;
|
||||||
import at.pcgamingfreaks.Bukkit.Utils;
|
import at.pcgamingfreaks.StringUtils;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
@ -59,7 +59,7 @@ public Backpack(OfflinePlayer owner, int size)
|
|||||||
public Backpack(OfflinePlayer owner, int Size, int ID)
|
public Backpack(OfflinePlayer owner, int Size, int ID)
|
||||||
{
|
{
|
||||||
this.owner = owner;
|
this.owner = owner;
|
||||||
titleOther = Utils.limitLength(String.format(MinePacks.backpackTitleOther, owner.getName()), 32);
|
titleOther = StringUtils.limitLength(String.format(MinePacks.getInstance().backpackTitleOther, owner.getName()), 32);
|
||||||
bp = Bukkit.createInventory(this, Size, titleOther);
|
bp = Bukkit.createInventory(this, Size, titleOther);
|
||||||
size = Size;
|
size = Size;
|
||||||
ownerID = ID;
|
ownerID = ID;
|
||||||
@ -94,7 +94,7 @@ public void open(Player p, boolean editable)
|
|||||||
Player player = owner.getPlayer();
|
Player player = owner.getPlayer();
|
||||||
if(player != null)
|
if(player != null)
|
||||||
{
|
{
|
||||||
int size = MinePacks.getBackpackPermSize(player);
|
int size = MinePacks.getInstance().getBackpackPermSize(player);
|
||||||
if(size != bp.getSize())
|
if(size != bp.getSize())
|
||||||
{
|
{
|
||||||
List<ItemStack> items = setSize(size);
|
List<ItemStack> items = setSize(size);
|
||||||
@ -117,7 +117,7 @@ public void open(Player p, boolean editable)
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
FIELD_TITLE.setAccessible(true);
|
FIELD_TITLE.setAccessible(true);
|
||||||
FIELD_TITLE.set(METHOD_GET_INVENTORY.invoke(bp), p.equals(owner) ? MinePacks.backpackTitle : titleOther);
|
FIELD_TITLE.set(METHOD_GET_INVENTORY.invoke(bp), p.equals(owner) ? MinePacks.getInstance().backpackTitle : titleOther);
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(Exception e)
|
||||||
{
|
{
|
||||||
|
@ -195,9 +195,4 @@ public double getFullInvRadius()
|
|||||||
{
|
{
|
||||||
return config.getDouble("full_inventory.collect_radius", 1.5); // in blocks
|
return config.getDouble("full_inventory.collect_radius", 1.5); // in blocks
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isV2InfoDisabled()
|
|
||||||
{
|
|
||||||
return config.getBoolean("Misc.DisableV2Info", false);
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -27,13 +27,13 @@
|
|||||||
|
|
||||||
public class Database
|
public class Database
|
||||||
{
|
{
|
||||||
protected MinePacks plugin;
|
protected static final String START_UUID_UPDATE = "Start updating database to UUIDs ...", UUIDS_UPDATED = "Updated %d accounts to UUIDs.";
|
||||||
|
|
||||||
|
protected MinePacks plugin;
|
||||||
protected boolean useUUIDs, useUUIDSeparators;
|
protected boolean useUUIDs, useUUIDSeparators;
|
||||||
protected long maxAge;
|
protected long maxAge;
|
||||||
|
|
||||||
private HashMap<OfflinePlayer, Backpack> backpacks = new HashMap<>();
|
|
||||||
protected InventorySerializer itsSerializer = new InventorySerializer();
|
protected InventorySerializer itsSerializer = new InventorySerializer();
|
||||||
|
private HashMap<OfflinePlayer, Backpack> backpacks = new HashMap<>();
|
||||||
|
|
||||||
public Database(MinePacks mp)
|
public Database(MinePacks mp)
|
||||||
{
|
{
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-2015 GeorgH93
|
* Copyright (C) 2014-2016 GeorgH93
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -33,43 +33,50 @@
|
|||||||
|
|
||||||
public class Files extends Database
|
public class Files extends Database
|
||||||
{
|
{
|
||||||
|
private static final String EXT = ".backpack", EXT_REGEX = "\\.backpack";
|
||||||
|
|
||||||
private File saveFolder;
|
private File saveFolder;
|
||||||
private final String ext = ".backpack";
|
|
||||||
|
|
||||||
public Files(MinePacks mp)
|
public Files(MinePacks plugin)
|
||||||
{
|
{
|
||||||
super(mp);
|
super(plugin);
|
||||||
maxAge *= 24 * 3600000L;
|
maxAge *= 24 * 3600000L;
|
||||||
saveFolder = new File(plugin.getDataFolder(), "backpacks");
|
saveFolder = new File(this.plugin.getDataFolder(), "backpacks");
|
||||||
if(!saveFolder.exists())
|
if(!saveFolder.exists())
|
||||||
{
|
{
|
||||||
//noinspection ResultOfMethodCallIgnored
|
if(!saveFolder.mkdirs())
|
||||||
saveFolder.mkdirs();
|
{
|
||||||
|
plugin.getLogger().warning("Failed to create save folder (" + saveFolder.getAbsolutePath() + ").");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
CheckFiles();
|
checkFiles();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("ResultOfMethodCallIgnored")
|
@SuppressWarnings("ResultOfMethodCallIgnored")
|
||||||
private void CheckFiles()
|
private void checkFiles()
|
||||||
{
|
{
|
||||||
File[] allFiles = saveFolder.listFiles(new BackpackFileFilter());
|
File[] allFiles = saveFolder.listFiles(new BackpackFileFilter());
|
||||||
|
if(allFiles == null) return;
|
||||||
int len;
|
int len;
|
||||||
for (File file : allFiles)
|
for (File file : allFiles)
|
||||||
{
|
{
|
||||||
if(maxAge > 0 && (new Date()).getTime() - file.lastModified() > maxAge) // Check if the file is older then x days
|
if(maxAge > 0 && (new Date()).getTime() - file.lastModified() > maxAge) // Check if the file is older then x days
|
||||||
{
|
{
|
||||||
file.delete(); // Delete old files
|
if(!file.delete())
|
||||||
|
{
|
||||||
|
plugin.getLogger().warning("Failed to delete file (" + file.getAbsolutePath() + ").");
|
||||||
|
}
|
||||||
continue; // We don't have to check if the file name is correct cause we have the deleted the file
|
continue; // We don't have to check if the file name is correct cause we have the deleted the file
|
||||||
}
|
}
|
||||||
len = file.getName().length() - ext.length();
|
len = file.getName().length() - EXT.length();
|
||||||
if(useUUIDs) // Use UUID-based saving
|
if(useUUIDs) // Use UUID-based saving
|
||||||
{
|
{
|
||||||
if(len <= 16) // It's a player name
|
if(len <= 16) // It's a player name
|
||||||
{
|
{
|
||||||
file.renameTo(new File(saveFolder, UUIDConverter.getUUIDFromName(file.getName().substring(0, len), true, useUUIDSeparators) + ext));
|
file.renameTo(new File(saveFolder, UUIDConverter.getUUIDFromName(file.getName().substring(0, len), true, useUUIDSeparators) + EXT));
|
||||||
}
|
}
|
||||||
else // It's an UUID
|
else // It's an UUID
|
||||||
{
|
{
|
||||||
@ -84,7 +91,7 @@ private void CheckFiles()
|
|||||||
{
|
{
|
||||||
if(useUUIDSeparators)
|
if(useUUIDSeparators)
|
||||||
{
|
{
|
||||||
file.renameTo(new File(saveFolder, file.getName().replaceAll("(\\w{8})(\\w{4})(\\w{4})(\\w{4})(\\w{12})" + ext, "$1-$2-$3-$4-$5" + ext)));
|
file.renameTo(new File(saveFolder, file.getName().replaceAll("(\\w{8})(\\w{4})(\\w{4})(\\w{4})(\\w{12})" + EXT_REGEX, "$1-$2-$3-$4-$5" + EXT)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -93,7 +100,7 @@ private void CheckFiles()
|
|||||||
{
|
{
|
||||||
if(len > 16) // We only have to rename it if it's name is more than 16 chars (minecraft max player name length)
|
if(len > 16) // We only have to rename it if it's name is more than 16 chars (minecraft max player name length)
|
||||||
{
|
{
|
||||||
file.renameTo(new File(saveFolder, UUIDConverter.getNameFromUUID(file.getName().substring(0, len)) + ext));
|
file.renameTo(new File(saveFolder, UUIDConverter.getNameFromUUID(file.getName().substring(0, len)) + EXT));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -101,7 +108,7 @@ private void CheckFiles()
|
|||||||
|
|
||||||
private String getFileName(OfflinePlayer player)
|
private String getFileName(OfflinePlayer player)
|
||||||
{
|
{
|
||||||
return getPlayerNameOrUUID(player) + ext;
|
return getPlayerNameOrUUID(player) + EXT;
|
||||||
}
|
}
|
||||||
|
|
||||||
// DB Functions
|
// DB Functions
|
||||||
@ -109,13 +116,11 @@ private String getFileName(OfflinePlayer player)
|
|||||||
public void saveBackpack(Backpack backpack)
|
public void saveBackpack(Backpack backpack)
|
||||||
{
|
{
|
||||||
File save = new File(saveFolder, getFileName(backpack.getOwner()));
|
File save = new File(saveFolder, getFileName(backpack.getOwner()));
|
||||||
try
|
try(FileOutputStream fos = new FileOutputStream(save))
|
||||||
{
|
{
|
||||||
FileOutputStream fos = new FileOutputStream(save);
|
|
||||||
fos.write(itsSerializer.getUsedSerializer());
|
fos.write(itsSerializer.getUsedSerializer());
|
||||||
fos.write(itsSerializer.serialize(backpack.getInventory()));
|
fos.write(itsSerializer.serialize(backpack.getInventory()));
|
||||||
fos.flush();
|
fos.flush();
|
||||||
fos.close();
|
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(Exception e)
|
||||||
{
|
{
|
||||||
@ -131,13 +136,17 @@ public Backpack loadBackpack(OfflinePlayer player)
|
|||||||
{
|
{
|
||||||
if(save.exists())
|
if(save.exists())
|
||||||
{
|
{
|
||||||
FileInputStream fis = new FileInputStream(save);
|
try(FileInputStream fis = new FileInputStream(save))
|
||||||
int v = fis.read();
|
{
|
||||||
byte[] out = new byte[(int)(save.length()-1)];
|
int v = fis.read();
|
||||||
//noinspection ResultOfMethodCallIgnored
|
byte[] out = new byte[(int) (save.length() - 1)];
|
||||||
fis.read(out);
|
int c = fis.read(out);
|
||||||
fis.close();
|
if(v != c)
|
||||||
return new Backpack(player, itsSerializer.deserialize(out, v), -1);
|
{
|
||||||
|
plugin.getLogger().warning("Problem reading file, only read " + c + " of " + v + " bytes.");
|
||||||
|
}
|
||||||
|
return new Backpack(player, itsSerializer.deserialize(out, v), -1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(Exception e)
|
||||||
@ -147,14 +156,14 @@ public Backpack loadBackpack(OfflinePlayer player)
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
class BackpackFileFilter extends FileFilter implements FilenameFilter
|
private static class BackpackFileFilter extends FileFilter implements FilenameFilter
|
||||||
{
|
{
|
||||||
String description, extension;
|
String description, extension;
|
||||||
|
|
||||||
public BackpackFileFilter()
|
public BackpackFileFilter()
|
||||||
{
|
{
|
||||||
description = "Filters for Minepack backpack files.";
|
description = "Filters for Minepack backpack files.";
|
||||||
extension = "backpack";
|
extension = EXT.substring(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -27,8 +27,8 @@
|
|||||||
|
|
||||||
public class InventorySerializer
|
public class InventorySerializer
|
||||||
{
|
{
|
||||||
ItemStackSerializer serializer, baseItemStackSerializer = new BukkitItemStackSerializer();
|
private ItemStackSerializer serializer, baseItemStackSerializer = new BukkitItemStackSerializer();
|
||||||
int usedSerializer = 1;
|
private int usedSerializer = 1;
|
||||||
|
|
||||||
public InventorySerializer()
|
public InventorySerializer()
|
||||||
{
|
{
|
||||||
|
@ -17,27 +17,96 @@
|
|||||||
|
|
||||||
package at.pcgamingfreaks.MinePacks.Database;
|
package at.pcgamingfreaks.MinePacks.Database;
|
||||||
|
|
||||||
|
import at.pcgamingfreaks.yaml.YAML;
|
||||||
|
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
public class Language extends at.pcgamingfreaks.Bukkit.Language
|
public class Language extends at.pcgamingfreaks.Bukkit.Language
|
||||||
{
|
{
|
||||||
private static final int LANG_VERSION = 4;
|
private static final int LANG_VERSION = 10, UPGRADE_THRESHOLD = 10;
|
||||||
|
|
||||||
public Language(JavaPlugin plugin)
|
public Language(JavaPlugin plugin)
|
||||||
{
|
{
|
||||||
super(plugin, LANG_VERSION);
|
super(plugin, LANG_VERSION, UPGRADE_THRESHOLD);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("SpellCheckingInspection")
|
|
||||||
@Override
|
@Override
|
||||||
protected void doUpdate()
|
protected void doUpdate() {}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void doUpgrade(at.pcgamingfreaks.Language oldLang)
|
||||||
{
|
{
|
||||||
switch(getVersion())
|
if(oldLang.getVersion() < UPGRADE_THRESHOLD)
|
||||||
{
|
{
|
||||||
case 1: lang.set("Language.Ingame.Cooldown", "Please wait till you reopen your backpack.");
|
YAML oldYAML = oldLang.getLang(), newYAML = getLang();
|
||||||
case 2: lang.set("Language.Ingame.InvalidBackpack", lang.getString("Language.Ingame.IvalidBackpack", "Invalid backpack."));
|
Map<String, String> simpleConverter = new LinkedHashMap<>(), advancedConverter = new LinkedHashMap<>();
|
||||||
case 3: lang.set("Language.Console.MinecraftVersionNotCompatible", "Your minecraft version (MC %1$s) is currently not compatible with this plugins version (%2$s). Please check for updates!");
|
String[] keys;
|
||||||
break;
|
String helper;
|
||||||
|
for(String key : oldYAML.getKeys(true))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
keys = key.split("\\.");
|
||||||
|
if(keys.length == 3)
|
||||||
|
{
|
||||||
|
switch(keys[1])
|
||||||
|
{
|
||||||
|
case "Console":
|
||||||
|
switch(keys[2])
|
||||||
|
{
|
||||||
|
case "NotFromConsole": advancedConverter.put("Language.NotFromConsole", ChatColor.RED + oldYAML.getString(key)); break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "Ingame":
|
||||||
|
switch(keys[3])
|
||||||
|
{
|
||||||
|
case "NoPermission": advancedConverter.put(key, ChatColor.RED + oldYAML.getString(key)); break;
|
||||||
|
case "OwnBackPackClose": simpleConverter.put(key, key); break;
|
||||||
|
case "PlayerBackPackClose": simpleConverter.put(key, key); break;
|
||||||
|
case "InvalidBackpack": simpleConverter.put(key, key); break;
|
||||||
|
case "BackpackCleaned": simpleConverter.put(key, key); break;
|
||||||
|
case "Cooldown": advancedConverter.put(key, ChatColor.DARK_GREEN + oldYAML.getString(key)); break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "Description":
|
||||||
|
helper = "Language.Commands.Description.";
|
||||||
|
simpleConverter.put(helper + keys[2], key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
plugin.getLogger().warning("Failed to convert the old \"" + key + "\" language value into the corresponding new one.");
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Patch them into the lang file
|
||||||
|
try
|
||||||
|
{
|
||||||
|
for(Map.Entry<String, String> entry : advancedConverter.entrySet())
|
||||||
|
{
|
||||||
|
newYAML.set(entry.getKey(), entry.getValue());
|
||||||
|
}
|
||||||
|
for(Map.Entry<String, String> entry : simpleConverter.entrySet())
|
||||||
|
{
|
||||||
|
newYAML.set(entry.getKey(), oldYAML.getString(entry.getValue()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
plugin.getLogger().warning("Failed to write the old language values into the new language file.");
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
super.doUpgrade(oldLang);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -48,8 +48,8 @@ protected HikariConfig getPoolConfig()
|
|||||||
@Override
|
@Override
|
||||||
protected void updateQuerysForDialect()
|
protected void updateQuerysForDialect()
|
||||||
{
|
{
|
||||||
Query_DeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` + INTERVAL {VarMaxAge} day < NOW()";
|
queryDeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` + INTERVAL {VarMaxAge} day < NOW()";
|
||||||
Query_UpdateBP = Query_UpdateBP.replaceAll("\\{NOW\\}", "NOW()");
|
queryUpdateBP = queryUpdateBP.replaceAll("\\{NOW\\}", "NOW()");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -60,52 +60,52 @@ protected void checkDB()
|
|||||||
ResultSet res;
|
ResultSet res;
|
||||||
if(useUUIDs)
|
if(useUUIDs)
|
||||||
{
|
{
|
||||||
stmt.execute("CREATE TABLE IF NOT EXISTS `" + Table_Players + "` (`" + Field_PlayerID + "` INT UNSIGNED NOT NULL AUTO_INCREMENT,`" + Field_Name + "` CHAR(16) NOT NULL,`" + Field_UUID + "` CHAR(36) UNIQUE, PRIMARY KEY (`" + Field_PlayerID + "`));");
|
stmt.execute("CREATE TABLE IF NOT EXISTS `" + tablePlayers + "` (`" + fieldPlayerID + "` INT UNSIGNED NOT NULL AUTO_INCREMENT,`" + fieldName + "` CHAR(16) NOT NULL,`" + fieldUUID + "` CHAR(36) UNIQUE, PRIMARY KEY (`" + fieldPlayerID + "`));");
|
||||||
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Players + "' AND COLUMN_NAME = '" + Field_UUID + "';");
|
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tablePlayers + "' AND COLUMN_NAME = '" + fieldUUID + "';");
|
||||||
if(!res.next())
|
if(!res.next())
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Players + "` ADD COLUMN `" + Field_UUID + "` CHAR(36) UNIQUE;");
|
stmt.execute("ALTER TABLE `" + tablePlayers + "` ADD COLUMN `" + fieldUUID + "` CHAR(36) UNIQUE;");
|
||||||
}
|
}
|
||||||
res.close();
|
res.close();
|
||||||
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Players + "' AND COLUMN_NAME = '" + Field_Name + "' AND COLUMN_KEY='UNI';");
|
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tablePlayers + "' AND COLUMN_NAME = '" + fieldName + "' AND COLUMN_KEY='UNI';");
|
||||||
if(res.next())
|
if(res.next())
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Players + "` DROP INDEX `" + Field_Name + "_UNIQUE`;");
|
stmt.execute("ALTER TABLE `" + tablePlayers + "` DROP INDEX `" + fieldName + "_UNIQUE`;");
|
||||||
}
|
}
|
||||||
res.close();
|
res.close();
|
||||||
if(useUUIDSeparators)
|
if(useUUIDSeparators)
|
||||||
{
|
{
|
||||||
res = stmt.executeQuery("SELECT CHARACTER_MAXIMUM_LENGTH FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Players + "' AND COLUMN_NAME = '" + Field_UUID + "';");
|
res = stmt.executeQuery("SELECT CHARACTER_MAXIMUM_LENGTH FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tablePlayers + "' AND COLUMN_NAME = '" + fieldUUID + "';");
|
||||||
if(res.next() && res.getInt(1) < 36)
|
if(res.next() && res.getInt(1) < 36)
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Players + "` MODIFY `" + Field_UUID + "` CHAR(36) UNIQUE;");
|
stmt.execute("ALTER TABLE `" + tablePlayers + "` MODIFY `" + fieldUUID + "` CHAR(36) UNIQUE;");
|
||||||
}
|
}
|
||||||
res.close();
|
res.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
stmt.execute("CREATE TABLE IF NOT EXISTS `" + Table_Players + "` (`" + Field_PlayerID + "` INT UNSIGNED NOT NULL AUTO_INCREMENT,`" + Field_Name + "` CHAR(16) NOT NULL, PRIMARY KEY (`" + Field_PlayerID + "`));");
|
stmt.execute("CREATE TABLE IF NOT EXISTS `" + tablePlayers + "` (`" + fieldPlayerID + "` INT UNSIGNED NOT NULL AUTO_INCREMENT,`" + fieldName + "` CHAR(16) NOT NULL, PRIMARY KEY (`" + fieldPlayerID + "`));");
|
||||||
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Players + "' AND COLUMN_NAME = '" + Field_Name + "' AND COLUMN_KEY='UNI';");
|
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tablePlayers + "' AND COLUMN_NAME = '" + fieldName + "' AND COLUMN_KEY='UNI';");
|
||||||
if(!res.next())
|
if(!res.next())
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Players + "` ADD UNIQUE INDEX `" + Field_Name + "_UNIQUE` (`" + Field_Name + "` ASC);");
|
stmt.execute("ALTER TABLE `" + tablePlayers + "` ADD UNIQUE INDEX `" + fieldName + "_UNIQUE` (`" + fieldName + "` ASC);");
|
||||||
}
|
}
|
||||||
res.close();
|
res.close();
|
||||||
}
|
}
|
||||||
stmt.execute("CREATE TABLE IF NOT EXISTS `" + Table_Backpacks + "` (`" + Field_BPOwner + "` INT UNSIGNED NOT NULL, `" + Field_BPITS + "` BLOB, `"
|
stmt.execute("CREATE TABLE IF NOT EXISTS `" + tableBackpacks + "` (`" + fieldBpOwner + "` INT UNSIGNED NOT NULL, `" + fieldBpIts + "` BLOB, `"
|
||||||
+ Field_BPVersion + "` INT DEFAULT 0, " + ((maxAge > 0) ? "`" + Field_BPLastUpdate + "` TIMESTAMP DEFAULT CURRENT_TIMESTAMP, " : "") + "PRIMARY KEY (`" + Field_BPOwner + "`));");
|
+ fieldBpVersion + "` INT DEFAULT 0, " + ((maxAge > 0) ? "`" + fieldBpLastUpdate + "` TIMESTAMP DEFAULT CURRENT_TIMESTAMP, " : "") + "PRIMARY KEY (`" + fieldBpOwner + "`));");
|
||||||
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Backpacks + "' AND COLUMN_NAME = '" + Field_BPVersion + "';");
|
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tableBackpacks + "' AND COLUMN_NAME = '" + fieldBpVersion + "';");
|
||||||
if(!res.next())
|
if(!res.next())
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Backpacks + "` ADD COLUMN `" + Field_BPVersion + "` INT DEFAULT 0;");
|
stmt.execute("ALTER TABLE `" + tableBackpacks + "` ADD COLUMN `" + fieldBpVersion + "` INT DEFAULT 0;");
|
||||||
}
|
}
|
||||||
if(maxAge > 0)
|
if(maxAge > 0)
|
||||||
{
|
{
|
||||||
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + Table_Backpacks + "' AND COLUMN_NAME = '" + Field_BPLastUpdate + "';");
|
res = stmt.executeQuery("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '" + tableBackpacks + "' AND COLUMN_NAME = '" + fieldBpLastUpdate + "';");
|
||||||
if(!res.next())
|
if(!res.next())
|
||||||
{
|
{
|
||||||
stmt.execute("ALTER TABLE `" + Table_Backpacks + "` ADD COLUMN `" + Field_BPLastUpdate + "` TIMESTAMP DEFAULT CURRENT_TIMESTAMP;");
|
stmt.execute("ALTER TABLE `" + tableBackpacks + "` ADD COLUMN `" + fieldBpLastUpdate + "` TIMESTAMP DEFAULT CURRENT_TIMESTAMP;");
|
||||||
}
|
}
|
||||||
res.close();
|
res.close();
|
||||||
}
|
}
|
||||||
|
@ -36,10 +36,10 @@ public abstract class SQL extends Database
|
|||||||
{
|
{
|
||||||
private HikariDataSource dataSource;
|
private HikariDataSource dataSource;
|
||||||
|
|
||||||
protected String Table_Players, Table_Backpacks; // Table Names
|
protected String tablePlayers, tableBackpacks; // Table Names
|
||||||
protected String Field_Name, Field_PlayerID, Field_UUID, Field_BPOwner, Field_BPITS, Field_BPVersion, Field_BPLastUpdate; // Table Fields
|
protected String fieldName, fieldPlayerID, fieldUUID, fieldBpOwner, fieldBpIts, fieldBpVersion, fieldBpLastUpdate; // Table Fields
|
||||||
protected String Query_UpdatePlayerAdd, Query_GetPlayerID, Query_InsertBP, Query_UpdateBP, Query_GetBP, Query_DeleteOldBackpacks, Query_GetUnsetOrInvalidUUIDs, Query_FixUUIDs; // DB Querys
|
protected String queryUpdatePlayerAdd, queryGetPlayerID, queryInsertBP, queryUpdateBP, queryGetBP, queryDeleteOldBackpacks, queryGetUnsetOrInvalidUUIDs, queryFixUUIDs; // DB Querys
|
||||||
protected boolean UpdatePlayer;
|
protected boolean updatePlayer;
|
||||||
|
|
||||||
public SQL(MinePacks mp)
|
public SQL(MinePacks mp)
|
||||||
{
|
{
|
||||||
@ -50,7 +50,7 @@ public SQL(MinePacks mp)
|
|||||||
loadSettings();
|
loadSettings();
|
||||||
buildQuerys();
|
buildQuerys();
|
||||||
checkDB();
|
checkDB();
|
||||||
if(useUUIDs && UpdatePlayer)
|
if(useUUIDs && updatePlayer)
|
||||||
{
|
{
|
||||||
checkUUIDs(); // Check if there are user accounts without UUID
|
checkUUIDs(); // Check if there are user accounts without UUID
|
||||||
}
|
}
|
||||||
@ -60,7 +60,10 @@ public SQL(MinePacks mp)
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
getConnection().createStatement().execute(Query_DeleteOldBackpacks);
|
try(Connection connection = getConnection(); Statement statement = connection.createStatement())
|
||||||
|
{
|
||||||
|
statement.execute(queryDeleteOldBackpacks);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch(SQLException e)
|
catch(SQLException e)
|
||||||
{
|
{
|
||||||
@ -74,16 +77,16 @@ public SQL(MinePacks mp)
|
|||||||
protected void loadSettings()
|
protected void loadSettings()
|
||||||
{
|
{
|
||||||
// Load table and field names
|
// Load table and field names
|
||||||
Table_Players = plugin.config.getUserTable();
|
tablePlayers = plugin.config.getUserTable();
|
||||||
Table_Backpacks = plugin.config.getBackpackTable();
|
tableBackpacks = plugin.config.getBackpackTable();
|
||||||
Field_PlayerID = plugin.config.getDBFields("User.Player_ID");
|
fieldPlayerID = plugin.config.getDBFields("User.Player_ID");
|
||||||
Field_Name = plugin.config.getDBFields("User.Name");
|
fieldName = plugin.config.getDBFields("User.Name");
|
||||||
Field_UUID = plugin.config.getDBFields("User.UUID");
|
fieldUUID = plugin.config.getDBFields("User.UUID");
|
||||||
Field_BPOwner = plugin.config.getDBFields("Backpack.Owner_ID");
|
fieldBpOwner = plugin.config.getDBFields("Backpack.Owner_ID");
|
||||||
Field_BPITS = plugin.config.getDBFields("Backpack.ItemStacks");
|
fieldBpIts = plugin.config.getDBFields("Backpack.ItemStacks");
|
||||||
Field_BPVersion = plugin.config.getDBFields("Backpack.Version");
|
fieldBpVersion = plugin.config.getDBFields("Backpack.Version");
|
||||||
Field_BPLastUpdate = plugin.config.getDBFields("Backpack.LastUpdate");
|
fieldBpLastUpdate = plugin.config.getDBFields("Backpack.LastUpdate");
|
||||||
UpdatePlayer = plugin.config.getUpdatePlayer();
|
updatePlayer = plugin.config.getUpdatePlayer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -97,12 +100,11 @@ protected void checkUUIDs()
|
|||||||
class UpdateData // Helper class for fixing UUIDs
|
class UpdateData // Helper class for fixing UUIDs
|
||||||
{
|
{
|
||||||
int id;
|
int id;
|
||||||
String name, uuid;
|
String uuid;
|
||||||
|
|
||||||
public UpdateData(String name, String uuid, int id)
|
public UpdateData(String uuid, int id)
|
||||||
{
|
{
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.name = name;
|
|
||||||
this.uuid = uuid;
|
this.uuid = uuid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -110,23 +112,23 @@ public UpdateData(String name, String uuid, int id)
|
|||||||
{
|
{
|
||||||
Map<String, UpdateData> toConvert = new HashMap<>();
|
Map<String, UpdateData> toConvert = new HashMap<>();
|
||||||
List<UpdateData> toUpdate = new LinkedList<>();
|
List<UpdateData> toUpdate = new LinkedList<>();
|
||||||
try(Statement stmt = connection.createStatement(); ResultSet res = stmt.executeQuery(Query_GetUnsetOrInvalidUUIDs))
|
try(Statement stmt = connection.createStatement(); ResultSet res = stmt.executeQuery(queryGetUnsetOrInvalidUUIDs))
|
||||||
{
|
{
|
||||||
while(res.next())
|
while(res.next())
|
||||||
{
|
{
|
||||||
if(res.isFirst())
|
if(res.isFirst())
|
||||||
{
|
{
|
||||||
plugin.log.info(plugin.lang.get("Console.UpdateUUIDs"));
|
plugin.log.info(START_UUID_UPDATE);
|
||||||
}
|
}
|
||||||
String uuid = res.getString(Field_UUID);
|
String uuid = res.getString(fieldUUID);
|
||||||
if(uuid == null)
|
if(uuid == null)
|
||||||
{
|
{
|
||||||
toConvert.put(res.getString(Field_Name).toLowerCase(), new UpdateData(res.getString(Field_Name), null, res.getInt(Field_PlayerID)));
|
toConvert.put(res.getString(fieldName).toLowerCase(), new UpdateData(null, res.getInt(fieldPlayerID)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
uuid = (useUUIDSeparators) ? uuid.replaceAll("(\\w{8})(\\w{4})(\\w{4})(\\w{4})(\\w{12})", "$1-$2-$3-$4-$5") : uuid.replaceAll("-", "");
|
uuid = (useUUIDSeparators) ? uuid.replaceAll("(\\w{8})(\\w{4})(\\w{4})(\\w{4})(\\w{12})", "$1-$2-$3-$4-$5") : uuid.replaceAll("-", "");
|
||||||
toUpdate.add(new UpdateData(res.getString(Field_Name), uuid, res.getInt(Field_PlayerID)));
|
toUpdate.add(new UpdateData(uuid, res.getInt(fieldPlayerID)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -142,7 +144,7 @@ public UpdateData(String name, String uuid, int id)
|
|||||||
toUpdate.add(updateData);
|
toUpdate.add(updateData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
try(PreparedStatement ps = connection.prepareStatement(Query_FixUUIDs))
|
try(PreparedStatement ps = connection.prepareStatement(queryFixUUIDs))
|
||||||
{
|
{
|
||||||
for(UpdateData updateData : toUpdate)
|
for(UpdateData updateData : toUpdate)
|
||||||
{
|
{
|
||||||
@ -152,7 +154,7 @@ public UpdateData(String name, String uuid, int id)
|
|||||||
ps.executeBatch();
|
ps.executeBatch();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
plugin.log.info(String.format(plugin.lang.get("Console.UpdatedUUIDs"), toUpdate.size()));
|
plugin.log.info(String.format(UUIDS_UPDATED, toUpdate.size()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(SQLException e)
|
catch(SQLException e)
|
||||||
@ -171,48 +173,48 @@ protected Connection getConnection() throws SQLException
|
|||||||
protected final void buildQuerys()
|
protected final void buildQuerys()
|
||||||
{
|
{
|
||||||
// Build the SQL querys with placeholders for the table and field names
|
// Build the SQL querys with placeholders for the table and field names
|
||||||
Query_GetBP = "SELECT `{FieldBPOwner}`,`{FieldBPITS}`,`{FieldBPVersion}` FROM `{TableBackpacks}` INNER JOIN `{TablePlayers}` ON `{TableBackpacks}`.`{FieldBPOwner}`=`{TablePlayers}`.`{FieldPlayerID}` WHERE ";
|
queryGetBP = "SELECT `{FieldBPOwner}`,`{FieldBPITS}`,`{FieldBPVersion}` FROM `{TableBackpacks}` INNER JOIN `{TablePlayers}` ON `{TableBackpacks}`.`{FieldBPOwner}`=`{TablePlayers}`.`{FieldPlayerID}` WHERE ";
|
||||||
if(useUUIDs)
|
if(useUUIDs)
|
||||||
{
|
{
|
||||||
Query_UpdatePlayerAdd = "INSERT INTO `{TablePlayers}` (`{FieldName}`,`{FieldUUID}`) VALUES (?,?) ON DUPLICATE KEY UPDATE `{FieldName}`=?;";
|
queryUpdatePlayerAdd = "INSERT INTO `{TablePlayers}` (`{FieldName}`,`{FieldUUID}`) VALUES (?,?) ON DUPLICATE KEY UPDATE `{FieldName}`=?;";
|
||||||
Query_GetPlayerID = "SELECT `{FieldPlayerID}` FROM `{TablePlayers}` WHERE `{FieldUUID}`=?;";
|
queryGetPlayerID = "SELECT `{FieldPlayerID}` FROM `{TablePlayers}` WHERE `{FieldUUID}`=?;";
|
||||||
Query_GetBP += "`{FieldUUID}`=?;";
|
queryGetBP += "`{FieldUUID}`=?;";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Query_UpdatePlayerAdd = "INSERT IGNORE INTO `{TablePlayers}` (`{FieldName}`) VALUES (?);";
|
queryUpdatePlayerAdd = "INSERT IGNORE INTO `{TablePlayers}` (`{FieldName}`) VALUES (?);";
|
||||||
Query_GetPlayerID = "SELECT `{FieldPlayerID}` FROM `{TablePlayers}` WHERE `{FieldName}`=?;";
|
queryGetPlayerID = "SELECT `{FieldPlayerID}` FROM `{TablePlayers}` WHERE `{FieldName}`=?;";
|
||||||
Query_GetBP += "`{FieldName}`=?;";
|
queryGetBP += "`{FieldName}`=?;";
|
||||||
}
|
}
|
||||||
Query_InsertBP = "INSERT INTO `{TableBackpacks}` (`{FieldBPOwner}`,`{FieldBPITS}`,`{FieldBPVersion}`) VALUES (?,?,?);";
|
queryInsertBP = "INSERT INTO `{TableBackpacks}` (`{FieldBPOwner}`,`{FieldBPITS}`,`{FieldBPVersion}`) VALUES (?,?,?);";
|
||||||
Query_UpdateBP = "UPDATE `{TableBackpacks}` SET `{FieldBPITS}`=?,`{FieldBPVersion}`=?";
|
queryUpdateBP = "UPDATE `{TableBackpacks}` SET `{FieldBPITS}`=?,`{FieldBPVersion}`=?";
|
||||||
if(maxAge > 0)
|
if(maxAge > 0)
|
||||||
{
|
{
|
||||||
Query_UpdateBP += ",`{FieldBPLastUpdate}`={NOW}";
|
queryUpdateBP += ",`{FieldBPLastUpdate}`={NOW}";
|
||||||
}
|
}
|
||||||
Query_UpdateBP += " WHERE `{FieldBPOwner}`=?;";
|
queryUpdateBP += " WHERE `{FieldBPOwner}`=?;";
|
||||||
Query_DeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` < DATE('now', '-{VarMaxAge} days')";
|
queryDeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` < DATE('now', '-{VarMaxAge} days')";
|
||||||
if(useUUIDSeparators)
|
if(useUUIDSeparators)
|
||||||
{
|
{
|
||||||
Query_GetUnsetOrInvalidUUIDs = "SELECT `{FieldPlayerID}`,`{FieldName}`,`{FieldUUID}` FROM `{TablePlayers}` WHERE `{FieldUUID}` IS NULL OR `{FieldUUID}` NOT LIKE '%-%-%-%-%';";
|
queryGetUnsetOrInvalidUUIDs = "SELECT `{FieldPlayerID}`,`{FieldName}`,`{FieldUUID}` FROM `{TablePlayers}` WHERE `{FieldUUID}` IS NULL OR `{FieldUUID}` NOT LIKE '%-%-%-%-%';";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Query_GetUnsetOrInvalidUUIDs = "SELECT `{FieldPlayerID}`,`{FieldName}`,`{FieldUUID}` FROM `{TablePlayers}` WHERE `{FieldUUID}` IS NULL OR `{FieldUUID}` LIKE '%-%';";
|
queryGetUnsetOrInvalidUUIDs = "SELECT `{FieldPlayerID}`,`{FieldName}`,`{FieldUUID}` FROM `{TablePlayers}` WHERE `{FieldUUID}` IS NULL OR `{FieldUUID}` LIKE '%-%';";
|
||||||
}
|
}
|
||||||
Query_FixUUIDs = "UPDATE `{TablePlayers}` SET `{FieldUUID}`=? WHERE `{FieldPlayerID}`=?;";
|
queryFixUUIDs = "UPDATE `{TablePlayers}` SET `{FieldUUID}`=? WHERE `{FieldPlayerID}`=?;";
|
||||||
|
|
||||||
updateQuerysForDialect();
|
updateQuerysForDialect();
|
||||||
|
|
||||||
// Replace the table and filed names with the names from the config
|
// Replace the table and filed names with the names from the config
|
||||||
Query_UpdatePlayerAdd = Query_UpdatePlayerAdd.replaceAll("\\{TablePlayers\\}", Table_Players).replaceAll("\\{FieldName\\}", Field_Name).replaceAll("\\{FieldUUID\\}", Field_UUID).replaceAll("\\{FieldPlayerID\\}", Field_PlayerID);
|
queryUpdatePlayerAdd = queryUpdatePlayerAdd.replaceAll("\\{TablePlayers\\}", tablePlayers).replaceAll("\\{FieldName\\}", fieldName).replaceAll("\\{FieldUUID\\}", fieldUUID).replaceAll("\\{FieldPlayerID\\}", fieldPlayerID);
|
||||||
Query_GetPlayerID = Query_GetPlayerID.replaceAll("\\{TablePlayers\\}", Table_Players).replaceAll("\\{FieldName\\}", Field_Name).replaceAll("\\{FieldUUID\\}", Field_UUID).replaceAll("\\{FieldPlayerID\\}", Field_PlayerID);
|
queryGetPlayerID = queryGetPlayerID.replaceAll("\\{TablePlayers\\}", tablePlayers).replaceAll("\\{FieldName\\}", fieldName).replaceAll("\\{FieldUUID\\}", fieldUUID).replaceAll("\\{FieldPlayerID\\}", fieldPlayerID);
|
||||||
Query_GetBP = Query_GetBP.replaceAll("\\{FieldBPOwner\\}", Field_BPOwner).replaceAll("\\{FieldBPITS\\}", Field_BPITS).replaceAll("\\{FieldBPVersion\\}", Field_BPVersion).replaceAll("\\{TableBackpacks\\}", Table_Backpacks).replaceAll("\\{TablePlayers\\}", Table_Players).replaceAll("\\{FieldPlayerID\\}", Field_PlayerID).replaceAll("\\{FieldName\\}", Field_Name).replaceAll("\\{FieldUUID\\}", Field_UUID);
|
queryGetBP = queryGetBP.replaceAll("\\{FieldBPOwner\\}", fieldBpOwner).replaceAll("\\{FieldBPITS\\}", fieldBpIts).replaceAll("\\{FieldBPVersion\\}", fieldBpVersion).replaceAll("\\{TableBackpacks\\}", tableBackpacks).replaceAll("\\{TablePlayers\\}", tablePlayers).replaceAll("\\{FieldPlayerID\\}", fieldPlayerID).replaceAll("\\{FieldName\\}", fieldName).replaceAll("\\{FieldUUID\\}", fieldUUID);
|
||||||
Query_InsertBP = Query_InsertBP.replaceAll("\\{TableBackpacks\\}", Table_Backpacks).replaceAll("\\{FieldBPOwner\\}", Field_BPOwner).replaceAll("\\{FieldBPITS\\}", Field_BPITS).replaceAll("\\{FieldBPVersion\\}", Field_BPVersion).replaceAll("\\{FieldBPLastUpdate\\}", Field_BPLastUpdate);
|
queryInsertBP = queryInsertBP.replaceAll("\\{TableBackpacks\\}", tableBackpacks).replaceAll("\\{FieldBPOwner\\}", fieldBpOwner).replaceAll("\\{FieldBPITS\\}", fieldBpIts).replaceAll("\\{FieldBPVersion\\}", fieldBpVersion).replaceAll("\\{FieldBPLastUpdate\\}", fieldBpLastUpdate);
|
||||||
Query_UpdateBP = Query_UpdateBP.replaceAll("\\{TableBackpacks\\}", Table_Backpacks).replaceAll("\\{FieldBPOwner\\}", Field_BPOwner).replaceAll("\\{FieldBPITS\\}", Field_BPITS).replaceAll("\\{FieldBPVersion\\}", Field_BPVersion).replaceAll("\\{FieldBPLastUpdate\\}", Field_BPLastUpdate);
|
queryUpdateBP = queryUpdateBP.replaceAll("\\{TableBackpacks\\}", tableBackpacks).replaceAll("\\{FieldBPOwner\\}", fieldBpOwner).replaceAll("\\{FieldBPITS\\}", fieldBpIts).replaceAll("\\{FieldBPVersion\\}", fieldBpVersion).replaceAll("\\{FieldBPLastUpdate\\}", fieldBpLastUpdate);
|
||||||
Query_DeleteOldBackpacks = Query_DeleteOldBackpacks.replaceAll("\\{TableBackpacks\\}", Table_Backpacks).replaceAll("\\{FieldBPLastUpdate\\}", Field_BPLastUpdate).replaceAll("\\{VarMaxAge\\}", maxAge + "");
|
queryDeleteOldBackpacks = queryDeleteOldBackpacks.replaceAll("\\{TableBackpacks\\}", tableBackpacks).replaceAll("\\{FieldBPLastUpdate\\}", fieldBpLastUpdate).replaceAll("\\{VarMaxAge\\}", maxAge + "");
|
||||||
Query_GetUnsetOrInvalidUUIDs = Query_GetUnsetOrInvalidUUIDs.replaceAll("\\{TablePlayers\\}", Table_Players).replaceAll("\\{FieldName\\}", Field_Name).replaceAll("\\{FieldUUID\\}", Field_UUID).replaceAll("\\{FieldPlayerID\\}", Field_PlayerID);
|
queryGetUnsetOrInvalidUUIDs = queryGetUnsetOrInvalidUUIDs.replaceAll("\\{TablePlayers\\}", tablePlayers).replaceAll("\\{FieldName\\}", fieldName).replaceAll("\\{FieldUUID\\}", fieldUUID).replaceAll("\\{FieldPlayerID\\}", fieldPlayerID);
|
||||||
Query_FixUUIDs = Query_FixUUIDs.replaceAll("\\{TablePlayers\\}", Table_Players).replaceAll("\\{FieldUUID\\}", Field_UUID).replaceAll("\\{FieldPlayerID\\}", Field_PlayerID);
|
queryFixUUIDs = queryFixUUIDs.replaceAll("\\{TablePlayers\\}", tablePlayers).replaceAll("\\{FieldUUID\\}", fieldUUID).replaceAll("\\{FieldPlayerID\\}", fieldPlayerID);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract void updateQuerysForDialect();
|
protected abstract void updateQuerysForDialect();
|
||||||
@ -252,11 +254,11 @@ public void updatePlayer(final Player player)
|
|||||||
{
|
{
|
||||||
if(useUUIDs)
|
if(useUUIDs)
|
||||||
{
|
{
|
||||||
runStatementAsync(Query_UpdatePlayerAdd, player.getName(), getPlayerFormattedUUID(player), player.getName());
|
runStatementAsync(queryUpdatePlayerAdd, player.getName(), getPlayerFormattedUUID(player), player.getName());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
runStatementAsync(Query_UpdatePlayerAdd, player.getName());
|
runStatementAsync(queryUpdatePlayerAdd, player.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,7 +279,7 @@ public void run()
|
|||||||
if(id <= 0)
|
if(id <= 0)
|
||||||
{
|
{
|
||||||
final int newID;
|
final int newID;
|
||||||
try(PreparedStatement ps = connection.prepareStatement(Query_GetPlayerID))
|
try(PreparedStatement ps = connection.prepareStatement(queryGetPlayerID))
|
||||||
{
|
{
|
||||||
ps.setString(1, nameOrUUID);
|
ps.setString(1, nameOrUUID);
|
||||||
try(ResultSet rs = ps.executeQuery())
|
try(ResultSet rs = ps.executeQuery())
|
||||||
@ -305,7 +307,7 @@ public void run()
|
|||||||
plugin.log.warning("Failed saving backpack for: " + name + " (Unable to get players ID from database)");
|
plugin.log.warning("Failed saving backpack for: " + name + " (Unable to get players ID from database)");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try(PreparedStatement ps = connection.prepareStatement(Query_InsertBP))
|
try(PreparedStatement ps = connection.prepareStatement(queryInsertBP))
|
||||||
{
|
{
|
||||||
ps.setInt(1, newID);
|
ps.setInt(1, newID);
|
||||||
ps.setBytes(2, data);
|
ps.setBytes(2, data);
|
||||||
@ -315,7 +317,7 @@ public void run()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
try(PreparedStatement ps = connection.prepareStatement(Query_UpdateBP))
|
try(PreparedStatement ps = connection.prepareStatement(queryUpdateBP))
|
||||||
{
|
{
|
||||||
ps.setBytes(1, data);
|
ps.setBytes(1, data);
|
||||||
ps.setInt(2, usedSerializer);
|
ps.setInt(2, usedSerializer);
|
||||||
@ -324,7 +326,7 @@ public void run()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(SQLException e)
|
||||||
{
|
{
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -340,7 +342,7 @@ protected void loadBackpack(final OfflinePlayer player, final Callback<Backpack>
|
|||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
try(Connection conn = getConnection(); PreparedStatement ps = conn.prepareStatement(Query_GetBP))
|
try(Connection conn = getConnection(); PreparedStatement ps = conn.prepareStatement(queryGetBP))
|
||||||
{
|
{
|
||||||
ps.setString(1, getPlayerNameOrUUID(player));
|
ps.setString(1, getPlayerNameOrUUID(player));
|
||||||
final int bpID, version;
|
final int bpID, version;
|
||||||
@ -377,7 +379,7 @@ public void run()
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(SQLException e)
|
||||||
{
|
{
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
callback.onFail();
|
callback.onFail();
|
||||||
@ -389,7 +391,7 @@ public void run()
|
|||||||
@Override
|
@Override
|
||||||
public Backpack loadBackpack(OfflinePlayer player) // The sync function shouldn't be called at all
|
public Backpack loadBackpack(OfflinePlayer player) // The sync function shouldn't be called at all
|
||||||
{
|
{
|
||||||
try(Connection connection = getConnection(); PreparedStatement ps = connection.prepareStatement(Query_GetBP))
|
try(Connection connection = getConnection(); PreparedStatement ps = connection.prepareStatement(queryGetBP))
|
||||||
{
|
{
|
||||||
ps.setString(1, getPlayerNameOrUUID(player));
|
ps.setString(1, getPlayerNameOrUUID(player));
|
||||||
try(ResultSet rs = ps.executeQuery())
|
try(ResultSet rs = ps.executeQuery())
|
||||||
|
@ -41,20 +41,20 @@ public SQLite(MinePacks mp)
|
|||||||
protected void loadSettings()
|
protected void loadSettings()
|
||||||
{
|
{
|
||||||
// Set table and field names to fixed values to prevent users from destroying old databases.
|
// Set table and field names to fixed values to prevent users from destroying old databases.
|
||||||
Field_PlayerID = "player_id";
|
fieldPlayerID = "player_id";
|
||||||
Field_Name = "name";
|
fieldName = "name";
|
||||||
Field_UUID = "uuid";
|
fieldUUID = "uuid";
|
||||||
Field_BPOwner = "owner";
|
fieldBpOwner = "owner";
|
||||||
//noinspection SpellCheckingInspection
|
//noinspection SpellCheckingInspection
|
||||||
Field_BPITS = "itemstacks";
|
fieldBpIts = "itemstacks";
|
||||||
Field_BPVersion = "version";
|
fieldBpVersion = "version";
|
||||||
//noinspection SpellCheckingInspection
|
//noinspection SpellCheckingInspection
|
||||||
Field_BPLastUpdate = "lastupdate";
|
fieldBpLastUpdate = "lastupdate";
|
||||||
Table_Players = "backpack_players";
|
tablePlayers = "backpack_players";
|
||||||
Table_Backpacks = "backpacks";
|
tableBackpacks = "backpacks";
|
||||||
// Set fixed settings
|
// Set fixed settings
|
||||||
useUUIDSeparators = false;
|
useUUIDSeparators = false;
|
||||||
UpdatePlayer = true;
|
updatePlayer = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -80,17 +80,17 @@ protected void updateQuerysForDialect()
|
|||||||
{
|
{
|
||||||
if(maxAge > 0)
|
if(maxAge > 0)
|
||||||
{
|
{
|
||||||
Query_InsertBP = Query_InsertBP.replaceAll("\\) VALUES \\(\\?,\\?,\\?", "{FieldBPLastUpdate}) VALUES (?,?,?,DATE('now')");
|
queryInsertBP = queryInsertBP.replaceAll("\\) VALUES \\(\\?,\\?,\\?", "{FieldBPLastUpdate}) VALUES (?,?,?,DATE('now')");
|
||||||
}
|
}
|
||||||
Query_DeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` < DATE('now', '-{VarMaxAge} days')";
|
queryDeleteOldBackpacks = "DELETE FROM `{TableBackpacks}` WHERE `{FieldBPLastUpdate}` < DATE('now', '-{VarMaxAge} days')";
|
||||||
Query_UpdateBP = Query_UpdateBP.replaceAll("\\{NOW\\}", "DATE('now')");
|
queryUpdateBP = queryUpdateBP.replaceAll("\\{NOW\\}", "DATE('now')");
|
||||||
if(useUUIDs)
|
if(useUUIDs)
|
||||||
{
|
{
|
||||||
Query_UpdatePlayerAdd = "INSERT OR IGNORE INTO `{TablePlayers}` (`{FieldName}`,`{FieldUUID}`) VALUES (?,?);";
|
queryUpdatePlayerAdd = "INSERT OR IGNORE INTO `{TablePlayers}` (`{FieldName}`,`{FieldUUID}`) VALUES (?,?);";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Query_UpdatePlayerAdd = Query_UpdatePlayerAdd.replaceAll("INSERT IGNORE INTO", "INSERT OR IGNORE INTO");
|
queryUpdatePlayerAdd = queryUpdatePlayerAdd.replaceAll("INSERT IGNORE INTO", "INSERT OR IGNORE INTO");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -142,14 +142,14 @@ public void updatePlayer(final Player player)
|
|||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
runStatement(Query_UpdatePlayerAdd, player.getName(), getPlayerFormattedUUID(player));
|
runStatement(queryUpdatePlayerAdd, player.getName(), getPlayerFormattedUUID(player));
|
||||||
runStatement("UPDATE `" + Table_Players + "` SET `" + Field_Name + "`=? WHERE `" + Field_UUID + "`=?;", player.getName(), getPlayerFormattedUUID(player));
|
runStatement("UPDATE `" + tablePlayers + "` SET `" + fieldName + "`=? WHERE `" + fieldUUID + "`=?;", player.getName(), getPlayerFormattedUUID(player));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
runStatementAsync(Query_UpdatePlayerAdd, player.getName());
|
runStatementAsync(queryUpdatePlayerAdd, player.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-2015 GeorgH93
|
* Copyright (C) 2014-2016 GeorgH93
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -34,16 +34,16 @@ public class EventListener implements Listener
|
|||||||
private MinePacks plugin;
|
private MinePacks plugin;
|
||||||
private boolean drop_on_death, showCloseMessageOwn, showCloseMessageOther;
|
private boolean drop_on_death, showCloseMessageOwn, showCloseMessageOther;
|
||||||
|
|
||||||
private String message_OwnBPClose, message_PlayerBPClose;
|
private String messageOwnBPClose, messagePlayerBPClose;
|
||||||
|
|
||||||
public EventListener(MinePacks mp)
|
public EventListener(MinePacks mp)
|
||||||
{
|
{
|
||||||
plugin = mp;
|
plugin = mp;
|
||||||
drop_on_death = plugin.config.getDropOnDeath();
|
drop_on_death = plugin.config.getDropOnDeath();
|
||||||
message_OwnBPClose = plugin.lang.getTranslated("Ingame.OwnBackPackClose");
|
messageOwnBPClose = plugin.lang.getTranslated("Ingame.OwnBackPackClose");
|
||||||
message_PlayerBPClose = plugin.lang.getTranslated("Ingame.PlayerBackPackClose");
|
messagePlayerBPClose = plugin.lang.getTranslated("Ingame.PlayerBackPackClose");
|
||||||
showCloseMessageOther = message_PlayerBPClose != null && plugin.config.getShowCloseMessage();
|
showCloseMessageOther = messagePlayerBPClose != null && plugin.config.getShowCloseMessage();
|
||||||
showCloseMessageOwn = message_OwnBPClose != null && plugin.config.getShowCloseMessage();
|
showCloseMessageOwn = messageOwnBPClose != null && plugin.config.getShowCloseMessage();
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
@ -97,14 +97,14 @@ public void onClose(InventoryCloseEvent event)
|
|||||||
{
|
{
|
||||||
if(showCloseMessageOwn)
|
if(showCloseMessageOwn)
|
||||||
{
|
{
|
||||||
closer.sendMessage(message_OwnBPClose);
|
closer.sendMessage(messageOwnBPClose);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(showCloseMessageOther)
|
if(showCloseMessageOther)
|
||||||
{
|
{
|
||||||
closer.sendMessage(String.format(message_PlayerBPClose, backpack.getOwner().getName()));
|
closer.sendMessage(String.format(messagePlayerBPClose, backpack.getOwner().getName()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-2015 GeorgH93
|
* Copyright (C) 2014-2016 GeorgH93
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -29,13 +29,13 @@
|
|||||||
|
|
||||||
public class ItemsCollector extends BukkitRunnable
|
public class ItemsCollector extends BukkitRunnable
|
||||||
{
|
{
|
||||||
private double radius = 1.5;
|
private final MinePacks plugin;
|
||||||
private MinePacks plugin;
|
private final double radius;
|
||||||
|
|
||||||
public ItemsCollector(MinePacks mp)
|
public ItemsCollector(MinePacks plugin)
|
||||||
{
|
{
|
||||||
plugin = mp;
|
this.plugin = plugin;
|
||||||
radius = plugin.config.getFullInvRadius();
|
radius = this.plugin.config.getFullInvRadius();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -17,13 +17,14 @@
|
|||||||
|
|
||||||
package at.pcgamingfreaks.MinePacks;
|
package at.pcgamingfreaks.MinePacks;
|
||||||
|
|
||||||
|
import at.pcgamingfreaks.Bukkit.MCVersion;
|
||||||
|
import at.pcgamingfreaks.Bukkit.Updater;
|
||||||
import at.pcgamingfreaks.Bukkit.Utils;
|
import at.pcgamingfreaks.Bukkit.Utils;
|
||||||
import at.pcgamingfreaks.ConsoleColor;
|
import at.pcgamingfreaks.ConsoleColor;
|
||||||
import at.pcgamingfreaks.MinePacks.Database.Config;
|
import at.pcgamingfreaks.MinePacks.Database.Config;
|
||||||
import at.pcgamingfreaks.MinePacks.Database.Database;
|
import at.pcgamingfreaks.MinePacks.Database.Database;
|
||||||
import at.pcgamingfreaks.MinePacks.Database.Language;
|
import at.pcgamingfreaks.MinePacks.Database.Language;
|
||||||
import at.pcgamingfreaks.MinePacks.Updater.UpdateResult;
|
import at.pcgamingfreaks.StringUtils;
|
||||||
import at.pcgamingfreaks.MinePacks.Updater.Updater;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
@ -45,10 +46,10 @@ public class MinePacks extends JavaPlugin
|
|||||||
|
|
||||||
public HashMap<Player, Long> cooldowns = new HashMap<>();
|
public HashMap<Player, Long> cooldowns = new HashMap<>();
|
||||||
|
|
||||||
public static String backpackTitleOther, backpackTitle;
|
public String backpackTitleOther, backpackTitle;
|
||||||
public String messageInvalidBackpack;
|
public String messageInvalidBackpack;
|
||||||
|
|
||||||
private static int maxSize;
|
private int maxSize;
|
||||||
|
|
||||||
public static MinePacks getInstance()
|
public static MinePacks getInstance()
|
||||||
{
|
{
|
||||||
@ -62,11 +63,11 @@ public void onEnable()
|
|||||||
Utils.warnOnJava_1_7(log);
|
Utils.warnOnJava_1_7(log);
|
||||||
instance = this;
|
instance = this;
|
||||||
//region Check compatibility with used minecraft version
|
//region Check compatibility with used minecraft version
|
||||||
String name = Bukkit.getServer().getClass().getPackage().getName();
|
if(MCVersion.is(MCVersion.UNKNOWN) || MCVersion.isNewerThan(MCVersion.MC_NMS_1_10_R1))
|
||||||
String[] version = name.substring(name.lastIndexOf('.') + 2).split("_");
|
|
||||||
if((version[0].equals("1") && Integer.valueOf(version[1]) > 10) || Integer.valueOf(version[0]) > 1)
|
|
||||||
{
|
{
|
||||||
MinePacks.getInstance().warnOnVersionIncompatibility(version[0] + "." + version[1]);
|
String name = Bukkit.getServer().getClass().getPackage().getName();
|
||||||
|
String[] version = name.substring(name.lastIndexOf('.') + 2).split("_");
|
||||||
|
this.warnOnVersionIncompatibility(version[0] + "." + version[1]);
|
||||||
this.setEnabled(false);
|
this.setEnabled(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -85,7 +86,7 @@ public void onEnable()
|
|||||||
|
|
||||||
maxSize = config.getBackpackMaxSize();
|
maxSize = config.getBackpackMaxSize();
|
||||||
backpackTitleOther = config.getBPTitleOther();
|
backpackTitleOther = config.getBPTitleOther();
|
||||||
backpackTitle = Utils.limitLength(config.getBPTitle(), 32);
|
backpackTitle = StringUtils.limitLength(config.getBPTitle(), 32);
|
||||||
messageInvalidBackpack = lang.getTranslated("Ingame.InvalidBackpack");
|
messageInvalidBackpack = lang.getTranslated("Ingame.InvalidBackpack");
|
||||||
getServer().getServicesManager().register(MinePacks.class, this, this, ServicePriority.Normal);
|
getServer().getServicesManager().register(MinePacks.class, this, this, ServicePriority.Normal);
|
||||||
|
|
||||||
@ -93,19 +94,10 @@ public void onEnable()
|
|||||||
{
|
{
|
||||||
log.info("Checking for updates ...");
|
log.info("Checking for updates ...");
|
||||||
Updater updater = new Updater(this, this.getFile(), true, 83445); // Create a new updater with dev.bukkit.org as update provider
|
Updater updater = new Updater(this, this.getFile(), true, 83445); // Create a new updater with dev.bukkit.org as update provider
|
||||||
updater.update(new at.pcgamingfreaks.MinePacks.Updater.Updater.UpdaterResponse() {
|
updater.update(); // Starts the update
|
||||||
@Override
|
|
||||||
public void onDone(UpdateResult updateResult)
|
|
||||||
{
|
|
||||||
if(updateResult == UpdateResult.UPDATE_AVAILABLE_V2)
|
|
||||||
{
|
|
||||||
new MinepacksV2IsOut(MinePacks.this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}); // Starts the update, if there is a new update available it will download while we close the rest
|
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info(lang.get("Console.Enabled"));
|
log.info(lang.get(ConsoleColor.GREEN + "MinePacks has been enabled! " + ConsoleColor.YELLOW + ":)"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -122,13 +114,13 @@ public void onDisable()
|
|||||||
DB.close(); // Close the DB connection, we won't need them any longer
|
DB.close(); // Close the DB connection, we won't need them any longer
|
||||||
if(updater != null) updater.waitForAsyncOperation(); // The update can download while we kill the listeners and close the DB connections
|
if(updater != null) updater.waitForAsyncOperation(); // The update can download while we kill the listeners and close the DB connections
|
||||||
instance = null;
|
instance = null;
|
||||||
log.info(lang.get("Console.Disabled"));
|
log.info(lang.get(ConsoleColor.RED + "MinePacks has been disabled. " + ConsoleColor.YELLOW + ":)"));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void warnOnVersionIncompatibility(String version)
|
public void warnOnVersionIncompatibility(String version)
|
||||||
{
|
{
|
||||||
log.warning(ConsoleColor.RED + "################################" + ConsoleColor.RESET);
|
log.warning(ConsoleColor.RED + "################################" + ConsoleColor.RESET);
|
||||||
log.warning(ConsoleColor.RED + String.format(lang.getTranslated("Console.MinecraftVersionNotCompatible"), version, getDescription().getVersion()) + ConsoleColor.RESET);
|
log.warning(ConsoleColor.RED + String.format("Your minecraft version (MC %1$s) is currently not compatible with this plugins version (%2$s). Please check for updates!", version, getDescription().getVersion()) + ConsoleColor.RESET);
|
||||||
log.warning(ConsoleColor.RED + "################################" + ConsoleColor.RESET);
|
log.warning(ConsoleColor.RED + "################################" + ConsoleColor.RESET);
|
||||||
Utils.blockThread(5);
|
Utils.blockThread(5);
|
||||||
}
|
}
|
||||||
@ -162,7 +154,7 @@ public void openBackpack(Player opener, Backpack backpack, boolean editable)
|
|||||||
backpack.open(opener, editable);
|
backpack.open(opener, editable);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int getBackpackPermSize(Player player)
|
public int getBackpackPermSize(Player player)
|
||||||
{
|
{
|
||||||
for(int i = maxSize; i > 1; i--)
|
for(int i = maxSize; i > 1; i--)
|
||||||
{
|
{
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 GeorgH93
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package at.pcgamingfreaks.MinePacks;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
|
||||||
|
|
||||||
public class MinepacksV2IsOut implements Listener
|
|
||||||
{
|
|
||||||
public static MinepacksV2IsOut instance = null;
|
|
||||||
private MinePacks plugin;
|
|
||||||
|
|
||||||
public MinepacksV2IsOut(MinePacks plugin)
|
|
||||||
{
|
|
||||||
if(plugin.config.isV2InfoDisabled()) return;
|
|
||||||
instance = this;
|
|
||||||
this.plugin = plugin;
|
|
||||||
plugin.getServer().getPluginManager().registerEvents(this, plugin);
|
|
||||||
Bukkit.getConsoleSender().sendMessage(ChatColor.GRAY + "#####################################");
|
|
||||||
Bukkit.getConsoleSender().sendMessage(ChatColor.GOLD + "Minepacks V2 has been released! " + ChatColor.YELLOW + ":)");
|
|
||||||
Bukkit.getConsoleSender().sendMessage("Please download it form here:" + ChatColor.AQUA + " https://www.spigotmc.org/resources/19286/");
|
|
||||||
Bukkit.getConsoleSender().sendMessage(ChatColor.GRAY + "#####################################");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void announce(Player player)
|
|
||||||
{
|
|
||||||
if(player != null && player.isOnline())
|
|
||||||
{
|
|
||||||
player.sendMessage(ChatColor.GRAY + "#####################################");
|
|
||||||
player.sendMessage(ChatColor.GOLD + "Minepacks V2 has been released! " + ChatColor.YELLOW + ":)");
|
|
||||||
player.sendMessage("Please download it form here:" + ChatColor.AQUA + " https://www.spigotmc.org/resources/19286/");
|
|
||||||
player.sendMessage(ChatColor.GRAY + "#####################################");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onJoin(PlayerJoinEvent event)
|
|
||||||
{
|
|
||||||
final Player player = event.getPlayer();
|
|
||||||
if(player.isOp())
|
|
||||||
{
|
|
||||||
plugin.getServer().getScheduler().runTaskLater(plugin, new Runnable()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
announce(player);
|
|
||||||
}
|
|
||||||
}, 100L);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-2015 GeorgH93
|
* Copyright (C) 2014-2016 GeorgH93
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -39,10 +39,10 @@ public class OnCommand implements CommandExecutor
|
|||||||
public OnCommand(MinePacks mp)
|
public OnCommand(MinePacks mp)
|
||||||
{
|
{
|
||||||
plugin = mp;
|
plugin = mp;
|
||||||
Message_NotFromConsole = plugin.lang.getTranslated("Console.NotFromConsole");
|
Message_NotFromConsole = plugin.lang.getTranslated("NotFromConsole");
|
||||||
Message_NoPermission = ChatColor.RED + plugin.lang.getTranslated("Ingame.NoPermission");
|
Message_NoPermission = plugin.lang.getTranslated("Ingame.NoPermission");
|
||||||
Message_BackpackCleaned = ChatColor.DARK_GREEN + plugin.lang.getTranslated("Ingame.BackpackCleaned");
|
Message_BackpackCleaned = plugin.lang.getTranslated("Ingame.BackpackCleaned");
|
||||||
Message_Cooldown = ChatColor.DARK_GREEN + plugin.lang.getTranslated("Ingame.Cooldown");
|
Message_Cooldown = plugin.lang.getTranslated("Ingame.Cooldown");
|
||||||
cooldown = plugin.config.getCommandCooldown();
|
cooldown = plugin.config.getCommandCooldown();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,18 +95,18 @@ public boolean onCommand(CommandSender sender, Command cmd, String arg, String[]
|
|||||||
if(player.hasPermission("backpack"))
|
if(player.hasPermission("backpack"))
|
||||||
{
|
{
|
||||||
player.sendMessage(ChatColor.GOLD + "Minepacks Help:");
|
player.sendMessage(ChatColor.GOLD + "Minepacks Help:");
|
||||||
player.sendMessage(ChatColor.AQUA + "/backpack" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Description.Backpack"));
|
player.sendMessage(ChatColor.AQUA + "/backpack" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Commands.Description.Backpack"));
|
||||||
if(player.hasPermission("backpack.clean"))
|
if(player.hasPermission("backpack.clean"))
|
||||||
{
|
{
|
||||||
player.sendMessage(ChatColor.AQUA + "/backpack clean" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Description.Clean"));
|
player.sendMessage(ChatColor.AQUA + "/backpack clean" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Commands.Description.Clean"));
|
||||||
}
|
}
|
||||||
if(player.hasPermission("backpack.clean.other"))
|
if(player.hasPermission("backpack.clean.other"))
|
||||||
{
|
{
|
||||||
player.sendMessage(ChatColor.AQUA + "/backpack clean <playername>" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Description.CleanOther"));
|
player.sendMessage(ChatColor.AQUA + "/backpack clean <playername>" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Commands.Description.CleanOther"));
|
||||||
}
|
}
|
||||||
if(player.hasPermission("backpack.other"))
|
if(player.hasPermission("backpack.other"))
|
||||||
{
|
{
|
||||||
player.sendMessage(ChatColor.AQUA + "/backpack <playername>" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Description.View"));
|
player.sendMessage(ChatColor.AQUA + "/backpack <playername>" + ChatColor.WHITE + " - " + plugin.lang.getTranslated("Commands.Description.View"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1,181 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 GeorgH93
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package at.pcgamingfreaks.MinePacks.Updater;
|
|
||||||
|
|
||||||
import at.pcgamingfreaks.ConsoleColor;
|
|
||||||
import at.pcgamingfreaks.Updater.UpdateProviders.NotSuccessfullyQueriedException;
|
|
||||||
|
|
||||||
import com.google.gson.Gson;
|
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.net.MalformedURLException;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.URLConnection;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
import java.util.logging.Logger;
|
|
||||||
|
|
||||||
public class BukkitUpdateProvider
|
|
||||||
{
|
|
||||||
//region static stuff
|
|
||||||
private static final String USER_AGENT = "Plugin-Updater";
|
|
||||||
private static final String HOST = "https://api.curseforge.com/servermods/files?projectIds=";
|
|
||||||
private static final String VERSION_DELIMITER = "^[vV]|[\\s_-][vV]"; // Used for locating version numbers in file names, bukkit doesn't provide the version on it's own :(
|
|
||||||
//endregion
|
|
||||||
|
|
||||||
private final int projectID;
|
|
||||||
private final String apiKey;
|
|
||||||
private URL url = null;
|
|
||||||
|
|
||||||
private Version[] versions = null;
|
|
||||||
|
|
||||||
public BukkitUpdateProvider(int projectID)
|
|
||||||
{
|
|
||||||
this(projectID, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public BukkitUpdateProvider(int projectID, String apiKey)
|
|
||||||
{
|
|
||||||
this.projectID = projectID;
|
|
||||||
this.apiKey = apiKey;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
url = new URL(HOST + projectID);
|
|
||||||
}
|
|
||||||
catch(MalformedURLException ignored) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
public UpdateResult query(Logger logger)
|
|
||||||
{
|
|
||||||
if(url == null) return UpdateResult.FAIL_FILE_NOT_FOUND;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
URLConnection connection = url.openConnection();
|
|
||||||
connection.setConnectTimeout(5000);
|
|
||||||
if(apiKey != null) connection.addRequestProperty("X-API-Key", apiKey);
|
|
||||||
connection.addRequestProperty("User-Agent", USER_AGENT);
|
|
||||||
connection.setDoOutput(true);
|
|
||||||
|
|
||||||
try(BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream())))
|
|
||||||
{
|
|
||||||
versions = new Gson().fromJson(reader, Version[].class);
|
|
||||||
if(versions == null || versions.length == 0)
|
|
||||||
{
|
|
||||||
logger.warning(ConsoleColor.RED + "The updater could not find any files for the project id " + projectID + " " + ConsoleColor.RESET);
|
|
||||||
return UpdateResult.FAIL_FILE_NOT_FOUND;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(final IOException e)
|
|
||||||
{
|
|
||||||
if(e.getMessage().contains("HTTP response code: 403"))
|
|
||||||
{
|
|
||||||
logger.severe(ConsoleColor.RED + "dev.bukkit.org rejected the provided API key!" + ConsoleColor.RESET);
|
|
||||||
logger.severe(ConsoleColor.RED + "Please double-check your configuration to ensure it is correct." + ConsoleColor.RESET);
|
|
||||||
logger.log(Level.SEVERE, null, e);
|
|
||||||
return UpdateResult.FAIL_API_KEY;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
logger.severe(ConsoleColor.RED + "The updater could not contact dev.bukkit.org for updating!" + ConsoleColor.RESET);
|
|
||||||
logger.severe(ConsoleColor.RED + "If this is the first time you are seeing this message, the site may be experiencing temporary downtime." + ConsoleColor.RESET);
|
|
||||||
logger.log(Level.SEVERE, null, e);
|
|
||||||
return UpdateResult.FAIL_SERVER_OFFLINE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return UpdateResult.SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
private class Version
|
|
||||||
{
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
public String name, downloadUrl, fileName, fileUrl, releaseType, gameVersion, md5, projectId;
|
|
||||||
}
|
|
||||||
|
|
||||||
//region provider property's
|
|
||||||
public boolean provideDownloadURL()
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean provideMD5Checksum()
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
//endregion
|
|
||||||
|
|
||||||
//region getter for the latest version
|
|
||||||
public String getLatestVersion() throws NotSuccessfullyQueriedException
|
|
||||||
{
|
|
||||||
String name = getLatestName();
|
|
||||||
String[] help = name.split(VERSION_DELIMITER);
|
|
||||||
if(help.length == 2)
|
|
||||||
{
|
|
||||||
return help[1].split("\\s+")[0];
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getLatestVersionFileName() throws NotSuccessfullyQueriedException
|
|
||||||
{
|
|
||||||
if(versions == null)
|
|
||||||
{
|
|
||||||
throw new NotSuccessfullyQueriedException();
|
|
||||||
}
|
|
||||||
return versions[versions.length - 1].fileName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public URL getLatestFileURL() throws NotSuccessfullyQueriedException
|
|
||||||
{
|
|
||||||
if(versions == null)
|
|
||||||
{
|
|
||||||
throw new NotSuccessfullyQueriedException();
|
|
||||||
}
|
|
||||||
try
|
|
||||||
{
|
|
||||||
return new URL(versions[versions.length - 1].downloadUrl);
|
|
||||||
}
|
|
||||||
catch(MalformedURLException e)
|
|
||||||
{
|
|
||||||
System.out.println(ConsoleColor.RED + "Failed to interpret download url \"" + versions[versions.length - 1].downloadUrl + "\"!" + ConsoleColor.RESET);
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getLatestName() throws NotSuccessfullyQueriedException
|
|
||||||
{
|
|
||||||
if(versions == null)
|
|
||||||
{
|
|
||||||
throw new NotSuccessfullyQueriedException();
|
|
||||||
}
|
|
||||||
return versions[versions.length - 1].name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getLatestChecksum() throws NotSuccessfullyQueriedException
|
|
||||||
{
|
|
||||||
if(versions == null)
|
|
||||||
{
|
|
||||||
throw new NotSuccessfullyQueriedException();
|
|
||||||
}
|
|
||||||
return versions[versions.length - 1].md5;
|
|
||||||
}
|
|
||||||
//endregion
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 GeorgH93
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/package at.pcgamingfreaks.MinePacks.Updater;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gives the developer the result of the update process.
|
|
||||||
*/
|
|
||||||
public enum UpdateResult
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* The updater found an update, and has readied it to be loaded the next time the server restarts/reloads.
|
|
||||||
*/
|
|
||||||
SUCCESS,
|
|
||||||
/**
|
|
||||||
* The updater did not find an update, and nothing was downloaded.
|
|
||||||
*/
|
|
||||||
NO_UPDATE,
|
|
||||||
/**
|
|
||||||
* The server administrator has disabled the updating system.
|
|
||||||
*/
|
|
||||||
DISABLED,
|
|
||||||
/**
|
|
||||||
* The updater found an update, but was unable to download it.
|
|
||||||
*/
|
|
||||||
FAIL_DOWNLOAD,
|
|
||||||
/**
|
|
||||||
* For some reason, the updater was unable to contact the server to download the file.
|
|
||||||
*/
|
|
||||||
FAIL_SERVER_OFFLINE,
|
|
||||||
/**
|
|
||||||
* When running the version check, the file did not contain a recognizable version.
|
|
||||||
*/
|
|
||||||
FAIL_NO_VERSION_FOUND,
|
|
||||||
/**
|
|
||||||
* The update provider was unable to find the file.
|
|
||||||
*/
|
|
||||||
FAIL_FILE_NOT_FOUND,
|
|
||||||
/**
|
|
||||||
* The server administrator has improperly configured their API key in the configuration.
|
|
||||||
*/
|
|
||||||
FAIL_API_KEY,
|
|
||||||
/**
|
|
||||||
* The updater found an update, but the used provider doesn't provide us with a download link.
|
|
||||||
*/
|
|
||||||
UPDATE_AVAILABLE,
|
|
||||||
UPDATE_AVAILABLE_V2
|
|
||||||
}
|
|
@ -1,351 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 GeorgH93
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package at.pcgamingfreaks.MinePacks.Updater;
|
|
||||||
|
|
||||||
import at.pcgamingfreaks.Updater.UpdateProviders.NotSuccessfullyQueriedException;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
|
||||||
|
|
||||||
import java.io.BufferedInputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.net.HttpURLConnection;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.security.DigestInputStream;
|
|
||||||
import java.security.MessageDigest;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
import java.util.logging.Logger;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public class Updater
|
|
||||||
{
|
|
||||||
private final static int BUFFER_SIZE = 1024;
|
|
||||||
|
|
||||||
private final File updateFolder;
|
|
||||||
private final BukkitUpdateProvider updateProvider;
|
|
||||||
private final boolean announceDownloadProgress;
|
|
||||||
private final Logger logger;
|
|
||||||
private final String localVersion, targetFileName;
|
|
||||||
private final JavaPlugin plugin;
|
|
||||||
|
|
||||||
private Thread thread;
|
|
||||||
private UpdateResult result;
|
|
||||||
|
|
||||||
public Updater(JavaPlugin plugin, File file, boolean announceDownloadProgress, int bukkitPluginID)
|
|
||||||
{
|
|
||||||
this(plugin, file, announceDownloadProgress, new BukkitUpdateProvider(bukkitPluginID));
|
|
||||||
}
|
|
||||||
|
|
||||||
public Updater(JavaPlugin plugin, File file, boolean announceDownloadProgress, BukkitUpdateProvider updateProvider)
|
|
||||||
{
|
|
||||||
this.updateFolder = Bukkit.getUpdateFolderFile();
|
|
||||||
this.updateProvider = updateProvider;
|
|
||||||
this.announceDownloadProgress = announceDownloadProgress;
|
|
||||||
this.logger = plugin.getLogger();
|
|
||||||
this.localVersion = plugin.getDescription().getVersion();
|
|
||||||
this.targetFileName = file.getName();
|
|
||||||
this.plugin = plugin;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void runSync(Runnable runnable)
|
|
||||||
{
|
|
||||||
plugin.getServer().getScheduler().runTask(plugin, runnable);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void runAsync(Runnable runnable)
|
|
||||||
{
|
|
||||||
thread = new Thread(runnable);
|
|
||||||
thread.start();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected String getAuthor()
|
|
||||||
{
|
|
||||||
return plugin.getDescription().getAuthors().size() > 0 ? plugin.getDescription().getAuthors().get(0) : "";
|
|
||||||
}
|
|
||||||
|
|
||||||
public void waitForAsyncOperation()
|
|
||||||
{
|
|
||||||
if (thread != null && thread.isAlive())
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
thread.join();
|
|
||||||
}
|
|
||||||
catch (InterruptedException e)
|
|
||||||
{
|
|
||||||
plugin.getLogger().log(Level.SEVERE, null, e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//region version checking logic
|
|
||||||
protected String[] prepareVersion(String version)
|
|
||||||
{
|
|
||||||
String[] v = version.toLowerCase().split("-")[0].split(Pattern.quote("."));
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if(version.contains("snapshot") || version.contains("alpha") || version.contains("beta"))
|
|
||||||
{
|
|
||||||
if(v.length == 1)
|
|
||||||
{
|
|
||||||
v = new String[] { Integer.toString(Integer.parseInt(v[0]) - 1), Integer.toString(Integer.MAX_VALUE) };
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for(int i = v.length - 1; i > 0; i--)
|
|
||||||
{
|
|
||||||
if(Integer.parseInt(v[i]) > 0)
|
|
||||||
{
|
|
||||||
v[i] = Integer.toString(Integer.parseInt(v[i]) - 1);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception ignored) {}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected boolean shouldUpdate(String remoteVersion)
|
|
||||||
{
|
|
||||||
String[] locVersion = prepareVersion(localVersion), remVersion = prepareVersion(remoteVersion);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
int c = Math.min(locVersion.length, remVersion.length);
|
|
||||||
for(int i = 0; i < c; i++)
|
|
||||||
{
|
|
||||||
int r = Integer.parseInt(remVersion[i]), l = Integer.parseInt(locVersion[i]);
|
|
||||||
if(r > l)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else if(r < l)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If both version are the same for the length of the shorter version the version that has more digits probably is the newer one.
|
|
||||||
if(remVersion.length > locVersion.length)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
// There was a problem parsing the version. Use the fallback (if they don't match the remote version is the newer one)
|
|
||||||
logger.warning("Failed to determine the newer version between local version \"" + localVersion +
|
|
||||||
"\" and remote version \"" + remoteVersion + "\"! Using fallback method (if they don't match the remote version is the newer one)!");
|
|
||||||
return !localVersion.equalsIgnoreCase(remoteVersion);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected boolean versionCheck(String remoteVersion)
|
|
||||||
{
|
|
||||||
if(remoteVersion != null)
|
|
||||||
{
|
|
||||||
if(!this.shouldUpdate(remoteVersion))
|
|
||||||
{
|
|
||||||
// We already have the latest version, or this build is tagged for no-update
|
|
||||||
result = UpdateResult.NO_UPDATE;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// OMG!!! We have no version to work with!
|
|
||||||
logger.warning("There was a problem retrieving the remote version of the plugin!");
|
|
||||||
logger.warning("You should contact the plugin author (" + getAuthor() + ") about this!");
|
|
||||||
result = UpdateResult.FAIL_NO_VERSION_FOUND;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
//endregion
|
|
||||||
|
|
||||||
protected void download(URL url, String fileName) // Saves file into servers update directory
|
|
||||||
{
|
|
||||||
download(url, fileName, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void download(URL url, String fileName, int movedCount) // Saves file into servers update directory
|
|
||||||
{
|
|
||||||
if(!updateFolder.exists())
|
|
||||||
{
|
|
||||||
//noinspection ResultOfMethodCallIgnored
|
|
||||||
updateFolder.mkdirs();
|
|
||||||
}
|
|
||||||
try
|
|
||||||
{
|
|
||||||
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
|
||||||
connection.setInstanceFollowRedirects(false);
|
|
||||||
connection.setConnectTimeout(15000);
|
|
||||||
connection.setReadTimeout(15000);
|
|
||||||
switch (connection.getResponseCode())
|
|
||||||
{
|
|
||||||
case HttpURLConnection.HTTP_MOVED_PERM:
|
|
||||||
case HttpURLConnection.HTTP_MOVED_TEMP:
|
|
||||||
if(movedCount == 5)
|
|
||||||
{
|
|
||||||
logger.warning("Target url moved more than 5 times. Abort.");
|
|
||||||
result = UpdateResult.FAIL_DOWNLOAD;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
download(new URL(url, connection.getHeaderField("Location")), fileName, ++movedCount);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
//endregion
|
|
||||||
long fileLength = connection.getContentLengthLong();
|
|
||||||
int count, percent, percentHelper = -1;
|
|
||||||
File downloadFile = new File(updateFolder.getAbsolutePath() + File.separator + fileName);
|
|
||||||
MessageDigest md5HashGenerator = updateProvider.provideMD5Checksum() ? MessageDigest.getInstance("MD5") : null;
|
|
||||||
try(InputStream inputStream = (md5HashGenerator != null) ? new DigestInputStream(new BufferedInputStream(connection.getInputStream()), md5HashGenerator) : new BufferedInputStream(url.openStream());
|
|
||||||
FileOutputStream outputStream = new FileOutputStream(downloadFile))
|
|
||||||
{
|
|
||||||
byte[] buffer = new byte[BUFFER_SIZE];
|
|
||||||
if(announceDownloadProgress)
|
|
||||||
{
|
|
||||||
logger.info("Start downloading update: " + updateProvider.getLatestVersion());
|
|
||||||
}
|
|
||||||
long downloaded = 0;
|
|
||||||
while((count = inputStream.read(buffer, 0, BUFFER_SIZE)) != -1)
|
|
||||||
{
|
|
||||||
downloaded += count;
|
|
||||||
outputStream.write(buffer, 0, count);
|
|
||||||
percent = (int) ((downloaded * 100) / fileLength);
|
|
||||||
if(announceDownloadProgress && percent % 10 == 0 && percent / 10 > percentHelper)
|
|
||||||
{
|
|
||||||
percentHelper++;
|
|
||||||
logger.info("Downloading update: " + percent + "% of " + fileLength + " bytes.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
outputStream.flush();
|
|
||||||
}
|
|
||||||
connection.disconnect();
|
|
||||||
if(md5HashGenerator != null)
|
|
||||||
{
|
|
||||||
String MD5Download = byteArrayToHex(md5HashGenerator.digest()).toLowerCase(), MD5Target = updateProvider.getLatestChecksum().toLowerCase();
|
|
||||||
if(!MD5Download.equals(MD5Target))
|
|
||||||
{
|
|
||||||
logger.warning("The auto-updater was able to download the file, but the checksum did not match! Delete file.");
|
|
||||||
logger.warning("Checksum expected: " + MD5Target + " Checksum download: " + MD5Download);
|
|
||||||
result = UpdateResult.FAIL_DOWNLOAD;
|
|
||||||
//noinspection ResultOfMethodCallIgnored
|
|
||||||
downloadFile.delete();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(result != UpdateResult.FAIL_DOWNLOAD && announceDownloadProgress)
|
|
||||||
{
|
|
||||||
result = UpdateResult.SUCCESS;
|
|
||||||
logger.info("Finished updating.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception ignored)
|
|
||||||
{
|
|
||||||
logger.warning("The auto-updater tried to download a new update, but was unsuccessful.");
|
|
||||||
ignored.printStackTrace();
|
|
||||||
result = UpdateResult.FAIL_DOWNLOAD;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String byteArrayToHex(byte[] bytes)
|
|
||||||
{
|
|
||||||
if(bytes == null || bytes.length == 0) return "";
|
|
||||||
StringBuilder hexBuilder = new StringBuilder(bytes.length * 2);
|
|
||||||
for(byte b: bytes)
|
|
||||||
{
|
|
||||||
hexBuilder.append(String.format("%02x", b));
|
|
||||||
}
|
|
||||||
return hexBuilder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected String getRemoteVersion()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
return updateProvider.getLatestVersion();
|
|
||||||
}
|
|
||||||
catch(NotSuccessfullyQueriedException ignored) {}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void update()
|
|
||||||
{
|
|
||||||
update(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void update(final UpdaterResponse response)
|
|
||||||
{
|
|
||||||
if(result == UpdateResult.DISABLED) return;
|
|
||||||
runAsync(new Runnable()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
result = updateProvider.query(logger);
|
|
||||||
if(result == UpdateResult.SUCCESS)
|
|
||||||
{
|
|
||||||
if(getRemoteVersion().startsWith("2"))
|
|
||||||
{
|
|
||||||
result = UpdateResult.UPDATE_AVAILABLE_V2;
|
|
||||||
if(response != null) runSync(new Runnable()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
response.onDone(result);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else if(versionCheck(getRemoteVersion()))
|
|
||||||
{
|
|
||||||
result = UpdateResult.UPDATE_AVAILABLE;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if(updateProvider.provideDownloadURL() && updateProvider.getLatestFileURL() != null)
|
|
||||||
{
|
|
||||||
download(updateProvider.getLatestFileURL(), (updateProvider.getLatestVersionFileName().toLowerCase().endsWith(".zip")) ? updateProvider.getLatestVersionFileName() : targetFileName);
|
|
||||||
if(response != null) runSync(new Runnable()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
response.onDone(result);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public interface UpdaterResponse
|
|
||||||
{
|
|
||||||
void onDone(UpdateResult result);
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user