| 
							
							# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						
						
						
						
							 | 
							
							# lint: pylint
 | 
						
						
						
						
							 | 
							
							"""Implementation of the redis client (redis-py_).
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							.. _redis-py: https://github.com/redis/redis-py
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							This implementation uses the :ref:`settings redis` setup from ``settings.yml``.
 | 
						
						
						
						
							 | 
							
							A redis DB connect can be tested by::
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							  >>> from searx.shared import redisdb
 | 
						
						
						
						
							 | 
							
							  >>> redisdb.init()
 | 
						
						
						
						
							 | 
							
							  True
 | 
						
						
						
						
							 | 
							
							  >>> db = redisdb.client()
 | 
						
						
						
						
							 | 
							
							  >>> db.set("foo", "bar")
 | 
						
						
						
						
							 | 
							
							  True
 | 
						
						
						
						
							 | 
							
							  >>> db.get("foo")
 | 
						
						
						
						
							 | 
							
							  b'bar'
 | 
						
						
						
						
							 | 
							
							  >>>
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							"""
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							import os
 | 
						
						
						
						
							 | 
							
							import pwd
 | 
						
						
						
						
							 | 
							
							import logging
 | 
						
						
						
						
							 | 
							
							import redis
 | 
						
						
						
						
							 | 
							
							from searx import get_setting
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							logger = logging.getLogger('searx.shared.redis')
 | 
						
						
						
						
							 | 
							
							_client = None
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							def client():
 | 
						
						
						
						
							 | 
							
							    global _client  # pylint: disable=global-statement
 | 
						
						
						
						
							 | 
							
							    if _client is None:
 | 
						
						
						
						
							 | 
							
							        # not thread safe: in the worst case scenario, two or more clients are
 | 
						
						
						
						
							 | 
							
							        # initialized only one is kept, the others are garbage collected.
 | 
						
						
						
						
							 | 
							
							        _client = redis.Redis.from_url(get_setting('redis.url'))
 | 
						
						
						
						
							 | 
							
							    return _client
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							def init():
 | 
						
						
						
						
							 | 
							
							    try:
 | 
						
						
						
						
							 | 
							
							        c = client()
 | 
						
						
						
						
							 | 
							
							        logger.info("connected redis DB --> %s", c.acl_whoami())
 | 
						
						
						
						
							 | 
							
							        return True
 | 
						
						
						
						
							 | 
							
							    except redis.exceptions.ConnectionError as exc:
 | 
						
						
						
						
							 | 
							
							        _pw = pwd.getpwuid(os.getuid())
 | 
						
						
						
						
							 | 
							
							        logger.error("[%s (%s)] can't connect redis DB ...", _pw.pw_name, _pw.pw_uid)
 | 
						
						
						
						
							 | 
							
							        logger.error("  %s", exc)
 | 
						
						
						
						
							 | 
							
							    return False
 |