Merge pull request #1324 from thomasborgen/feature/persistent-settings-python

Feature/persistent settings python
This commit is contained in:
Kristian Haugene
2020-08-10 20:59:52 +02:00
committed by GitHub
2 changed files with 84 additions and 36 deletions

View File

@@ -1,30 +1,44 @@
import argparse
import os
import sys
import json
parser = argparse.ArgumentParser(
description='Store env vars into runnable .sh file with export statements',
)
parser.add_argument(
'env_var_script_file',
type=str,
help='Path to variables-script.sh',
)
# Verify script arguments
if len(sys.argv) != 2:
sys.exit(
'Invalid number of arguments. Usage:\n persistEnvironment.py /path/to/varibles-script.sh')
args = parser.parse_args()
envVarsScriptFile = sys.argv[1]
wanted_variables = {
'OPENVPN_PROVIDER',
'ENABLE_UFW',
'PUID',
'PGID',
'DROP_DEFAULT_ROUTE',
'GLOBAL_APPLY_PERMISSIONS',
'DOCKER_LOG',
}
wantedVariables = ['OPENVPN_PROVIDER', 'ENABLE_UFW', 'PUID', 'PGID', 'DROP_DEFAULT_ROUTE', 'GLOBAL_APPLY_PERMISSIONS', 'DOCKER_LOG']
variables_to_persist = {}
variablesToPersist = {}
for variable in os.environ:
if variable.startswith('TRANSMISSION_'):
variablesToPersist[variable] = os.environ.get(variable)
if variable.startswith('WEBPROXY_'):
variablesToPersist[variable] = os.environ.get(variable)
if variable in wantedVariables:
variablesToPersist[variable] = os.environ.get(variable)
for env_var in os.environ:
if env_var.startswith('TRANSMISSION_'):
variables_to_persist[env_var] = os.environ.get(env_var)
elif env_var.startswith('WEBPROXY_'):
variables_to_persist[env_var] = os.environ.get(env_var)
elif env_var in wanted_variables:
variables_to_persist[env_var] = os.environ.get(env_var)
# Dump resulting settings to file
with open(envVarsScriptFile, 'w') as file:
for variable in variablesToPersist:
file.write('export ' + variable + '=' +
variablesToPersist[variable] + '\n')
with open(args.env_var_script_file, 'w') as script_file:
for var_name, var_value in variables_to_persist.items():
script_file.write(
'export {env_var} = {env_var_value}\n'.format(
env_var=var_name,
env_var_value=var_value,
),
)

View File

@@ -1,36 +1,70 @@
import argparse
import json
import os
import sys
import json
parser = argparse.ArgumentParser(
description='Updates output settings file based on a default file',
)
# Verify script arguments
if len(sys.argv) != 3:
sys.exit('Invalid number of arguments. Usage:\n updateSettings.py defaultSettingsFile.json outputSettingsFile.json')
parser.add_argument(
'input_file',
type=str,
help='Path to default settings json file',
)
default_settings = sys.argv[1]
transmission_settings = sys.argv[2]
parser.add_argument(
'output_file',
type=str,
help='Path to output settings json file',
)
args = parser.parse_args()
default_settings = args.input_file
transmission_settings = args.output_file
# Fail if default settings file doesnt exist.
if not os.path.isfile(default_settings):
sys.exit('Invalid arguments, default settings file does not exist')
sys.exit(
'Invalid arguments, default settings file{file} does not exist'.format(
file=default_settings,
),
)
# Define which file to base the config on
if os.path.isfile(transmission_settings):
configuration_baseline=transmission_settings
configuration_baseline = transmission_settings
else:
configuration_baseline=default_settings
configuration_baseline = default_settings
print('Using config baseline ' + configuration_baseline)
print('Using config baseline', configuration_baseline)
# Read config base
with open(configuration_baseline, 'r') as f:
settings_dict = json.load(f)
with open(configuration_baseline, 'r') as input_file:
settings_dict = json.load(input_file)
def setting_as_env(setting: str) -> str:
"""Get a transmission settings environment variable name."""
return 'TRANSMISSION_{setting}'.format(
setting=setting.upper().replace('-', '_'),
)
# For each setting, check if an environment variable is set to override it
for setting in settings_dict:
setting_env_name = 'TRANSMISSION_' + setting.upper().replace('-', '_')
setting_env_name = setting_as_env(setting)
if setting_env_name in os.environ:
print('Overriding ' + setting + ' because ' + setting_env_name + ' is set to ' + os.environ.get(setting_env_name))
settings_dict[setting] = os.environ.get(setting_env_name)
env_value = os.environ.get(setting_env_name)
print(
'Overriding {setting} because {env_name} is set to {value}'.format(
setting=setting,
env_name=setting_env_name,
value=env_value,
),
)
settings_dict[setting] = env_value
# Dump resulting settings to file
with open(transmission_settings, 'w') as fp: