X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=deconnaisseur.py;h=1eaa4831953efa025141b0860fb3dc9eb2643752;hb=07540bfd4c327d1097e66d5f720394f7505be243;hp=09aa2e19e7926376c2ba54f9081d2ab79da46592;hpb=3279df8a38beee7c91fb1af36f87f15ceb263748;p=bots%2Fdeconnaisseur.git diff --git a/deconnaisseur.py b/deconnaisseur.py index 09aa2e1..1eaa483 100755 --- a/deconnaisseur.py +++ b/deconnaisseur.py @@ -5,15 +5,22 @@ # Un bot IRC qui sort des déconnaissances -import irclib -import ircbot import threading import random import time import pickle import re +import signal +import sys +import os from remplace_accents import remplace_accents +# Oui, j'ai recodé ma version d'irclib pour pouvoir rattrapper les SIGHUP +sys.path.insert(0, "/home/vincent/scripts/python-myirclib") +import irclib +import ircbot + + config_password="PatrickSébastien" config_pseudo="deconnaisseur" config_chanlist=["#bot","#flood"] @@ -59,7 +66,7 @@ config_leave_messages=[u"On continuera à jouer plus tard ;)"] # 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","___"] +config_idle_bots=["deconnaisseur","Basile","historien","hung","salesman","Shadobot","Wen","___","Sanctuary","Saturnin"] class UnicodeBotError(Exception): pass @@ -571,7 +578,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(message[1],"") + self.update_activity(channel,"") # on ne dit rien au rejoin #l1,l2=config_kick_answers,config_kick_actions #n1,n2=len(l1),len(l2) @@ -619,23 +626,70 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): self.last_activity[canal]=time.time() def is_active(self,canal): return time.time()-self.last_activity[canal] [--debug]" + print "Usage : deconnaisseur.py [--debug] [--no-output] [--daemon [--pidfile]] [--outfile]" + print " --outfile sans --no-output ni --daemon n'a aucun effet" exit(1) serveur=sys.argv[1] + if "--daemon" in sys.argv: + thisfile = os.path.realpath(__file__) + thisdirectory = thisfile.rsplit("/", 1)[0] + os.chdir(thisdirectory) + daemon = True + else: + daemon = False if "debug" in sys.argv or "--debug" in sys.argv: debug=True else: debug=False serveurs={"a♡":"acoeur.crans.org","acoeur":"acoeur.crans.org","acoeur.crans.org":"acoeur.crans.org", "irc":"irc.crans.org","crans":"irc.crans.org","irc.crans.org":"irc.crans.org"} + if "--no-output" in sys.argv or "--daemon" in sys.argv: + outfile = "/var/log/bots/deconnaisseur.full.log" + for arg in sys.argv: + arg = arg.split("=") + if arg[0].strip('-') in ["out", "outfile", "logfile"]: + outfile = arg[1] + sys.stdout = Logger(outfile) try: serveur=serveurs[serveur] except KeyError: print "Server Unknown : %s"%(serveur) exit(404) - deco=Deconnaisseur(serveur,debug) - deco.start() + deconnaisseur=Deconnaisseur(serveur,debug) + if daemon: + child_pid = os.fork() + if child_pid == 0: + os.setsid() + deconnaisseur.start_as_daemon(outfile) + else: + # on enregistre le pid de deconnaisseur + pidfile = "/var/run/bots/deconnaisseur.pid" + for arg in sys.argv: + arg = arg.split("=") + if arg[0].strip('-') in ["pidfile"]: + pidfile = arg[1] + f = open(pidfile, "w") + f.write("%s\n" % child_pid) + f.close() + else: + deconnaisseur.start() \ No newline at end of file