settings.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import collections.abc
  2. import yaml
  3. from searx.exceptions import SearxSettingsException
  4. from os import environ
  5. from os.path import dirname, join, abspath, isfile
  6. searx_dir = abspath(dirname(__file__))
  7. def check_settings_yml(file_name):
  8. if isfile(file_name):
  9. return file_name
  10. else:
  11. return None
  12. def load_yaml(file_name):
  13. try:
  14. with open(file_name, 'r', encoding='utf-8') as settings_yaml:
  15. settings = yaml.safe_load(settings_yaml)
  16. if not isinstance(settings, dict) or len(settings) == 0:
  17. raise SearxSettingsException('Empty file', file_name)
  18. return settings
  19. except IOError as e:
  20. raise SearxSettingsException(e, file_name)
  21. except yaml.YAMLError as e:
  22. raise SearxSettingsException(e, file_name)
  23. def get_default_settings_path():
  24. return check_settings_yml(join(searx_dir, 'settings.yml'))
  25. def get_user_settings_path():
  26. # find location of settings.yml
  27. if 'SEARX_SETTINGS_PATH' in environ:
  28. # if possible set path to settings using the
  29. # enviroment variable SEARX_SETTINGS_PATH
  30. return check_settings_yml(environ['SEARX_SETTINGS_PATH'])
  31. else:
  32. # if not, get it from searx code base or last solution from /etc/searx
  33. return check_settings_yml('/etc/searx/settings.yml')
  34. def update_dict(d, u):
  35. for k, v in u.items():
  36. if isinstance(v, collections.abc.Mapping):
  37. d[k] = update_dict(d.get(k, {}), v)
  38. else:
  39. d[k] = v
  40. return d
  41. def update_settings(default_settings, user_settings):
  42. for k, v in user_settings.items():
  43. if k == 'use_default_settings':
  44. continue
  45. elif k == 'engines':
  46. default_engines = default_settings[k]
  47. default_engines_dict = dict((definition['name'], definition) for definition in default_engines)
  48. default_settings[k] = [update_dict(default_engines_dict[definition['name']], definition)
  49. for definition in v]
  50. else:
  51. update_dict(default_settings[k], v)
  52. return default_settings
  53. def load_settings(load_user_setttings=True):
  54. default_settings_path = get_default_settings_path()
  55. user_settings_path = get_user_settings_path()
  56. if user_settings_path is None or not load_user_setttings:
  57. # no user settings
  58. return (load_yaml(default_settings_path),
  59. 'load the default settings from {}'.format(default_settings_path))
  60. # user settings
  61. user_settings = load_yaml(user_settings_path)
  62. if user_settings.get('use_default_settings'):
  63. # the user settings are merged with the default configuration
  64. default_settings = load_yaml(default_settings_path)
  65. update_settings(default_settings, user_settings)
  66. return (default_settings,
  67. 'merge the default settings ( {} ) and the user setttings ( {} )'
  68. .format(default_settings_path, user_settings_path))
  69. # the user settings, fully replace the default configuration
  70. return (user_settings,
  71. 'load the user settings from {}'.format(user_settings_path))