3 # Codé par 20-100 (commencé le 21/06/12)
5 # Un bot IRC pour kicker à tour de bras de #déprime
10 import socket
, ssl
, json
17 # Oui, j'ai recodé ma version d'irclib pour pouvoir rattrapper les SIGHUP
18 sys
.path
.insert(0, "/home/vincent/scripts/python-myirclib")
27 def get_config_logfile(serveur
):
28 serveurs
={"acoeur.crans.org":"acoeur","irc.crans.org":"crans"}
29 return config
.logfile_template
%(serveurs
[serveur
])
32 def log(serveur
,channel
,auteur
=None,message
=None):
33 f
=open(get_config_logfile(serveur
),"a")
34 if auteur
==message
==None:
35 # alors c'est que c'est pas un channel mais juste une ligne de log
36 chain
="%s %s"%(time
.strftime("%F %T"),channel
)
38 chain
="%s [%s:%s] %s"%(time
.strftime("%F %T"),channel
,auteur
,message
)
40 if config
.debug_stdout
:
44 def ignore_event(serv
, ev
):
45 """Retourne ``True`` si il faut ignorer cet évènement."""
46 for (blackmask
, exceptmask
) in config
.blacklisted_masks
:
47 usermask
= ev
.source()
48 if exceptmask
is None:
51 exceptit
= bool(irclib
.mask_matches(usermask
, exceptmask
))
52 blackit
= bool(irclib
.mask_matches(usermask
, blackmask
))
53 return blackit
and not exceptit
55 reg_is_smiley
= re
.compile(u
".*("+u
"|".join(config
.smileys
)+u
")")
57 chain
=unicode(chain
,"utf8")
58 o
=re
.match(reg_is_smiley
,chain
)
61 reg_is_anglicisme
= re
.compile(u
".*(?:^| )(" + u
"|".join(config
.anglicismes
) + u
")(?:$|\.| |,|;)")
62 def is_anglicisme(chain
):
63 chain
= unicode(chain
, "utf8").lower()
64 o
= re
.match(reg_is_anglicisme
, chain
)
67 # Cette liste contient la liste des raisons pour lesquelles on peut se faire kicker
68 # chaque élément contient :
69 # - la fonction de détection du kick (qui matchera une regexp et renverra l'objet de match)
70 # - la raison donnée au moment du kick ({0} étant remplacé par ce qui a matché)
71 config
.kicking_list
= [
72 [is_smiley
, u
'"{0}" ? Ici on déprime.'],
73 [is_anglicisme
, u
'"{0}" ? Get out, you and your fucking anglicism !']
76 def is_something(chain
,matches
,avant
=u
".*(?:^| )",apres
=u
"(?:$|\.| |,|;).*",case_sensitive
=False,debug
=False):
78 chain
=unicode(chain
,"utf8")
80 chain
=unicode(chain
,"utf8").lower()
81 allmatches
="("+"|".join(matches
)+")"
82 reg
=(avant
+allmatches
+apres
).lower()
86 def is_insult(chain
,debug
=True):
87 return is_something(chain
,config
.insultes
,avant
=".*(?:^| |')")
88 def is_not_insult(chain
):
89 chain
=unicode(chain
,"utf8")
90 insult_regexp
=u
"("+u
"|".join(config
.insultes
)+u
")"
91 middle_regexp
=u
"(une? (?:(?:putain|enfoiré) d(?:e |'))*|)(?:| super )(?: (?:gros|petit|grand|énorme) |)"
92 reg
=".*pas %s%s.*"%(middle_regexp
,insult_regexp
)
93 if re
.match(reg
,chain
):
97 def is_compliment(chain
,debug
=True):
98 return is_something(chain
,config
.compliment_triggers
,avant
=".*(?:^| |')")
100 return is_something(chain
,config
.perdu
)
102 return is_something(chain
,config
.tag_triggers
)
104 return is_something(chain
,config
.tesla_triggers
,avant
=u
"^",apres
=u
"$",debug
=True)
106 return is_something(chain
,config
.merci_triggers
)
107 def is_tamere(chain
):
108 return is_something(chain
,config
.tamere_triggers
)
109 def is_bad_action_trigger(chain
,pseudo
):
110 return is_something(chain
,config
.bad_action_triggers
,avant
=u
"^",
111 apres
="(?: [a-z]*ment)? %s($|\.| |,|;).*"%(pseudo))
112 def is_good_action_trigger(chain
,pseudo
):
113 return is_something(chain
,config
.good_action_triggers
,avant
=u
"^",
114 apres
="(?: [a-z]*ment)? %s($|\.| |,|;).*"%(pseudo))
115 def is_bonjour(chain
):
116 return is_something(chain
,config
.bonjour_triggers
,avant
=u
"^")
117 def is_bonne_nuit(chain
):
118 return is_something(chain
,config
.bonne_nuit_triggers
,avant
=u
"^")
120 return re
.match(u
"^(pan|bim|bang)( .*)?$",unicode(chain
,"utf8").lower().strip())
123 _
,_
,_
,h
,m
,s
,_
,_
,_
=time
.localtime()
124 return (conf
[0],0,0)<(h
,m
,s
)<(conf
[1],0,0)
126 return is_time(config
.daytime
)
128 return is_time(config
.nighttime
)
131 class UnicodeBotError(Exception):
133 def bot_unicode(chain
):
135 unicode(chain
,"utf8")
136 except UnicodeDecodeError as exc
:
137 raise UnicodeBotError
139 class Themis(ircbot
.SingleServerIRCBot
):
140 def __init__(self
,serveur
,debug
=False):
141 temporary_pseudo
=config
.irc_pseudo
+str(random
.randrange(10000,100000))
142 ircbot
.SingleServerIRCBot
.__init
__(self
, [(serveur
, 6667)],
143 temporary_pseudo
,"Des[bot]e de #déprime", 10)
146 self
.overops
=config
.overops
147 self
.ops
=self
.overops
+config
.ops
148 self
.report_bugs_to
=config
.report_bugs_to
149 self
.chanlist
=config
.chanlist
150 self
.kick_channels
=config
.kick_channels
151 self
.stay_channels
=config
.stay_channels
152 self
.quiet_channels
=config
.quiet_channels
156 def give_me_my_pseudo(self
,serv
):
157 serv
.privmsg("NickServ","RECOVER %s %s"%(config
.irc_pseudo
,config
.irc_password
))
158 serv
.privmsg("NickServ","RELEASE %s %s"%(config
.irc_pseudo
,config
.irc_password
))
160 serv
.nick(config
.irc_pseudo
)
162 def give_me_my_op_status(self
,serv
,chan
):
163 serv
.privmsg("ChanServ","OP %s"%(chan))
165 def on_welcome(self
, serv
, ev
):
166 self
.serv
=serv
# ça serv ira
167 self
.give_me_my_pseudo(serv
)
168 serv
.privmsg("NickServ","identify %s"%(config
.irc_password
))
169 log(self
.serveur
,"Connected")
171 self
.chanlist
=["#bot"]
172 self
.kick_channels
=["#bot"]
173 for c
in self
.chanlist
:
174 log(self
.serveur
,"JOIN %s"%(c))
176 self
.give_me_my_op_status(serv
,c
)
179 def lost(self
,serv
,channel
,forced
=False):
180 if self
.last_perdu
+config
.time_between_perdu
<time
.time() or forced
:
181 if not channel
in self
.quiet_channels
or forced
:
182 serv
.privmsg(channel
,"J'ai perdu !")
183 self
.last_perdu
=time
.time()
184 delay
=config
.time_between_perdu_trigger
185 delta
=config
.time_between_perdu_trigger_delta
186 serv
.execute_delayed(random
.randrange(delay
-delta
,delay
+delta
),self
.lost
,(serv
,channel
))
188 def pourmoi(self
, serv
, message
):
189 """renvoie (False,lemessage) ou (True, le message amputé de "pseudo: ")"""
192 if message
[:size
]==pseudo
and len(message
)>size
and message
[size
]==":":
193 return (True,message
[size
+1:].lstrip(" "))
195 return (False,message
)
197 def on_privmsg(self
, serv
, ev
):
198 if ignore_event(serv
, ev
):
200 message
=ev
.arguments()[0]
201 auteur
= irclib
.nm_to_n(ev
.source())
203 test
=bot_unicode(message
)
204 except UnicodeBotError
:
205 if config
.utf8_trigger
:
206 serv
.privmsg(auteur
, random
.choice(config
.utf8_fail_answers
).encode("utf8"))
208 message
=message
.split()
209 cmd
=message
[0].lower()
212 helpdico
={"help":["""HELP <commande>
213 Affiche de l'aide sur la commande""",None,None],
214 "join": [None, """JOIN <channel>
215 Me fait rejoindre le channel""",None],
216 "leave": [None,"""LEAVE <channel>
217 Me fait quitter le channel (sauf s'il est dans ma stay_list).""",None],
218 "quiet": [None,"""QUIET <channel>
219 Me rend silencieux sur le channel.""",None],
220 "noquiet": [None,"""NOQUIET <channel>
221 Me rend la parole sur le channel.""",None],
222 "reload": [None,"""RELOAD
223 Recharge la configuration.""",None],
224 "say": [None,None,"""SAY <channel> <message>
225 Me fait parler sur le channel."""],
226 "do": [None,None,"""DO <channel> <action>
227 Me fait faitre une action (/me) sur le channel."""],
228 "stay": [None,None,"""STAY <channel>
229 Ajoute le channel à ma stay_list."""],
230 "nostay": [None,None,"""NOSTAY <channel>
231 Retire le channel de ma stay_list."""],
232 "ops": [None,None,"""OPS
233 Affiche la liste des ops."""],
234 "overops": [None,None,"""OVEROPS
235 Affiche la liste des overops."""],
236 "kick": [None,None,"""KICK <channel> <pseudo> [<raison>]
237 Kicke <pseudo> du channel (Il faut bien entendu que j'y sois op)."""],
238 "die": [None,None,"""DIE
239 Me déconnecte du serveur IRC."""]
241 helpmsg_default
="Liste des commandes disponibles :\nHELP"
242 helpmsg_ops
=" JOIN LEAVE QUIET NOQUIET LOST RELOAD"
243 helpmsg_overops
=" SAY DO STAY NOSTAY OPS OVEROPS KICK DIE"
244 op
,overop
=auteur
in self
.ops
, auteur
in self
.overops
246 helpmsg
=helpmsg_default
250 helpmsg
+=helpmsg_overops
252 helpmsgs
=helpdico
.get(message
[1].lower(),["Commande inconnue.",None,None])
254 if op
and helpmsgs
[1]:
256 helpmsg
+="\n"+helpmsgs
[1]
259 if overop
and helpmsgs
[2]:
261 helpmsg
+="\n"+helpmsgs
[2]
264 for ligne
in helpmsg
.split("\n"):
265 serv
.privmsg(auteur
,ligne
)
267 if auteur
in self
.ops
:
269 if message
[1] in self
.chanlist
:
270 serv
.privmsg(auteur
,"Je suis déjà sur %s"%(message
[1]))
272 serv
.join(message
[1])
273 self
.chanlist
.append(message
[1])
274 serv
.privmsg(auteur
,"Channels : "+" ".join(self
.chanlist
))
275 log(self
.serveur
,"priv",auteur
," ".join(message
))
277 serv
.privmsg(auteur
,"Channels : "+" ".join(self
.chanlist
))
281 if auteur
in self
.ops
and len(message
)>1:
282 if message
[1] in self
.chanlist
:
283 if not (message
[1] in self
.stay_channels
) or auteur
in self
.overops
:
284 self
.quitter(message
[1]," ".join(message
[2:]))
285 self
.chanlist
.remove(message
[1])
286 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
288 serv
.privmsg(auteur
,random
.choice(config
.leave_fail_messages
))
289 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
291 serv
.privmsg(auteur
,"Je ne suis pas sur %s"%(message
[1]))
295 if auteur
in self
.overops
:
297 if message
[1] in self
.stay_channels
:
298 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
299 serv
.privmsg(auteur
,"Je stay déjà sur %s."%(message
[1]))
301 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
302 self
.stay_channels
.append(message
[1])
303 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
305 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
309 if auteur
in self
.overops
:
311 if message
[1] in self
.stay_channels
:
312 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
313 self
.stay_channels
.remove(message
[1])
314 serv
.privmsg(auteur
,"Stay channels : "+" ".join(self
.stay_channels
))
316 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
317 serv
.privmsg(auteur
,"Je ne stay pas sur %s."%(message
[1]))
322 if auteur
in self
.overops
:
323 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
328 if auteur
in self
.ops
:
330 if message
[1] in self
.quiet_channels
:
331 serv
.privmsg(auteur
,"Je me la ferme déjà sur %s"%(message
[1]))
332 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
334 self
.quiet_channels
.append(message
[1])
335 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
336 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
338 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
342 if auteur
in self
.ops
:
344 if message
[1] in self
.quiet_channels
:
345 self
.quiet_channels
.remove(message
[1])
346 serv
.privmsg(auteur
,"Quiet channels : "+" ".join(self
.quiet_channels
))
347 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
349 serv
.privmsg(auteur
,"Je ne me la ferme pas sur %s."%(message
[1]))
350 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[failed]")
354 if auteur
in self
.ops
:
356 log(self
.serveur
,"priv",auteur
," ".join(message
)+"[successful]")
360 if auteur
in self
.overops
and len(message
)>2:
361 serv
.privmsg(message
[1]," ".join(message
[2:]))
362 log(self
.serveur
,"priv",auteur
," ".join(message
))
363 elif len(message
)<=2:
364 serv
.privmsg(auteur
,"Syntaxe : SAY <channel> <message>")
368 if auteur
in self
.overops
and len(message
)>2:
369 serv
.action(message
[1]," ".join(message
[2:]))
370 log(self
.serveur
,"priv",auteur
," ".join(message
))
371 elif len(message
)<=2:
372 serv
.privmsg(auteur
,"Syntaxe : DO <channel> <action>")
376 if auteur
in self
.overops
and len(message
)>2:
377 serv
.kick(message
[1],message
[2]," ".join(message
[3:]))
378 log(self
.serveur
,"priv",auteur
," ".join(message
))
379 elif len(message
)<=2:
380 serv
.privmsg(auteur
,"Syntaxe : KICK <channel> <pseudo> [<raison>]")
384 if auteur
in self
.overops
:
385 serv
.privmsg(auteur
," ".join(self
.ops
))
389 if auteur
in self
.overops
:
390 serv
.privmsg(auteur
," ".join(self
.overops
))
396 serv
.privmsg(auteur
,"Je n'ai pas compris. Essayez HELP…")
398 def on_pubmsg(self
, serv
, ev
):
399 if ignore_event(serv
, ev
):
401 auteur
= irclib
.nm_to_n(ev
.source())
403 message
= ev
.arguments()[0]
405 test
=bot_unicode(message
)
406 except UnicodeBotError
:
407 if config
.utf8_trigger
and not canal
in self
.quiet_channels
:
408 serv
.privmsg(canal
, (u
"%s: %s"%(auteur
,random
.choice(config
.utf8_fail_answers
))).encode("utf8"))
410 pour_moi
,message
=self
.pourmoi(serv
,message
)
411 for (detect
, reason
) in config
.kicking_list
:
412 matching
= detect(message
)
414 if canal
in self
.kick_channels
:
415 serv
.kick(canal
,auteur
,(reason
.format(matching
.groups()[0])).encode("utf8"))
417 if pour_moi
and message
.split()!=[]:
418 cmd
=message
.split()[0].lower()
420 args
=" ".join(message
.split()[1:])
423 if cmd
in ["meurs","die","crève","pends-toi"]:
424 if auteur
in self
.overops
:
425 log(self
.serveur
,canal
,auteur
,message
+"[successful]")
428 serv
.privmsg(canal
,"%s: %s"%(auteur
,random
.choice(config
.quit_fail_messages
)))
429 log(self
.serveur
,canal
,auteur
,message
+"[failed]")
430 elif cmd
== "reload":
431 if auteur
in self
.ops
:
432 log(self
.serveur
, canal
, auteur
, message
+"[successful]")
434 elif cmd
in ["part","leave","dégage","va-t-en"]:
435 if auteur
in self
.ops
and (not (canal
in self
.stay_channels
)
436 or auteur
in self
.overops
):
438 log(self
.serveur
,canal
,auteur
,message
+"[successful]")
439 if canal
in self
.chanlist
:
440 self
.chanlist
.remove(canal
)
442 serv
.privmsg(canal
,"%s: %s"%(auteur
,random
.choice(config
.leave_fail_messages
)))
443 log(self
.serveur
,canal
,auteur
,message
+"[failed]")
445 elif cmd
in ["deviens","pseudo"]:
446 if auteur
in self
.ops
:
449 log(self
.serveur
,canal
,auteur
,message
+"[successful]")
451 elif cmd
in ["meur", "meurt","meurre","meurres"] and not canal
in self
.quiet_channels
:
452 serv
.privmsg(canal
,'%s: Mourir, impératif, 2ème personne du singulier : "meurs" (de rien)'%(auteur))
453 elif cmd
in ["ping"] and not canal
in self
.quiet_channels
:
454 serv
.privmsg(canal
,"%s: pong"%(auteur))
455 # if is_insult(message) and not canal in self.quiet_channels:
456 # if is_not_insult(message):
457 # answer=random.choice(config.compliment_answers)
458 # for ligne in answer.split("\n"):
459 # serv.privmsg(canal,"%s: %s"%(auteur,ligne.encode("utf8")))
461 # answer=random.choice(config.insultes_answers)
462 # for ligne in answer.split("\n"):
463 # serv.privmsg(canal,"%s: %s"%(auteur,ligne.encode("utf8")))
464 # elif is_compliment(message) and not canal in self.quiet_channels:
465 # answer=random.choice(config.compliment_answers)
466 # for ligne in answer.split("\n"):
467 # serv.privmsg(canal,"%s: %s"%(auteur,ligne.encode("utf8")))
468 elif is_tesla(message
) and not canal
in self
.quiet_channels
:
469 l1
,l2
=config
.tesla_answers
,config
.tesla_actions
470 n1
,n2
=len(l1
),len(l2
)
471 i
=random
.randrange(n1
+n2
)
473 serv
.action(canal
,l2
[i
-n1
].encode("utf8"))
475 serv
.privmsg(canal
,"%s: %s"%(auteur
,l1
[i
].encode("utf8")))
476 elif is_tag(message
) and not canal
in self
.quiet_channels
:
477 if auteur
in self
.ops
:
478 action
=random
.choice(config
.tag_actions
)
479 serv
.action(canal
,action
.encode("utf8"))
480 self
.quiet_channels
.append(canal
)
482 answer
=random
.choice(config
.tag_answers
)
483 for ligne
in answer
.split("\n"):
484 serv
.privmsg(canal
,"%s: %s"%(auteur
,ligne
.encode("utf8")))
485 elif is_bonjour(message
) and not canal
in self
.quiet_channels
:
487 answer
=random
.choice(config
.night_answers
)
489 answer
=random
.choice(config
.bonjour_answers
)
491 answer
=random
.choice(config
.bonsoir_answers
)
492 serv
.privmsg(canal
,answer
.format(auteur
).encode("utf8"))
493 elif is_bonne_nuit(message
) and not canal
in self
.quiet_channels
:
494 answer
=random
.choice(config
.bonne_nuit_answers
)
495 serv
.privmsg(canal
,answer
.format(auteur
).encode("utf8"))
497 if not canal
in self
.quiet_channels
:
499 if re
.match((u
"^("+u
"|".join(config
.bonjour_triggers
)
500 +u
")( {}| all| tout le monde|(|à) tous)(\.|( |)!|)$"
501 ).format(mypseudo
).lower(), message
.strip().lower()):
502 answer
=random
.choice(config
.bonjour_answers
)
503 serv
.privmsg(canal
,answer
.format(auteur
).encode("utf8"))
505 def on_action(self
, serv
, ev
):
506 if ignore_event(serv
, ev
):
508 action
= ev
.arguments()[0]
509 auteur
= irclib
.nm_to_n(ev
.source())
510 channel
= ev
.target()
512 test
=bot_unicode(action
)
513 except UnicodeBotError
:
514 if config
.utf8_trigger
and not canal
in self
.quiet_channels
:
515 serv
.privmsg(canal
, (u
"%s: %s"%(auteur
,random
.choice(config
.utf8_fail_answers
))).encode("utf8"))
519 # if is_bad_action_trigger(action,mypseudo) and not channel in self.quiet_channels:
520 # l1,l2=config.bad_action_answers,config.bad_action_actions
521 # n1,n2=len(l1),len(l2)
522 # i=random.randrange(n1+n2)
524 # serv.action(channel,l2[i-n1].format(auteur).encode("utf8"))
526 # serv.privmsg(channel,l1[i].format(auteur).format(auteur).encode("utf8"))
527 # if is_good_action_trigger(action,mypseudo) and not channel in self.quiet_channels:
528 # l1,l2=config.good_action_answers,config.good_action_actions
529 # n1,n2=len(l1),len(l2)
530 # i=random.randrange(n1+n2)
532 # serv.action(channel,l2[i-n1].format(auteur).format(auteur).encode("utf8"))
534 # serv.privmsg(channel,l1[i].format(auteur).format(auteur).encode("utf8"))
536 def on_kick(self
,serv
,ev
):
537 auteur
= irclib
.nm_to_n(ev
.source())
538 channel
= ev
.target()
539 victime
= ev
.arguments()[0]
540 raison
= ev
.arguments()[1]
541 if victime
==self
.nick
:
542 log(self
.serveur
,"%s kické de %s par %s (raison : %s)" %(victime
,channel
,auteur
,raison
))
545 username
= irclib
.nm_to_u(ev
.source()).lower()
547 print channel
, username
548 if channel
== "#déprime" and "peb" in username
or "becue" in username
:
550 serv
.execute_delayed(5, serv
.kick
, (auteur
, "Va abuser de tes droits ailleurs !"))
552 def kicker(self
, chan
, pseudo
, raison
=None):
554 raison
= config
.kick_default_reason
555 self
.serv
.kick(chan
,pseudo
,raison
)
557 def quitter(self
,chan
,leave_message
=None):
558 if leave_message
==None:
559 leave_message
=random
.choice(config
.leave_messages
)
560 self
.serv
.part(chan
,message
=leave_message
.encode("utf8"))
563 quit_message
=random
.choice(config
.quit_messages
)
564 self
.die(msg
=quit_message
.encode("utf8"))
567 return self
.serv
.get_nickname()
568 nick
=property(_getnick
)
570 def reload(self
, auteur
=None):
572 if auteur
in [None, "SIGHUP"]:
573 towrite
= "Config reloaded" + " (SIGHUP received)"*(auteur
== "SIGHUP")
574 for to
in config
.report_bugs_to
:
575 self
.serv
.privmsg(to
, towrite
)
576 log(self
.serveur
, towrite
)
578 self
.serv
.privmsg(auteur
,"Config reloaded")
580 def start_as_daemon(self
, outfile
):
581 sys
.stderr
= Logger(outfile
)
585 class Logger(object):
586 """Pour écrire ailleurs que sur stdout"""
587 def __init__(self
, filename
="themis.full.log"):
588 self
.filename
= filename
590 def write(self
, message
):
591 f
= open(self
.filename
, "a")
596 if __name__
=="__main__":
599 print "Usage : themis.py <serveur> [--debug] [--no-output] [--daemon [--pidfile]] [--outfile]"
600 print " --outfile sans --no-output ni --daemon n'a aucun effet"
603 if "--daemon" in sys
.argv
:
604 thisfile
= os
.path
.realpath(__file__
)
605 thisdirectory
= thisfile
.rsplit("/", 1)[0]
606 os
.chdir(thisdirectory
)
610 if "debug" in sys
.argv
or "--debug" in sys
.argv
:
614 if "--no-output" in sys
.argv
or "--daemon" in sys
.argv
:
615 outfile
= "/var/log/bots/themis.full.log"
618 if arg
[0].strip('-') in ["out", "outfile", "logfile"]:
620 sys
.stdout
= Logger(outfile
)
621 serveurs
={"a♡":"acoeur.crans.org","acoeur":"acoeur.crans.org","acoeur.crans.org":"acoeur.crans.org",
622 "irc":"irc.crans.org","crans":"irc.crans.org","irc.crans.org":"irc.crans.org"}
624 serveur
=serveurs
[serveur
]
626 print "Server Unknown : %s"%(serveur)
628 themis
=Themis(serveur
,debug
)
629 # Si on reçoit un SIGHUP, on reload la config
630 def sighup_handler(signum
, frame
):
631 themis
.reload("SIGHUP")
632 signal
.signal(signal
.SIGHUP
, sighup_handler
)
634 child_pid
= os
.fork()
637 themis
.start_as_daemon(outfile
)
639 # on enregistre le pid de themis
640 pidfile
= "/var/run/bots/themis.pid"
643 if arg
[0].strip('-') in ["pidfile"]:
645 f
= open(pidfile
, "w")
646 f
.write("%s\n" % child_pid
)