12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- # SPDX-License-Identifier: AGPL-3.0-or-later
- """build environment used by shell scripts
- """
- # set path
- import sys
- import os
- from os.path import realpath, dirname, join, sep, abspath
- repo_root = realpath(dirname(realpath(__file__)) + sep + '..')
- sys.path.insert(0, repo_root)
- # Under the assumption that a brand is always a fork assure that the settings
- # file from reposetorie's working tree is used to generate the build_env, not
- # from /etc/searx/settings.yml.
- os.environ['SEARX_SETTINGS_PATH'] = abspath(dirname(__file__) + sep + 'settings.yml')
- def _env(*arg, **kwargs):
- val = get_setting(*arg, **kwargs)
- if val is True:
- val = '1'
- elif val is False:
- val = ''
- return val
- name_val = [
- ('SEARX_URL' , 'server.base_url'),
- ('GIT_URL' , 'brand.git_url'),
- ('GIT_BRANCH' , 'brand.git_branch'),
- ('ISSUE_URL' , 'brand.issue_url'),
- ('DOCS_URL' , 'brand.docs_url'),
- ('PUBLIC_INSTANCES' , 'brand.public_instances'),
- ('WIKI_URL' , 'brand.wiki_url'),
- ]
- brand_env = 'utils' + sep + 'brand.env'
- # Some defaults in the settings.yml are taken from the environment,
- # e.g. SEARX_BIND_ADDRESS (:py:obj:`searx.settings_defaults.SHEMA`). When the
- # 'brand.env' file is created these enviroment variables should be unset first::
- _unset = object()
- for name, option in name_val:
- if not os.environ.get(name, _unset) is _unset:
- del os.environ[name]
- # After the variables are unset in the environ, we can import settings
- # (get_setting) from searx module.
- from searx import get_setting
- print('build %s (settings from: %s)' % (brand_env, os.environ['SEARX_SETTINGS_PATH']))
- sys.path.insert(0, repo_root)
- from searx import settings
- with open(repo_root + sep + brand_env, 'w', encoding='utf-8') as f:
- for name, option in name_val:
- print("export %s='%s'" % (name, _env(option)), file=f)
|