X-Git-Url: http://gitweb.pimeys.fr/?p=bots%2Fbasile.git;a=blobdiff_plain;f=basile.py;h=2fedf6ed76a4a0aa8dc9dfb3a644b892edd0dcc9;hp=66dab704126a61c3198c55baa7b18b438d0df4f2;hb=4c600255d74b7e058ffa4d0c729c7e495e61b484;hpb=dbe5bf98884e46debd42ee0fa791d268fcd261a0 diff --git a/basile.py b/basile.py index 66dab70..2fedf6e 100755 --- a/basile.py +++ b/basile.py @@ -56,14 +56,15 @@ def log(serveur, channel, auteur=None, message=None): def ignore_event(serv, ev): """Retourne ``True`` si il faut ignorer cet évènement.""" - for (blackmask, exceptmask) in config.blacklisted_masks: + for (blackmask, exceptlist) in config.blacklisted_masks: usermask = ev.source() - if exceptmask is None: - exceptit = False - else: - exceptit = bool(irclib.mask_matches(usermask, exceptmask)) blackit = bool(irclib.mask_matches(usermask, blackmask)) - return blackit and not exceptit + exceptit = any([bool(irclib.mask_matches(usermask, exceptmask)) for exceptmask in exceptlist]) + if exceptit: # Il est exempté + return False + else: + if blackit: # Il n'est pas exempté et matche la blacklist + return True def regex_join(liste, avant=u".*(?:^| )", apres=u"(?:$|\.| |,|;).*"): """Fabrique une regexp à partir d'une liste d'éléments à matcher.""" @@ -73,8 +74,10 @@ def is_something(chain, regexp=None, matches=[], avant=u".*(?:^| )", apres=u"(?: case_sensitive=False): """Vérifie si chain contient un des éléments de ``matches``. Si ``regexp`` est fournie, c'est simplement elle qui est testée""" - if case_sensitive: + if not case_sensitive: chain = chain.lower() + apres = apres.lower() + avant = avant.lower() if regexp == None: regexp = regex_join(matches, avant, apres) regexp = re.compile(regexp) @@ -310,7 +313,7 @@ class Basile(ircbot.SingleServerIRCBot): def crash(self, chan="nowhere", who="nobody"): """Fait crasher le bot.""" where = "en privé" if chan == "priv" else "sur le chan %s" % chan - raise CrashError("Crash demandé par %s %s" % (who, where)) + raise CrashError((u"Crash demandé par %s %s" % (who, where)).encode("utf-8")) ACTIONS = { "reload" : execute_reload, @@ -537,7 +540,7 @@ class Basile(ircbot.SingleServerIRCBot): notunderstood = True elif cmd == u"say": if auteur in self.overops and len(message) > 2: - serv.privmsg(message[1], " ".join(message[2:])) + serv.privmsg(message[1].encode("utf-8"), (u" ".join(message[2:])).encode("utf-8")) log(self.serveur, "priv", auteur, " ".join(message)) elif len(message) <= 2: serv.privmsg(auteur, "Syntaxe : SAY ") @@ -553,7 +556,7 @@ class Basile(ircbot.SingleServerIRCBot): notunderstood = True elif cmd == u"kick": if auteur in self.overops and len(message) > 2: - serv.kick(message[1], message[2], " ".join(message[3:])) + serv.kick(message[1].encode("utf-8"), message[2].encode("utf-8"), " ".join(message[3:]).encode("utf-8")) log(self.serveur, "priv", auteur, " ".join(message)) elif len(message) <= 2: serv.privmsg(auteur, "Syntaxe : KICK []") @@ -679,10 +682,10 @@ class Basile(ircbot.SingleServerIRCBot): else: serv.privmsg(canal, "%s: Je ne connais pas votre pseudo note." % (auteur)) log(self.serveur, canal, auteur, message + "[unknown]") - elif (re.match("!?(pain au chocolat|chocolatine)", message.lower()) + elif (re.match("(pain au chocolat|chocolatine)", message.lower()) and not canal in self.quiet_channels): serv.action(canal, "sert un pain au chocolat à %s" % (auteur)) - elif re.match("!?manzana",message.lower()) and not canal in self.quiet_channels: + elif re.match("manzana",message.lower()) and not canal in self.quiet_channels: if auteur in config.manzana: serv.action(canal, "sert une bouteille de manzana à %s" % (auteur)) elif auteur in config.manzana_bis: @@ -845,7 +848,7 @@ class Basile(ircbot.SingleServerIRCBot): victime = ev.arguments()[0] raison = ev.arguments()[1] if victime == self.nick: - log(self.serveur, "%s kické de %s par %s (raison : %s)" % (victime, channel, auteur, raison)) + log(self.serveur, u"%s kické de %s par %s (raison : %s)" % (victime, channel.decode("utf-8"), auteur, raison)) time.sleep(2) serv.join(channel) l1, l2 = config.kick_answers, config.kick_actions