From 4b671cc4c7c0652cad41fd2a6bf28955db672e46 Mon Sep 17 00:00:00 2001 From: unknown Date: Tue, 18 Mar 2014 16:07:51 +0100 Subject: [PATCH] Block plugin-specific commands for 1.7.2-R0.3 --- buildnumber.properties | 4 +-- .../TotalFreedomMod/TFM_CommandBlocker.java | 31 ++++++++++++------- .../TotalFreedomMod/TFM_ConfigEntry.java | 2 +- 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/buildnumber.properties b/buildnumber.properties index 7c1be24..6e828e6 100644 --- a/buildnumber.properties +++ b/buildnumber.properties @@ -1,3 +1,3 @@ #Build Number for ANT. Do not edit! -#Tue Jan 14 20:43:15 CET 2014 -build.number=698 +#Tue Mar 18 16:06:56 CET 2014 +build.number=702 diff --git a/src/me/StevenLawson/TotalFreedomMod/TFM_CommandBlocker.java b/src/me/StevenLawson/TotalFreedomMod/TFM_CommandBlocker.java index de88ab5..e909aa2 100644 --- a/src/me/StevenLawson/TotalFreedomMod/TFM_CommandBlocker.java +++ b/src/me/StevenLawson/TotalFreedomMod/TFM_CommandBlocker.java @@ -14,6 +14,7 @@ import org.bukkit.entity.Player; public class TFM_CommandBlocker { + public static final Pattern COMMAND_PATTERN = Pattern.compile("^/?(\\S+)"); private Map blockedCommands = new HashMap(); private TFM_CommandBlocker() @@ -35,19 +36,19 @@ public class TFM_CommandBlocker List _blockedCommands = (List) TFM_ConfigEntry.BLOCKED_COMMANDS.getList(); for (String rawEntry : _blockedCommands) { - String[] parts = rawEntry.split(":"); + final String[] parts = rawEntry.split(":"); if (parts.length < 3 || parts.length > 4) { continue; } - CommandBlockerRank rank = CommandBlockerRank.fromToken(parts[0]); + final CommandBlockerRank rank = CommandBlockerRank.fromToken(parts[0]); if (rank == null) { continue; } - CommandBlockerAction action = CommandBlockerAction.fromToken(parts[1]); + final CommandBlockerAction action = CommandBlockerAction.fromToken(parts[1]); if (action == null) { continue; @@ -58,7 +59,7 @@ public class TFM_CommandBlocker { continue; } - Matcher matcher = Pattern.compile("^/?(\\S+)").matcher(command); + final Matcher matcher = COMMAND_PATTERN.matcher(command); if (matcher.find()) { command = matcher.group(1); @@ -82,9 +83,9 @@ public class TFM_CommandBlocker message = parts[3]; } - CommandBlockerEntry blockedCommandEntry = new CommandBlockerEntry(rank, action, command, message); + final CommandBlockerEntry blockedCommandEntry = new CommandBlockerEntry(rank, action, command, message); - Command bukkitCommand = commandMap.getCommand(command); + final Command bukkitCommand = commandMap.getCommand(command); if (bukkitCommand == null) { //TFM_Log.info("Blocking unknown command: " + blockedCommandEntry.getCommand()); @@ -118,7 +119,7 @@ public class TFM_CommandBlocker return false; } - Matcher matcher = Pattern.compile("^/?(\\S+)").matcher(command); + final Matcher matcher = COMMAND_PATTERN.matcher(command); if (matcher.find()) { command = matcher.group(1); @@ -136,15 +137,21 @@ public class TFM_CommandBlocker return false; } - final CommandBlockerEntry blockedCommandEntry = blockedCommands.get(command); - - if (blockedCommandEntry != null) + if (command.contains(":")) { - if (!blockedCommandEntry.getRank().hasPermission(sender)) + TFM_Util.playerMsg(sender, "Plugin-specific commands are disabled."); + return true; + } + + final CommandBlockerEntry entry = blockedCommands.get(command); + + if (entry != null) + { + if (!entry.getRank().hasPermission(sender)) { if (doAction) { - blockedCommandEntry.doActions(sender); + entry.doActions(sender); } return true; diff --git a/src/me/StevenLawson/TotalFreedomMod/TFM_ConfigEntry.java b/src/me/StevenLawson/TotalFreedomMod/TFM_ConfigEntry.java index cf219b6..665d1d7 100644 --- a/src/me/StevenLawson/TotalFreedomMod/TFM_ConfigEntry.java +++ b/src/me/StevenLawson/TotalFreedomMod/TFM_ConfigEntry.java @@ -121,7 +121,7 @@ public enum TFM_ConfigEntry return value; } - public List getList() + public List getList() { return TFM_Config.getInstance().getList(this); }