X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=basile.py;h=c71ec0e033f1a0f5c9d432470c7b7703f7ba9889;hb=3ec045e6407085f652e0fa89240d0d16c7d3a843;hp=f3c193c99a4f32fc2feaf90ea94a1346cdf1763b;hpb=5076791b641fced9605fb52fd5ce56aacda40f89;p=bots%2Fbasile.git diff --git a/basile.py b/basile.py index f3c193c..c71ec0e 100755 --- a/basile.py +++ b/basile.py @@ -52,7 +52,19 @@ def log(serveur, channel, auteur=None, message=None): f.write((chain + u"\n").encode("utf-8")) f.close() if config.debug_stdout: - print chain + print chain.encode("utf-8") + +def ignore_event(serv, ev): + """Retourne ``True`` si il faut ignorer cet évènement.""" + for (blackmask, exceptlist) in config.blacklisted_masks: + usermask = ev.source() + blackit = bool(irclib.mask_matches(usermask, blackmask)) + 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.""" @@ -336,6 +348,8 @@ class Basile(ircbot.SingleServerIRCBot): def on_privmsg(self, serv, ev): """À la réception d'un message en privé.""" + if ignore_event(serv, ev): + return message = ev.arguments()[0] auteur = irclib.nm_to_n(ev.source()) try: @@ -425,7 +439,7 @@ class Basile(ircbot.SingleServerIRCBot): if auteur in self.ops and len(message) > 1: if message[1] in self.chanlist: if not (message[1] in self.stay_channels) or auteur in self.overops: - self.quitter(message[1], " ".join(message[2:])) + self.quitter(message[1].encode("utf-8"), " ".join(message[2:])) self.chanlist.remove(message[1]) log(self.serveur, "priv", auteur, " ".join(message) + "[successful]") else: @@ -580,6 +594,8 @@ class Basile(ircbot.SingleServerIRCBot): def on_pubmsg(self, serv, ev): """À la réception d'un message sur un channel.""" + if ignore_event(serv, ev): + return auteur = irclib.nm_to_n(ev.source()) canal = ev.target() message = ev.arguments()[0] @@ -651,15 +667,15 @@ class Basile(ircbot.SingleServerIRCBot): elif cmd in [u"ping"] and not canal in self.quiet_channels: serv.privmsg(canal, "%s: pong" % (auteur)) - elif cmd in [u"solde", u"!solde", u"!coca"]: + elif cmd in [u"solde", u"!solde", u"!coca"] or cmd.startswith("!"): if self.identities.has_key(auteur): idbde = self.identities[auteur]["idbde"] if cmd in [u"solde", u"!solde"]: success, solde, pseudo = nk.get_solde(self.nk, self.identities[auteur]["idbde"], serv, canal) if success: serv.privmsg(canal, "%s: %s (%s)" % (auteur, float(solde)/100, pseudo.encode("utf8"))) - elif cmd in [u"!coca"]: - success = nk.consomme(self.nk, self.identities[auteur]["idbde"], u"Coca", serv, canal) + elif cmd in [u"!coca"] or cmd.startswith("!"): + success = nk.consomme(self.nk, self.identities[auteur]["idbde"], message[1:], serv, canal) log(self.serveur, canal, auteur, message + ("[successful]" if success else "[failed]")) else: serv.privmsg(canal, "%s: Je ne connais pas votre pseudo note." % (auteur)) @@ -793,6 +809,8 @@ class Basile(ircbot.SingleServerIRCBot): def on_action(self, serv, ev): """À la réception d'une action.""" + if ignore_event(serv, ev): + return action = ev.arguments()[0] auteur = irclib.nm_to_n(ev.source()) channel = ev.target()