__init__.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. # pylint: disable=missing-function-docstring, 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
  44. class _brand_namespace: # pylint: disable=invalid-name
  45. @classmethod
  46. def get_val(cls, group, name, default=''):
  47. return settings.get(group, {}).get(name) or default
  48. @property
  49. def SEARX_URL(self):
  50. return self.get_val('server', 'base_url')
  51. @property
  52. def CONTACT_URL(self):
  53. return self.get_val('general', 'contact_url')
  54. @property
  55. def GIT_URL(self):
  56. return self.get_val('brand', 'git_url')
  57. @property
  58. def GIT_BRANCH(self):
  59. return self.get_val('brand', 'git_branch')
  60. @property
  61. def ISSUE_URL(self):
  62. return self.get_val('brand', 'issue_url')
  63. @property
  64. def NEW_ISSUE_URL(self):
  65. return self.get_val('brand', 'new_issue_url')
  66. @property
  67. def DOCS_URL(self):
  68. return self.get_val('brand', 'docs_url')
  69. @property
  70. def PUBLIC_INSTANCES(self):
  71. return self.get_val('brand', 'public_instances')
  72. @property
  73. def WIKI_URL(self):
  74. return self.get_val('brand', 'wiki_url')
  75. brand = _brand_namespace()