From 638eee0d685c06d258cb55287204ca97bca7c344 Mon Sep 17 00:00:00 2001 From: jesopo Date: Tue, 10 Dec 2019 05:27:35 +0000 Subject: move core modules to src/core_modules, make them uneffected by white/black list --- src/core_modules/ircv3_message_tracking.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 src/core_modules/ircv3_message_tracking.py (limited to 'src/core_modules/ircv3_message_tracking.py') diff --git a/src/core_modules/ircv3_message_tracking.py b/src/core_modules/ircv3_message_tracking.py new file mode 100644 index 00000000..3f4ad88c --- /dev/null +++ b/src/core_modules/ircv3_message_tracking.py @@ -0,0 +1,17 @@ +from src import ModuleManager, utils + +MSGID_TAG = "draft/msgid" +READ_TAG = "+draft/read" +DELIVERED_TAG = "+draft/delivered" +MESSAGE_TAG_CAPS = set(["draft/message-tags-0.2", "message-tags"]) + +class Module(ModuleManager.BaseModule): + @utils.hook("received.message.private") + @utils.hook("received.notice.private") + def privmsg(self, event): + if MSGID_TAG in event["tags"] and ( + event["server"].agreed_capabilities & MESSAGE_TAG_CAPS): + target = event.get("channel", event["user"]) + msgid = event["tags"][MSGID_TAG] + tags = {DELIVERED_TAG: msgid, READ_TAG: msgid} + target.send_tagmsg(tags) -- cgit v1.3.1-10-gc9f91