"""IRC plugin for retrieval of facts.""" import logging from irc.client import NickMask from ircbot.lib import Plugin, has_permission from facts.models import Fact, FactCategory log = logging.getLogger('facts.ircplugin') class Facts(Plugin): """Present facts to IRC.""" def start(self): """Set up the handlers.""" self.connection.reactor.add_global_regex_handler(['pubmsg', 'privmsg'], r'^!facts\s+add\s+(\S+)\s+(.*)$', self.handle_add_fact, -20) self.connection.reactor.add_global_regex_handler(['pubmsg', 'privmsg'], r'^!facts\s+(\S+)(\s+(.*)$|$)', self.handle_facts, -20) super(Facts, self).start() def stop(self): """Tear down handlers.""" self.connection.reactor.remove_global_regex_handler(['pubmsg', 'privmsg'], self.handle_add_fact) self.connection.reactor.remove_global_regex_handler(['pubmsg', 'privmsg'], self.handle_facts) super(Facts, self).stop() def handle_facts(self, connection, event, match): """Respond to the facts command with desired fact.""" category = match.group(1) regex = None if match.group(2) != '': regex = match.group(3) fact = Fact.objects.random_fact(category, regex) if fact: if fact.category.show_source: nick = NickMask(fact.nickmask).nick msg = "{0:s} ({1:s})".format(fact.fact, nick) else: msg = fact.fact return self.bot.reply(event, msg) def handle_add_fact(self, connection, event, match): """Add a new fact to the database.""" category_name = match.group(1) fact_text = match.group(2) if has_permission(event.source, 'facts.add_fact'): # create the category category, created = FactCategory.objects.get_or_create(name=category_name) fact = Fact.objects.create(fact=fact_text, category=category, nickmask=event.source) if fact: return self.bot.reply(event, "fact added to {0:s}".format(category.name)) plugin = Facts