From 78c376af79f1550941166bcfa43a8d3625111693 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 02:38:22 +0200 Subject: Created an interface for settings. --- .../src/com/earth2me/essentials/Essentials.java | 4 +- .../src/com/earth2me/essentials/IEssentials.java | 2 +- .../src/com/earth2me/essentials/ISettings.java | 129 +++++++++++++++++++++ .../src/com/earth2me/essentials/Settings.java | 72 ++++++++++-- 4 files changed, 193 insertions(+), 14 deletions(-) create mode 100644 Essentials/src/com/earth2me/essentials/ISettings.java diff --git a/Essentials/src/com/earth2me/essentials/Essentials.java b/Essentials/src/com/earth2me/essentials/Essentials.java index e7a57f9b5..b308407c2 100644 --- a/Essentials/src/com/earth2me/essentials/Essentials.java +++ b/Essentials/src/com/earth2me/essentials/Essentials.java @@ -48,7 +48,7 @@ public class Essentials extends JavaPlugin implements IEssentials { public static final int BUKKIT_VERSION = 974; private static final Logger LOGGER = Logger.getLogger("Minecraft"); - private transient Settings settings; + private transient ISettings settings; private final transient TNTExplodeListener tntListener = new TNTExplodeListener(this); private transient Spawn spawn; private transient Jail jail; @@ -65,7 +65,7 @@ public class Essentials extends JavaPlugin implements IEssentials private transient final EssentialsErrorHandler errorHandler = new EssentialsErrorHandler(); private transient IPermissionsHandler permissionsHandler; - public Settings getSettings() + public ISettings getSettings() { return settings; } diff --git a/Essentials/src/com/earth2me/essentials/IEssentials.java b/Essentials/src/com/earth2me/essentials/IEssentials.java index 3e5dbbbd3..b1c420e7d 100644 --- a/Essentials/src/com/earth2me/essentials/IEssentials.java +++ b/Essentials/src/com/earth2me/essentials/IEssentials.java @@ -25,7 +25,7 @@ public interface IEssentials extends Plugin int broadcastMessage(String name, String message); - Settings getSettings(); + ISettings getSettings(); CraftScheduler getScheduler(); diff --git a/Essentials/src/com/earth2me/essentials/ISettings.java b/Essentials/src/com/earth2me/essentials/ISettings.java new file mode 100644 index 000000000..c641a8b3f --- /dev/null +++ b/Essentials/src/com/earth2me/essentials/ISettings.java @@ -0,0 +1,129 @@ +package com.earth2me.essentials; + +import com.earth2me.essentials.commands.IEssentialsCommand; +import java.util.List; +import java.util.Map; +import org.bukkit.ChatColor; + + +public interface ISettings extends IConf +{ + + boolean areSignsDisabled(); + + String format(String format, IUser user); + + String getAnnounceNewPlayerFormat(IUser user); + + boolean getAnnounceNewPlayers(); + + String getBackupCommand(); + + long getBackupInterval(); + + boolean getBedSetsHome(); + + String getChatFormat(String group); + + int getChatRadius(); + + double getCommandCost(IEssentialsCommand cmd); + + double getCommandCost(String label); + + String getCurrencySymbol(); + + int getDefaultStackSize(); + + boolean getGenerateExitPortals(); + + double getHealCooldown(); + + Object getKit(String name); + + Map getKits(); + + String getLocale(); + + String getNetherName(); + + boolean getNetherPortalsEnabled(); + + double getNetherRatio(); + + String getNewbieSpawn(); + + String getNicknamePrefix(); + + ChatColor getOperatorColor() throws Exception; + + boolean getPerWarpPermission(); + + boolean getProtectBoolean(final String configName, boolean def); + + int getProtectCreeperMaxHeight(); + + List getProtectList(final String configName); + + boolean getProtectPreventSpawn(final String creatureName); + + String getProtectString(final String configName); + + boolean getReclaimSetting(); + + boolean getRespawnAtHome(); + + boolean getSortListByGroups(); + + int getSpawnMobLimit(); + + int getStartingBalance(); + + double getTeleportCooldown(); + + double getTeleportDelay(); + + boolean hidePermissionlessHelp(); + + boolean isCommandDisabled(final IEssentialsCommand cmd); + + boolean isCommandDisabled(String label); + + boolean isCommandOverridden(String name); + + boolean isCommandRestricted(IEssentialsCommand cmd); + + boolean isCommandRestricted(String label); + + boolean isDebug(); + + boolean isEcoDisabled(); + + boolean isNetherEnabled(); + + boolean isTradeInStacks(int id); + + List itemSpawnBlacklist(); + + boolean permissionBasedItemSpawn(); + + void reloadConfig(); + + boolean showNonEssCommandsInHelp(); + + boolean spawnIfNoHome(); + + boolean use1to1RatioInNether(); + + boolean warnOnBuildDisallow(); + + boolean warnOnSmite(); + + double getMaxMoney(); + + boolean isEcoLogEnabled(); + + boolean removeGodOnDisconnect(); + + boolean changeDisplayName(); +} diff --git a/Essentials/src/com/earth2me/essentials/Settings.java b/Essentials/src/com/earth2me/essentials/Settings.java index 17248a6cc..75063a15b 100644 --- a/Essentials/src/com/earth2me/essentials/Settings.java +++ b/Essentials/src/com/earth2me/essentials/Settings.java @@ -11,7 +11,7 @@ import java.util.Map; import org.bukkit.inventory.ItemStack; -public class Settings implements IConf +public class Settings implements ISettings { private final transient EssentialsConf config; private final static Logger logger = Logger.getLogger("Minecraft"); @@ -22,49 +22,58 @@ public class Settings implements IConf this.ess = ess; config = new EssentialsConf(new File(ess.getDataFolder(), "config.yml")); config.setTemplateName("/config.yml"); - config.load(); + reloadConfig(); } + @Override public boolean getRespawnAtHome() { return config.getBoolean("respawn-at-home", false); } + @Override public boolean getBedSetsHome() { return config.getBoolean("bed-sethome", false); } + @Override public int getChatRadius() { return config.getInt("chat.radius", config.getInt("chat-radius", 0)); } + @Override public double getTeleportDelay() { return config.getDouble("teleport-delay", 0); } + @Override public int getDefaultStackSize() { return config.getInt("default-stack-size", 64); } + @Override public int getStartingBalance() { return config.getInt("starting-balance", 0); } + @Override public boolean getNetherPortalsEnabled() { return isNetherEnabled() && config.getBoolean("nether.portals-enabled", false); } + @Override public boolean isCommandDisabled(final IEssentialsCommand cmd) { return isCommandDisabled(cmd.getName()); } + @Override public boolean isCommandDisabled(String label) { for (String c : config.getStringList("disabled-commands", new ArrayList(0))) @@ -75,11 +84,13 @@ public class Settings implements IConf return config.getBoolean("disable-" + label.toLowerCase(), false); } + @Override public boolean isCommandRestricted(IEssentialsCommand cmd) { return isCommandRestricted(cmd.getName()); } + @Override public boolean isCommandRestricted(String label) { for (String c : config.getStringList("restricted-commands", new ArrayList(0))) @@ -90,6 +101,7 @@ public class Settings implements IConf return config.getBoolean("restrict-" + label.toLowerCase(), false); } + @Override public boolean isCommandOverridden(String name) { List defaultList = new ArrayList(1); @@ -103,11 +115,13 @@ public class Settings implements IConf return config.getBoolean("override-" + name.toLowerCase(), false); } + @Override public double getCommandCost(IEssentialsCommand cmd) { return getCommandCost(cmd.getName()); } + @Override public double getCommandCost(String label) { double cost = config.getDouble("command-costs." + label, 0.0); @@ -116,26 +130,25 @@ public class Settings implements IConf return cost; } - public String getCommandPrefix() - { - return config.getString("command-prefix", ""); - } - + @Override public String getNicknamePrefix() { return config.getString("nickname-prefix", "~"); } + @Override public double getTeleportCooldown() { return config.getDouble("teleport-cooldown", 60); } + @Override public double getHealCooldown() { return config.getDouble("heal-cooldown", 60); } + @Override public Object getKit(String name) { Map kits = (Map)config.getProperty("kits"); @@ -148,11 +161,13 @@ public class Settings implements IConf return null; } + @Override public Map getKits() { return (Map)config.getProperty("kits"); } + @Override public ChatColor getOperatorColor() throws Exception { String colorName = config.getString("ops-name-color", null); @@ -173,100 +188,120 @@ public class Settings implements IConf return ChatColor.getByCode(Integer.parseInt(colorName, 16)); } + @Override public boolean getReclaimSetting() { return config.getBoolean("reclaim-onlogout", true); } + @Override public String getNetherName() { return config.getString("nether.folder", "nether"); } + @Override public boolean isNetherEnabled() { return config.getBoolean("nether.enabled", true); } + @Override public int getSpawnMobLimit() { return config.getInt("spawnmob-limit", 10); } + @Override public boolean showNonEssCommandsInHelp() { return config.getBoolean("non-ess-in-help", true); } + @Override public boolean hidePermissionlessHelp() { return config.getBoolean("hide-permissionless-help", true); } + @Override public int getProtectCreeperMaxHeight() { return config.getInt("protect.creeper.max-height", -1); } + @Override public boolean areSignsDisabled() { return config.getBoolean("signs-disabled", false); } + @Override public long getBackupInterval() { return config.getInt("backup.interval", 1440); // 1440 = 24 * 60 } + @Override public String getBackupCommand() { return config.getString("backup.command", null); } + @Override public String getChatFormat(String group) { return config.getString("chat.group-formats." + (group == null ? "Default" : group), config.getString("chat.format", "&7[{GROUP}]&f {DISPLAYNAME}&7:&f {MESSAGE}")); } + @Override public boolean getGenerateExitPortals() { return config.getBoolean("nether.generate-exit-portals", true); } + @Override public boolean getAnnounceNewPlayers() { return !config.getString("newbies.announce-format", "-").isEmpty(); } + @Override public String getAnnounceNewPlayerFormat(IUser user) { return format(config.getString("newbies.announce-format", "&dWelcome {DISPLAYNAME} to the server!"), user); } + @Override public String format(String format, IUser user) { return format.replace('&', '§').replace("§§", "&").replace("{PLAYER}", user.getDisplayName()).replace("{DISPLAYNAME}", user.getDisplayName()).replace("{GROUP}", user.getGroup()).replace("{USERNAME}", user.getName()).replace("{ADDRESS}", user.getAddress().toString()); } + @Override public String getNewbieSpawn() { return config.getString("newbies.spawnpoint", "default"); } + @Override public boolean getPerWarpPermission() { return config.getBoolean("per-warp-permission", false); } + @Override public boolean getSortListByGroups() { return config.getBoolean("sort-list-by-groups", true); } + @Override public void reloadConfig() { config.load(); } + @Override public List itemSpawnBlacklist() { final List epItemSpwn = new ArrayList(); @@ -286,21 +321,25 @@ public class Settings implements IConf return epItemSpwn; } + @Override public boolean spawnIfNoHome() { return config.getBoolean("spawn-if-no-home", false); } + @Override public boolean warnOnBuildDisallow() { return config.getBoolean("protect.disable.warn-on-build-disallow", false); } + @Override public boolean use1to1RatioInNether() { return config.getBoolean("nether.use-1to1-ratio", false); } + @Override public double getNetherRatio() { if (config.getBoolean("nether.use-1to1-ratio", false)) { @@ -309,46 +348,55 @@ public class Settings implements IConf return config.getDouble("nether.ratio", 16.0); } + @Override public boolean isDebug() { return config.getBoolean("debug", false); } + @Override public boolean warnOnSmite() { return config.getBoolean("warn-on-smite" ,true); } + @Override public boolean permissionBasedItemSpawn() { return config.getBoolean("permission-based-item-spawn", false); } + @Override public String getLocale() { return config.getString("locale", ""); } + @Override public String getCurrencySymbol() { return config.getString("currency-symbol", "$").substring(0, 1).replaceAll("[0-9]", "$"); } + @Override public boolean isTradeInStacks(int id) { return config.getBoolean("trade-in-stacks-" + id, false); } + @Override public boolean isEcoDisabled() { return config.getBoolean("disable-eco", false); } + @Override public boolean getProtectPreventSpawn(final String creatureName) { return config.getBoolean("protect.prevent.spawn."+creatureName, false); } + @Override public List getProtectList(final String configName) { final List list = new ArrayList(); @@ -368,18 +416,20 @@ public class Settings implements IConf return list; } + @Override public String getProtectString(final String configName) { return config.getString(configName, null); } + @Override public boolean getProtectBoolean(final String configName, boolean def) { return config.getBoolean(configName, def); } private final static double MAXMONEY = 10000000000000.0; - double getMaxMoney() + public double getMaxMoney() { double max = config.getDouble("max-money", MAXMONEY); if (Math.abs(max) > MAXMONEY) { @@ -388,17 +438,17 @@ public class Settings implements IConf return max; } - boolean isEcoLogEnabled() + public boolean isEcoLogEnabled() { return config.getBoolean("economy-log-enabled", false); } - boolean removeGodOnDisconnect() + public boolean removeGodOnDisconnect() { return config.getBoolean("remove-god-on-disconnect", false); } - boolean changeDisplayName() + public boolean changeDisplayName() { return config.getBoolean("change-displayname", true); } -- cgit v1.2.3 From 66c4a248523436e33535c9f48dc00d97eced9000 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 02:45:12 +0200 Subject: Fixing the UnitTests --- Essentials/test/com/earth2me/essentials/EconomyTest.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Essentials/test/com/earth2me/essentials/EconomyTest.java b/Essentials/test/com/earth2me/essentials/EconomyTest.java index ff9a6b6b7..219d68b40 100644 --- a/Essentials/test/com/earth2me/essentials/EconomyTest.java +++ b/Essentials/test/com/earth2me/essentials/EconomyTest.java @@ -5,6 +5,7 @@ import com.earth2me.essentials.api.NoLoanPermittedException; import com.earth2me.essentials.api.UserDoesNotExistException; import java.io.IOException; import junit.framework.TestCase; +import org.bukkit.World.Environment; import org.bukkit.plugin.InvalidDescriptionException; import org.junit.Test; @@ -20,6 +21,7 @@ public class EconomyTest extends TestCase super(testName); ess = new Essentials(); final FakeServer server = new FakeServer(); + server.createWorld("testWorld", Environment.NORMAL); try { ess.setupForTesting(server); -- cgit v1.2.3 From 5ab3422b2953da397e521ab015a7998ee30aa598 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 02:54:35 +0200 Subject: German language file corrections --- Essentials/src/messages_de.properties | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Essentials/src/messages_de.properties b/Essentials/src/messages_de.properties index cfc7f41e4..5161fe335 100644 --- a/Essentials/src/messages_de.properties +++ b/Essentials/src/messages_de.properties @@ -14,7 +14,7 @@ backupStarted = Backup gestartet balance = \u00a77Geldb\u00f6rse: {0} balanceTop = \u00a77 Top {0} Guthaben banIpAddress = \u00a77IP-Adresse gesperrt. -banExempt = \u00a7cDu kan ikke forbyde den p\u00e5g\u00e6ldende spiller. +banExempt = \u00a7cDu kannst diesen Spieler nicht sperren. bannedIpsFileError = Fehler beim Lesen von banned-ips.txt bannedIpsFileNotFound = banned-ips.txt nicht gefunden bannedPlayersFileError = Fehler beim Lesen von banned-players.txt @@ -132,7 +132,7 @@ jailNotExist = Dieses Gef\u00e4ngnis existiert nicht. jailSet = \u00a77Gef\u00e4ngnis {0} wurde erstellt. jumpError = Das w\u00fcrde deinen Computer \u00fcberlasten. kickDefault = Vom Server geworfen -kickExempt = \u00a7cSie k\u00f6nnen nicht kicken, dass Spieler. +kickExempt = \u00a7cDu kannst diesen Spieler nicht rauswerfen. kill = \u00a77{0} get\u00f6tet. kitError = \u00a7cEs gibt keine g\u00fcltigen Ausr\u00fcstungen. kitError2 = \u00a7cDiese Ausr\u00fcstung existiert nicht oder ist ung\u00fcltig. @@ -256,7 +256,7 @@ teleportationEnabled = \u00a77Teleportierung aktiviert. teleporting = \u00a77Teleportiere... teleportingPortal = \u00a77Teleportiere durch Portal. tempBanned = Zeitlich gesperrt vom Server f\u00fcr {0} -tempbanExempt = \u00a77You may not tempban that player +tempbanExempt = \u00a77Du kannst diesen Spieler nicht zeitlich sperren. thunder = Du hast Donner in deiner Welt {0}. thunderDuration = Du hast Donner in deiner Welt {0} f\u00fcr {1} Sekunden. timeBeforeHeal = Zeit bis zur n\u00e4chsten Heilung: {0} -- cgit v1.2.3 From d0345e45b69763e6a7b39ff91d38f94df708b245 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 03:11:52 +0200 Subject: Revert broken ban reason for /tempban --- Essentials/src/com/earth2me/essentials/commands/Commandtempban.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Essentials/src/com/earth2me/essentials/commands/Commandtempban.java b/Essentials/src/com/earth2me/essentials/commands/Commandtempban.java index f1d91d2ac..639c2bda0 100644 --- a/Essentials/src/com/earth2me/essentials/commands/Commandtempban.java +++ b/Essentials/src/com/earth2me/essentials/commands/Commandtempban.java @@ -29,7 +29,7 @@ public class Commandtempban extends EssentialsCommand final String time = getFinalArg(args, 1); final long banTimestamp = Util.parseDateDiff(time, true); - final String banReason = (args.length == 3 && !args[2].isEmpty()) ? args[2].toString() + " - " + Util.formatDateDiff(banTimestamp) : Util.format("tempBanned", Util.formatDateDiff(banTimestamp)); + final String banReason = Util.format("tempBanned", Util.formatDateDiff(banTimestamp)); player.setBanReason(banReason); player.setBanTimeout(banTimestamp); player.kickPlayer(banReason); -- cgit v1.2.3 From c3a89580465e2e1ebfabab1b8ace02bbee7cb956 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 03:23:58 +0200 Subject: Colored signs with &0-f Permissions: essentials.signs.color --- .../src/com/earth2me/essentials/signs/SignBlockListener.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Essentials/src/com/earth2me/essentials/signs/SignBlockListener.java b/Essentials/src/com/earth2me/essentials/signs/SignBlockListener.java index dfa1ed052..c452e1b63 100644 --- a/Essentials/src/com/earth2me/essentials/signs/SignBlockListener.java +++ b/Essentials/src/com/earth2me/essentials/signs/SignBlockListener.java @@ -1,6 +1,7 @@ package com.earth2me.essentials.signs; import com.earth2me.essentials.IEssentials; +import com.earth2me.essentials.User; import java.util.logging.Level; import java.util.logging.Logger; import org.bukkit.Material; @@ -100,6 +101,13 @@ public class SignBlockListener extends BlockListener return; } } + User user = ess.getUser(event.getPlayer()); + if (user.isAuthorized("essentials.signs.color")) + { + for (int i = 0; i < 4; i++) { + event.setLine(i, event.getLine(i).replaceAll("&([0-9a-f])", "§$1")); + } + } } @Override -- cgit v1.2.3 From a8fdce257b6160b7edf131a3488af7d22decd6f3 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 03:51:12 +0200 Subject: Log free signs. We don't how much the user takes out of the free sign, so we log the maximum value. Also corrected the stack sizes. --- Essentials/src/com/earth2me/essentials/signs/SignFree.java | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/Essentials/src/com/earth2me/essentials/signs/SignFree.java b/Essentials/src/com/earth2me/essentials/signs/SignFree.java index 46c5a0f6e..55ea1d241 100644 --- a/Essentials/src/com/earth2me/essentials/signs/SignFree.java +++ b/Essentials/src/com/earth2me/essentials/signs/SignFree.java @@ -1,6 +1,8 @@ package com.earth2me.essentials.signs; import com.earth2me.essentials.IEssentials; +import com.earth2me.essentials.InventoryWorkaround; +import com.earth2me.essentials.Trade; import com.earth2me.essentials.User; import net.minecraft.server.InventoryPlayer; import org.bukkit.craftbukkit.inventory.CraftInventoryPlayer; @@ -17,18 +19,20 @@ public class SignFree extends EssentialsSign @Override protected boolean onSignCreate(final ISign sign, final User player, final String username, final IEssentials ess) throws SignException { - getItemStack(sign.getLine(1), 9 * 4 * 64, ess); + getItemStack(sign.getLine(1), 1, ess); return true; } @Override protected boolean onSignInteract(final ISign sign, final User player, final String username, final IEssentials ess) throws SignException { - final ItemStack item = getItemStack(sign.getLine(1), 9 * 4 * 64, ess); + final ItemStack item = getItemStack(sign.getLine(1), 1, ess); + item.setAmount(item.getType().getMaxStackSize()*9*4); final CraftInventoryPlayer inv = new CraftInventoryPlayer(new InventoryPlayer(player.getHandle())); inv.clear(); - inv.addItem(item); + InventoryWorkaround.addItem(inv, true, item); player.showInventory(inv); + Trade.log("Sign", "Free", "Interact", username, null, username, new Trade(item, ess), ess); return true; } } -- cgit v1.2.3 From d9b88a83d11540a31551754557ea4c625c65fdb2 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 04:05:43 +0200 Subject: restricted-commands have been removed from config.yml Now we have a whitelist: player-commands --- .../essentials/ConfigPermissionsHandler.java | 3 +- .../src/com/earth2me/essentials/ISettings.java | 2 + .../src/com/earth2me/essentials/Settings.java | 11 +++ Essentials/src/config.yml | 78 ++++++++++------------ 4 files changed, 49 insertions(+), 45 deletions(-) diff --git a/Essentials/src/com/earth2me/essentials/ConfigPermissionsHandler.java b/Essentials/src/com/earth2me/essentials/ConfigPermissionsHandler.java index 9e3b24b0d..200aa34f8 100644 --- a/Essentials/src/com/earth2me/essentials/ConfigPermissionsHandler.java +++ b/Essentials/src/com/earth2me/essentials/ConfigPermissionsHandler.java @@ -30,7 +30,8 @@ public class ConfigPermissionsHandler implements IPermissionsHandler public boolean hasPermission(final Player base, final String node) { final String[] cmds = node.split("\\.", 2); - return !ess.getSettings().isCommandRestricted(cmds[cmds.length - 1]); + return !ess.getSettings().isCommandRestricted(cmds[cmds.length - 1]) + && ess.getSettings().isPlayerCommand(cmds[cmds.length - 1]); } public String getPrefix(final Player base) diff --git a/Essentials/src/com/earth2me/essentials/ISettings.java b/Essentials/src/com/earth2me/essentials/ISettings.java index c641a8b3f..638f0593a 100644 --- a/Essentials/src/com/earth2me/essentials/ISettings.java +++ b/Essentials/src/com/earth2me/essentials/ISettings.java @@ -126,4 +126,6 @@ public interface ISettings extends IConf boolean removeGodOnDisconnect(); boolean changeDisplayName(); + + boolean isPlayerCommand(String string); } diff --git a/Essentials/src/com/earth2me/essentials/Settings.java b/Essentials/src/com/earth2me/essentials/Settings.java index 75063a15b..d63bc7194 100644 --- a/Essentials/src/com/earth2me/essentials/Settings.java +++ b/Essentials/src/com/earth2me/essentials/Settings.java @@ -100,6 +100,17 @@ public class Settings implements ISettings } return config.getBoolean("restrict-" + label.toLowerCase(), false); } + + @Override + public boolean isPlayerCommand(String label) + { + for (String c : config.getStringList("player-commands", new ArrayList(0))) + { + if (!c.equalsIgnoreCase(label)) continue; + return true; + } + return false; + } @Override public boolean isCommandOverridden(String name) diff --git a/Essentials/src/config.yml b/Essentials/src/config.yml index 50c71aa65..d50144956 100644 --- a/Essentials/src/config.yml +++ b/Essentials/src/config.yml @@ -114,52 +114,42 @@ overridden-commands: disabled-commands: # - nick -# Restricted commands will only be available to ops. +# Restricted commands have been removed. +# Now we have a whitelist, all commands not on this list are only available to ops. # These will have NO EFFECT if you have Permissions installed! # These are here only if you want something simpler than Permissions. -restricted-commands: - - bigtree - - item - - give - - heal - - plugin - - time - - top - - tp - - tphere - - tree - - setspawn - - antioch - - kick - - ban - - unban - - top - - jump - - tpo - - tppos - - tpohere - - economy - - setwarp - - delwarp - - essentials - - gc - - spawnmob - - broadcast - - burn - - ext - - kill - - ping - - banip - - unban - - mute - - kick - - kickall - - unbanip - - togglejail - - setjail - - eco.loan - - teleport.timer.bypass - - teleport.cooldown.bypass +player-commands: + - afk + - back + - back.ondeath + - balance + - clearinventory + - compass + - help + - helpop + - home + - home.others + - ignore + - info + - list + - mail + - motd + - msg + - nick + - pay + - powertool + - r + - rules + - seen + - sell + - sethome + - suicide + - tpa + - tpaccept + - tpahere + - tpdeny + - world + - worth # Note: All items MUST be followed by a quantity! # Times are measured in seconds. -- cgit v1.2.3 From d9bfabd6521db72b2120e370d895c8aea19e0536 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 05:06:08 +0200 Subject: Revert to correct class loader --- Essentials/src/com/earth2me/essentials/Essentials.java | 2 +- .../earth2me/essentials/permissions/EssentialsPermissionsCommands.java | 2 +- EssentialsSpawn/src/com/earth2me/essentials/spawn/EssentialsSpawn.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Essentials/src/com/earth2me/essentials/Essentials.java b/Essentials/src/com/earth2me/essentials/Essentials.java index b308407c2..a7252b1c5 100644 --- a/Essentials/src/com/earth2me/essentials/Essentials.java +++ b/Essentials/src/com/earth2me/essentials/Essentials.java @@ -355,7 +355,7 @@ public class Essentials extends JavaPlugin implements IEssentials @Override public boolean onCommand(CommandSender sender, Command command, String commandLabel, String[] args) { - return onCommandEssentials(sender, command, commandLabel, args, Thread.currentThread().getContextClassLoader(), "com.earth2me.essentials.commands.Command", "essentials."); + return onCommandEssentials(sender, command, commandLabel, args, Essentials.class.getClassLoader(), "com.earth2me.essentials.commands.Command", "essentials."); } public boolean onCommandEssentials(CommandSender sender, Command command, String commandLabel, String[] args, ClassLoader classLoader, String commandPath, String permissionPrefix) diff --git a/EssentialsPermissionsCommands/src/com/earth2me/essentials/permissions/EssentialsPermissionsCommands.java b/EssentialsPermissionsCommands/src/com/earth2me/essentials/permissions/EssentialsPermissionsCommands.java index 0f126afb6..14e9a117c 100644 --- a/EssentialsPermissionsCommands/src/com/earth2me/essentials/permissions/EssentialsPermissionsCommands.java +++ b/EssentialsPermissionsCommands/src/com/earth2me/essentials/permissions/EssentialsPermissionsCommands.java @@ -47,7 +47,7 @@ public class EssentialsPermissionsCommands extends JavaPlugin @Override public boolean onCommand(final CommandSender sender, final Command command, final String label, final String[] args) { - return ess.onCommandEssentials(sender, command, label, args, Thread.currentThread().getContextClassLoader(), "com.earth2me.essentials.permissions.Command", "groupmanager."); + return ess.onCommandEssentials(sender, command, label, args, EssentialsPermissionsCommands.class.getClassLoader(), "com.earth2me.essentials.permissions.Command", "groupmanager."); } @Override diff --git a/EssentialsSpawn/src/com/earth2me/essentials/spawn/EssentialsSpawn.java b/EssentialsSpawn/src/com/earth2me/essentials/spawn/EssentialsSpawn.java index fcc8f6276..1bae3fed3 100644 --- a/EssentialsSpawn/src/com/earth2me/essentials/spawn/EssentialsSpawn.java +++ b/EssentialsSpawn/src/com/earth2me/essentials/spawn/EssentialsSpawn.java @@ -41,6 +41,6 @@ public class EssentialsSpawn extends JavaPlugin @Override public boolean onCommand(CommandSender sender, Command command, String commandLabel, String[] args) { - return ess.onCommandEssentials(sender, command, commandLabel, args, Thread.currentThread().getContextClassLoader(), "com.earth2me.essentials.spawn.Command", "essentials."); + return ess.onCommandEssentials(sender, command, commandLabel, args, EssentialsSpawn.class.getClassLoader(), "com.earth2me.essentials.spawn.Command", "essentials."); } } -- cgit v1.2.3 From f867f675b92a125eaa25c23589ddb68e89f7d9bf Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 05:55:52 +0200 Subject: fix kickexempt --- Essentials/src/com/earth2me/essentials/commands/Commandkick.java | 1 + 1 file changed, 1 insertion(+) diff --git a/Essentials/src/com/earth2me/essentials/commands/Commandkick.java b/Essentials/src/com/earth2me/essentials/commands/Commandkick.java index ac3bcd5f6..6bae4e713 100644 --- a/Essentials/src/com/earth2me/essentials/commands/Commandkick.java +++ b/Essentials/src/com/earth2me/essentials/commands/Commandkick.java @@ -25,6 +25,7 @@ public class Commandkick extends EssentialsCommand if (u.isAuthorized("essentials.kick.exempt")) { sender.sendMessage(Util.i18n("kickExempt")); + return; } charge(sender); final String kickReason = args.length > 1 ? getFinalArg(args, 1) : Util.i18n("kickDefault"); -- cgit v1.2.3 From e6685abe4d437b89f3ecfc73b0f2f16838d00b6f Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 05:56:35 +0200 Subject: Disable old message about iconomy not being enabled before essentials --- Essentials/src/com/earth2me/essentials/register/payment/Methods.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Essentials/src/com/earth2me/essentials/register/payment/Methods.java b/Essentials/src/com/earth2me/essentials/register/payment/Methods.java index 927d4de4c..71e0adae0 100644 --- a/Essentials/src/com/earth2me/essentials/register/payment/Methods.java +++ b/Essentials/src/com/earth2me/essentials/register/payment/Methods.java @@ -70,7 +70,7 @@ public class Methods { if(!plugin.isEnabled()) { this.self = true; - Logger.getLogger("Minecraft").log(Level.SEVERE, name + " Plugin was found, but not enabled before Essentials. Read the Essentials thread for help."); + //Logger.getLogger("Minecraft").log(Level.SEVERE, name + " Plugin was found, but not enabled before Essentials. Read the Essentials thread for help."); //manager.enablePlugin(plugin); } -- cgit v1.2.3 From 5ad12b52f87175e289f1af513baa216a6040f716 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 14:04:30 +0200 Subject: Register API #8f66f7dcae80945250301a9d9e644a74ab28d0b6 Supports BOSE7 --- Essentials/nbproject/project.properties | 6 +- .../essentials/register/payment/Methods.java | 48 ++--- .../essentials/register/payment/methods/BOSE.java | 195 --------------------- .../essentials/register/payment/methods/BOSE6.java | 194 ++++++++++++++++++++ .../essentials/register/payment/methods/BOSE7.java | 188 ++++++++++++++++++++ .../essentials/register/payment/methods/iCo5.java | 2 +- lib/BOSEconomy.jar | Bin 130814 -> 0 bytes lib/BOSEconomy7.jar | Bin 0 -> 155916 bytes 8 files changed, 414 insertions(+), 219 deletions(-) delete mode 100644 Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE.java create mode 100644 Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE6.java create mode 100644 Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE7.java delete mode 100644 lib/BOSEconomy.jar create mode 100644 lib/BOSEconomy7.jar diff --git a/Essentials/nbproject/project.properties b/Essentials/nbproject/project.properties index 850d0d4d8..f8b41cf41 100644 --- a/Essentials/nbproject/project.properties +++ b/Essentials/nbproject/project.properties @@ -26,7 +26,7 @@ dist.jar=${dist.dir}/Essentials.jar dist.javadoc.dir=${dist.dir}/javadoc endorsed.classpath= excludes= -file.reference.BOSEconomy.jar=../lib/BOSEconomy.jar +file.reference.BOSEconomy7.jar=../lib/BOSEconomy7.jar file.reference.craftbukkit-0.0.1-SNAPSHOT.jar=..\\lib\\craftbukkit-0.0.1-SNAPSHOT.jar file.reference.iCo4.jar=../lib/iCo4.jar file.reference.iCo5.jar=../lib/iCo5.jar @@ -37,9 +37,9 @@ jar.compress=false javac.classpath=\ ${file.reference.Permissions3.jar}:\ ${file.reference.craftbukkit-0.0.1-SNAPSHOT.jar}:\ - ${file.reference.BOSEconomy.jar}:\ ${file.reference.iCo4.jar}:\ - ${file.reference.iCo5.jar} + ${file.reference.iCo5.jar}:\ + ${file.reference.BOSEconomy7.jar} # Space-separated list of extra javac options javac.compilerargs= javac.deprecation=false diff --git a/Essentials/src/com/earth2me/essentials/register/payment/Methods.java b/Essentials/src/com/earth2me/essentials/register/payment/Methods.java index 71e0adae0..0ebbcfb84 100644 --- a/Essentials/src/com/earth2me/essentials/register/payment/Methods.java +++ b/Essentials/src/com/earth2me/essentials/register/payment/Methods.java @@ -1,14 +1,12 @@ package com.earth2me.essentials.register.payment; +import org.bukkit.plugin.Plugin; +import org.bukkit.plugin.PluginManager; + import java.util.HashSet; import java.util.Set; -import java.util.logging.Level; -import java.util.logging.Logger; -import org.bukkit.plugin.Plugin; -import org.bukkit.plugin.PluginManager; - -/*** +/** * Methods.java * Controls the getting / setting of methods & the method of payment used. * @@ -19,18 +17,36 @@ import org.bukkit.plugin.PluginManager; public class Methods { private boolean self = false; private Method Method = null; - private String preferred = ""; + private String preferred = ""; private Set Methods = new HashSet(); private Set Dependencies = new HashSet(); - private Set Attachables = new HashSet(); + private Set Attachables = new HashSet(); public Methods() { + this._init(); + } + + /** + * Allows you to set which economy plugin is most preferred. + * + * @param preferred - preferred economy plugin + */ + public Methods(String preferred) { + this._init(); + + if(this.Dependencies.contains(preferred)) { + this.preferred = preferred; + } + } + + private void _init() { this.addMethod("iConomy", new com.earth2me.essentials.register.payment.methods.iCo4()); this.addMethod("iConomy", new com.earth2me.essentials.register.payment.methods.iCo5()); - this.addMethod("BOSEconomy", new com.earth2me.essentials.register.payment.methods.BOSE()); + this.addMethod("BOSEconomy", new com.earth2me.essentials.register.payment.methods.BOSE6()); + this.addMethod("BOSEconomy", new com.earth2me.essentials.register.payment.methods.BOSE7()); } - public Set getDependencies() { + public Set getDependencies() { return Dependencies; } @@ -60,7 +76,7 @@ public class Methods { int count = 0; boolean match = false; - Plugin plugin = null; + Plugin plugin; PluginManager manager = method.getServer().getPluginManager(); for(String name: this.getDependencies()) { @@ -68,14 +84,6 @@ public class Methods { if(method.getDescription().getName().equals(name)) plugin = method; else plugin = manager.getPlugin(name); if(plugin == null) continue; - if(!plugin.isEnabled()) { - this.self = true; - //Logger.getLogger("Minecraft").log(Level.SEVERE, name + " Plugin was found, but not enabled before Essentials. Read the Essentials thread for help."); - //manager.enablePlugin(plugin); - } - - if(plugin == null) continue; - Method current = this.createMethod(plugin); if(current == null) continue; @@ -86,7 +94,7 @@ public class Methods { } } - if(!this.preferred.isEmpty()) { + if(!this.preferred.isEmpty()) { do { if(hasMethod()) { match = true; diff --git a/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE.java b/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE.java deleted file mode 100644 index cce5691b9..000000000 --- a/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE.java +++ /dev/null @@ -1,195 +0,0 @@ -package com.earth2me.essentials.register.payment.methods; - -import com.earth2me.essentials.register.payment.Method; -import cosine.boseconomy.BOSEconomy; -import org.bukkit.plugin.Plugin; - -public class BOSE implements Method { - private BOSEconomy BOSEconomy; - - public BOSEconomy getPlugin() { - return this.BOSEconomy; - } - - public String getName() { - return "BOSEconomy"; - } - - public String getVersion() { - return "0.6.2"; - } - - public String format(double amount) { - String currency = this.BOSEconomy.getMoneyNamePlural(); - if(amount == 1) currency = this.BOSEconomy.getMoneyName(); - return amount + " " + currency; - } - - public boolean hasBanks() { - return true; - } - - public boolean hasBank(String bank) { - return this.BOSEconomy.bankExists(bank); - } - - public boolean hasAccount(String name) { - return this.BOSEconomy.playerRegistered(name, false); - } - - public boolean hasBankAccount(String bank, String name) { - return this.BOSEconomy.isBankOwner(bank, name); - } - - public MethodAccount getAccount(String name) { - if(!hasAccount(name)) return null; - return new BOSEAccount(name, this.BOSEconomy); - } - - public MethodBankAccount getBankAccount(String bank, String name) { - return new BOSEBankAccount(bank, name, BOSEconomy); - } - - public boolean isCompatible(Plugin plugin) { - return plugin.getDescription().getName().equalsIgnoreCase("boseconomy") && plugin instanceof BOSEconomy; - } - - public void setPlugin(Plugin plugin) { - BOSEconomy = (BOSEconomy)plugin; - } - - public class BOSEAccount implements MethodAccount { - private String name; - private BOSEconomy BOSEconomy; - - public BOSEAccount(String name, BOSEconomy bOSEconomy) { - this.name = name; - this.BOSEconomy = bOSEconomy; - } - - public double balance() { - return Double.valueOf(this.BOSEconomy.getPlayerMoney(this.name)); - } - - public boolean set(double amount) { - int IntAmount = (int)Math.ceil(amount); - return this.BOSEconomy.setPlayerMoney(this.name, IntAmount, false); - } - - public boolean add(double amount) { - int IntAmount = (int)Math.ceil(amount); - return this.BOSEconomy.addPlayerMoney(this.name, IntAmount, false); - } - - public boolean subtract(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setPlayerMoney(this.name, (balance - IntAmount), false); - } - - public boolean multiply(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setPlayerMoney(this.name, (balance * IntAmount), false); - } - - public boolean divide(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setPlayerMoney(this.name, (balance / IntAmount), false); - } - - public boolean hasEnough(double amount) { - return (this.balance() >= amount); - } - - public boolean hasOver(double amount) { - return (this.balance() > amount); - } - - public boolean hasUnder(double amount) { - return (this.balance() < amount); - } - - public boolean isNegative() { - return (this.balance() < 0); - } - - public boolean remove() { - return false; - } - } - - public class BOSEBankAccount implements MethodBankAccount { - private String bank; - private String name; - private BOSEconomy BOSEconomy; - - public BOSEBankAccount(String bank, String name, BOSEconomy bOSEconomy) { - this.name = name; - this.bank = bank; - this.BOSEconomy = bOSEconomy; - } - - public String getBankName() { - return this.bank; - } - - public int getBankId() { - return -1; - } - - public double balance() { - return Double.valueOf(this.BOSEconomy.getBankMoney(name)); - } - - public boolean set(double amount) { - int IntAmount = (int)Math.ceil(amount); - return this.BOSEconomy.setBankMoney(name, IntAmount, true); - } - - public boolean add(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setBankMoney(this.name, (balance + IntAmount), false); - } - - public boolean subtract(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setBankMoney(this.name, (balance - IntAmount), false); - } - - public boolean multiply(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setBankMoney(this.name, (balance * IntAmount), false); - } - - public boolean divide(double amount) { - int IntAmount = (int)Math.ceil(amount); - int balance = (int)this.balance(); - return this.BOSEconomy.setBankMoney(this.name, (balance / IntAmount), false); - } - - public boolean hasEnough(double amount) { - return (this.balance() >= amount); - } - - public boolean hasOver(double amount) { - return (this.balance() > amount); - } - - public boolean hasUnder(double amount) { - return (this.balance() < amount); - } - - public boolean isNegative() { - return (this.balance() < 0); - } - - public boolean remove() { - return this.BOSEconomy.removeBank(bank); - } - } -} \ No newline at end of file diff --git a/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE6.java b/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE6.java new file mode 100644 index 000000000..6293f81be --- /dev/null +++ b/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE6.java @@ -0,0 +1,194 @@ +package com.earth2me.essentials.register.payment.methods; + +import com.earth2me.essentials.register.payment.Method; +import cosine.boseconomy.BOSEconomy; +import org.bukkit.plugin.Plugin; + +public class BOSE6 implements Method { + private BOSEconomy BOSEconomy; + + public BOSEconomy getPlugin() { + return this.BOSEconomy; + } + + public String getName() { + return "BOSEconomy"; + } + + public String getVersion() { + return "0.6.2"; + } + + public String format(double amount) { + String currency = this.BOSEconomy.getMoneyNamePlural(); + if(amount == 1) currency = this.BOSEconomy.getMoneyName(); + return amount + " " + currency; + } + + public boolean hasBanks() { + return true; + } + + public boolean hasBank(String bank) { + return this.BOSEconomy.bankExists(bank); + } + + public boolean hasAccount(String name) { + return this.BOSEconomy.playerRegistered(name, false); + } + + public boolean hasBankAccount(String bank, String name) { + return this.BOSEconomy.isBankOwner(bank, name) || this.BOSEconomy.isBankMember(bank, name); + } + + public MethodAccount getAccount(String name) { + if(!hasAccount(name)) return null; + return new BOSEAccount(name, this.BOSEconomy); + } + + public MethodBankAccount getBankAccount(String bank, String name) { + if(!hasBankAccount(bank, name)) return null; + return new BOSEBankAccount(bank, BOSEconomy); + } + + public boolean isCompatible(Plugin plugin) { + return plugin.getDescription().getName().equalsIgnoreCase("boseconomy") && plugin instanceof BOSEconomy && plugin.getDescription().getVersion().equals("0.6.2"); + } + + public void setPlugin(Plugin plugin) { + BOSEconomy = (BOSEconomy)plugin; + } + + public class BOSEAccount implements MethodAccount { + private String name; + private BOSEconomy BOSEconomy; + + public BOSEAccount(String name, BOSEconomy bOSEconomy) { + this.name = name; + this.BOSEconomy = bOSEconomy; + } + + public double balance() { + return Double.valueOf(this.BOSEconomy.getPlayerMoney(this.name)); + } + + public boolean set(double amount) { + int IntAmount = (int)Math.ceil(amount); + return this.BOSEconomy.setPlayerMoney(this.name, IntAmount, false); + } + + public boolean add(double amount) { + int IntAmount = (int)Math.ceil(amount); + return this.BOSEconomy.addPlayerMoney(this.name, IntAmount, false); + } + + public boolean subtract(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance - IntAmount), false); + } + + public boolean multiply(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance * IntAmount), false); + } + + public boolean divide(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance / IntAmount), false); + } + + public boolean hasEnough(double amount) { + return (this.balance() >= amount); + } + + public boolean hasOver(double amount) { + return (this.balance() > amount); + } + + public boolean hasUnder(double amount) { + return (this.balance() < amount); + } + + public boolean isNegative() { + return (this.balance() < 0); + } + + public boolean remove() { + return false; + } + } + + public class BOSEBankAccount implements MethodBankAccount { + private String bank; + private BOSEconomy BOSEconomy; + + public BOSEBankAccount(String bank, BOSEconomy bOSEconomy) { + this.bank = bank; + this.BOSEconomy = bOSEconomy; + } + + public String getBankName() { + return this.bank; + } + + public int getBankId() { + return -1; + } + + public double balance() { + return Double.valueOf(this.BOSEconomy.getBankMoney(bank)); + } + + public boolean set(double amount) { + int IntAmount = (int)Math.ceil(amount); + return this.BOSEconomy.setBankMoney(bank, IntAmount, true); + } + + public boolean add(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance + IntAmount), false); + } + + public boolean subtract(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance - IntAmount), false); + } + + public boolean multiply(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance * IntAmount), false); + } + + public boolean divide(double amount) { + int IntAmount = (int)Math.ceil(amount); + int balance = (int)this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance / IntAmount), false); + } + + public boolean hasEnough(double amount) { + return (this.balance() >= amount); + } + + public boolean hasOver(double amount) { + return (this.balance() > amount); + } + + public boolean hasUnder(double amount) { + return (this.balance() < amount); + } + + public boolean isNegative() { + return (this.balance() < 0); + } + + public boolean remove() { + return this.BOSEconomy.removeBank(bank); + } + } +} \ No newline at end of file diff --git a/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE7.java b/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE7.java new file mode 100644 index 000000000..3612c89e4 --- /dev/null +++ b/Essentials/src/com/earth2me/essentials/register/payment/methods/BOSE7.java @@ -0,0 +1,188 @@ +package com.earth2me.essentials.register.payment.methods; + +import com.earth2me.essentials.register.payment.Method; +import cosine.boseconomy.BOSEconomy; +import org.bukkit.plugin.Plugin; + +/** + * @author Acrobot + */ + +public class BOSE7 implements Method { + private BOSEconomy BOSEconomy; + + public BOSEconomy getPlugin() { + return this.BOSEconomy; + } + + public String getName() { + return "BOSEconomy"; + } + + public String getVersion() { + return "0.7.0"; + } + + public String format(double amount) { + String currency = this.BOSEconomy.getMoneyNamePlural(); + if(amount == 1) currency = this.BOSEconomy.getMoneyName(); + return amount + " " + currency; + } + + public boolean hasBanks() { + return true; + } + + public boolean hasBank(String bank) { + return this.BOSEconomy.bankExists(bank); + } + + public boolean hasAccount(String name) { + return this.BOSEconomy.playerRegistered(name, false); + } + + public boolean hasBankAccount(String bank, String name) { + return this.BOSEconomy.isBankOwner(bank, name) || this.BOSEconomy.isBankMember(bank, name); + } + + public MethodAccount getAccount(String name) { + if(!hasAccount(name)) return null; + return new BOSEAccount(name, this.BOSEconomy); + } + + public MethodBankAccount getBankAccount(String bank, String name) { + if(!hasBankAccount(bank, name)) return null; + return new BOSEBankAccount(bank, BOSEconomy); + } + + public boolean isCompatible(Plugin plugin) { + return plugin.getDescription().getName().equalsIgnoreCase("boseconomy") && plugin instanceof BOSEconomy && !plugin.getDescription().getVersion().equals("0.6.2"); + } + + public void setPlugin(Plugin plugin) { + BOSEconomy = (BOSEconomy)plugin; + } + + public class BOSEAccount implements MethodAccount { + private String name; + private BOSEconomy BOSEconomy; + + public BOSEAccount(String name, BOSEconomy bOSEconomy) { + this.name = name; + this.BOSEconomy = bOSEconomy; + } + + public double balance() { + return this.BOSEconomy.getPlayerMoneyDouble(this.name); + } + + public boolean set(double amount) { + return this.BOSEconomy.setPlayerMoney(this.name, amount, false); + } + + public boolean add(double amount) { + return this.BOSEconomy.addPlayerMoney(this.name, amount, false); + } + + public boolean subtract(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance - amount), false); + } + + public boolean multiply(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance * amount), false); + } + + public boolean divide(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setPlayerMoney(this.name, (balance / amount), false); + } + + public boolean hasEnough(double amount) { + return (this.balance() >= amount); + } + + public boolean hasOver(double amount) { + return (this.balance() > amount); + } + + public boolean hasUnder(double amount) { + return (this.balance() < amount); + } + + public boolean isNegative() { + return (this.balance() < 0); + } + + public boolean remove() { + return false; + } + } + + public class BOSEBankAccount implements MethodBankAccount { + private String bank; + private BOSEconomy BOSEconomy; + + public BOSEBankAccount(String bank, BOSEconomy bOSEconomy) { + this.bank = bank; + this.BOSEconomy = bOSEconomy; + } + + public String getBankName() { + return this.bank; + } + + public int getBankId() { + return -1; + } + + public double balance() { + return this.BOSEconomy.getBankMoneyDouble(bank); + } + + public boolean set(double amount) { + return this.BOSEconomy.setBankMoney(bank, amount, true); + } + + public boolean add(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance + amount), false); + } + + public boolean subtract(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance - amount), false); + } + + public boolean multiply(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance * amount), false); + } + + public boolean divide(double amount) { + double balance = this.balance(); + return this.BOSEconomy.setBankMoney(bank, (balance / amount), false); + } + + public boolean hasEnough(double amount) { + return (this.balance() >= amount); + } + + public boolean hasOver(double amount) { + return (this.balance() > amount); + } + + public boolean hasUnder(double amount) { + return (this.balance() < amount); + } + + public boolean isNegative() { + return (this.balance() < 0); + } + + public boolean remove() { + return this.BOSEconomy.removeBank(bank); + } + } +} \ No newline at end of file diff --git a/Essentials/src/com/earth2me/essentials/register/payment/methods/iCo5.java b/Essentials/src/com/earth2me/essentials/register/payment/methods/iCo5.java index f30af7dde..28931eac2 100644 --- a/Essentials/src/com/earth2me/essentials/register/payment/methods/iCo5.java +++ b/Essentials/src/com/earth2me/essentials/register/payment/methods/iCo5.java @@ -208,4 +208,4 @@ public class iCo5 implements Method { return true; } } -} \ No newline at end of file +} diff --git a/lib/BOSEconomy.jar b/lib/BOSEconomy.jar deleted file mode 100644 index bba5231f9..000000000 Binary files a/lib/BOSEconomy.jar and /dev/null differ diff --git a/lib/BOSEconomy7.jar b/lib/BOSEconomy7.jar new file mode 100644 index 000000000..2ce672afa Binary files /dev/null and b/lib/BOSEconomy7.jar differ -- cgit v1.2.3 From 088f50ce8ae6d3b75392526cff929c3c8aed928a Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 16:52:50 +0200 Subject: mute for offline users --- Essentials/src/com/earth2me/essentials/commands/Commandmute.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Essentials/src/com/earth2me/essentials/commands/Commandmute.java b/Essentials/src/com/earth2me/essentials/commands/Commandmute.java index aca821aac..5b3fef6de 100644 --- a/Essentials/src/com/earth2me/essentials/commands/Commandmute.java +++ b/Essentials/src/com/earth2me/essentials/commands/Commandmute.java @@ -21,7 +21,7 @@ public class Commandmute extends EssentialsCommand throw new NotEnoughArgumentsException(); } - User p = getPlayer(server, args, 0); + User p = getPlayer(server, args, 0, true); long muteTimestamp = 0; if (args.length > 1) { -- cgit v1.2.3 From 48230f615d0d3a6f3d98d03960ccf71c337f914a Mon Sep 17 00:00:00 2001 From: snowleo Date: Sat, 16 Jul 2011 17:04:25 +0200 Subject: Fixes to EssentialsProtect that will remove conflicts with WorldGuard and other protection plugins. --- .../essentials/protect/EssentialsProtectBlockListener.java | 8 ++++++++ .../essentials/protect/EssentialsProtectEntityListener.java | 4 ++++ .../essentials/protect/EssentialsProtectPlayerListener.java | 4 ++++ 3 files changed, 16 insertions(+) diff --git a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectBlockListener.java b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectBlockListener.java index 8bc26f67e..1b9736a5a 100644 --- a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectBlockListener.java +++ b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectBlockListener.java @@ -97,6 +97,10 @@ public class EssentialsProtectBlockListener extends BlockListener @Override public void onBlockIgnite(BlockIgniteEvent event) { + if (event.isCancelled()) + { + return; + } Block block = event.getBlock(); if (block.getType() == Material.RAILS && prot.getSettingBool(ProtectConfig.protect_rails)) @@ -185,6 +189,10 @@ public class EssentialsProtectBlockListener extends BlockListener @Override public void onBlockBurn(final BlockBurnEvent event) { + if (event.isCancelled()) + { + return; + } final Block block = event.getBlock(); if (block.getType() == Material.RAILS && prot.getSettingBool(ProtectConfig.protect_rails)) { diff --git a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectEntityListener.java b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectEntityListener.java index f8166b1d5..defbde243 100644 --- a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectEntityListener.java +++ b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectEntityListener.java @@ -292,6 +292,10 @@ public class EssentialsProtectEntityListener extends EntityListener @Override public void onEntityTarget(final EntityTargetEvent event) { + if (event.isCancelled()) + { + return; + } if (!(event.getTarget() instanceof Player)) { return; diff --git a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectPlayerListener.java b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectPlayerListener.java index a2209a46a..aefb6bfe6 100644 --- a/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectPlayerListener.java +++ b/EssentialsProtect/src/com/earth2me/essentials/protect/EssentialsProtectPlayerListener.java @@ -24,6 +24,10 @@ public class EssentialsProtectPlayerListener extends PlayerListener @Override public void onPlayerInteract(final PlayerInteractEvent event) { + if (event.isCancelled()) + { + return; + } final User user = ess.getUser(event.getPlayer()); if (prot.getSettingBool(ProtectConfig.disable_build) && !user.canBuild()) -- cgit v1.2.3