bitbot-3.11-fork/modules/in.py

41 lines
1.5 KiB
Python
Raw Normal View History

2016-03-29 11:56:58 +00:00
import time
from src import ModuleManager, utils
2016-03-29 11:56:58 +00:00
SECONDS_MAX = utils.SECONDS_WEEKS*8
2016-03-29 11:56:58 +00:00
SECONDS_MAX_DESCRIPTION = "8 weeks"
class Module(ModuleManager.BaseModule):
@utils.hook("received.command.in", min_args=2)
2016-03-29 11:56:58 +00:00
def in_command(self, event):
"""
:help: Set a reminder
:usage: <time> <message>
"""
seconds = utils.from_pretty_time(event["args_split"][0])
2016-03-29 11:56:58 +00:00
message = " ".join(event["args_split"][1:])
if seconds:
if seconds <= SECONDS_MAX:
due_time = int(time.time())+seconds
self.timers.add_persistent("in", seconds, due_time=due_time,
2018-09-28 15:51:36 +00:00
target=event["target"].name, server_id=event["server"].id,
nickname=event["user"].nickname, message=message)
event["stdout"].write("Saved")
2016-03-29 11:56:58 +00:00
else:
event["stderr"].write(
"The given time is above the max (%s)" % (
SECONDS_MAX_DESCRIPTION))
else:
event["stderr"].write(
"Please provided a valid time above 0 seconds")
@utils.hook("timer.in")
def timer_due(self, event):
server = self.bot.get_server(event["server_id"])
if server:
2018-11-21 20:05:08 +00:00
message = "%s: this is your reminder: %s" % (
event["nickname"], event["message"])
target = server.get_target(event["target"])
self.events.on("send.stdout").call(target=target, module_name="In",
server=server, message=message)