]> gitweb.pimeys.fr Git - bots/saturnin.git/commitdiff
Fonction de blacklist
authorVincent Le Gallic <legallic@crans.org>
Tue, 18 Jun 2013 17:22:32 +0000 (19:22 +0200)
committerVincent Le Gallic <legallic@crans.org>
Tue, 18 Jun 2013 17:22:32 +0000 (19:22 +0200)
config.py
saturnin.py

index 9f2768f87ceaf95401214db06f036d68ab919b3d..0e31d89682fa7c5df8a5e3933068aba82e28a443 100644 (file)
--- a/config.py
+++ b/config.py
@@ -98,5 +98,4 @@ u"Are you the farmer?",
 times_up_delays = [60*10, 60*20]
 times_up_sentences = [u"I stayed alive, you're too slow !!!"]
 
-ignored_pseudos = r'^Soldat\d+$'
-ignored_pan_masks = [("*!leger@zamok.crans.org", "jben!*@*")]
+blacklisted_masks = [("*!leger@zamok.crans.org", None)]
index 4903ec32892e35832c00df7351d9205f36b349e2..75165dfbe8615dfb1f891b93a853226db9a23e05 100755 (executable)
@@ -56,11 +56,17 @@ def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case
 regexp_pan = re.compile(u".*(" + "|".join(config.killwords) + u").*")
 def is_pan(chain):
     return regexp_pan.match(unicode(chain,"utf8").lower())
-def ignore_pan(serv, ev):
-    """Retourne ``True`` si il faut ignorer ce pan."""
-    for (blackmask, exceptmask) in config.ignored_pan_masks:
+
+def ignore_event(serv, ev):
+    """Retourne ``True`` si il faut ignorer cet évènement."""
+    for (blackmask, exceptmask) in config.blacklisted_masks:
         usermask = ev.source()
-        return bool(irclib.mask_matches(usermask, blackmask) and not irclib.mask_matches(usermask, exceptmask))
+        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
 
 class UnicodeBotError(Exception):
     pass
@@ -121,6 +127,8 @@ class Saturnin(ircbot.SingleServerIRCBot):
             return (False,message)
     
     def on_privmsg(self, serv, ev):
+        if ignore_event(serv, ev):
+            return
         message=ev.arguments()[0]
         auteur = irclib.nm_to_n(ev.source())
         try:
@@ -454,9 +462,9 @@ class Saturnin(ircbot.SingleServerIRCBot):
         self.serv.privmsg(to, "Scores by pseudo : "+" ; ".join(["%s %s"%(i[0],i[1]) for i in scores]))
     
     def on_pubmsg(self, serv, ev):
-        auteur = irclib.nm_to_n(ev.source())
-        if re.match(config.ignored_pseudos, auteur):
+        if ignore_event(serv, ev):
             return
+        auteur = irclib.nm_to_n(ev.source())
         channel = ev.target()
         message = ev.arguments()[0]
         try:
@@ -499,11 +507,11 @@ class Saturnin(ircbot.SingleServerIRCBot):
                 self.sendscores(auteur)
         else:
             if is_pan(message):
-                if ignore_pan(serv, ev):
-                    return
                 self.shot(channel, auteur)
     
     def on_action(self, serv, ev):
+        if ignore_event(serv, ev):
+            return
         action = ev.arguments()[0]
         auteur = irclib.nm_to_n(ev.source())
         channel = ev.target()