]> gitweb.pimeys.fr Git - bots/salesman.git/blobdiff - Salesman.py
On ne propose pas d'énigme si le chan est mort
[bots/salesman.git] / Salesman.py
index d437e873de6a3630f1d6608d4f1ca062cd8534df..ffb6be559faeb9306bb74513d230c063cd8896b6 100755 (executable)
@@ -55,6 +55,12 @@ config_quit_messages=[u"goto Tombouctou"]
 
 config_leave_messages=[u"On continuera à jouer plus tard ;)"]
 
+# Quand personne ne cause, on finit par se taire
+# temps au bout duquel, si personne n'a parlé, on se tait
+config_idle_time=20*60
+# liste des bots, qui ne sont pas considérés comme de l'activité
+config_idle_bots=["deconnaisseur","Basile","historien","Hung","Salesman","Shadobot","Wen","___"]
+
 class UnicodeBotError(Exception):
     pass
 def bot_unicode(chain):
@@ -82,7 +88,7 @@ def reussi(message,answer,auteur):
     if auteur in config_level2:
         return remplace_accents(answer) in message
     else:
-        if re.match(remplace_accents(answer).lower(),remplace_accents(message).lower()):
+        if re.match(".*"+remplace_accents(answer).lower(),remplace_accents(message).lower()):
             return True
 
 def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case_sensitive=False,debug=False):
@@ -101,7 +107,7 @@ def is_tag(chain):
 class RefuseError(Exception):
     pass
 
-class Deconnaisseur(ircbot.SingleServerIRCBot):
+class Salesman(ircbot.SingleServerIRCBot):
     def __init__(self,serveur,debug=False):
         temporary_pseudo=config_pseudo+str(random.randrange(10000,100000))
         ircbot.SingleServerIRCBot.__init__(self, [(serveur, 6667)],
@@ -114,6 +120,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         self.stay_channels=config_stay_channels
         self.play_channels=config_play_channels
         self.play_status={i:[0] for i in self.play_channels}
+        self.last_activity={}
         self.quiet_channels=[]
 
     def give_me_my_pseudo(self,serv):
@@ -133,12 +140,17 @@ 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
         for c in self.play_channels:
             token=time.time()-3600
             self.play_status[c]=[0,token]
             serv.execute_delayed(random.randrange(ttrig),self.start_enigme,(serv,c,token))
 
     def start_enigme(self,serv,channel,token=None):
+        # On reste silencieux si lechan n'est pas actif
+        if not self.is_active(channel):
+            serv.execute_delayed(ttrig*5,self.start_enigme,(serv,channel,token))
+            return
         if self.play_status[channel][0]==0 and channel in self.play_channels:
             ok="skip"
             if token==self.play_status[channel][-1]:
@@ -169,7 +181,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
     def get_enigme(self):
         # on récupère les capitales
         f=open(config_source_file)
-        l=f.readlines()
+        l=[i.strip("\n") for i in f.readlines()]
         f.close()
         l=[i.split(" | ") for i in l]
         dec={int(i[0]):list(i[1:]) for i in l}
@@ -446,6 +458,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         auteur = irclib.nm_to_n(ev.source())
         canal = ev.target()
         message = ev.arguments()[0]
+        self.update_activity(canal,auteur)
         try:
             test=bot_unicode(message)
         except UnicodeBotError:
@@ -541,9 +554,10 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
         victime = ev.arguments()[0]
         raison = ev.arguments()[1]
         if victime==self.nick:
-            log(self.serveur,"%s kické par %s (raison : %s)" %(victime,auteur,raison))
+            log(self.serveur,"%s kické de %s par %s (raison : %s)" %(victime,channel,auteur,raison))
             time.sleep(5)
             serv.join(channel)
+            self.update_activity(message[1],"")
             # on ne dit rien au rejoin
             #l1,l2=config_kick_answers,config_kick_actions
             #n1,n2=len(l1),len(l2)
@@ -584,6 +598,12 @@ class Deconnaisseur(ircbot.SingleServerIRCBot):
     def _getnick(self):
         return self.serv.get_nickname()
     nick = property(_getnick)
+    
+    def update_activity(self,canal,pseudo):
+        if not pseudo in config_idle_bots:
+            self.last_activity[canal]=time.time()
+    def is_active(self,canal):
+        return time.time()-self.last_activity[canal]<config_idle_time
 
 if __name__=="__main__":
     import sys