aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar jesopo2018-07-19 14:39:10 +0100
committerGravatar jesopo2018-07-19 14:39:10 +0100
commite99671aced1cab3921399dbd3f2b3915e91cef12 (patch)
treea52d33562ae1b0db80c90b2dce6fc0072d066810
parentmove sending CAP sasl request to sasl.py (diff)
signature
Added a channel setting for banmask, added !unban
-rw-r--r--IRCChannel.py2
-rw-r--r--modules/channel_op.py33
2 files changed, 33 insertions, 2 deletions
diff --git a/IRCChannel.py b/IRCChannel.py
index 63ffaae6..f92d1b43 100644
--- a/IRCChannel.py
+++ b/IRCChannel.py
@@ -87,6 +87,8 @@ class Channel(object):
self.server.send_kick(self.name, target, reason)
def send_ban(self, hostmask):
self.server.send_mode(self.name, "+b", hostmask)
+ def send_unban(self, hostmask):
+ self.server.send_mode(self.name, "-b", hostmask)
def mode_or_above(self, user, mode):
mode_orders = list(self.server.mode_prefixes.values())
diff --git a/modules/channel_op.py b/modules/channel_op.py
index 1093ad10..e26e360b 100644
--- a/modules/channel_op.py
+++ b/modules/channel_op.py
@@ -7,20 +7,28 @@ class Module(object):
bot.events.on("received").on("command").on("kick", "k"
).hook(self.kick, channel_only=True, require_mode="o",
min_args=1)
+
bot.events.on("received").on("command").on("ban"
).hook(self.ban, channel_only=True, require_mode="o",
min_args=1)
+ bot.events.on("received").on("command").on("unban"
+ ).hook(self.unban, channel_only=True, require_mode="o",
+ min_args=1)
+
bot.events.on("received").on("command").on("kickban", "kb"
).hook(self.kickban, channel_only=True, require_mode="o",
min_args=1)
+
bot.events.on("received").on("command").on("op"
).hook(self.op, channel_only=True, require_mode="o")
bot.events.on("received").on("command").on("deop"
).hook(self.deop, channel_only=True, require_mode="o")
+
bot.events.on("received").on("command").on("voice"
).hook(self.voice, channel_only=True, require_mode="o")
bot.events.on("received").on("command").on("devoice"
).hook(self.devoice, channel_only=True, require_mode="o")
+
bot.events.on("received").on("message").on("channel").hook(self.highlight_spam)
bot.events.on("postboot").on("configure").on(
@@ -35,6 +43,10 @@ class Module(object):
"channelset").call(setting="highlight-spam-ban",
help="Enable/Disable banning highlight spammers instead of just kicking",
validate=Utils.bool_or_none)
+ bot.events.on("postboot").on("configure").on(
+ "channelset").call(setting="ban-format",
+ help="Set ban format ($n = nick, $u = username, $h = hostname)",
+ validate=Utils.bool_or_none)
def kick(self, event):
target = event["args_split"][0]
@@ -52,13 +64,30 @@ class Module(object):
else:
event["stderr"].write("That user is not in this channel")
+ def _ban_format(self, user, s):
+ return s.replace("$n", user.nickname).replace("$u", user.username
+ ).replace("$h", user.hostname)
+ def _ban(self, channel, ban, user):
+ format = channel.get_setting("ban-format", "*!$u@$h")
+ hostmask_split = format.split("$$")
+ hostmask_split = [self._ban_format(user, s) for s in hostmask_split]
+ hostmask = "".join(hostmask_split)
+ if ban:
+ channel.send_ban(hostmask)
+ else:
+ channel.send_unban(hostmask)
def ban(self, event):
target_user = event["server"].get_user(event["args_split"][0])
if event["target"].has_user(target_user):
- event["target"].send_ban("*!%s@%s" % (target_user.username,
- target_user.hostname))
+ self._ban(event["target"], True, target_user)
else:
event["target"].send_ban(event["args_split"][0])
+ def unban(self, event):
+ target_user = event["server"].get_user(event["args_split"][0])
+ if event["target"].has_user(target_user):
+ self._ban(event["target"], False, target_user)
+ else:
+ event["target"].send_unban(event["args_split"][0])
def kickban(self, event):
if event["server"].has_user(event["args_split"][0]):