From: Vincent Le Gallic Date: Tue, 25 Jun 2013 17:35:59 +0000 (+0200) Subject: Meilleure gestion de la blacklist X-Git-Url: http://gitweb.pimeys.fr/?p=bots%2Fbasile.git;a=commitdiff_plain;h=3ec045e6407085f652e0fa89240d0d16c7d3a843 Meilleure gestion de la blacklist --- diff --git a/basile.py b/basile.py index 66dab70..c71ec0e 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.""" diff --git a/config.py b/config.py index e01a1d9..4db2ae8 100644 --- a/config.py +++ b/config.py @@ -281,6 +281,6 @@ helpmsg_ops = u" JOIN LEAVE QUIET NOQUIET LOST RECONNECT RELOAD" #: Message d'aide par défaut à ajouter pour les OVEROPs helpmsg_overops = u" SAY DO STAY NOSTAY OPS OVEROPS KICK DIE CRASH" -#: Liste de paires de masques ``[black, except]`` : on blacklistera ce qui match ``black`` -#: et pas ``except``. ``except`` peut être None. +#: Liste de paires de masques ``[black, exceptlist]`` : on blacklistera ce qui match ``black`` +#: et aucun élément de ``exceptlist`` blacklisted_masks = []