X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=deconnaisseur.py;h=9726d66ae220149fecc7717b53778dbe776b6dea;hb=d9cc90569cdf10d4883dc00e6904f9529e27d111;hp=9444519bc7ca3eb60f9c2931b55f3464cb306309;hpb=35aaf028252abc0c87f200efd32ba36f25c10f00;p=bots%2Fdeconnaisseur.git diff --git a/deconnaisseur.py b/deconnaisseur.py index 9444519..9726d66 100755 --- a/deconnaisseur.py +++ b/deconnaisseur.py @@ -21,17 +21,26 @@ config_stay_channels=["#flood","#bot"] config_overops=["[20-100]","[20-100]_","PEB"] config_ops=["Nit","Eguel","Harry"] -config_source_file_template="deconnaissances.%s.txt" #il faut rajouter le nom du serveur -def get_config_source_file(serveur): +config_source_file="deconnaissances.txt" +config_played_file_template="played.%s.txt" #il faut rajouter le nom du serveur +def get_config_played_file(serveur): serveurs={"acoeur.crans.org":"acoeur","irc.crans.org":"crans"} - return config_source_file_template%(serveurs[serveur]) + return config_played_file_template%(serveurs[serveur]) ttrig=120 #time trigger (normalement 120, mais diminué pour les tests) Ttrig=600 #between two enigms -config_time_incompressible=60 #on peut pas retrigger en dessous de ce temps (60) +config_time_incompressible=15 #on peut pas retrigger en dessous de ce temps (60) config_time_incompressible_clue=60 #on peut pas forcer la demande d'indice en dessous config_score_file="scores.pickle" +config_tag_triggers=[u"t(|a)g",u"ta gueule",u"la ferme",u"ferme( |-)la",u"tais-toi",u"chut"] +config_tag_actions=[u"se tait",u"ferme sa gueule",u"se la ferme",u"la ferme"] +config_tag_answers=[u"J'me tais si j'veux !", +u"Je t'entends pas :°", +u"Héhé, try again", +u"Non, j'ai pas envie", +u"Peut-être quand toi tu la fermeras, et encore…"] + class UnicodeBotError(Exception): pass def bot_unicode(chain): @@ -40,7 +49,7 @@ def bot_unicode(chain): except UnicodeDecodeError: raise UnicodeBotError -def log(channel,auteur=None,message=None): +def log(serveur,channel="prout",auteur=None,message=None): #f=open(config_logfile,"a") #if auteur==message==None: # chain=channel @@ -64,6 +73,19 @@ def tolere(regexp): reg=reg.replace(u"œ",u"(œ|oe)").replace(u"æ",u"(æ|ae)") return reg +def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case_sensitive=False,debug=False): + if case_sensitive: + chain=unicode(chain,"utf8") + else: + chain=unicode(chain,"utf8").lower() + allmatches="("+"|".join(matches)+")" + reg=(avant+allmatches+apres).lower() + o=re.match(reg,chain) + return o + +def is_tag(chain): + return is_something(chain,config_tag_triggers) + class RefuseError(Exception): pass @@ -80,6 +102,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.quiet_channels=[] def give_me_my_pseudo(self,serv): serv.privmsg("NickServ","RECOVER %s %s"%(config_pseudo,config_password)) @@ -141,22 +164,29 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): serv.execute_delayed(random.randrange(Ttrig*5,Ttrig*10),self.start_enigme,(serv,channel,token)) def get_enigme(self): - f=open(get_config_source_file(self.serveur)) + # on récupère les déconnaissances + f=open(config_source_file) t=f.read() + f.close() l=re.findall("%\n(.*)\n(.*)\n(.*)\n(.*)\n(.*)\n",t) - l=[list(i) for i in l if len(i)==5] - l.sort(lambda x,y: cmp(int(x[4]),int(y[4]))) + dec={int(i[0]):list(i[1:]) for i in l if len(i)==5} + # on va chercher combien de fois elles ont été jouées + played_file=get_config_played_file(self.serveur) + f=open(played_file) + t=f.read() + f.close() + l=re.findall("(.*):(.*)",t) + played={int(i[0]):int(i[1]) for i in l} # on récupère le nombre d'occurrences le plus faible - mini=l[0][4] - # on garde que ceux qui ont le même nombre d'occurrences - l_mini=[en for en in l if en[4]==mini] - # on tire au hasard dedans - choisi=random.randrange(len(l_mini)) - enigme,indice,answer_reg,answer,_=l_mini[choisi] - real_index=l.index(l_mini[choisi]) - l[real_index][4]=str(int(l[real_index][4])+1) - f=open(get_config_source_file(self.serveur),"w") - f.write("%\n"+"\n%\n".join(["%s\n%s\n%s\n%s\n%s"%(i[0],i[1],i[2],i[3],i[4]) for i in l])+"\n%") + mini=min(played.values()) + # on choisit un id dans ceux qui ont ce nombre d'occurences + id_choisi=random.choice([k for k,v in played.items() if v==mini]) + enigme,indice,answer_reg,answer=dec[id_choisi] + # on incrémente la choisie + played[id_choisi]+=1 + # on enregistre le played_file + f=open(played_file,"w") + f.write("\n".join(["%-3s : %s"%(k,v) for k,v in played.items()])) f.close() return enigme,indice,answer_reg,answer @@ -189,7 +219,9 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): JOIN Faire rejoindre un channel (sans paramètres, donne la liste des chans actuels) LEAVE Faire quitter un channel PLAY Passe un channel en mode "jouer" - NOPLAY Passe un channel en mode "ne pas jouer" """ + NOPLAY Passe un channel en mode "ne pas jouer" + QUIET Se taire sur un channel + NOQUIET Opposé de QUIET""" helpmsg_overops=""" SCORES {DEL|ADD|SUB} Tu veux un dessin ? SAY Fais envoyer un message sur un chan ou à une personne @@ -285,6 +317,32 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): log("priv",auteur," ".join(message)+"[failed]") else: notunderstood=True + elif cmd=="quiet": + if auteur in self.ops: + if len(message)>1: + if message[1] in self.quiet_channels: + serv.privmsg(auteur,"Je me la ferme déjà sur %s"%(message[1])) + log(self.serveur,"priv",auteur," ".join(message)+"[failed]") + else: + self.quiet_channels.append(message[1]) + serv.privmsg(auteur,"Quiet channels : "+" ".join(self.quiet_channels)) + log(self.serveur,"priv",auteur," ".join(message)+"[successful]") + else: + serv.privmsg(auteur,"Quiet channels : "+" ".join(self.quiet_channels)) + else: + notunderstood=True + elif cmd=="noquiet": + if auteur in self.ops: + if len(message)>1: + if message[1] in self.quiet_channels: + self.quiet_channels.remove(message[1]) + serv.privmsg(auteur,"Quiet channels : "+" ".join(self.quiet_channels)) + log(self.serveur,"priv",auteur," ".join(message)+"[successful]") + else: + serv.privmsg(auteur,"Je ne me la ferme pas sur %s."%(message[1])) + log(self.serveur,"priv",auteur," ".join(message)+"[failed]") + else: + notunderstood=True elif cmd in ["states","status"]: if auteur in self.overops: for k in self.play_status.keys(): @@ -340,7 +398,6 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): serv.privmsg(auteur,"Scores by score : "+" ; ".join(["%s %s"%(i[0],i[1]) for i in scores])) # trie par pseudo scores.sort(lambda x,y:cmp(x[0].lower(),y[0].lower())) - scores.reverse() serv.privmsg(auteur,"Scores by pseudo : "+" ; ".join(["%s %s"%(i[0],i[1]) for i in scores])) elif auteur in self.overops: souscmd=message[1].lower() @@ -389,7 +446,7 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): if not canal in self.quiet_channels: serv.privmsg(canal, "%s: Euh, tu fais de la merde avec ton encodage là, j'ai failli crasher…"%(auteur)) - return + return tryother=False pour_moi,message=self.pourmoi(serv,message) if pour_moi and message.split()!=[]: @@ -405,8 +462,8 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): else: serv.privmsg(canal,"%s: crève !"%(auteur)) log(canal,auteur,message+"[failed]") - if cmd in ["meur", "meurt","meurre","meurres"]: - serv.privmsg(canal,'%s: Mourir, impératif, 2ème personne du pluriel : "meurs" (de rien)'%(auteur)) + if cmd in ["meur", "meurt","meurre","meurres"] and not canal in self.quiet_channels: + serv.privmsg(canal,'%s: Mourir, impératif, 2ème personne du singulier : "meurs" (de rien)'%(auteur)) if cmd in ["part","leave","dégage"]: if auteur in self.ops and (not (canal in self.stay_channels) or auteur in self.overops): @@ -423,9 +480,9 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): serv.nick(become) log(canal,auteur,message+"[successful]") - if cmd in ["coucou"]: + if cmd in ["coucou"] and not canal in self.quiet_channels: serv.privmsg(canal,"%s: coucou"%(auteur)) - if cmd in ["ping"]: + if cmd in ["ping"] and not canal in self.quiet_channels: serv.privmsg(canal,"%s: pong"%(auteur)) if cmd in ["déconnaissance","deconnaissance","énigme","enigme","encore"]: if canal in self.play_channels: @@ -440,6 +497,15 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): serv.privmsg(canal,"%s: pas ici…"%(auteur)) if cmd=="indice" and canal in self.play_channels: self.give_indice(serv,canal,None) + if is_tag(message) and not canal in self.quiet_channels: + if auteur in self.ops: + action=random.choice(config_tag_actions) + serv.action(canal,action.encode("utf8")) + self.quiet_channels.append(canal) + else: + answer=random.choice(config_tag_answers) + for ligne in answer.split("\n"): + serv.privmsg(canal,"%s: %s"%(auteur,ligne.encode("utf8"))) else: tryother=True else: