Mass changes, upgrade to v3.0.0

- Change storage method
- Add converter for both methods of storage
    - Dropping upgrade support possibly in the future
- Change backup location
This commit is contained in:
gomeow
2013-03-29 23:02:53 -07:00
parent 18472870e1
commit 3bea5284be
5 changed files with 273 additions and 81 deletions
@@ -4,18 +4,22 @@ package com.drtshock.playervaults;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.List;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.milkbowl.vault.economy.Economy; import net.milkbowl.vault.economy.Economy;
import org.bukkit.configuration.file.FileConfiguration; import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.inventory.Inventory;
import org.bukkit.plugin.RegisteredServiceProvider; import org.bukkit.plugin.RegisteredServiceProvider;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import com.drtshock.playervaults.commands.Commands; import com.drtshock.playervaults.commands.Commands;
import com.drtshock.playervaults.util.BackwardsCompatibility;
import com.drtshock.playervaults.util.Lang; import com.drtshock.playervaults.util.Lang;
import com.drtshock.playervaults.util.Metrics; import com.drtshock.playervaults.util.Metrics;
import com.drtshock.playervaults.util.Serialization;
import com.drtshock.playervaults.util.Updater; import com.drtshock.playervaults.util.Updater;
@@ -33,10 +37,16 @@ public class Main extends JavaPlugin {
public static FileConfiguration config; public static FileConfiguration config;
public static YamlConfiguration lang; public static YamlConfiguration lang;
public static File langFile; public static File langFile;
public static String directory = "plugins" + File.separator + "PlayerVaults" + File.separator + "vaults";
@Override @Override
public void onEnable() { public void onEnable() {
transferVaults(); try {
transferVaults();
} catch (IOException e) {
e.printStackTrace();
}
loadLang(); loadLang();
log = getServer().getLogger(); log = getServer().getLogger();
getServer().getPluginManager().registerEvents(new Listeners(this), this); getServer().getPluginManager().registerEvents(new Listeners(this), this);
@@ -62,24 +72,28 @@ public class Main extends JavaPlugin {
inventoriesToDrop = getConfig().getInt("drop-on-death.inventories"); inventoriesToDrop = getConfig().getInt("drop-on-death.inventories");
} }
new File(directory + File.separator + "backups").mkdirs();
config = getConfig(); config = getConfig();
} }
public void transferVaults() { public void transferVaults() throws IOException {
File f = new File(getDataFolder() + File.separator + "vaults.yml"); File f = new File(getDataFolder() + File.separator + "vaults.yml");
if(f.exists() && !new File(getDataFolder() + File.separator + "vaults").exists()) { if(f.exists() && !new File(getDataFolder() + File.separator + "vaults").exists()) {
YamlConfiguration vaults = YamlConfiguration.loadConfiguration(f); YamlConfiguration vaults = YamlConfiguration.loadConfiguration(f);
for(String key:vaults.getKeys(false)) { for(String person:vaults.getKeys(false)) {
YamlConfiguration newPerson = new YamlConfiguration(); YamlConfiguration yaml = new YamlConfiguration();
for(String key2:vaults.getConfigurationSection(key).getKeys(false)) { for(String vault:vaults.getConfigurationSection(person).getKeys(false)) {
newPerson.set(key2, vaults.getString(key + "." + key2)); String data = vaults.getString(person + "." + vault);
} Inventory inv = BackwardsCompatibility.pre2_0_0ToCurrent(data);
try { List<String> list = Serialization.toString(inv);
newPerson.save(new File(getDataFolder() + File.separator + "vaults" + File.separator + key + ".yml")); String[] ser = list.toArray(new String[list.size()]);
} catch (IOException e) { for(int x = 0; x < ser.length; x++) {
e.printStackTrace(); if(!ser[x].equalsIgnoreCase("null"))
yaml.set(vault + "." + x, ser[x]);
}
} }
yaml.save(new File(directory + File.separator + person + ".yml"));
} }
getLogger().warning("Found old storage format used! Converting to new format!"); getLogger().warning("Found old storage format used! Converting to new format!");
} }
@@ -0,0 +1,95 @@
package com.drtshock.playervaults.util;
import java.io.ByteArrayInputStream;
import java.io.DataInputStream;
import net.minecraft.server.v1_5_R1.NBTBase;
import net.minecraft.server.v1_5_R1.NBTTagCompound;
import net.minecraft.server.v1_5_R1.NBTTagList;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.Material;
import org.bukkit.craftbukkit.v1_5_R1.inventory.CraftInventoryCustom;
import org.bukkit.craftbukkit.v1_5_R1.inventory.CraftItemStack;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import org.yaml.snakeyaml.external.biz.base64Coder.Base64Coder;
import com.drtshock.playervaults.Main;
public class BackwardsCompatibility {
Main plugin;
public BackwardsCompatibility(Main m) {
this.plugin = m;
}
public static Inventory pre2_0_0ToCurrent(String invString) {
String[] serializedBlocks = invString.split(";");
Inventory deserializedInventory = Bukkit.getServer().createInventory(null, 54);
for (int i = 1; i < serializedBlocks.length; i++) {
String[] serializedBlock = serializedBlocks[i].split("#");
int stackPosition = Integer.valueOf(serializedBlock[0]).intValue();
if (stackPosition < deserializedInventory.getSize()) {
ItemStack is = null;
Boolean createdItemStack = Boolean.valueOf(false);
String[] serializedItemStack = serializedBlock[1].split(":");
for (String itemInfo : serializedItemStack) {
String[] itemAttribute = itemInfo.split("@");
if (itemAttribute[0].equals("t")) {
is = new ItemStack(Material.getMaterial(Integer.valueOf(itemAttribute[1]).intValue()));
createdItemStack = Boolean.valueOf(true);
} else if ((itemAttribute[0].equals("d")) && (createdItemStack.booleanValue())) {
is.setDurability(Short.valueOf(itemAttribute[1]).shortValue());
} else if ((itemAttribute[0].equals("a")) && (createdItemStack.booleanValue())) {
is.setAmount(Integer.valueOf(itemAttribute[1]).intValue());
} else if ((itemAttribute[0].equals("e")) && (createdItemStack.booleanValue())) {
is.addEnchantment(Enchantment.getById(Integer.valueOf(itemAttribute[1]).intValue()), Integer.valueOf(itemAttribute[2]).intValue());
} else {
if ((!itemAttribute[0].equals("i")) || (!createdItemStack.booleanValue()))
continue;
ItemMeta meta = is.getItemMeta();
meta.setDisplayName(itemAttribute[1]);
is.setItemMeta(meta);
}
}
deserializedInventory.setItem(stackPosition, is);
}
}
return deserializedInventory;
}
public static Inventory pre3_0_0ToCurrent(String data) {
ByteArrayInputStream inputStream = new ByteArrayInputStream(Base64Coder.decodeLines(data));
NBTTagList itemList = (NBTTagList) NBTBase.b(new DataInputStream(inputStream));
Inventory inventory = new CraftInventoryCustom(null, itemList.size(), ChatColor.DARK_RED + "Vault");
for (int i = 0; i < itemList.size(); i++) {
NBTTagCompound inputObject = (NBTTagCompound) itemList.get(i);
if (!inputObject.isEmpty()) {
inventory.setItem(i, CraftItemStack.asCraftMirror(net.minecraft.server.v1_5_R1.ItemStack.createStack(inputObject)));
}
}
return inventory;
}
private static CraftItemStack getCraftVersion(org.bukkit.inventory.ItemStack stack) {
if ((stack instanceof CraftItemStack))
return (CraftItemStack) stack;
if (stack != null) {
return CraftItemStack.asCraftCopy(stack);
}
return null;
}
}
@@ -1,68 +1,129 @@
package com.drtshock.playervaults.util; package com.drtshock.playervaults.util;
import java.io.ByteArrayInputStream; import java.util.ArrayList;
import java.io.ByteArrayOutputStream; import java.util.HashMap;
import java.io.DataInputStream; import java.util.Iterator;
import java.io.DataOutputStream; import java.util.List;
import java.util.Map;
import net.minecraft.server.v1_5_R1.NBTBase; import java.util.Map.Entry;
import net.minecraft.server.v1_5_R1.NBTTagCompound;
import net.minecraft.server.v1_5_R1.NBTTagList;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.craftbukkit.v1_5_R1.inventory.CraftInventoryCustom; import org.bukkit.configuration.serialization.ConfigurationSerializable;
import org.bukkit.craftbukkit.v1_5_R1.inventory.CraftItemStack; import org.bukkit.configuration.serialization.ConfigurationSerialization;
import org.bukkit.inventory.Inventory; import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.yaml.snakeyaml.external.biz.base64Coder.Base64Coder; import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
public class Serialization { public class Serialization {
public static String toBase64(Inventory inventory) { /*
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); * All normal functions
DataOutputStream dataOutput = new DataOutputStream(outputStream); */
NBTTagList itemList = new NBTTagList();
// Save every element in the list @SuppressWarnings("unchecked")
for (int i = 0; i < inventory.getSize(); i++) { public static Map<String, Object> toMap(JSONObject object) throws JSONException {
NBTTagCompound outputObject = new NBTTagCompound(); Map<String, Object> map = new HashMap<String, Object>();
CraftItemStack craft = getCraftVersion(inventory.getItem(i)); Iterator<String> keys = object.keys();
while (keys.hasNext()) {
// Convert the item stack to a NBT compound String key = (String) keys.next();
if (craft != null) map.put(key, fromJson(object.get(key)));
CraftItemStack.asNMSCopy(craft).save(outputObject); }
itemList.add(outputObject); return map;
}
private static Object fromJson(Object json) throws JSONException {
if (json == JSONObject.NULL) {
return null;
} else if (json instanceof JSONObject) {
return toMap((JSONObject) json);
} else if (json instanceof JSONArray) {
return toList((JSONArray) json);
} else {
return json;
} }
// Now save the list
NBTBase.a(itemList, dataOutput);
// Serialize that array
return Base64Coder.encodeLines(outputStream.toByteArray());
} }
public static Inventory fromBase64(String data, int number) { public static List<Object> toList(JSONArray array) throws JSONException {
ByteArrayInputStream inputStream = new ByteArrayInputStream(Base64Coder.decodeLines(data)); List<Object> list = new ArrayList<Object>();
NBTTagList itemList = (NBTTagList) NBTBase.b(new DataInputStream(inputStream)); for (int i = 0; i < array.length(); i++) {
Inventory inventory = new CraftInventoryCustom(null, itemList.size(), ChatColor.DARK_RED + "Vault #" + String.valueOf(number)); list.add(fromJson(array.get(i)));
for (int i = 0; i < itemList.size(); i++) { }
NBTTagCompound inputObject = (NBTTagCompound) itemList.get(i); return list;
}
if (!inputObject.isEmpty()) { public static List<String> toString(Inventory inv) {
inventory.setItem(i, CraftItemStack.asCraftMirror(net.minecraft.server.v1_5_R1.ItemStack.createStack(inputObject))); List<String> result = new ArrayList<String>();
List<ConfigurationSerializable> items = new ArrayList<ConfigurationSerializable>();
for(ItemStack is:inv.getContents()) {
items.add(is);
}
for(ConfigurationSerializable cs:items) {
if(cs == null) {
result.add("null");
}
else {
result.add(new JSONObject(serialize(cs)).toString());
}
}
return result;
}
public static Inventory toInventory(List<String> stringItems, int number) {
Inventory inv = Bukkit.createInventory(null, 54, ChatColor.RED + "Vault #" + number);
List<ItemStack> contents = new ArrayList<ItemStack>();
for(String piece:stringItems) {
if(piece.equalsIgnoreCase("null")) {
contents.add(null);
}
else {
try {
ItemStack item = (ItemStack) deserialize(toMap(new JSONObject(piece)));
contents.add(item);
} catch (JSONException e) {
e.printStackTrace();
}
}
}
ItemStack[] items = new ItemStack[contents.size()];
for(int x = 0; x < contents.size(); x++)
items[x] = contents.get(x);
inv.setContents(items);
return inv;
}
public static Map<String, Object> serialize(ConfigurationSerializable cs) {
Map<String, Object> serialized = recreateMap(cs.serialize());
for (Entry<String, Object> entry : serialized.entrySet()) {
if (entry.getValue() instanceof ConfigurationSerializable) {
entry.setValue(serialize((ConfigurationSerializable)entry.getValue()));
} }
} }
serialized.put(ConfigurationSerialization.SERIALIZED_TYPE_KEY, ConfigurationSerialization.getAlias(cs.getClass()));
// Serialize that array return serialized;
return inventory; }
public static Map<String, Object> recreateMap(Map<String, Object> original) {
Map<String, Object> map = new HashMap<String, Object>();
for (Entry<String, Object> entry : original.entrySet()) {
map.put(entry.getKey(), entry.getValue());
}
return map;
} }
private static CraftItemStack getCraftVersion(ItemStack stack) { @SuppressWarnings({ "unchecked", "rawtypes" })
if (stack instanceof CraftItemStack) public static ConfigurationSerializable deserialize(Map<String, Object> map) {
return (CraftItemStack) stack; for (Entry<String, Object> entry : map.entrySet()) {
else if (stack != null) // Check if any of its sub-maps are ConfigurationSerializable. They need to be done first.
return CraftItemStack.asCraftCopy(stack); if (entry.getValue() instanceof Map && ((Map)entry.getValue()).containsKey(ConfigurationSerialization.SERIALIZED_TYPE_KEY)) {
else entry.setValue(deserialize((Map)entry.getValue()));
return null; }
}
return ConfigurationSerialization.deserializeObject(map);
} }
/*
* All old methods for transferring
*/
} }
@@ -2,6 +2,8 @@ package com.drtshock.playervaults.util;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
@@ -30,9 +32,14 @@ public class VaultManager {
* @throws IOException * @throws IOException
*/ */
public void saveVault(Inventory inv, String player, int number) throws IOException { public void saveVault(Inventory inv, String player, int number) throws IOException {
String ser = Serialization.toBase64(inv);
YamlConfiguration yaml = playerVaultFile(player); YamlConfiguration yaml = playerVaultFile(player);
yaml.set("vault" + number + "", ser); yaml.set("vault" + number, null);
List<String> list = Serialization.toString(inv);
String[] ser = list.toArray(new String[list.size()]);
for(int x = 0; x < ser.length; x++) {
if(!ser[x].equalsIgnoreCase("null"))
yaml.set("vault" + number + "." + x, ser[x]);
}
saveFile(player, yaml); saveFile(player, yaml);
} }
@@ -43,15 +50,29 @@ public class VaultManager {
* TODO: Check to see if the path exists before we get it! * TODO: Check to see if the path exists before we get it!
*/ */
public void loadVault(Player player, String holder, int number) { public void loadVault(Player player, String holder, int number) {
Inventory inv = null;
YamlConfiguration playerFile = playerVaultFile(holder); YamlConfiguration playerFile = playerVaultFile(holder);
String data = playerFile.getString("vault" + number); if(!playerFile.getString("vault" + number, "~").equals("~") && playerFile.getString("vault" + number, "~").trim().endsWith("=")) {
if(data == null) { String data = playerFile.getString("vault" + number);
Inventory inv = Bukkit.createInventory(player, 54, ChatColor.DARK_RED + "Vault #" + String.valueOf(number)); inv = BackwardsCompatibility.pre3_0_0ToCurrent(data);
player.openInventory(inv);
} else {
Inventory inv = Serialization.fromBase64(data, number);
player.openInventory(inv);
} }
else if(playerFile.getConfigurationSection("vault" + number) == null) {
inv = Bukkit.createInventory(player, 54, ChatColor.DARK_RED + "Vault #" + String.valueOf(number));
}
else {
List<String> data = new ArrayList<String>();
for(int x = 0; x < 54; x++) {
String line = playerFile.getString("vault" + number + "." + x);
if(line != null) {
data.add(line);
}
else {
data.add("null");
}
}
inv = Serialization.toInventory(data, number);
}
player.openInventory(inv);
} }
/** /**
@@ -63,12 +84,12 @@ public class VaultManager {
*/ */
public Inventory getVault(Player player, int number) { public Inventory getVault(Player player, int number) {
YamlConfiguration playerFile = playerVaultFile(player.getName()); YamlConfiguration playerFile = playerVaultFile(player.getName());
String data = playerFile.getString("vault" + number); List<String> data = playerFile.getStringList("vault" + number);
if(data == null) { if(data == null) {
Inventory inv = Bukkit.createInventory(player, 54, ChatColor.GREEN + "Vault #" + String.valueOf(number)); Inventory inv = Bukkit.createInventory(player, 54, ChatColor.GREEN + "Vault #" + String.valueOf(number));
return inv; return inv;
} else { } else {
Inventory inv = Serialization.fromBase64(data, number); Inventory inv = Serialization.toInventory(data, number);
return inv; return inv;
} }
} }
@@ -128,7 +149,7 @@ public class VaultManager {
public void saveFile(String name, YamlConfiguration yaml) throws IOException { public void saveFile(String name, YamlConfiguration yaml) throws IOException {
File file = new File(directory + File.separator + name.toLowerCase() + ".yml"); File file = new File(directory + File.separator + name.toLowerCase() + ".yml");
if (file.exists()) { if (file.exists()) {
file.renameTo(new File(directory + File.separator + name.toLowerCase() + ".yml.bak")); file.renameTo(new File(directory + File.separator + "backups" + File.separator + name.toLowerCase() + ".yml"));
} }
yaml.save(file); yaml.save(file);
} }
+4 -3
View File
@@ -1,12 +1,13 @@
name: PlayerVaults name: PlayerVaults
main: com.drtshock.playervaults.Main main: com.drtshock.playervaults.Main
authors: [drtshock, gomeow, chester] authors: [drtshock, gomeow, Chester]
version: 2.1.1 version: 3.0.0
website: http://dev.bukkit.org/server-mods/PlayerVaults website: http://dev.bukkit.org/server-mods/PlayerVaults
softdepend: [Vault] softdepend: [Vault]
commands: commands:
pv: pv:
description: Open a vault with /vault <number> description: Open a vault with /vault <number>
aliases: [vault, playervault, playervaults] aliases: [vault]
pvdel: pvdel:
description: Delete a vault. description: Delete a vault.
aliases: [vaultdel]