Added command intercepter tool, used it for //calc #49

Closed
Dico200 wants to merge 8 commits from command-intercepter into dev
2 changed files with 31 additions and 100 deletions
Showing only changes of commit 80eff984e8 - Show all commits

129
imbusy.py
View File

@ -209,110 +209,43 @@ def reply(sender):
reply_targets[target.getName()] = (sender_name, True) reply_targets[target.getName()] = (sender_name, True)
return True return True
try:
class CommandWrapper(Command): def msg_interception(sender, args):
return not is_player(sender) or len(args) <= 1 or whisper(sender, args[0])
def __init__(self, wrapped, checker): def reply_interception(sender, args):
Command.__init__(self, wrapped.getName()) return not is_player(sender) or len(args) == 0 or reply(sender)
self.setDescription(wrapped.getDescription())
self.setPermission(wrapped.getPermission())
self.setUsage(wrapped.getUsage())
self.setAliases(wrapped.getAliases())
self.wrapped = wrapped
self.checker = checker
def execute(self, sender, label, args): def tpa_interception(sender, args):
try: if len(args) == 0 or not is_player(sender):
if not is_player(sender) or self.checker(sender, args): return True
return self.wrapped.execute(sender, label, args) target = server.getPlayer(args[0])
except: if target is not None and not can_send(sender, target):
error(trace()) msg(sender, "&c[&fBUSY&c] %s&r is busy!" % target.getDisplayName())
return False
return True return True
def tabComplete(self, sender, alias, args): def tpahere_interception(sender, args):
return self.wrapped.tabComplete(sender, alias, args) return tpa_command_checker(sender, args)
def mail_interception(sender, args):
def msg_command_checker(sender, args): if len(args) < 3 or args[0].lower() != "send" or not is_player(sender):
return len(args) <= 1 or whisper(sender, args[0]) return True
target = server.getPlayer(args[1])
def reply_command_checker(sender, args): if target is not None and not can_send(sender, target):
return len(args) == 0 or reply(sender) msg(sender, "&c[&fBUSY&c] %s&r is busy!" % target.getDisplayName())
return False
def tpa_command_checker(sender, args):
if len(args) == 0:
return True return True
target = server.getPlayer(args[0])
if target is not None and not can_send(sender, target):
msg(sender, "&c[&fBUSY&c] %s&r is busy!" % target.getDisplayName())
return False
return True
def tpahere_command_checker(sender, args): register = shared["modules"]["misc"].CommandInterceptions.register
return tpa_command_checker(sender, args) register("essentials", "msg", msg_interception)
register("minecraft", "tell", msg_interception)
register("essentials", "reply", reply_interception)
register("essentials", "tpa", tpa_interception)
register("essentials", "tpahere", tpahere_interception)
register("essentials", "mail", mail_interception)
def mail_command_checker(sender, args): except:
if len(args) < 3 or args[0].lower() != "send": error("[Imbusy] Failed to intercept commands:")
return True error(trace())
target = server.getPlayer(args[1])
if target is not None and not can_send(sender, target):
msg(sender, "&c[&fBUSY&c] %s&r is busy!" % target.getDisplayName())
return False
return True
@hook.event("player.PlayerCommandPreprocessEvent", "monitor")
def on_player_command_preprocess(event):
message = event.getMessage().split(" ")
if len(message) > 1 and message[0].lower() in ("/tell", "/minecraft:tell") and not whisper(event.getPlayer(), message[1]):
event.setCancelled(True)
def replace_ess_commands():
try:
map_field = server.getPluginManager().getClass().getDeclaredField("commandMap")
map_field.setAccessible(True)
command_map = map_field.get(server.getPluginManager())
commands_field = command_map.getClass().getDeclaredField("knownCommands")
commands_field.setAccessible(True)
map = commands_field.get(command_map)
ess_msg_cmd = map.get("essentials:msg")
ess_reply_cmd = map.get("essentials:reply")
ess_tpa_cmd = map.get("essentials:tpa")
ess_tpahere_cmd = map.get("essentials:tpahere")
ess_mail_cmd = map.get("essentials:mail")
msg_cmd_wrapper = CommandWrapper(ess_msg_cmd, msg_command_checker)
reply_cmd_wrapper = CommandWrapper(ess_reply_cmd, reply_command_checker)
tpa_cmd_wrapper = CommandWrapper(ess_tpa_cmd, tpa_command_checker)
tpahere_cmd_wrapper = CommandWrapper(ess_tpahere_cmd, tpahere_command_checker)
mail_cmd_wrapper = CommandWrapper(ess_mail_cmd, mail_command_checker)
iterator = map.entrySet().iterator()
wrapped_commands = []
while iterator.hasNext():
entry = iterator.next()
value = entry.getValue()
changed = True
if value is ess_msg_cmd:
entry.setValue(msg_cmd_wrapper)
elif value is ess_reply_cmd:
entry.setValue(reply_cmd_wrapper)
elif value is ess_tpa_cmd:
entry.setValue(tpa_cmd_wrapper)
elif value is ess_tpahere_cmd:
entry.setValue(tpahere_cmd_wrapper)
elif value is ess_mail_cmd:
entry.setValue(mail_cmd_wrapper)
else:
changed = False
if changed:
wrapped_commands.append(entry.getKey())
info("[imbusy] wrapped commands: /" + ", /".join(wrapped_commands))
except:
error("[Imbusy] Failed to wrap essentials commands")
error(trace())

View File

@ -21,8 +21,6 @@ except:
def on_enable(): def on_enable():
if "blockplacemods" in shared["modules"]: if "blockplacemods" in shared["modules"]:
shared["modules"]["blockplacemods"].schedule_torch_breaker() shared["modules"]["blockplacemods"].schedule_torch_breaker()
if "imbusy" in shared["modules"]:
shared["modules"]["imbusy"].replace_ess_commands()
if "serversigns" in shared["modules"]: if "serversigns" in shared["modules"]:
shared["modules"]["serversigns"].check_all_signs_and_force_commands() shared["modules"]["serversigns"].check_all_signs_and_force_commands()
info("RedstonerUtils enabled!") info("RedstonerUtils enabled!")