| 
									
										
										
										
											2021-06-01 16:03:19 +02:00
										 |  |  | # SPDX-License-Identifier: AGPL-3.0-or-later | 
					
						
							|  |  |  | # lint: pylint | 
					
						
							| 
									
										
										
										
											2021-09-07 13:34:35 +02:00
										 |  |  | # pylint: disable=missing-module-docstring | 
					
						
							| 
									
										
										
										
											2014-09-13 18:39:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | import sys | 
					
						
							|  |  |  | import os | 
					
						
							| 
									
										
										
										
											2021-06-01 16:03:19 +02:00
										 |  |  | from os.path import dirname, abspath | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-09 04:01:31 +01:00
										 |  |  | import logging | 
					
						
							| 
									
										
										
										
											2021-06-01 16:03:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-08 11:34:36 +02:00
										 |  |  | import searx.unixthreadname | 
					
						
							| 
									
										
										
										
											2020-11-27 19:32:45 +01:00
										 |  |  | import searx.settings_loader | 
					
						
							| 
									
										
										
										
											2021-05-28 18:45:22 +02:00
										 |  |  | from searx.settings_defaults import settings_set_defaults | 
					
						
							| 
									
										
										
										
											2014-01-19 00:17:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Debug | 
					
						
							|  |  |  | LOG_FORMAT_DEBUG = '%(levelname)-7s %(name)-30.30s: %(message)s' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Production | 
					
						
							|  |  |  | LOG_FORMAT_PROD = '%(asctime)-15s %(levelname)s:%(name)s: %(message)s' | 
					
						
							| 
									
										
										
										
											2021-09-08 08:44:40 +02:00
										 |  |  | LOG_LEVEL_PROD = logging.WARNING | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 22:59:01 +01:00
										 |  |  | searx_dir = abspath(dirname(__file__)) | 
					
						
							| 
									
										
										
										
											2021-04-27 10:42:00 +02:00
										 |  |  | searx_parent_dir = abspath(dirname(dirname(__file__))) | 
					
						
							| 
									
										
										
										
											2020-11-27 19:32:45 +01:00
										 |  |  | settings, settings_load_message = searx.settings_loader.load_settings() | 
					
						
							| 
									
										
										
										
											2014-09-14 11:09:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-28 18:45:22 +02:00
										 |  |  | if settings is not None: | 
					
						
							|  |  |  |     settings = settings_set_defaults(settings) | 
					
						
							| 
									
										
										
										
											2016-10-22 19:07:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-17 19:03:54 +02:00
										 |  |  | _unset = object() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_setting(name, default=_unset): | 
					
						
							|  |  |  |     """Returns the value to which ``name`` point.  If there is no such name in the
 | 
					
						
							|  |  |  |     settings and the ``default`` is unset, a :py:obj:`KeyError` is raised. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     value = settings | 
					
						
							|  |  |  |     for a in name.split('.'): | 
					
						
							|  |  |  |         if isinstance(value, dict): | 
					
						
							|  |  |  |             value = value.get(a, _unset) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             value = _unset | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if value is _unset: | 
					
						
							|  |  |  |             if default is _unset: | 
					
						
							|  |  |  |                 raise KeyError(name) | 
					
						
							|  |  |  |             value = default | 
					
						
							|  |  |  |             break | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return value | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def is_color_terminal(): | 
					
						
							|  |  |  |     if os.getenv('TERM') in ('dumb', 'unknown'): | 
					
						
							|  |  |  |         return False | 
					
						
							|  |  |  |     return sys.stdout.isatty() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def logging_config_debug(): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         import coloredlogs  # pylint: disable=import-outside-toplevel | 
					
						
							|  |  |  |     except ImportError: | 
					
						
							|  |  |  |         coloredlogs = None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-02 12:21:02 +02:00
										 |  |  |     log_level = os.environ.get('SEARXNG_DEBUG_LOG_LEVEL', 'DEBUG') | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  |     if coloredlogs and is_color_terminal(): | 
					
						
							|  |  |  |         level_styles = { | 
					
						
							|  |  |  |             'spam': {'color': 'green', 'faint': True}, | 
					
						
							|  |  |  |             'debug': {}, | 
					
						
							|  |  |  |             'notice': {'color': 'magenta'}, | 
					
						
							|  |  |  |             'success': {'bold': True, 'color': 'green'}, | 
					
						
							|  |  |  |             'info': {'bold': True, 'color': 'cyan'}, | 
					
						
							|  |  |  |             'warning': {'color': 'yellow'}, | 
					
						
							|  |  |  |             'error': {'color': 'red'}, | 
					
						
							|  |  |  |             'critical': {'bold': True, 'color': 'red'}, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         field_styles = { | 
					
						
							|  |  |  |             'asctime': {'color': 'green'}, | 
					
						
							|  |  |  |             'hostname': {'color': 'magenta'}, | 
					
						
							|  |  |  |             'levelname': {'color': 8}, | 
					
						
							|  |  |  |             'name': {'color': 8}, | 
					
						
							|  |  |  |             'programname': {'color': 'cyan'}, | 
					
						
							|  |  |  |             'username': {'color': 'yellow'} | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         coloredlogs.install( | 
					
						
							|  |  |  |             level=log_level, | 
					
						
							|  |  |  |             level_styles=level_styles, | 
					
						
							|  |  |  |             field_styles=field_styles, | 
					
						
							|  |  |  |             fmt=LOG_FORMAT_DEBUG | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         logging.basicConfig(level=logging.getLevelName(log_level), format=LOG_FORMAT_DEBUG) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | searx_debug = settings['general']['debug'] | 
					
						
							|  |  |  | if searx_debug: | 
					
						
							|  |  |  |     logging_config_debug() | 
					
						
							|  |  |  | else: | 
					
						
							| 
									
										
										
										
											2021-09-08 08:44:40 +02:00
										 |  |  |     logging.basicConfig(level=LOG_LEVEL_PROD, format=LOG_FORMAT_PROD) | 
					
						
							|  |  |  |     logging.root.setLevel(level=LOG_LEVEL_PROD) | 
					
						
							|  |  |  |     logging.getLogger('werkzeug').setLevel(level=LOG_LEVEL_PROD) | 
					
						
							| 
									
										
										
										
											2021-09-06 19:47:50 +02:00
										 |  |  | logger = logging.getLogger('searx') | 
					
						
							|  |  |  | logger.info(settings_load_message) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # log max_request_timeout | 
					
						
							|  |  |  | max_request_timeout = settings['outgoing']['max_request_timeout'] | 
					
						
							|  |  |  | if max_request_timeout is None: | 
					
						
							|  |  |  |     logger.info('max_request_timeout=%s', repr(max_request_timeout)) | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     logger.info('max_request_timeout=%i second(s)', max_request_timeout) |