mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-13 13:42:37 +01:00
Add command @scheduler remind
This is a safe command for admins to allow as it's limited to text reminders, unlike the equivalent scheduler.add (+ misc.echo) which usually needs to be restricted to prevent abuse
This commit is contained in:
parent
4213d95356
commit
df6ebc78a0
@ -90,7 +90,12 @@ class Scheduler(callbacks.Plugin):
|
|||||||
# though we'll never know for sure, because other
|
# though we'll never know for sure, because other
|
||||||
# plugins can schedule stuff, too.
|
# plugins can schedule stuff, too.
|
||||||
n = int(name)
|
n = int(name)
|
||||||
self._add(network, event['msg'], event['time'], event['command'], n)
|
# Here we use event.get() method instead of event[]
|
||||||
|
# This is to maintain compatibility with older bots
|
||||||
|
# lacking 'is_reminder' in their event dicts
|
||||||
|
is_reminder = event.get('is_reminder', False)
|
||||||
|
self._add(network, event['msg'], event['time'], event['command'],
|
||||||
|
is_reminder, n)
|
||||||
elif event['type'] == 'repeat': # repeating event
|
elif event['type'] == 'repeat': # repeating event
|
||||||
now = time.time()
|
now = time.time()
|
||||||
first_run = event.get('first_run')
|
first_run = event.get('first_run')
|
||||||
@ -145,13 +150,27 @@ class Scheduler(callbacks.Plugin):
|
|||||||
self.Proxy(irc, msg, tokens)
|
self.Proxy(irc, msg, tokens)
|
||||||
return f
|
return f
|
||||||
|
|
||||||
def _add(self, network, msg, t, command, name=None):
|
def _makeReminderFunction(self, network, msg, text):
|
||||||
f = self._makeCommandFunction(network, msg, command)
|
"""Makes a function suitable for scheduling text"""
|
||||||
|
def f():
|
||||||
|
# If the network isn't available, pick any other one
|
||||||
|
irc = world.getIrc(network) or world.ircs[0]
|
||||||
|
replyIrc = callbacks.ReplyIrcProxy(irc, msg)
|
||||||
|
replyIrc.reply(_('Reminder: %s') % text, msg=msg, prefixNick=True)
|
||||||
|
del self.events[str(f.eventId)]
|
||||||
|
return f
|
||||||
|
|
||||||
|
def _add(self, network, msg, t, command, is_reminder=False, name=None):
|
||||||
|
if is_reminder:
|
||||||
|
f = self._makeReminderFunction(network, msg, command)
|
||||||
|
else:
|
||||||
|
f = self._makeCommandFunction(network, msg, command)
|
||||||
id = schedule.addEvent(f, t, name)
|
id = schedule.addEvent(f, t, name)
|
||||||
f.eventId = id
|
f.eventId = id
|
||||||
self.events[str(id)] = {'command':command,
|
self.events[str(id)] = {'command':command,
|
||||||
|
'is_reminder':is_reminder,
|
||||||
'msg':msg,
|
'msg':msg,
|
||||||
'network': network,
|
'network':network,
|
||||||
'time':t,
|
'time':t,
|
||||||
'type':'single'}
|
'type':'single'}
|
||||||
return id
|
return id
|
||||||
@ -171,6 +190,19 @@ class Scheduler(callbacks.Plugin):
|
|||||||
irc.replySuccess(format(_('Event #%i added.'), id))
|
irc.replySuccess(format(_('Event #%i added.'), id))
|
||||||
add = wrap(add, ['positiveInt', 'text'])
|
add = wrap(add, ['positiveInt', 'text'])
|
||||||
|
|
||||||
|
@internationalizeDocstring
|
||||||
|
def remind(self, irc, msg, args, seconds, text):
|
||||||
|
""" <seconds> <text>
|
||||||
|
|
||||||
|
Sets a reminder with string <text> to run <seconds> seconds in the
|
||||||
|
future. For example, 'scheduler remind [seconds 30m] "Hello World"'
|
||||||
|
will return '<nick> Reminder: Hello World' 30 minutes after being set.
|
||||||
|
"""
|
||||||
|
t = time.time() + seconds
|
||||||
|
id = self._add(irc.network, msg, t, text, is_reminder=True)
|
||||||
|
irc.replySuccess(format(_('Reminder Event #%i added.'), id))
|
||||||
|
remind = wrap(remind, ['positiveInt', 'text'])
|
||||||
|
|
||||||
@internationalizeDocstring
|
@internationalizeDocstring
|
||||||
def remove(self, irc, msg, args, id):
|
def remove(self, irc, msg, args, id):
|
||||||
"""<id>
|
"""<id>
|
||||||
@ -200,7 +232,7 @@ class Scheduler(callbacks.Plugin):
|
|||||||
assert id == name
|
assert id == name
|
||||||
self.events[name] = {'command':command,
|
self.events[name] = {'command':command,
|
||||||
'msg':msg,
|
'msg':msg,
|
||||||
'network': network,
|
'network':network,
|
||||||
'time':seconds,
|
'time':seconds,
|
||||||
'type':'repeat',
|
'type':'repeat',
|
||||||
'first_run': first_run,
|
'first_run': first_run,
|
||||||
|
@ -74,6 +74,21 @@ class SchedulerTestCase(ChannelPluginTestCase):
|
|||||||
timeFastForward(5)
|
timeFastForward(5)
|
||||||
self.assertNoResponse(' ', timeout=1)
|
self.assertNoResponse(' ', timeout=1)
|
||||||
|
|
||||||
|
def testRemind(self):
|
||||||
|
self.assertNotError('scheduler remind 5 testRemind')
|
||||||
|
self.assertResponse(
|
||||||
|
'scheduler list',
|
||||||
|
'3 (in 4 seconds): "testRemind"')
|
||||||
|
timeFastForward(3)
|
||||||
|
self.assertNoResponse(' ', timeout=1)
|
||||||
|
timeFastForward(3)
|
||||||
|
self.assertResponse(' ', 'Reminder: testRemind')
|
||||||
|
timeFastForward(5)
|
||||||
|
self.assertNoResponse(' ', timeout=1)
|
||||||
|
self.assertResponse(
|
||||||
|
'scheduler list', 'There are currently no scheduled commands.')
|
||||||
|
|
||||||
|
|
||||||
def testRepeat(self):
|
def testRepeat(self):
|
||||||
self.assertRegexp('scheduler repeat repeater 5 echo testRepeat',
|
self.assertRegexp('scheduler repeat repeater 5 echo testRepeat',
|
||||||
'testRepeat')
|
'testRepeat')
|
||||||
|
Loading…
Reference in New Issue
Block a user