making seen stuff a Module
This commit is contained in:
parent
a6eb6b36d6
commit
df91495652
72
dr.botzo.py
72
dr.botzo.py
|
@ -261,6 +261,36 @@ class Dice(Module):
|
|||
|
||||
connection.privmsg(replypath, result)
|
||||
|
||||
class Seen(Module):
|
||||
"""Keeps track of when people say things in public channels, and reports on when
|
||||
they last said something.
|
||||
"""
|
||||
|
||||
def __init__(self, config, server):
|
||||
super(Seen, self).__init__(config, server)
|
||||
|
||||
def register_handlers(self, server):
|
||||
server.add_global_handler('pubmsg', self.on_pubmsg)
|
||||
server.add_global_handler('privmsg', self.on_privmsg)
|
||||
|
||||
def do(self, connection, event, nick, userhost, replypath, what, admin_unlocked):
|
||||
# whatever it is, store it
|
||||
if not self.config.has_section('seen'):
|
||||
self.config.add_section('seen')
|
||||
|
||||
self.config.set('seen', nick, userhost + '|:|' + datetime.utcnow().isoformat() + '|:|' + what)
|
||||
|
||||
# also see if it's a query
|
||||
whats = what.split(' ')
|
||||
if whats[0] == 'seen' and len(whats) >= 2:
|
||||
query = whats[1]
|
||||
if query != 'debug':
|
||||
try:
|
||||
seendata = self.config.get('seen', query).split('|:|')
|
||||
converted = datetime.strptime(seendata[1], "%Y-%m-%dT%H:%M:%S.%f").replace(tzinfo=tzutc())
|
||||
connection.privmsg(replypath, 'last saw ' + query + ' at ' + converted.astimezone(tzlocal()).strftime("%Y/%m/%d %H:%M:%S %Z") + ' saying \'' + seendata[2] + '\'')
|
||||
except NoOptionError: pass
|
||||
|
||||
#####
|
||||
# sub_join_channel
|
||||
# join a channel when told to by an admin
|
||||
|
@ -329,33 +359,6 @@ def sub_autojoin_manipulate(connection, event, nick, userhost, replypath, what,
|
|||
connection.privmsg(replypath, 'removed ' + channel + ' from autojoin')
|
||||
except NoOptionError: pass
|
||||
|
||||
#####
|
||||
# sub_add_to_seen
|
||||
# when someone says a pubmsg, keep it in the config
|
||||
#####
|
||||
|
||||
def sub_add_to_seen(connection, event, nick, userhost, what):
|
||||
if not config.has_section('seen'):
|
||||
config.add_section('seen')
|
||||
|
||||
config.set('seen', nick, userhost + '|:|' + datetime.utcnow().isoformat() + '|:|' + what)
|
||||
|
||||
#####
|
||||
# sub_report_seen
|
||||
# report when a person has been seen, based on config
|
||||
#####
|
||||
|
||||
def sub_report_seen(connection, event, nick, userhost, replypath, what, admin_unlocked):
|
||||
whats = what.split(' ')
|
||||
if whats[0] == 'seen' and len(whats) >= 2:
|
||||
query = whats[1]
|
||||
if query != 'debug':
|
||||
try:
|
||||
seendata = config.get('seen', query).split('|:|')
|
||||
converted = datetime.strptime(seendata[1], "%Y-%m-%dT%H:%M:%S.%f").replace(tzinfo=tzutc())
|
||||
connection.privmsg(replypath, 'last saw ' + query + ' at ' + converted.astimezone(tzlocal()).strftime("%Y/%m/%d %H:%M:%S %Z") + ' saying \'' + seendata[2] + '\'')
|
||||
except NoOptionError: pass
|
||||
|
||||
#####
|
||||
# sub_save_config
|
||||
# save the config file
|
||||
|
@ -427,9 +430,6 @@ def on_privmsg(connection, event):
|
|||
sub_save_config(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
sub_change_nick(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
|
||||
# standard commands
|
||||
sub_report_seen(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
|
||||
#####
|
||||
# on_pubmsg
|
||||
# public messages in a channel where the bot is
|
||||
|
@ -448,8 +448,6 @@ def on_pubmsg(connection, event):
|
|||
admin_unlocked = True
|
||||
except NoOptionError: pass
|
||||
|
||||
sub_add_to_seen(connection, event, nick, userhost, what)
|
||||
|
||||
# only do commands if the bot has been addressed directly
|
||||
addressed_pattern = '^' + connection.get_nickname() + '[:,]?\s+'
|
||||
addressed_re = re.compile(addressed_pattern)
|
||||
|
@ -467,9 +465,6 @@ def on_pubmsg(connection, event):
|
|||
sub_save_config(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
sub_change_nick(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
|
||||
# standard commands
|
||||
sub_report_seen(connection, event, nick, userhost, replypath, what, admin_unlocked)
|
||||
|
||||
#####
|
||||
# init
|
||||
#####
|
||||
|
@ -505,9 +500,10 @@ server.add_global_handler("welcome", on_connect)
|
|||
server.add_global_handler('privmsg', on_privmsg)
|
||||
server.add_global_handler('pubmsg', on_pubmsg)
|
||||
|
||||
count = Countdown(config, server)
|
||||
dice = Dice(config, server)
|
||||
gt = GoogleTranslate(config, server)
|
||||
count = Countdown(config, server)
|
||||
dice = Dice(config, server)
|
||||
gt = GoogleTranslate(config, server)
|
||||
seen = Seen(config, server)
|
||||
|
||||
# loop forever
|
||||
irc.process_forever()
|
||||
|
|
Loading…
Reference in New Issue