'quiet' -> 'mute', add duration parameter

This commit is contained in:
jesopo 2019-06-27 20:52:32 +01:00
parent 1c5e1efecd
commit 74befb18bc

View file

@ -23,15 +23,15 @@ class InvalidTimeoutException(Exception):
@utils.export("channelset", {"setting": "ban-format", @utils.export("channelset", {"setting": "ban-format",
"help": "Set ban format ($n = nick, $u = username, $h = hostname)", "help": "Set ban format ($n = nick, $u = username, $h = hostname)",
"example": "*!$u@$h"}) "example": "*!$u@$h"})
@utils.export("serverset", {"setting": "quiet-method", @utils.export("serverset", {"setting": "mute-method",
"help": "Set this server's method of quieting users", "example": "qmode"}) "help": "Set this server's method of muting users", "example": "qmode"})
class Module(ModuleManager.BaseModule): class Module(ModuleManager.BaseModule):
_name = "ChanOp" _name = "ChanOp"
@utils.hook("timer.unban") @utils.hook("timer.unban")
def _timer_unban(self, event): def _timer_unban(self, event):
server = self.bot.get_server_by_id(event["server_id"]) server = self.bot.get_server_by_id(event["server_id"])
if event["channel_name"] in server.channels: if server and event["channel_name"] in server.channels:
channel = server.channels.get(event["channel_name"]) channel = server.channels.get(event["channel_name"])
channel.send_unban(event["hostmask"]) channel.send_unban(event["hostmask"])
@ -313,29 +313,28 @@ class Module(ModuleManager.BaseModule):
""" """
event["target"].send_part() event["target"].send_part()
def _quiet_method(self, server, user): def _mute_method(self, server, user):
mask = "*!*@%s" % user.hostname mask = "*!*@%s" % user.hostname
quiet_method = server.get_setting("quiet-method", "qmode").lower() mute_method = server.get_setting("mute-method", "qmode").lower()
if quiet_method == "qmode": if mute_method == "qmode":
return "q", mask return "q", mask
elif quiet_method == "insp": elif mute_method == "insp":
return "b", "m:%s" % mask return "b", "m:%s" % mask
elif quiet_method == "unreal": elif mute_method == "unreal":
return "b", "~q:%s" % mask return "b", "~q:%s" % mask
raise ValueError("Unknown quiet-method '%s'" % quiet_method) raise ValueError("Unknown mute-method '%s'" % mute_method)
@utils.hook("received.command.mute", usage="<nickname> [duration]")
@utils.hook("received.command.quiet") @utils.hook("received.command.unmute", usage="<nickname>")
@utils.hook("received.command.unquiet")
@utils.kwarg("min_args", 1) @utils.kwarg("min_args", 1)
@utils.kwarg("channel-only", True) @utils.kwarg("channel-only", True)
@utils.kwarg("require-mode", "o") @utils.kwarg("require-mode", "o")
@utils.kwarg("require-access", "quiet") @utils.kwarg("require-access", "mute")
@utils.kwarg("help", "Quiet a given user") @utils.kwarg("help", "Mute a given user")
@utils.kwarg("usage", "<nickname>") @utils.kwarg("usage", "<nickname>")
def _do_quiet(self, event): def _mute(self, event):
add = event.name == "received.command.quiet" add = event.name == "received.command.mute"
target_name = event["args_split"][0] target_name = event["args_split"][0]
if not event["server"].has_user(target_name): if not event["server"].has_user(target_name):
@ -345,6 +344,23 @@ class Module(ModuleManager.BaseModule):
if not event["target"].has_user(target_user): if not event["target"].has_user(target_user):
raise utils.EventError("No such user") raise utils.EventError("No such user")
mode, mask = self._quiet_method(event["server"], target_user) mode, mask = self._mute_method(event["server"], target_user)
if add and len(event["args_split"]) > 1:
duration = utils.from_pretty_time(event["args_split"][1])
if duration == None:
raise utils.EventError("Invalid duration")
self.timers.add_persistent("unmute", duration,
server_id=event["server"].id, channel_name=event["target"].name,
mode=mode, mask=mask)
mode_modifier = "+" if add else "-" mode_modifier = "+" if add else "-"
event["target"].send_mode("%s%s" % (mode_modifier, mode), [mask]) event["target"].send_mode("%s%s" % (mode_modifier, mode), [mask])
@utils.hook("timer.unmute")
def _timer_unmute(self, event):
server = self.bot.get_server_by_id(event["server_id"])
if server and event["channel_name"] in server.channels:
channel = server.channels.get(event["channel_name"])
channel.send_mode("-%s" % event["mode"], [event["mask"]])