summaryrefslogtreecommitdiff
path: root/searx/engines/redis_server.py
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2021-06-02 12:35:33 +0200
committerGitHub <noreply@github.com>2021-06-02 12:35:33 +0200
commit7457f3fe402383a0cf6f5b463f589122fd59726e (patch)
treea10a1f7566e9429e00e04c47496981ce3b6db490 /searx/engines/redis_server.py
parent3ce1b40512d8a9d0e93fc0bbe154881961e196b1 (diff)
parent39c18274c62f2eb8edf2b55b2e4e66a138376913 (diff)
Merge pull request #124 from return42/searx-merge
merge redis offline engine from searx
Diffstat (limited to 'searx/engines/redis_server.py')
-rw-r--r--searx/engines/redis_server.py77
1 files changed, 77 insertions, 0 deletions
diff --git a/searx/engines/redis_server.py b/searx/engines/redis_server.py
new file mode 100644
index 000000000..e8c248e32
--- /dev/null
+++ b/searx/engines/redis_server.py
@@ -0,0 +1,77 @@
+# SPDX-License-Identifier: AGPL-3.0-or-later
+# lint: pylint
+# pylint: disable=missing-function-docstring
+"""Redis engine (offline)
+
+"""
+
+import redis # pylint: disable=import-error
+
+engine_type = 'offline'
+
+# redis connection variables
+host = '127.0.0.1'
+port = 6379
+password = ''
+db = 0
+
+# engine specific variables
+paging = False
+result_template = 'key-value.html'
+exact_match_only = True
+
+_redis_client = None
+def init(_engine_settings):
+ global _redis_client # pylint: disable=global-statement
+ _redis_client = redis.StrictRedis(
+ host = host,
+ port = port,
+ db = db,
+ password = password or None,
+ decode_responses = True,
+ )
+
+def search(query, _params):
+ global _redis_client # pylint: disable=global-statement
+
+ if not exact_match_only:
+ return search_keys(query)
+
+ ret = _redis_client.hgetall(query)
+ if ret:
+ ret['template'] = result_template
+ return [ret]
+
+ if ' ' in query:
+ qset, rest = query.split(' ', 1)
+ ret = []
+ for res in _redis_client.hscan_iter(
+ qset, match='*{}*'.format(rest)
+ ):
+ ret.append({
+ res[0]: res[1],
+ 'template': result_template,
+ })
+ return ret
+ return []
+
+def search_keys(query):
+ global _redis_client # pylint: disable=global-statement
+
+ ret = []
+ for key in _redis_client.scan_iter(
+ match='*{}*'.format(query)
+ ):
+ key_type = _redis_client.type(key)
+ res = None
+
+ if key_type == 'hash':
+ res = _redis_client.hgetall(key)
+ elif key_type == 'list':
+ res = dict(enumerate(_redis_client.lrange(key, 0, -1)))
+
+ if res:
+ res['template'] = result_template
+ res['redis_key'] = key
+ ret.append(res)
+ return ret