summaryrefslogtreecommitdiff
path: root/crocoite/irc.py
diff options
context:
space:
mode:
authorLars-Dominik Braun <lars@6xq.net>2019-01-27 11:36:29 +0100
committerLars-Dominik Braun <lars@6xq.net>2019-01-27 11:36:29 +0100
commit0af80da0b506a06593c81d3686e91b8b82a4f3ba (patch)
treef2593b60c3842b4ee8be6d60f6f76e707c6a4237 /crocoite/irc.py
parent668cc5e10c7097d51ba4e4fcae02f55d89283923 (diff)
downloadcrocoite-0af80da0b506a06593c81d3686e91b8b82a4f3ba.tar.gz
crocoite-0af80da0b506a06593c81d3686e91b8b82a4f3ba.tar.bz2
crocoite-0af80da0b506a06593c81d3686e91b8b82a4f3ba.zip
irc: Add URL blacklist
Diffstat (limited to 'crocoite/irc.py')
-rw-r--r--crocoite/irc.py16
1 files changed, 14 insertions, 2 deletions
diff --git a/crocoite/irc.py b/crocoite/irc.py
index 1b0fa1b..5351a85 100644
--- a/crocoite/irc.py
+++ b/crocoite/irc.py
@@ -368,11 +368,11 @@ def jobExists (func):
return inner
class Chromebot (ArgparseBot):
- __slots__ = ('jobs', 'tempdir', 'destdir', 'processLimit')
+ __slots__ = ('jobs', 'tempdir', 'destdir', 'processLimit', 'blacklist')
def __init__ (self, host, port, ssl, nick, logger, channels=[],
tempdir=tempfile.gettempdir(), destdir='.', processLimit=1,
- loop=None):
+ blacklist={}, loop=None):
super().__init__ (host=host, port=port, ssl=ssl, nick=nick,
logger=logger, channels=channels, loop=loop)
@@ -380,6 +380,7 @@ class Chromebot (ArgparseBot):
self.tempdir = tempdir
self.destdir = destdir
self.processLimit = asyncio.Semaphore (processLimit)
+ self.blacklist = blacklist
def getParser (self):
parser = NonExitingArgumentParser (prog=self.nick + ': ', add_help=False)
@@ -404,10 +405,21 @@ class Chromebot (ArgparseBot):
return parser
+ def isBlacklisted (self, url):
+ for k, v in self.blacklist.items():
+ if k.match (url):
+ return v
+ return False
+
@voice
async def handleArchive (self, user, args, reply):
""" Handle the archive command """
+ msg = self.isBlacklisted (args.url)
+ if msg:
+ reply (f'{args.url} cannot be queued: {msg}')
+ return
+
j = Job (args.url, user.name)
assert j.id not in self.jobs, 'duplicate job id'
self.jobs[j.id] = j