summaryrefslogtreecommitdiff
path: root/utils/searxng_check.py
blob: 0bff756ad305af99be09fe20a852bfc3e33f3f78 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# SPDX-License-Identifier: AGPL-3.0-or-later
"""Implement some checks in the active installation
"""

import os
import sys
import logging
import warnings
from pathlib import Path

repo_root = Path(__file__).resolve().parent.parent

LOG_FORMAT_DEBUG = '%(levelname)-7s %(name)-30.30s: %(message)s'
logging.basicConfig(level=logging.getLevelName('DEBUG'), format=LOG_FORMAT_DEBUG)
os.environ['SEARXNG_DEBUG'] = '1'

# from here on implement the checks of the installation

import searx

OLD_SETTING = '/etc/searx/settings.yml'

if os.path.isfile(OLD_SETTING):
    msg = (
        '%s is no longer valid, move setting to %s' % (
            OLD_SETTING,
            os.environ.get('SEARXNG_SETTINGS_PATH', '/etc/searxng/settings.yml')
        ))
    warnings.warn(msg, DeprecationWarning)

OLD_BRAND_ENV = repo_root / 'utils' / 'brand.env'

if os.path.isfile(OLD_BRAND_ENV):
    msg = ('%s is no longer needed, remove the file' % (OLD_BRAND_ENV))
    warnings.warn(msg, DeprecationWarning)

from searx import redisdb, get_setting

if not redisdb.initialize():
    warnings.warn("can't connect to redis DB at: %s" % get_setting('redis.url'), RuntimeWarning, stacklevel=2)
    warnings.warn("--> no bot protection without redis DB", RuntimeWarning, stacklevel=2)