summaryrefslogtreecommitdiff
path: root/utils/build_env.py
diff options
context:
space:
mode:
Diffstat (limited to 'utils/build_env.py')
-rw-r--r--utils/build_env.py41
1 files changed, 27 insertions, 14 deletions
diff --git a/utils/build_env.py b/utils/build_env.py
index c52111e81..52ca94611 100644
--- a/utils/build_env.py
+++ b/utils/build_env.py
@@ -9,15 +9,12 @@ from os.path import realpath, dirname, join, sep, abspath
repo_root = realpath(dirname(realpath(__file__)) + sep + '..')
sys.path.insert(0, repo_root)
-os.environ['SEARX_SETTINGS_PATH'] = abspath(dirname(__file__) + '/settings.yml')
# 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')
-from searx import get_setting
-
def _env(*arg, **kwargs):
val = get_setting(*arg, **kwargs)
if val is True:
@@ -27,19 +24,35 @@ def _env(*arg, **kwargs):
return val
name_val = [
- ('SEARX_URL' , _env('server.base_url','')),
- ('GIT_URL' , _env('brand.git_url', '')),
- ('GIT_BRANCH' , _env('brand.git_branch', '')),
- ('ISSUE_URL' , _env('brand.issue_url', '')),
- ('DOCS_URL' , _env('brand.docs_url', '')),
- ('PUBLIC_INSTANCES' , _env('brand.public_instances', '')),
- ('CONTACT_URL' , _env('general.contact_url', '')),
- ('WIKI_URL' , _env('brand.wiki_url', '')),
+ ('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'
-print('build %s' % 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, val in name_val:
- print("export %s='%s'" % (name, val), file=f)
+ for name, option in name_val:
+ print("export %s='%s'" % (name, _env(option)), file=f)