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)$"]
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]
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:
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:
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)
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
f.write("%s\n" % child_pid)
f.close()
else:
- deconnaisseur.start()
\ No newline at end of file
+ deconnaisseur.start()