#: Module de gestion des quotes
import quotes
-quote_pattern = re.compile(config.quote_regexp, flags=re.UNICODE)
+# Je veux pouvoir éditer ce que crée ce bot
+os.umask(002)
def get_config_logfile(serveur):
"""Renvoie le nom du fichier de log en fonction du ``serveur`` et de la config."""
self.quotedb = quotes.QuoteDB()
self.reload_quotes()
+
+ # Pour agir à la réception des whois 307 = registered nick
+ self.ircobj.add_global_handler("307", self.on_registered_nick)
### Utilitaires
"""Restaure les quotes à partir du dump. ``asked_where=None`` signifie en privé."""
self.quotedb = quotes.restore()
self.acknowledge(asked_by, asked_where, "Quotes restaurées à partir du dump (pas de backup effectué).")
+ many = self.quotedb.get_clash_authors()
+ if many:
+ self.acknowledge(asked_by, asked_where, "Auteurs de casse différente : %s" % (many))
### Surcharge des events du Bot
def on_welcome(self, serv, ev):
self.dump(asked_by=auteur, asked_where=canal)
elif cmd in [u"restore"] and auteur in self.overops:
self.restore(asked_by=auteur, asked_where=canal)
+ elif cmd in [u"display"]:
+ self.serv.privmsg(canal, "%s: %s" % (auteur, config.quote_display_url.encode("utf-8")))
else:
# Vu que ce bot est prévu pour parser des quotes il va falloir bosser ici
- match = quote_pattern.match(message)
+ match = self.quote_pattern.match(message)
if match:
d = match.groupdict()
- if self.quotedb.store(d["author"], d["content"]):
+ # On n'autorise pas les gens à déclarer le quoter
+ d["quoter"] = auteur.decode("utf-8")
+ if self.quotedb.store(**d):
serv.privmsg(canal, (u"%s: Ce sera retenu, répété, amplifié" % (auteur,)).encode("utf-8"))
self.quotedb.save()
else:
serv.privmsg(canal, (u"Pas de quote de %s en mémoire." % author).encode("utf-8"))
return
serv.privmsg(canal, str(q))
+ elif message.startswith(u"!author") or message.startswith(u"!from"):
+ words = message.split()
+ cmd = words[0].lstrip("!")
+ regexp = any([cmd.endswith(suffix) for suffix in config.regex_suffixes])
+ search = u" ".join(words[1:])
+ authors = self.quotedb.search_authors(search, regexp)
+ if not authors:
+ serv.privmsg(canal, "%s: Pas d'auteur correspondant à la recherche." % (auteur,))
+ return
+ if cmd.startswith("author"):
+ if len(authors) > config.search_max_authors:
+ authors = authors[:config.search_max_authors+1] + ["+%s" % (len(authors) - config.search_max_authors)]
+ serv.privmsg(canal, "%s: %s" % (auteur, (u", ".join(authors)).encode("utf-8")))
+ elif cmd.startswith("from"):
+ quotes = sum([self.quotedb.quotesfrom(a) for a in authors], [])
+ q = random.choice(quotes)
+ serv.privmsg(canal, str(q))
+ elif message.startswith(u"!search"):
+ words = message.split()
+ cmd = words[0].lstrip("!")
+ regexp = cmd in ["search" + suffix for suffix in config.regex_suffixes]
+ search = u" ".join(words[1:])
+ quotes = self.quotedb.search(inquote=search, regexp=regexp)
+ if quotes:
+ q = random.choice(quotes)
+ serv.privmsg(canal, str(q))
+ else:
+ serv.privmsg(canal, "%s: Pas de quotes correspondant à la recherche." % (auteur,))
def on_action(self, serv, ev):
"""À la réception d'une action."""
time.sleep(2)
serv.join(channel)
+ def on_registered_nick(self, serv, ev):
+ """À la réception d'un résultat de whois."""
+ pseudo, regis = ev.arguments()
+ if regis == 'is a registered nick':
+ print "%s est enregistré \o/" % pseudo
+
### .fork trick
def start_as_daemon(self, outfile):
sys.stderr = Logger(outfile)