bitbot-3.11-fork/modules/messages.py

26 lines
997 B
Python

import re
from src import ModuleManager, utils
class Module(ModuleManager.BaseModule):
_name = "MSG"
@utils.hook("received.command.msearch")
@utils.spec("!r~channel !<pattern>string")
def msearch(self, event):
pattern = re.compile(event["spec"][1], re.I)
message_list = list(event["spec"][0].buffer.find_all(pattern))
message_count = len(message_list)
if message_list:
messages = []
for i, message in enumerate(message_list):
seconds = utils.datetime.seconds_since(message.line.timestamp)
messages.append("(%d/%d) %s ago %s" % (i+1, message_count,
utils.datetime.format.to_pretty_since(seconds),
message.line.format()))
event["stdout"].write("%s: found: %s"
% (event["user"].nickname, "\n".join(messages)))
else:
event["stderr"].write("%s: no messages found"
% event["user"].nickname)