aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--modules/line_handler.py14
-rw-r--r--src/IRCServer.py5
2 files changed, 18 insertions, 1 deletions
diff --git a/modules/line_handler.py b/modules/line_handler.py
index 86de32b1..c4f32513 100644
--- a/modules/line_handler.py
+++ b/modules/line_handler.py
@@ -11,7 +11,7 @@ RE_MODES = re.compile(r"[-+]\w+")
CAPABILITIES = {"multi-prefix", "chghost", "invite-notify", "account-tag",
"account-notify", "extended-join", "away-notify", "userhost-in-names",
"draft/message-tags-0.2", "server-time", "cap-notify",
- "batch", "draft/labeled-response"}
+ "batch", "draft/labeled-response", "draft/rename"}
class Module(ModuleManager.BaseModule):
def _handle(self, server, line):
@@ -566,3 +566,15 @@ class Module(ModuleManager.BaseModule):
else:
self.events.on("self.kick").call(channel=channel,
reason=reason, user=user, server=event["server"])
+
+ # a channel has been renamed
+ @utils.hook("raw.rename")
+ def rename(self, event):
+ old_name = event["args"][0]
+ new_name = event["args"][1]
+ channel = event["server"].get_channel(old_name)
+
+ event["server"].rename_channel(old_name, new_name)
+ self.events.on("received.rename").call(channel=channel,
+ old_name=old_name, new_name=new_name,
+ reason=event["arbitrary"] or events["args"][2]))
diff --git a/src/IRCServer.py b/src/IRCServer.py
index 2a7ceb3b..86c1382c 100644
--- a/src/IRCServer.py
+++ b/src/IRCServer.py
@@ -214,6 +214,11 @@ class Server(IRCObject.Object):
for user in channel.users:
user.part_channel(channel)
del self.channels[channel.name]
+ def rename_channel(self, old_name, new_name):
+ channel = self.channels.pop(old_name.lower())
+ channel.name = new_name.lower()
+ self.channels[channel.name] = channel
+
def parse_data(self, line: str):
if not line:
return