__init__.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. # pylint: disable=missing-module-docstring
  4. from os.path import dirname, abspath
  5. import logging
  6. import searx.unixthreadname
  7. import searx.settings_loader
  8. from searx.settings_defaults import settings_set_defaults
  9. searx_dir = abspath(dirname(__file__))
  10. searx_parent_dir = abspath(dirname(dirname(__file__)))
  11. settings, settings_load_message = searx.settings_loader.load_settings()
  12. if settings is not None:
  13. settings = settings_set_defaults(settings)
  14. searx_debug = settings['general']['debug']
  15. if searx_debug:
  16. logging.basicConfig(level=logging.DEBUG)
  17. else:
  18. logging.basicConfig(level=logging.WARNING)
  19. logger = logging.getLogger('searx')
  20. logger.info(settings_load_message)
  21. # log max_request_timeout
  22. max_request_timeout = settings['outgoing']['max_request_timeout']
  23. if max_request_timeout is None:
  24. logger.info('max_request_timeout=%s', repr(max_request_timeout))
  25. else:
  26. logger.info('max_request_timeout=%i second(s)', max_request_timeout)
  27. _unset = object()
  28. def get_setting(name, default=_unset):
  29. """Returns the value to which ``name`` point. If there is no such name in the
  30. settings and the ``default`` is unset, a :py:obj:`KeyError` is raised.
  31. """
  32. value = settings
  33. for a in name.split('.'):
  34. if isinstance(value, dict):
  35. value = value.get(a, _unset)
  36. else:
  37. value = _unset
  38. if value is _unset:
  39. if default is _unset:
  40. raise KeyError(name)
  41. value = default
  42. break
  43. return value