]> gitweb.pimeys.fr Git - bots/basile.git/blobdiff - basile.py
On déhardcode le temps d'attente sur un whois
[bots/basile.git] / basile.py
index 08405b7f77afa2aede49cc16dd1680646521205d..8897bb195dcd80479109db675a4d634948671fd1 100755 (executable)
--- 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"