fix issue, when you got money withdrawn, but you did not have the item. fix issue with generating the config

This commit is contained in:
BuildTools 2021-07-16 01:38:32 +02:00
parent 45500ec06b
commit 1a12161a66
2 changed files with 98 additions and 106 deletions

View File

@ -49,6 +49,7 @@ public class EggCatcher extends JavaPlugin {
if (configVersion < 6.0) { if (configVersion < 6.0) {
MigrateConfigFile(); MigrateConfigFile();
this.saveConfig(); this.saveConfig();
this.reloadConfig();
return; return;
} }
if (configVersion == 6.0) { if (configVersion == 6.0) {
@ -65,50 +66,38 @@ public class EggCatcher extends JavaPlugin {
String[] keysWithStringValue = {"VaultTargetBankAccount"}; String[] keysWithStringValue = {"VaultTargetBankAccount"};
String[] entitiesInConfig = {"Axolotl", "Bat", "Bee", "Blaze", "Cat", "CaveSpider", "Chicken", "Cod", "Cow", "Creeper", "Dolphin", "Donkey", "Drowned", "ElderGuardian", "Enderman", "Endermite", "Evoker", "Fox", "Ghast", "GlowSquid", "Goat", "Guardian", "Hoglin", "Horse", "Husk", "Llama", "MagmaCube", "Mule", "MushroomCow", "Ocelot", "Panda", "Parrot", "Phantom", "Pig", "Piglin", "PiglinBrute", "PigZombie", "Pillager", "PolarBear", "Pufferfish", "Rabbit", "Ravager", "Salmon", "Sheep", "Shulker", "Silverfish", "Skeleton", "SkeletonHorse", "Slime", "Spider", "Squid", "Stray", "Strider", "TraderLlama", "TropicalFish", "Turtle", "Vex", "Villager", "Vindicator", "WanderingTrader", "Witch", "WitherSkeleton", "Wolf", "Zoglin", "Zombie", "ZombieHorse", "ZombieVillager", "ZombifiedPiglin"}; String[] entitiesInConfig = {"Axolotl", "Bat", "Bee", "Blaze", "Cat", "CaveSpider", "Chicken", "Cod", "Cow", "Creeper", "Dolphin", "Donkey", "Drowned", "ElderGuardian", "Enderman", "Endermite", "Evoker", "Fox", "Ghast", "GlowSquid", "Goat", "Guardian", "Hoglin", "Horse", "Husk", "Llama", "MagmaCube", "Mule", "MushroomCow", "Ocelot", "Panda", "Parrot", "Phantom", "Pig", "Piglin", "PiglinBrute", "PigZombie", "Pillager", "PolarBear", "Pufferfish", "Rabbit", "Ravager", "Salmon", "Sheep", "Shulker", "Silverfish", "Skeleton", "SkeletonHorse", "Slime", "Spider", "Squid", "Stray", "Strider", "TraderLlama", "TropicalFish", "Turtle", "Vex", "Villager", "Vindicator", "WanderingTrader", "Witch", "WitherSkeleton", "Wolf", "Zoglin", "Zombie", "ZombieHorse", "ZombieVillager", "ZombifiedPiglin"};
FileConfiguration config = this.getConfig(); FileConfiguration config = this.getConfig();
HashMap <String, HashMap> entityList = new HashMap<>(); HashMap <String, HashMap> entityList = new HashMap<>();
for (int i = 0; i < keysWithBoolValue.length; i++) { for (String value : keysWithBoolValue) {
config.set(keysWithBoolValue[i], config.getBoolean(keysWithBoolValue[i], true)); config.set(value, config.getBoolean(value, true));
} }
for (int i = 0; i < keysWithStringValue.length; i++) { for (String s : keysWithStringValue) {
config.set(keysWithStringValue[i], config.getString(keysWithStringValue[i], "")); config.set(s, config.getString(s, ""));
} }
for (int i = 0; i < entitiesInConfig.length; i++) { for (String s : entitiesInConfig) {
HashMap<String, HashMap> entity = new HashMap<>(); HashMap<String, Object> entity = new HashMap<String, Object>();
HashMap<String, Double> HealthPercentage = new HashMap<String, Double>(); HashMap<String, Object> ItemCost = new HashMap<String, Object>();
HashMap<String, Double> CatchChance = new HashMap<>();
HashMap<String, Double> VaultCost = new HashMap<>();
HashMap<String, HashMap> ItemCost = new HashMap<>();
HashMap<String, Double> ItemAmount = new HashMap<>();
HashMap<String, String> ItemName = new HashMap<>();
// generate ItemCost // generate ItemCost
ItemName.put("ItemName", config.getString("ItemCost.ItemId", "gold_nugget")); ItemCost.put("ItemName", config.getString("ItemCost.ItemId", "gold_nugget"));
ItemAmount.put("Amount", config.getDouble("ItemCost.Amount." + entitiesInConfig[i], 0.0)); ItemCost.put("Amount", config.getDouble("ItemCost.Amount." + s, 0.0));
ItemCost.put("ItemCost", ItemAmount); entity.put("ItemCost", ItemCost);
ItemCost.put("ItemCost", ItemName);
// generate VaultCost // generate VaultCost
VaultCost.put("VaultCost", config.getDouble("VaultCost." + entitiesInConfig[i], 0.0)); entity.put("VaultCost", config.getDouble("VaultCost." + s, 0.0));
// generate CatchChance // generate CatchChance
CatchChance.put("CatchChance", config.getDouble("CatchChance." + entitiesInConfig[i], 0.0)); entity.put("CatchChance", config.getDouble("CatchChance." + s, 0.0));
// generate HealthPercentage // generate HealthPercentage
HealthPercentage.put("HealthPercentage", config.getDouble("HealthPercentage." + entitiesInConfig[i], 0.0)); entity.put("HealthPercentage", config.getDouble("HealthPercentage." + s, 0.0));
// Build new Config Hash for entity
entity.put(entitiesInConfig[i], ItemCost);
entity.put(entitiesInConfig[i], VaultCost);
entity.put(entitiesInConfig[i], HealthPercentage);
entity.put(entitiesInConfig[i], CatchChance);
entityList.put(entitiesInConfig[i], entity); entityList.put(s, entity);
} }
config.set("Entity", entityList); config.set("Entity", entityList);
config.set("ConfigVersion", 6.0); config.set("ConfigVersion", 6.0);

View File

@ -158,92 +158,31 @@ public class EggCatcherEntityListener implements Listener {
if (egg.getShooter() instanceof Player) { if (egg.getShooter() instanceof Player) {
Player player = (Player) egg.getShooter(); Player player = (Player) egg.getShooter();
if (this.usePermissions) { // check if player meets all requirements
if (!player.hasPermission("eggcatcher.catch." + eggType.getFriendlyName().toLowerCase())) { if (!playerHasRequirements(entity, player, egg, eggType.getFriendlyName())) {
player.sendMessage(config.getString("Messages.PermissionFail")); if (!this.looseEggOnFail) {
if (!this.looseEggOnFail) { player.getInventory().addItem(new ItemStack(Material.EGG, 1));
player.getInventory().addItem(new ItemStack(Material.EGG, 1)); EggCatcher.eggs.add(egg);
EggCatcher.eggs.add(egg);
}
return;
} }
return;
} }
if (this.useHealthPercentage) { // Withdraw money
double healthPercentage = config.getDouble("Entity." + eggType.getFriendlyName() + ".HealthPercentage"); vaultCost = config.getDouble("Entity." + eggType.getFriendlyName() + ".VaultCost");
double currentHealth = ((LivingEntity) entity).getHealth() * 100.0 / ((LivingEntity) entity) EggCatcher.economy.withdrawPlayer(player, vaultCost);
.getAttribute(Attribute.GENERIC_MAX_HEALTH).getValue(); if (!this.vaultTargetBankAccount.isEmpty()) {
if (healthPercentage < currentHealth) { EggCatcher.economy.bankDeposit(this.vaultTargetBankAccount, vaultCost);
if (this.healthPercentageFailMessage.length() > 0) {
player.sendMessage(String.format(this.healthPercentageFailMessage, healthPercentage));
}
if (!this.looseEggOnFail) {
player.getInventory().addItem(new ItemStack(Material.EGG, 1));
EggCatcher.eggs.add(egg);
}
return;
}
} }
player.sendMessage(String.format(config.getString("Messages.VaultSuccess"), vaultCost));
if (this.useCatchChance) { // Take Items
double catchChance = config.getDouble("Entity." + eggType.getFriendlyName() + ".CatchChance"); Material itemMaterial = Material.matchMaterial(config.getString("Entity." + eggType.getFriendlyName() + ".ItemCost.ItemName", "gold_nugget"));
if (Math.random() * 100 <= catchChance) { int itemAmount = config.getInt("Entity." + eggType.getFriendlyName() + ".ItemCost.Amount", 0);
if (this.catchChanceSuccessMessage.length() > 0) { ItemStack itemStack = new ItemStack(itemMaterial, itemAmount);
player.sendMessage(catchChanceSuccessMessage); player.sendMessage(String.format(config.getString("Messages.ItemCostSuccess"),
} String.valueOf(itemAmount)));
} else { player.getInventory().removeItem(itemStack);
if (this.catchChanceFailMessage.length() > 0) {
player.sendMessage(this.catchChanceFailMessage);
}
if (!this.looseEggOnFail) {
player.getInventory().addItem(new ItemStack(Material.EGG, 1));
EggCatcher.eggs.add(egg);
}
return;
}
}
boolean freeCatch = player.hasPermission("eggcatcher.free");
if (this.useVaultCost && !freeCatch) {
vaultCost = config.getDouble("Entity." + eggType.getFriendlyName() + ".VaultCost");
if (!EggCatcher.economy.has(player, vaultCost)) {
player.sendMessage(String.format(config.getString("Messages.VaultFail"), vaultCost));
if (!this.looseEggOnFail) {
player.getInventory().addItem(new ItemStack(Material.EGG, 1));
EggCatcher.eggs.add(egg);
}
return;
} else {
EggCatcher.economy.withdrawPlayer(player, vaultCost);
if (!this.vaultTargetBankAccount.isEmpty()) {
EggCatcher.economy.bankDeposit(this.vaultTargetBankAccount, vaultCost);
}
player.sendMessage(String.format(config.getString("Messages.VaultSuccess"), vaultCost));
}
}
if (this.useItemCost && !freeCatch) {
Material itemMaterial = Material.matchMaterial(config.getString("Entity." + eggType.getFriendlyName() + ".ItemCost.ItemName", "gold_nugget"));
int itemData = config.getInt("Entity." + eggType.getFriendlyName() + ".ItemCost.ItemData", 0);
int itemAmount = config.getInt("Entity." + eggType.getFriendlyName() + ".ItemCost.Amount", 0);
ItemStack itemStack = new ItemStack(itemMaterial, itemAmount);
if (player.getInventory().containsAtLeast(itemStack, itemStack.getAmount())) {
player.sendMessage(String.format(config.getString("Messages.ItemCostSuccess"),
String.valueOf(itemAmount)));
player.getInventory().removeItem(itemStack);
} else {
player.sendMessage(String.format(config.getString("Messages.ItemCostFail"),
String.valueOf(itemAmount)));
if (!this.looseEggOnFail) {
player.getInventory().addItem(new ItemStack(Material.EGG, 1));
EggCatcher.eggs.add(egg);
}
return;
}
}
} else { } else {
// Dispenser // Dispenser
if (!this.nonPlayerCatching) { if (!this.nonPlayerCatching) {
@ -312,4 +251,68 @@ public class EggCatcherEntityListener implements Listener {
captureLogger.logToFile("Player " + ((Player) egg.getShooter()).getName() + " caught " + entity.getType() + " at X" + Math.round(entity.getLocation().getX()) + ",Y" + Math.round(entity.getLocation().getY()) + ",Z" + Math.round(entity.getLocation().getZ())); captureLogger.logToFile("Player " + ((Player) egg.getShooter()).getName() + " caught " + entity.getType() + " at X" + Math.round(entity.getLocation().getX()) + ",Y" + Math.round(entity.getLocation().getY()) + ",Z" + Math.round(entity.getLocation().getZ()));
} }
} }
private boolean playerHasRequirements(Entity entity, Player player, Egg egg, String eggtype) {
boolean hasRequirements = true;
double vaultCost = 0.0;
boolean freeCatch = player.hasPermission("eggcatcher.free");
if (this.usePermissions) {
if (!player.hasPermission("eggcatcher.catch." + eggtype.toLowerCase())) {
player.sendMessage(config.getString("Messages.PermissionFail"));
hasRequirements = false;
}
}
if (this.useHealthPercentage) {
double healthPercentage = config.getDouble("Entity." + eggtype + ".HealthPercentage");
double currentHealth = ((LivingEntity) entity).getHealth() * 100.0 / ((LivingEntity) entity)
.getAttribute(Attribute.GENERIC_MAX_HEALTH).getValue();
if (healthPercentage < currentHealth) {
if (this.healthPercentageFailMessage.length() > 0) {
player.sendMessage(String.format(this.healthPercentageFailMessage, healthPercentage));
}
hasRequirements = false;
}
}
if (this.useCatchChance) {
double catchChance = config.getDouble("Entity." + eggtype + ".CatchChance");
if (Math.random() * 100 <= catchChance) {
if (this.catchChanceSuccessMessage.length() > 0) {
player.sendMessage(catchChanceSuccessMessage);
}
} else {
if (this.catchChanceFailMessage.length() > 0) {
player.sendMessage(this.catchChanceFailMessage);
}
hasRequirements = false;
}
}
if (this.useVaultCost && !freeCatch) {
vaultCost = config.getDouble("Entity." + eggtype + ".VaultCost");
if (!EggCatcher.economy.has(player, vaultCost)) {
player.sendMessage(String.format(config.getString("Messages.VaultFail"), vaultCost));
hasRequirements = false;
}
}
if (this.useItemCost && !freeCatch) {
Material itemMaterial = Material.matchMaterial(config.getString("Entity." + eggtype + ".ItemCost.ItemName", "gold_nugget"));
int itemAmount = config.getInt("Entity." + eggtype + ".ItemCost.Amount", 0);
ItemStack itemStack = new ItemStack(itemMaterial, itemAmount);
if (!player.getInventory().containsAtLeast(itemStack, itemStack.getAmount())) {
player.sendMessage(String.format(config.getString("Messages.ItemCostFail"),
String.valueOf(itemAmount)));
hasRequirements = false;
}
}
return hasRequirements;
}
} }