summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeorg2021-08-26 19:32:58 +0200
committerGeorg2021-08-26 19:32:58 +0200
commitc5a37126bc71f8330db54376f46d1ef0d5251c83 (patch)
tree3f384814b97746182421fd18287722544eb8ded1
parent78161bda7f95cfd72b1386ab7bb93c4aad7b741c (diff)
downloadsnoparser-c5a37126bc71f8330db54376f46d1ef0d5251c83.tar.gz
snoparser-c5a37126bc71f8330db54376f46d1ef0d5251c83.tar.bz2
snoparser-c5a37126bc71f8330db54376f46d1ef0d5251c83.zip
Improved `ipcounting`
Signed-off-by: Georg <georg@lysergic.dev>
-rw-r--r--__pycache__/config.cpython-38.pycbin2704 -> 2814 bytes
-rw-r--r--__pycache__/plugin.cpython-38.pycbin10414 -> 10478 bytes
-rw-r--r--config.py7
-rw-r--r--plugin.py8
4 files changed, 12 insertions, 3 deletions
diff --git a/__pycache__/config.cpython-38.pyc b/__pycache__/config.cpython-38.pyc
index d7e3edd..3666f16 100644
--- a/__pycache__/config.cpython-38.pyc
+++ b/__pycache__/config.cpython-38.pyc
Binary files differ
diff --git a/__pycache__/plugin.cpython-38.pyc b/__pycache__/plugin.cpython-38.pyc
index 1a89f54..2038462 100644
--- a/__pycache__/plugin.cpython-38.pyc
+++ b/__pycache__/plugin.cpython-38.pyc
Binary files differ
diff --git a/config.py b/config.py
index 983cb6d..90dd9c9 100644
--- a/config.py
+++ b/config.py
@@ -140,6 +140,13 @@ conf.registerGlobalValue(SnoParser.whois, 'sample',
"""
, private=True
))
+conf.registerGlobalValue(SnoParser.whois, 'ttl',
+ registry.Integer('3600',
+ """
+ SnoParser: How long to cache WHOIS entries for.
+ """
+ , private=True
+))
conf.registerGroup(SnoParser.whois, 'redis')
conf.registerGlobalValue(SnoParser.whois.redis, 'db',
registry.Integer('0',
diff --git a/plugin.py b/plugin.py
index 4d9a797..4b16961 100644
--- a/plugin.py
+++ b/plugin.py
@@ -141,7 +141,8 @@ class SnoParser(callbacks.Plugin):
def whois_set_cache(self, key: str, value: str) -> bool:
"""Data to Redis."""
- state = self.redis_client_whois.setex(key, timedelta(seconds=3600), value=value,)
+ duration = self.registryValue('whois.ttl')
+ state = self.redis_client_whois.setex(key, timedelta(seconds=duration), value=value,)
return state
def whois_run(self, sourceip: str) -> dict:
@@ -238,12 +239,13 @@ class SnoParser(callbacks.Plugin):
"""
data = self.whois_get_cache(key=ipaddress)
- decoded = data.decode('utf-8')
+ decoded_data = data.decode('utf-8')
ttl = self.redis_client_whois.ttl(ipaddress)
count = self.redis_client_ips.get(ipaddress)
+ decoded_count = count.decode('utf-8')
print('SnoParser manual query: ', data, ' ', ttl)
- irc.reply(f'{decoded} - Count: {count} - Remaining: {ttl}s')
+ irc.reply(f'{decoded_data} - Count: {decoded_count} - Remaining: {ttl}s')
ipquery = wrap(ipquery, ['anything'])