diff options
author | Alexandre Flament <alex@al-f.net> | 2021-01-11 18:43:12 +0100 |
---|---|---|
committer | Alexandre Flament <alex@al-f.net> | 2021-01-12 11:47:17 +0100 |
commit | 87bafbc32b34ef7f3033bdea6a4bfa966a6068c1 (patch) | |
tree | 0086d7123da7f96f3895679dfe8cde1e0c1de08f /searx/search/checker/background.py | |
parent | f3e1bd308f8abb62b3ce0070973e0a494d15b122 (diff) | |
download | searxng-87bafbc32b34ef7f3033bdea6a4bfa966a6068c1.tar.gz searxng-87bafbc32b34ef7f3033bdea6a4bfa966a6068c1.zip |
[mod] checker: add status and timestamp to the result
for each engine: replace status by success
Diffstat (limited to 'searx/search/checker/background.py')
-rw-r--r-- | searx/search/checker/background.py | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/searx/search/checker/background.py b/searx/search/checker/background.py index 45188ab38..0fc13ddb6 100644 --- a/searx/search/checker/background.py +++ b/searx/search/checker/background.py @@ -35,28 +35,39 @@ def _get_every(): def get_result(): - serialized_result = storage.get_str('CHECKER_RESULT') + serialized_result = storage.get_str(CHECKER_RESULT) if serialized_result is not None: return json.loads(serialized_result) +def _set_result(result): + result['timestamp'] = int(time.time() / 3600) * 3600 + storage.set_str(CHECKER_RESULT, json.dumps(result)) + + def run(): if not running.acquire(blocking=False): return try: logger.info('Starting checker') - result = {} + result = { + 'status': 'ok', + 'engines': {} + } for name, processor in processors.items(): logger.debug('Checking %s engine', name) checker = Checker(processor) checker.run() if checker.test_results.succesfull: - result[name] = {'status': True} + result['engines'][name] = {'success': True} else: - result[name] = {'status': False, 'errors': checker.test_results.errors} + result['engines'][name] = {'success': False, 'errors': checker.test_results.errors} - storage.set_str('CHECKER_RESULT', json.dumps(result)) + _set_result(result) logger.info('Check done') + except Exception: + _set_result({'status': 'error'}) + logger.exception('Error while running the checker') finally: running.release() @@ -85,6 +96,9 @@ def initialize(): logger.info('Send SIGUSR1 signal to pid %i to start the checker', os.getpid()) signal.signal(signal.SIGUSR1, _signal_handler) + # disabled by default + _set_result({'status': 'disabled'}) + # special case when debug is activate if searx_debug and settings.get('checker', {}).get('off_when_debug', True): logger.info('debug mode: checker is disabled') @@ -97,6 +111,8 @@ def initialize(): return # + _set_result({'status': 'unknow'}) + start_after = scheduling.get('start_after', (300, 1800)) start_after = _get_interval(start_after, 'checker.scheduling.start_after is not a int or list') delay = random.randint(start_after[0], start_after[1]) |