notunderstood=True
elif cmd=="reload":
if auteur in self.ops:
- reload(config)
- serv.privmsg(auteur,"done")
+ self.reload(auteur)
+ log(self.serveur,"priv",auteur," ".join(message)+"[successful]")
else:
notunderstood=True
elif cmd=="score":
else:
serv.privmsg(channel,("%s: %s"%(auteur,random.choice(config.quit_fail_messages))).encode("utf8"))
log(self.serveur,channel,auteur,message+"[failed]")
+ elif cmd == "reload":
+ if auteur in self.ops:
+ log(self.serveur, channel, auteur, message+"[successful]")
+ self.reload(channel)
elif cmd in ["part","leave","dégage","va-t-en","tut'tiresailleurs,c'estmesgalets"]:
if auteur in self.ops and (not (channel in self.stay_channels)
or auteur in self.overops):
return self.serv.get_nickname()
nick=property(_getnick)
+ def reload(self, auteur=None):
+ reload(config)
+ if auteur in [None, "SIGHUP"]:
+ towrite = "Config reloaded" + " (SIGHUP received)"*(auteur == "SIGHUP")
+ for to in config.report_bugs_to:
+ self.serv.privmsg(to, towrite)
+ log(self.serveur, towrite)
+ else:
+ self.serv.privmsg(auteur,"Config reloaded")
+
def start_as_daemon(self, outfile):
sys.stderr = Logger(outfile)
self.start()
print "Server Unknown : %s"%(serveur)
exit(404)
saturnin = Saturnin(serveur,debug)
+ # Si on reçoit un SIGHUP, on reload la config
+ def sighup_handler(signum, frame):
+ saturnin.reload("SIGHUP")
+ signal.signal(signal.SIGHUP, sighup_handler)
if daemon:
child_pid = os.fork()
if child_pid == 0: