.oO SearXNG Developer Documentation Oo.
Loading...
Searching...
No Matches
__init__.py
Go to the documentation of this file.
1# SPDX-License-Identifier: AGPL-3.0-or-later
2# pylint: disable=missing-module-docstring, cyclic-import
3from __future__ import annotations
4
5import typing as t
6import sys
7import os
8from os.path import dirname, abspath
9
10import logging
11
12import searx.unixthreadname # pylint: disable=unused-import
13
14# Debug
15LOG_FORMAT_DEBUG: str = '%(levelname)-7s %(name)-30.30s: %(message)s'
16
17# Production
18LOG_FORMAT_PROD: str = '%(asctime)-15s %(levelname)s:%(name)s: %(message)s'
19LOG_LEVEL_PROD = logging.WARNING
20
21searx_dir: str = abspath(dirname(__file__))
22searx_parent_dir: str = abspath(dirname(dirname(__file__)))
23
24settings: dict[str, t.Any] = {}
25
26sxng_debug: bool = False
27logger = logging.getLogger('searx')
28
29_unset = object()
30
31
33 """Initialize global ``settings`` and ``sxng_debug`` variables and
34 ``logger`` from ``SEARXNG_SETTINGS_PATH``.
35 """
36
37 # pylint: disable=import-outside-toplevel
38 from searx import settings_loader
39 from searx.settings_defaults import SCHEMA, apply_schema
40
41 global settings, sxng_debug # pylint: disable=global-variable-not-assigned
42
43 cfg, msg = settings_loader.load_settings(load_user_settings=True)
44 cfg = cfg or {}
45 apply_schema(cfg, SCHEMA, [])
46
47 settings.clear()
48 settings.update(cfg)
49
50 sxng_debug = get_setting("general.debug")
51 if sxng_debug:
53 else:
54 logging.basicConfig(level=LOG_LEVEL_PROD, format=LOG_FORMAT_PROD)
55 logging.root.setLevel(level=LOG_LEVEL_PROD)
56 logging.getLogger('werkzeug').setLevel(level=LOG_LEVEL_PROD)
57 logger.info(msg)
58
59 # log max_request_timeout
60 max_request_timeout: int | None = settings['outgoing']['max_request_timeout']
61 if max_request_timeout is None:
62 logger.info('max_request_timeout=%s', repr(max_request_timeout))
63 else:
64 logger.info('max_request_timeout=%i second(s)', max_request_timeout)
65
66 if settings['server']['public_instance']:
67 logger.warning(
68 "Be aware you have activated features intended only for public instances. "
69 "This force the usage of the limiter and link_token / "
70 "see https://docs.searxng.org/admin/searx.limiter.html"
71 )
72
73
74def get_setting(name: str, default: t.Any = _unset) -> t.Any:
75 """Returns the value to which ``name`` point. If there is no such name in the
76 settings and the ``default`` is unset, a :py:obj:`KeyError` is raised.
77
78 """
79 value: dict[str, t.Any] = settings
80 for a in name.split('.'):
81 if isinstance(value, dict):
82 value = value.get(a, _unset)
83 else:
84 value = _unset # type: ignore
85
86 if value is _unset:
87 if default is _unset:
88 raise KeyError(name)
89 value = default # type: ignore
90 break
91
92 return value
93
94
96 if os.getenv('TERM') in ('dumb', 'unknown'):
97 return False
98 return sys.stdout.isatty()
99
100
102 try:
103 import coloredlogs # pylint: disable=import-outside-toplevel
104 except ImportError:
105 coloredlogs = None
106
107 log_level = os.environ.get('SEARXNG_DEBUG_LOG_LEVEL', 'DEBUG')
108 if coloredlogs and _is_color_terminal():
109 level_styles = {
110 'spam': {'color': 'green', 'faint': True},
111 'debug': {},
112 'notice': {'color': 'magenta'},
113 'success': {'bold': True, 'color': 'green'},
114 'info': {'bold': True, 'color': 'cyan'},
115 'warning': {'color': 'yellow'},
116 'error': {'color': 'red'},
117 'critical': {'bold': True, 'color': 'red'},
118 }
119 field_styles = {
120 'asctime': {'color': 'green'},
121 'hostname': {'color': 'magenta'},
122 'levelname': {'color': 8},
123 'name': {'color': 8},
124 'programname': {'color': 'cyan'},
125 'username': {'color': 'yellow'},
126 }
127 coloredlogs.install( # type: ignore
128 level=log_level,
129 level_styles=level_styles,
130 field_styles=field_styles,
131 fmt=LOG_FORMAT_DEBUG,
132 )
133 else:
134 logging.basicConfig(level=getattr(logging, log_level, "ERROR"), format=LOG_FORMAT_DEBUG)
135
136
_logging_config_debug()
Definition __init__.py:101
_is_color_terminal()
Definition __init__.py:95
init_settings()
Definition __init__.py:32
t.Any get_setting(str name, t.Any default=_unset)
Definition __init__.py:74