summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorMarc Abonce Seguin <marc-abonce@mailbox.org>2020-10-18 23:55:57 -0700
committerMarc Abonce Seguin <marc-abonce@mailbox.org>2020-10-25 17:59:43 -0700
commit32957cdf49c306a5f50ca78bb50c0978ffe5c072 (patch)
treefdf159379029c16a0fe3ed25ecd7963aa61bfd69 /utils
parentc3daa08537668c24224fffecbed4347fee936fcf (diff)
downloadsearxng-32957cdf49c306a5f50ca78bb50c0978ffe5c072.tar.gz
searxng-32957cdf49c306a5f50ca78bb50c0978ffe5c072.zip
add Ahmia filter plugin for onion results
Diffstat (limited to 'utils')
-rwxr-xr-xutils/fetch_ahmia_blacklist.py33
1 files changed, 33 insertions, 0 deletions
diff --git a/utils/fetch_ahmia_blacklist.py b/utils/fetch_ahmia_blacklist.py
new file mode 100755
index 000000000..3e393edbe
--- /dev/null
+++ b/utils/fetch_ahmia_blacklist.py
@@ -0,0 +1,33 @@
+#!/usr/bin/env python
+
+# This script saves Ahmia's blacklist for onion sites.
+# More info in https://ahmia.fi/blacklist/
+
+# set path
+from sys import path
+from os.path import realpath, dirname, join
+path.append(realpath(dirname(realpath(__file__)) + '/../'))
+
+#
+import requests
+from searx import searx_dir
+
+URL = 'https://ahmia.fi/blacklist/banned/'
+
+
+def fetch_ahmia_blacklist():
+ resp = requests.get(URL, timeout=3.0)
+ if resp.status_code != 200:
+ raise Exception("Error fetching Ahmia blacklist, HTTP code " + resp.status_code)
+ else:
+ blacklist = resp.text.split()
+ return blacklist
+
+
+def get_ahmia_blacklist_filename():
+ return join(join(searx_dir, "data"), "ahmia_blacklist.txt")
+
+
+blacklist = fetch_ahmia_blacklist()
+with open(get_ahmia_blacklist_filename(), "w") as f:
+ f.write('\n'.join(blacklist))