]>
gitweb.pimeys.fr Git - bots/saturnin.git/blob - saturnin.py
2 # -*- encoding: utf-8 -*-
6 # Un bot IRC pour remplacer le canard.
7 # parce que le canard, c'est le bien et que braice ne pong pas
12 import socket
, ssl
, json
18 from commands
import getstatusoutput
as ex
20 # Oui, j'ai recodé ma version d'irclib pour pouvoir rattrapper les SIGHUP
21 sys
.path
.insert(0, "/home/vincent/scripts/python-myirclib")
25 # on récupère la config
30 def get_config_logfile(serveur
):
31 serveurs
={"acoeur.crans.org":"acoeur","irc.crans.org":"crans"}
32 return config
.logfile_template
%(serveurs
[serveur
])
34 def log(serveur
,channel
,auteur
=None,message
=None):
35 f
=open(get_config_logfile(serveur
),"a")
36 if auteur
==message
==None:
37 # alors c'est que c'est pas un channel mais juste une ligne de log
38 chain
="%s %s"%(time
.strftime("%F %T"),channel
)
40 chain
="%s [%s:%s] %s"%(time
.strftime("%F %T"),channel
,auteur
,message
)
42 if config
.debug_stdout
:
46 def is_something(chain
,matches
,avant
=u
".*(?:^| )",apres
=u
"(?:$|\.| |,|;).*",case_sensitive
=False,debug
=False):
48 chain
=unicode(chain
,"utf8")
50 chain
=unicode(chain
,"utf8").lower()
51 allmatches
="("+"|".join(matches
)+")"
52 reg
=(avant
+allmatches
+apres
).lower()
56 regexp_pan
= re
.compile(u
".*(" + "|".join(config
.killwords
) + u
").*")
58 return regexp_pan
.match(unicode(chain
,"utf8").lower())
59 def ignore_pan(serv
, ev
):
60 """Retourne ``True`` si il faut ignorer ce pan."""
61 for (blackmask
, exceptmask
) in config
.ignored_pan_masks
:
62 usermask
= ev
.source()
63 return bool(irclib
.mask_matches(usermask
, blackmask
) and not irclib
.mask_matches(usermask
, exceptmask
))
65 class UnicodeBotError(Exception):
67 def bot_unicode(chain
):
70 except UnicodeDecodeError as exc
:
73 class Saturnin(ircbot
.SingleServerIRCBot
):
74 def __init__(self
,serveur
,debug
=False):
75 temporary_pseudo
=config
.irc_pseudo
+str(random
.randrange(10000,100000))
76 ircbot
.SingleServerIRCBot
.__init
__(self
, [(serveur
, 6667)],
77 temporary_pseudo
,"Coin ? ©braice [mais 'faut frapper 20-100]", 10)
80 self
.overops
=config
.overops
81 self
.ops
=self
.overops
+config
.ops
82 self
.chanlist
=config
.chanlist
83 self
.stay_channels
=config
.stay_channels
84 self
.quiet_channels
=config
.quiet_channels
85 self
.play_channels
=config
.play_channels
86 self
.status
= { chan
: [0, None] for chan
in self
.play_channels
}
87 # 0 : pas de spawn prévu
89 # avec en deuxième paramètre le timestamp du moment où il a été déclenché (pas du moment où il se fera)
93 def give_me_my_pseudo(self
,serv
):
94 serv
.privmsg("NickServ","RECOVER %s %s"%(config
.irc_pseudo
,config
.irc_password
))
95 serv
.privmsg("NickServ","RELEASE %s %s"%(config
.irc_pseudo
,config
.irc_password
))
97 serv
.nick(config
.irc_pseudo
)
99 def on_welcome(self
, serv
, ev
):
100 self
.serv
=serv
# ça serv ira :)
101 self
.give_me_my_pseudo(serv
)
102 serv
.privmsg("NickServ","IDENTIFY %s"%(config
.irc_password
))
103 log(self
.serveur
,"Connected")
105 self
.chanlist
= self
.play_channels
= ["#bot"]
106 self
.status
= { chan
: [0, 0] for chan
in self
.play_channels
}
107 for c
in self
.chanlist
:
108 log(self
.serveur
,"JOIN %s"%(c))
110 if c
in self
.play_channels
:
111 spawn_delay
= random
.randrange(*config
.spawn_delays
)
112 self
.spawn(c
, time
.time(), spawn_delay
)
114 def pourmoi(self
, serv
, message
):
115 """renvoie (False,lemessage) ou (True, le message amputé de "pseudo: ")"""
118 if message
[:size
]==pseudo
and len(message
)>size
and message
[size
]==":":
119 return (True,message
[size
+1:].lstrip(" "))
121 return (False,message
)
123 def on_privmsg(self
, serv
, ev
):
124 message
=ev
.arguments()[0]
125 auteur
= irclib
.nm_to_n(ev
.source())
127 test
=bot_unicode(message
)
128 except UnicodeBotError
:
129 if config
.utf8_trigger
:
130 serv
.privmsg(auteur
, random
.choice(config
.utf8_fail_answers
).encode("utf8"))
132 message
=message
.split()
133 cmd
=message
[0].lower()
136 helpdico
={"help":["""HELP <commande>
137 Affiche de l'aide sur la commande""",None,None],
139 Affiche votre score""", None, None],
141 Afficher tous les scores""", None, None],
142 "join": [None, """JOIN <channel>
143 Me fait rejoindre le channel""",None],
144 "leave": [None,"""LEAVE <channel>
145 Me fait quitter le channel (sauf s'il est dans ma stay_list).""",None],
146 "quiet": [None,"""QUIET <channel>
147 Me rend silencieux sur le channel.""",None],
148 "noquiet": [None,"""NOQUIET <channel>
149 Me rend la parole sur le channel.""",None],
150 "play": [None, """PLAY
151 Passe un channel en mode "jouer" """,None],
152 "noplay": [None, """NOPLAY
153 Passe un channel en mode "ne pas jouer" """,None],
154 "SPAWN": [None, """SPAWN <channel>
155 Me fait spawner sur le channel.""",None],
156 "reload": [None,"""RELOAD
157 Recharge la configuration.""",None],
158 "say": [None,None,"""SAY <channel> <message>
159 Me fait parler sur le channel."""],
160 "do": [None,None,"""DO <channel> <action>
161 Me fait faitre une action (/me) sur le channel."""],
162 "stay": [None,None,"""STAY <channel>
163 Ajoute le channel à ma stay_list."""],
164 "nostay": [None,None,"""NOSTAY <channel>
165 Retire le channel de ma stay_list."""],
166 "ops": [None,None,"""OPS
167 Affiche la liste des ops."""],
168 "overops": [None,None,"""OVEROPS
169 Affiche la liste des overops."""],
170 "kick": [None,None,"""KICK <channel> <pseudo> [<raison>]
171 Kicke <pseudo> du channel (Il faut bien entendu que j'y sois op)."""],
172 "die": [None,None,"""DIE
173 Me déconnecte du serveur IRC."""]
175 helpmsg_default
="Liste des commandes disponibles :\nHELP SCORE SCORES"
176 helpmsg_ops
=" JOIN LEAVE QUIET NOQUIET PLAY NOPLAY SPAWN"
177 helpmsg_overops
=" SAY DO STAY NOSTAY OPS OVEROPS KICK DIE"
178 op
,overop
=auteur
in self
.ops
, auteur
in self
.overops
180 helpmsg
=helpmsg_default
184 helpmsg
+=helpmsg_overops
186 helpmsgs
=helpdico
.get(message
[1].lower(),["Commande inconnue.",None,None])
188 if op
and helpmsgs
[1]:
190 helpmsg
+="\n"+helpmsgs
[1]
193 if overop
and helpmsgs
[2]:
195 helpmsg
+="\n"+helpmsgs
[2]
198 for ligne
in helpmsg
.split("\n"):
199 serv
.privmsg(auteur
,ligne
)
201 if auteur
in self
.ops
:
203 if message
[1] in self
.chanlist
:
204 serv
.privmsg(auteur
,"Je suis déjà sur %s"%(message
[1]))
206 serv
.join(message
[1])
207 self
.chanlist
.append(message
[1])
208 serv
.privmsg(auteur
,"Channels : "+" ".join(self
.chanlist
))
209 log(self
.serveur
,"priv",auteur
," ".join(message
))
211 serv
.privmsg(auteur
,"Channels : "+" ".join(self
.chanlist
))
215 if auteur
in self
.ops
and len(message
)>1:
216 if message
[1] in self
.chanlist
:
217 if not (message
[1] in self
.stay_channels
) or auteur
in self
.overops
:
218 self
.quitter(message
[1]," ".join(message
[2:]))
219 self
.chanlist
.remove(message
[1])
220 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
222 serv
.privmsg(auteur
,"Non, je reste !")
223 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
225 serv
.privmsg(auteur
,"Je ne suis pas sur %s"%(message
[1]))
229 if auteur
in self
.overops
:
231 if message
[1] in self
.stay_channels
:
232 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
233 serv
.privmsg(auteur
,"Je stay déjà sur %s."%(message
[1]))
235 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
236 self
.stay_channels
.append(message
[1])
237 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
239 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
243 if auteur
in self
.overops
:
245 if message
[1] in self
.stay_channels
:
246 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
247 self
.stay_channels
.remove(message
[1])
248 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
250 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
251 serv
.privmsg(auteur
,"Je ne stay pas sur %s."%(message
[1]))
256 if auteur
in self
.overops
:
257 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
262 if auteur
in self
.ops
:
264 if message
[1] in self
.quiet_channels
:
265 serv
.privmsg(auteur
,"Je me la ferme déjà sur %s"%(message
[1]))
266 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
268 self
.quiet_channels
.append(message
[1])
269 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
270 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
272 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
276 if auteur
in self
.ops
:
278 if message
[1] in self
.quiet_channels
:
279 self
.quiet_channels
.remove(message
[1])
280 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
281 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
283 serv
.privmsg(auteur
,"Je ne me la ferme pas sur %s."%(message
[1]))
284 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
288 if auteur
in self
.ops
:
290 if message
[1] in self
.play_channels
:
291 serv
.privmsg(auteur
,"Je play déjà sur %s."%(message
[1]))
292 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
294 self
.play_channels
.append(message
[1])
295 self
.spawn(message
[1], 1)
296 serv
.privmsg(auteur
,"Play channels : "+" ".join(self
.play_channels
))
297 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
299 serv
.privmsg(auteur
,"Play channels : "+" ".join(self
.play_channels
))
303 if auteur
in self
.ops
:
305 if message
[1] in self
.play_channels
:
306 self
.play_channels
.remove(message
[1])
307 serv
.privmsg(auteur
,"Play channels : "+" ".join(self
.play_channels
))
308 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
310 serv
.privmsg(auteur
,"Je ne play pas sur %s."%(message
[1]))
311 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
315 if auteur
in self
.ops
:
316 serv
.privmsg(auteur
,"Status : %s" % (self
.status
, ))
320 if auteur
in self
.ops
:
322 if message
[1] in self
.play_channels
:
323 # Le plus pratique pour pas s'embêter c'est de mettre un
324 # delay d'une seconde, comme ça .spawn() fait le boulot
325 self
.spawn(message
[1], time
.time(), 1)
327 serv
.privmsg(auteur
, "Je ne joue pas sur %s" % message
[1])
329 serv
.privmsg(auteur
, "Syntaxe : SPAWN <channel>")
333 if auteur
in self
.overops
and len(message
)>2:
334 serv
.privmsg(message
[1]," ".join(message
[2:]))
335 log(self
.serveur
,"priv",auteur
," ".join(message
))
336 elif len(message
)<=2:
337 serv
.privmsg(auteur
,"Syntaxe : SAY <channel> <message>")
341 if auteur
in self
.overops
and len(message
)>2:
342 serv
.action(message
[1]," ".join(message
[2:]))
343 log(self
.serveur
,"priv",auteur
," ".join(message
))
344 elif len(message
)<=2:
345 serv
.privmsg(auteur
,"Syntaxe : DO <channel> <action>")
349 if auteur
in self
.overops
and len(message
)>2:
350 serv
.kick(message
[1],message
[2]," ".join(message
[3:]))
351 log(self
.serveur
,"priv",auteur
," ".join(message
))
352 elif len(message
)<=2:
353 serv
.privmsg(auteur
,"Syntaxe : KICK <channel> <pseudo> [<raison>]")
357 if auteur
in self
.overops
:
358 serv
.privmsg(auteur
," ".join(self
.ops
))
362 if auteur
in self
.overops
:
363 serv
.privmsg(auteur
," ".join(self
.overops
))
367 if auteur
in self
.ops
:
369 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
374 if len(message
) in [3,4] and message
[1].lower()=="transfert":
375 scores
=self
.get_scores()
376 de
,to
=auteur
,message
[2]
377 value
=scores
.get(de
,0)
380 asked
=int(message
[3])
382 serv
.privmsg(auteur
,"Syntaxe : SCORE TRANSFERT <pseudo> [<n>]")
387 serv
.privmsg(auteur
,"Vous n'avez pas de points")
390 serv
.privmsg(auteur
,"Bien tenté…")
393 serv
.privmsg(auteur
,"Vous n'avez que %s points"%(value))
396 self
.add_score(de
,-asked
)
397 self
.add_score(to
,asked
)
398 serv
.privmsg(auteur
,"Transfert de %s points de %s à %s"%(asked
,de
,to
))
400 serv
.privmsg(auteur
,"Syntaxe : SCORE TRANSFERT <pseudo> [<n>]")
402 self
.sendscore(auteur
)
405 self
.sendscores(auteur
)
406 elif auteur
in self
.overops
:
407 souscmd
=message
[1].lower()
411 scores
=self
.get_scores()
412 if scores
.has_key(todelete
):
414 self
.save_scores(scores
)
415 serv
.privmsg(auteur
,"Score de %s supprimé"%(todelete))
417 serv
.privmsg(auteur
,"Ce score n'existe pas : %s"%(todelete))
419 serv
.privmsg(auteur
,"Syntaxe : SCORES DEL <pseudo>")
420 elif souscmd
in ["add","sub"]:
422 toadd
,val
=message
[2],message
[3]
426 serv
.privmsg(auteur
,"Syntaxe : SCORES {ADD|SUB} <pseudo> <n>")
430 self
.add_score(toadd
,val
)
431 serv
.privmsg(auteur
,"Done")
433 serv
.privmsg(auteur
,"Syntaxe : SCORES {ADD|SUB} <pseudo> <n>")
435 serv
.privmsg(auteur
,"Syntaxe : SCORES {DEL|ADD|SUB} <pseudo> [<n>]")
441 serv
.privmsg(auteur
,"Je n'ai pas compris. Essayez HELP…")
443 def sendscore(self
, to
):
444 self
.serv
.privmsg(to
, "Votre score : %s"%(self
.get_scores().get(to
,0)) )
446 def sendscores(self
, to
):
447 scores
=self
.get_scores().items()
449 scores
.sort(lambda x
,y
:cmp(x
[1],y
[1]))
451 self
.serv
.privmsg(to
, "Scores by score : "+" ; ".join(["%s %s"%(i
[0],i
[1]) for i
in scores
]))
453 scores
.sort(lambda x
,y
:cmp(x
[0].lower(),y
[0].lower()))
454 self
.serv
.privmsg(to
, "Scores by pseudo : "+" ; ".join(["%s %s"%(i
[0],i
[1]) for i
in scores
]))
456 def on_pubmsg(self
, serv
, ev
):
457 auteur
= irclib
.nm_to_n(ev
.source())
458 if re
.match(config
.ignored_pseudos
, auteur
):
460 channel
= ev
.target()
461 message
= ev
.arguments()[0]
463 test
=bot_unicode(message
)
464 except UnicodeBotError
:
465 if config
.utf8_trigger
and not channel
in self
.quiet_channels
:
466 serv
.privmsg(channel
, (u
"%s: %s"%(auteur
,random
.choice(config
.utf8_fail_answers
))).encode("utf8"))
468 pour_moi
,message
=self
.pourmoi(serv
,message
)
469 if pour_moi
and message
.split()!=[]:
470 cmd
=message
.split()[0].lower()
472 args
=" ".join(message
.split()[1:])
475 if cmd
in ["meurs","die","crève"]:
476 if auteur
in self
.overops
:
477 log(self
.serveur
,channel
,auteur
,message
+"[successful]")
480 serv
.privmsg(channel
,("%s: %s"%(auteur
,random
.choice(config
.quit_fail_messages
))).encode("utf8"))
481 log(self
.serveur
,channel
,auteur
,message
+"[failed]")
482 elif cmd
== "reload":
483 if auteur
in self
.ops
:
484 log(self
.serveur
, channel
, auteur
, message
+"[successful]")
486 elif cmd
in ["part","leave","dégage","va-t-en","tut'tiresailleurs,c'estmesgalets"]:
487 if auteur
in self
.ops
and (not (channel
in self
.stay_channels
)
488 or auteur
in self
.overops
):
489 self
.quitter(channel
)
490 log(self
.serveur
,channel
,auteur
,message
+"[successful]")
491 if channel
in self
.chanlist
:
492 self
.chanlist
.remove(channel
)
494 serv
.privmsg(channel
,("%s: %s"%(auteur
,random
.choice(config
.leave_fail_messages
))).encode("utf8"))
495 log(self
.serveur
,channel
,auteur
,message
+"[failed]")
497 self
.sendscore(auteur
)
498 elif cmd
== "scores":
499 self
.sendscores(auteur
)
502 if ignore_pan(serv
, ev
):
504 self
.shot(channel
, auteur
)
506 def on_action(self
, serv
, ev
):
507 action
= ev
.arguments()[0]
508 auteur
= irclib
.nm_to_n(ev
.source())
509 channel
= ev
.target()
511 #~ test=bot_unicode(action)
512 #~ except UnicodeBotError:
513 #~ if config.utf8_trigger and not channel in self.quiet_channels:
514 #~ serv.privmsg(channel, (u"%s: %s"%(auteur,random.choice(config.utf8_fail_answers))).encode("utf8"))
516 #~ mypseudo=self.nick
518 def on_kick(self
,serv
,ev
):
519 auteur
= irclib
.nm_to_n(ev
.source())
520 channel
= ev
.target()
521 victime
= ev
.arguments()[0]
522 raison
= ev
.arguments()[1]
523 if victime
==self
.nick
:
524 log(self
.serveur
,"%s kické de %s par %s (raison : %s)" %(victime
,channel
,auteur
,raison
))
527 #~ l1,l2=config.kick_answers,config.kick_actions
528 #~ n1,n2=len(l1),len(l2)
529 #~ i=random.randrange(n1+n2)
531 #~ serv.action(channel,l2[i-n1].format(auteur).encode("utf8"))
533 #~ serv.privmsg(channel,l1[i].format(auteur).encode("utf8"))
535 def spawn(self
, channel
, timestamp
, delay
=0):
536 if channel
in self
.play_channels
:
538 self
.serv
.execute_delayed(delay
, self
.spawn
, (channel
, timestamp
))
539 self
.status
[channel
] = [1, timestamp
]
541 # on teste le timestamp pour pas s'emmêler dans les spawn
542 infos
= self
.status
.get(channel
, [0,0])
543 if infos
== [1, timestamp
]:
544 spawn_sentence
= random
.choice(config
.canards
) + random
.choice(config
.spawn_sentences
)
545 self
.serv
.privmsg(channel
, spawn_sentence
.encode("utf8"))
546 self
.status
[channel
] = [2, timestamp
]
547 times_up_delay
= random
.randrange(*config
.times_up_delays
)
548 self
.serv
.execute_delayed(times_up_delay
, self
.too_slow
, (channel
, timestamp
))
550 def too_slow(self
, channel
, timestamp
):
551 infos
= self
.status
.get(channel
, [0,0])
552 if infos
== [2, timestamp
]:
553 self
.serv
.privmsg(channel
, random
.choice(config
.times_up_sentences
).encode("utf8"))
554 respawn_delay
= random
.randrange(*config
.spawn_delays
)
555 self
.spawn(channel
, time
.time(), respawn_delay
)
557 def shot(self
, channel
, auteur
):
558 if self
.status
.get(channel
, [0, 0])[0] == 2:
559 succeed
= random
.randrange(0,101) > config
.proba_miss
561 self
.serv
.privmsg(channel
, random
.choice(config
.killed_templates
).format(auteur
).encode("utf8"))
562 self
.add_score(auteur
, 1)
563 if random
.randrange(0, 101) < config
.proba_killed_sentence
:
564 self
.serv
.privmsg(channel
, random
.choice(config
.killed_sentences
).encode("utf8"))
565 respawn_delay
= random
.randrange(*config
.spawn_delays
)
566 self
.spawn(channel
, time
.time(), respawn_delay
)
568 self
.serv
.privmsg(channel
, random
.choice(config
.miss_templates
).format(auteur
).encode("utf8"))
569 if random
.randrange(0,101) < config
.proba_miss_sentence
:
570 self
.serv
.privmsg(channel
, random
.choice(config
.miss_sentences
).encode("utf8"))
572 def quitter(self
,chan
,leave_message
=None):
573 if leave_message
==None:
574 leave_message
=random
.choice(config
.leave_messages
)
575 self
.serv
.part(chan
,message
=leave_message
.encode("utf8"))
578 quit_message
=random
.choice(config
.quit_messages
)
579 self
.die(msg
=quit_message
.encode("utf8"))
581 def get_scores(self
):
582 f
=open(config
.score_file
)
583 scores
=pickle
.load(f
)
587 def add_score(self
, pseudo
, value
):
588 scores
=self
.get_scores()
589 if scores
.has_key(pseudo
):
590 scores
[pseudo
]+=value
593 self
.save_scores(scores
)
595 def save_scores(self
,scores
):
596 f
=open(config
.score_file
,"w")
597 pickle
.dump(scores
,f
)
601 return self
.serv
.get_nickname()
602 nick
=property(_getnick
)
604 def reload(self
, auteur
=None):
606 if auteur
in [None, "SIGHUP"]:
607 towrite
= "Config reloaded" + " (SIGHUP received)"*(auteur
== "SIGHUP")
608 for to
in config
.report_bugs_to
:
609 self
.serv
.privmsg(to
, towrite
)
610 log(self
.serveur
, towrite
)
612 self
.serv
.privmsg(auteur
,"Config reloaded")
614 def start_as_daemon(self
, outfile
):
615 sys
.stderr
= Logger(outfile
)
619 class Logger(object):
620 """Pour écrire ailleurs que sur stdout"""
621 def __init__(self
, filename
="saturnin.full.log"):
622 self
.filename
= filename
624 def write(self
, message
):
625 f
= open(self
.filename
, "a")
630 if __name__
=="__main__":
633 print "Usage : saturnin.py <serveur> [--debug] [--no-output] [--daemon [--pidfile]] [--outfile]"
634 print " --outfile sans --no-output ni --daemon n'a aucun effet"
637 if "--daemon" in sys
.argv
:
638 thisfile
= os
.path
.realpath(__file__
)
639 thisdirectory
= thisfile
.rsplit("/", 1)[0]
640 os
.chdir(thisdirectory
)
644 if "debug" in sys
.argv
or "--debug" in sys
.argv
:
648 if "--no-output" in sys
.argv
or "--daemon" in sys
.argv
:
649 outfile
= "/var/log/bots/saturnin.full.log"
652 if arg
[0].strip('-') in ["out", "outfile", "logfile"]:
654 sys
.stdout
= Logger(outfile
)
655 if "--quiet" in sys
.argv
:
656 config
.debug_stdout
=False
657 serveurs
={"a♡":"acoeur.crans.org","acoeur":"acoeur.crans.org","acoeur.crans.org":"acoeur.crans.org",
658 "irc":"irc.crans.org","crans":"irc.crans.org","irc.crans.org":"irc.crans.org",
661 serveur
=serveurs
[serveur
]
663 print "Server Unknown : %s"%(serveur)
665 saturnin
= Saturnin(serveur
,debug
)
666 # Si on reçoit un SIGHUP, on reload la config
667 def sighup_handler(signum
, frame
):
668 saturnin
.reload("SIGHUP")
669 signal
.signal(signal
.SIGHUP
, sighup_handler
)
671 child_pid
= os
.fork()
674 saturnin
.start_as_daemon(outfile
)
676 # on enregistre le pid de saturnin
677 pidfile
= "/var/run/bots/saturnin.pid"
680 if arg
[0].strip('-') in ["pidfile"]:
682 f
= open(pidfile
, "w")
683 f
.write("%s\n" % child_pid
)