X-Git-Url: http://gitweb.pimeys.fr/?p=bots%2Fbasile.git;a=blobdiff_plain;f=basile.py;h=86e8105df718f5ea96838885e468430959d060ef;hp=0c6fdc75af2568bd54991d71d1df4c909d1344d3;hb=72576d5db378d2117433337dfdb9d3df56ba03c0;hpb=ee7a287b0f564671d100fa29ae0269c482ef4efe diff --git a/basile.py b/basile.py index 0c6fdc7..86e8105 100755 --- a/basile.py +++ b/basile.py @@ -17,6 +17,8 @@ import sys # Oui, j'ai recodé ma version d'irclib pour pouvoir rattrapper les SIGHUP sys.path.insert(0, "/home/vincent/scripts/python-myirclib") import irclib +# On veut réagir sur la partie du whois qui dit qu'un nick est registered +irclib.numeric_events['307'] = "whoisregnick" import ircbot from commands import getstatusoutput as ex @@ -211,6 +213,11 @@ class Basile(ircbot.SingleServerIRCBot): self.serv.privmsg(place, message) log(self.serveur, place, auteur, something + "%r" % params + ("[successful]" if success else "[failed]")) + def whois(self, pseudo, askedwhy, askedby): + """Demande un whois sur ``pseudo``. La réponse sera handled par une autre fonction.""" + self.users.pending_whois[pseudo] = ["pending", askedwhy, askedby, None] + self.serv.whois([pseudo]) + ### Surcharge des events du Bot def on_welcome(self, serv, ev): """À l'arrivée sur le serveur.""" @@ -229,6 +236,42 @@ class Basile(ircbot.SingleServerIRCBot): for report in self.report_bugs_to: serv.privmsg(report, "Connection to NK2015 failed, invalid password ?") + def on_whoisregnick(self, serv, ev): + """Appelée sur une réponse à un whois au moment où ça dit "is a registered nick". + J'ai vérifié, "is a registered nick" ça inclu le fiat qu'il est identified correctement. + + On stocke l'information comme quoi cette personne est registered, et quand c'était.""" + pseudo, phrase = ev.arguments() + if phrase == 'is a registered nick': + # Le whois n'est plus "pending" + if self.users.pending_whois.has_key(pseudo): + self.users.pending_whois[pseudo][0] = "registered" + self.users.pending_whois[pseudo][3] = time.time() + _, askedwhy, askedby, _ = self.users.pending_whois[pseudo] + if askedwhy == "cmd WHOIS": + # Ce whois a été demandé par quelqu'un, on lui répond + self.serv.privmsg(askedby, "%s is a registered nick" % (pseudo,)) + + def on_endofwhois(self, serv, ev): + """Si on arrive à la fin du whois, on va voir si on n'a pas reçu "is a registered nick" + c'est que le pseudo n'est pas identifié. """ + pseudo = ev.arguments()[0] + # On laisse le temps au bot de souffler un coup + serv.execute_delayed(config.whois_timeout, self.fail_whoisregnick, (pseudo,)) + + def fail_whoisregnick(self, pseudo): + """Maintenant qu'on a laissé quelques secondes au bot pour gérer les affaires courantes, + on considère que le pseudo n'est pas registered. """ + # Attention, parce qu'il se pourrait qu'on n'ait pas sollicité ce whois + # et que donc pending_whois n'ai pas été peuplé en conséquence + if self.users.pending_whois.has_key(pseudo): + status, askedwhy, askedby, _ = self.users.pending_whois[pseudo] + if status == "pending": + # Si le status est encore pending, on n'a pas eu de réponse positive, donc elle est négative + self.users.pending_whois[pseudo] = "notregistered" + if askedwhy == "cmd WHOIS": + self.serv.privmsg(askedby, "%s is NOT a registered nick" % (pseudo,)) + def on_privmsg(self, serv, ev): """À la réception d'un message en privé.""" if ignore_event(serv, ev): @@ -270,10 +313,11 @@ class Basile(ircbot.SingleServerIRCBot): elif cmd == u"identify": if len(message) == 1: if self.users.has(auteur): - serv.privmsg(auteur, "Je vous connais sous le pseudo note %s." % ( - self.users[auteur].pseudonote.encode("utf8"))) + infos = self.users[auteur].get_infos(self.nk, serv, auteur) + serv.privmsg(auteur, (u"Vous avez le compte note n°%(idbde)s, pseudo : %(pseudo)s." % infos + ).encode("utf8")) else: - serv.privmsg(auteur, "Je ne connais pas votre pseudo note.") + serv.privmsg(auteur, "Je ne connais pas votre note.") elif len(message) >= 3: username, password = message[1], " ".join(message[2:]) success, info, _ = self.new_connection_NK(serv, username, password) @@ -299,7 +343,7 @@ class Basile(ircbot.SingleServerIRCBot): log(self.serveur, "priv", auteur, " ".join(message) + "[failed]") serv.privmsg(auteur, "Mot de passe invalide. (ou serveur down)") else: - serv.privmsg(auteur, "Je ne connais pas ton pseudo note.") + serv.privmsg(auteur, "Je ne connais pas votre note.") else: serv.privmsg(auteur, "Syntaxe : DROP ") elif cmd == u"join": @@ -457,7 +501,7 @@ class Basile(ircbot.SingleServerIRCBot): serv.privmsg(auteur, "%.2f (%s)" % (solde/100.0, pseudo.encode("utf8"))) log(self.serveur, "priv", auteur, " ".join(message) + ("[successful]" if success else "[failed]")) else: - serv.privmsg(canal, "Je ne connais pas ton pseudo note.") + serv.privmsg(auteur, "Je ne connais pas votre note.") elif cmd == u"ops": if auteur in self.overops: serv.privmsg(auteur, " ".join(self.ops)) @@ -468,6 +512,11 @@ class Basile(ircbot.SingleServerIRCBot): serv.privmsg(auteur, " ".join(self.overops)) else: notunderstood = True + elif cmd == u"whois": + if auteur in self.ops and len(message) > 1: + self.whois(message[1], askedwhy="cmd WHOIS", askedby=auteur) + else: + notunderstood = True else: notunderstood = True if notunderstood: @@ -755,7 +804,7 @@ class Logger(object): f.close() def main(): - """Exécution principal : lecture des paramètres et lancement du bot.""" + """Exécution principale : lecture des paramètres et lancement du bot.""" if len(sys.argv) == 1: print "Usage : basile.py [--debug] [--no-output] [--daemon [--pidfile]] [--outfile]" print " --outfile sans --no-output ni --daemon n'a aucun effet"