X-Git-Url: http://gitweb.pimeys.fr/?p=bots%2Fbasile.git;a=blobdiff_plain;f=basile.py;h=ad22ab649f74ded43ca500733377546a6cc20634;hp=08405b7f77afa2aede49cc16dd1680646521205d;hb=HEAD;hpb=5efcdc78864abeb8d69382f076fc0fe6c3a900b8 diff --git a/basile.py b/basile.py index 08405b7..ad22ab6 100755 --- a/basile.py +++ b/basile.py @@ -215,7 +215,7 @@ class Basile(ircbot.SingleServerIRCBot): 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] + self.users.pending_whois[pseudo] = ["pending", askedwhy, askedby, None] self.serv.whois([pseudo]) ### Surcharge des events du Bot @@ -246,7 +246,8 @@ class Basile(ircbot.SingleServerIRCBot): # Le whois n'est plus "pending" if self.users.pending_whois.has_key(pseudo): self.users.pending_whois[pseudo][0] = "registered" - _, askedwhy, askedby = self.users.pending_whois[pseudo] + 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,)) @@ -256,15 +257,15 @@ class Basile(ircbot.SingleServerIRCBot): 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(5, self.fail_whoisregnick, (pseudo,)) + serv.execute_delayed(config.whois_timeout, self.fail_whoisregnick, (pseudo,)) def fail_whoisregnick(self, pseudo): - """Maintenant qu'on a laissé 5 secondes au bot pour gérer les affaires courantes, + """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] + 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" @@ -307,6 +308,8 @@ class Basile(ircbot.SingleServerIRCBot): helpmsg += "\n" + helpmsgs[2] else: helpmsg = helpmsgs[2] + if not helpmsg: # Un non-op a demandé de l'aide sur une commande dont il n'est pas censé connaître l'existence + helpmsg = "Commande inacessible." for ligne in helpmsg.split("\n"): serv.privmsg(auteur, ligne.encode("utf-8")) elif cmd == u"identify": @@ -332,10 +335,11 @@ class Basile(ircbot.SingleServerIRCBot): elif cmd == u"drop": if len(message) > 1: if self.users.has(auteur): + idbde = self.users[auteur].idbde password = " ".join(message[1:]) - success, _, _ = self.new_connection_NK(serv, "#%s" % self.users[auteur].idbde, password) + success, _, _ = self.new_connection_NK(serv, "#%s" % idbde, password) if success: - self.users.drop(auteur) + self.users.drop(idbde) log(self.serveur, "priv", auteur, " ".join(message) + "[successful]") serv.privmsg(auteur, "Pseudo oublié.") else: @@ -500,7 +504,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 votre 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)) @@ -803,7 +807,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"