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 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 args = parser.parse_args()
if len(sys.argv) != 2:
sys.exit(
'Invalid number of arguments. Usage:\n persistEnvironment.py /path/to/varibles-script.sh')
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 env_var in os.environ:
if env_var.startswith('TRANSMISSION_'):
for variable in os.environ: variables_to_persist[env_var] = os.environ.get(env_var)
if variable.startswith('TRANSMISSION_'): elif env_var.startswith('WEBPROXY_'):
variablesToPersist[variable] = os.environ.get(variable) variables_to_persist[env_var] = os.environ.get(env_var)
if variable.startswith('WEBPROXY_'): elif env_var in wanted_variables:
variablesToPersist[variable] = os.environ.get(variable) variables_to_persist[env_var] = os.environ.get(env_var)
if variable in wantedVariables:
variablesToPersist[variable] = os.environ.get(variable)
# Dump resulting settings to file # Dump resulting settings to file
with open(envVarsScriptFile, 'w') as file: with open(args.env_var_script_file, 'w') as script_file:
for variable in variablesToPersist: for var_name, var_value in variables_to_persist.items():
file.write('export ' + variable + '=' + script_file.write(
variablesToPersist[variable] + '\n') '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 os
import sys import sys
import json
parser = argparse.ArgumentParser(
description='Updates output settings file based on a default file',
)
# Verify script arguments parser.add_argument(
if len(sys.argv) != 3: 'input_file',
sys.exit('Invalid number of arguments. Usage:\n updateSettings.py defaultSettingsFile.json outputSettingsFile.json') type=str,
help='Path to default settings json file',
)
default_settings = sys.argv[1] parser.add_argument(
transmission_settings = sys.argv[2] '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): 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 # Define which file to base the config on
if os.path.isfile(transmission_settings): if os.path.isfile(transmission_settings):
configuration_baseline=transmission_settings configuration_baseline = transmission_settings
else: else:
configuration_baseline=default_settings configuration_baseline = default_settings
print('Using config baseline ' + configuration_baseline) print('Using config baseline', configuration_baseline)
# Read config base # Read config base
with open(configuration_baseline, 'r') as f: with open(configuration_baseline, 'r') as input_file:
settings_dict = json.load(f) 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 each setting, check if an environment variable is set to override it
for setting in settings_dict: 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: if setting_env_name in os.environ:
print('Overriding ' + setting + ' because ' + setting_env_name + ' is set to ' + os.environ.get(setting_env_name)) env_value = os.environ.get(setting_env_name)
settings_dict[setting] = 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 # Dump resulting settings to file
with open(transmission_settings, 'w') as fp: with open(transmission_settings, 'w') as fp: