package net.knarcraft.stargate.utility; import net.knarcraft.stargate.Stargate; import net.milkbowl.vault.economy.Economy; import org.bukkit.Bukkit; import org.bukkit.entity.Player; import org.bukkit.plugin.Plugin; import org.bukkit.plugin.PluginManager; import org.bukkit.plugin.RegisteredServiceProvider; import java.util.UUID; /** * This handler handles economy actions such as payment for using a gate */ public final class EconomyHandler { public static boolean economyEnabled = false; public static Economy economy = null; public static Plugin vault = null; private static int useCost = 0; private static int createCost = 0; private static int destroyCost = 0; public static boolean toOwner = false; public static boolean chargeFreeDestination = true; public static boolean freeGatesGreen = false; /** * Gets the cost of using a gate without a specified cost * * @return
The gate use cost
*/ public static int getUseCost() { return useCost; } /** * Sets the cost of using a gate without a specified cost * *The use cost cannot be negative.
* * @param useCostThe gate use cost
*/ public static void setUseCost(int useCost) { if (useCost < 0) { throw new IllegalArgumentException("Using a gate cannot cost a negative amount"); } EconomyHandler.useCost = useCost; } /** * Gets the cost of creating a gate without a specified cost * * @returnThe gate creation cost
*/ public static int getCreateCost() { return createCost; } /** * Sets the cost of creating a gate without a specified cost * *The gate create cost cannot be negative
* * @param createCostThe gate creation cost
*/ public static void setCreateCost(int createCost) { EconomyHandler.createCost = createCost; } /** * Gets the cost of destroying a gate without a specified cost * * @returnThe gate destruction cost
*/ public static int getDestroyCost() { return destroyCost; } /** * Sets the cost of destroying a gate without a specified cost * * @param destroyCostThe gate destruction cost
*/ public static void setDestroyCost(int destroyCost) { EconomyHandler.destroyCost = destroyCost; } /** * Gets the balance (money) of the given player * * @param playerThe player to get balance for
* @returnThe current balance of the player. Returns 0 if economy is disabled
*/ public static double getBalance(Player player) { if (economyEnabled) { return economy.getBalance(player); } else { return 0; } } /** * Charges a player, giving the charge to a target * * @param playerThe player to charge
* @param targetThe UUID of the player to pay
* @param amountThe amount to charge
* @returnTrue if the payment succeeded, or if no payment was necessary
*/ public static boolean chargePlayer(Player player, UUID target, double amount) { if (economyEnabled && player.getUniqueId().compareTo(target) != 0 && economy != null) { if (!economy.has(player, amount)) { return false; } //Take money from the user and give to the owner economy.withdrawPlayer(player, amount); economy.depositPlayer(Bukkit.getOfflinePlayer(target), amount); } return true; } /** * Charges a player * * @param playerThe player to charge
* @param amountThe amount to charge
* @returnTrue if the payment succeeded, or if no payment was necessary
*/ public static boolean chargePlayer(Player player, double amount) { if (economyEnabled && economy != null) { if (!economy.has(player, amount)) { return false; } economy.withdrawPlayer(player, amount); } return true; } /** * Gets a formatted string for an amount, adding the name of the currency * * @param amountThe amount to display
* @returnA formatted text string describing the amount
*/ public static String format(int amount) { if (economyEnabled) { return economy.format(amount); } else { return ""; } } /** * Sets up economy by initializing vault and the vault economy provider * * @param pluginManagerThe plugin manager to get plugins from
* @returnTrue if economy was enabled
*/ public static boolean setupEconomy(PluginManager pluginManager) { if (!economyEnabled) { return false; } // Check for Vault Plugin vault = pluginManager.getPlugin("Vault"); if (vault != null && vault.isEnabled()) { RegisteredServiceProviderTrue if the user has turned on economy and economy is available
*/ public static boolean useEconomy() { return economyEnabled && economy != null; } }