]> gitweb.pimeys.fr Git - bots/deconnaisseur.git/commitdiff
On continue à idle quand les gens tuent le canard
authorVincent Le Gallic <legallic@crans.org>
Sat, 11 May 2013 13:44:10 +0000 (15:44 +0200)
committerVincent Le Gallic <legallic@crans.org>
Sat, 11 May 2013 13:44:10 +0000 (15:44 +0200)
config.py
deconnaisseur.py

index 00b0f64aa319102c35e9b17d60781a8eed8d42d9..6d555b11da0a2fdc8db8675c3561071ddce481f3 100644 (file)
--- a/config.py
+++ b/config.py
@@ -48,3 +48,4 @@ leave_messages=[u"On continuera à jouer plus tard ;)"]
 idle_time=20*60
 # liste des bots, qui ne sont pas considérés comme de l'activité
 idle_bots=["deconnaisseur","Basile","historien","hung","salesman","Shadobot","Wen","___","Sanctuary","Saturnin"]
+idle_messages=["^(pan|bang|bim)$"]
index ef8f25207257aa6e3112a22300f50d58b75b6b6f..9eac34f4e212e8b5e31e7455f2a0ffdc3b3a1570 100755 (executable)
@@ -110,7 +110,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         for c in self.chanlist:
             log(self.serveur,"JOIN %s"%(c))
             serv.join(c)
-            self.update_activity(c,"") # la chaîne vide ne sera jamais un nom de bot et donc marchera toujours
+            self.update_activity(c,force=True)
         for c in self.play_channels:
             token=time.time()-3600
             self.play_status[c]=[0,token]
@@ -240,7 +240,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
                     else:
                         serv.join(message[1])
                         self.chanlist.append(message[1])
-                        self.update_activity(message[1],"")
+                        self.update_activity(message[1],force=True)
                         serv.privmsg(auteur,"Channels : "+" ".join(self.chanlist))
                         log(self.serveur,"priv",auteur," ".join(message))
                 else:
@@ -444,7 +444,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         auteur = irclib.nm_to_n(ev.source())
         canal = ev.target()
         message = ev.arguments()[0]
-        self.update_activity(canal,auteur)
+        self.update_activity(canal,auteur,message)
         try:
             test=bot_unicode(message)
         except UnicodeBotError:
@@ -551,7 +551,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
             log(self.serveur,"%s kické de %s par %s (raison : %s)" %(victime,channel,auteur,raison))
             time.sleep(5)
             serv.join(channel)
-            self.update_activity(channel,"")
+            self.update_activity(channel,force=True)
             # on ne dit rien au rejoin
             #l1,l2=config.kick_answers,config.kick_actions
             #n1,n2=len(l1),len(l2)
@@ -594,8 +594,8 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         return self.serv.get_nickname()
     nick = property(_getnick)
     
-    def update_activity(self,canal,pseudo):
-        if not pseudo in config.idle_bots:
+    def update_activity(self,canal="",pseudo="",message="",force=False):
+        if force or (not pseudo in config.idle_bots and all([not re.match(ignore, message) for ignore in config.idle_messages])):
             self.last_activity[canal]=time.time()
     def is_active(self,canal):
         return time.time()-self.last_activity[canal]<config.idle_time
@@ -679,4 +679,4 @@ if __name__=="__main__":
             f.write("%s\n" % child_pid)
             f.close()
     else:
-        deconnaisseur.start()
\ No newline at end of file
+        deconnaisseur.start()