mirror of
https://github.com/YunoHost/yunohost.git
synced 2024-09-03 20:06:10 +02:00
Merge pull request #1706 from YunoHost/enh-bind-heritage-config-panel
[enh] bind heritage in config panel
This commit is contained in:
commit
8cfc929f25
2 changed files with 34 additions and 6 deletions
|
@ -108,11 +108,11 @@ _ynh_app_config_apply_one() {
|
||||||
else
|
else
|
||||||
local bind_after=""
|
local bind_after=""
|
||||||
local bind_key_="$(echo "$bind" | cut -d: -f1)"
|
local bind_key_="$(echo "$bind" | cut -d: -f1)"
|
||||||
bind_key_=${bind_key_:-$short_setting}
|
|
||||||
if [[ "$bind_key_" == *">"* ]]; then
|
if [[ "$bind_key_" == *">"* ]]; then
|
||||||
bind_after="$(echo "${bind_key_}" | cut -d'>' -f1)"
|
bind_after="$(echo "${bind_key_}" | cut -d'>' -f1)"
|
||||||
bind_key_="$(echo "${bind_key_}" | cut -d'>' -f2)"
|
bind_key_="$(echo "${bind_key_}" | cut -d'>' -f2)"
|
||||||
fi
|
fi
|
||||||
|
bind_key_=${bind_key_:-$short_setting}
|
||||||
local bind_file="$(echo "$bind" | cut -d: -f2 | sed s@__INSTALL_DIR__@$install_dir@ | sed s@__FINALPATH__@$final_path@ | sed s/__APP__/$app/)"
|
local bind_file="$(echo "$bind" | cut -d: -f2 | sed s@__INSTALL_DIR__@$install_dir@ | sed s@__FINALPATH__@$final_path@ | sed s/__APP__/$app/)"
|
||||||
|
|
||||||
ynh_backup_if_checksum_is_different --file="$bind_file"
|
ynh_backup_if_checksum_is_different --file="$bind_file"
|
||||||
|
@ -139,21 +139,49 @@ loaded_toml = toml.loads(file_content, _dict=OrderedDict)
|
||||||
|
|
||||||
for panel_name, panel in loaded_toml.items():
|
for panel_name, panel in loaded_toml.items():
|
||||||
if not isinstance(panel, dict): continue
|
if not isinstance(panel, dict): continue
|
||||||
|
bind_panel = panel.get('bind')
|
||||||
for section_name, section in panel.items():
|
for section_name, section in panel.items():
|
||||||
if not isinstance(section, dict): continue
|
if not isinstance(section, dict): continue
|
||||||
|
bind_section = section.get('bind')
|
||||||
|
if not bind_section:
|
||||||
|
bind_section = bind_panel
|
||||||
|
elif bind_section[-1] == ":" and bind_panel and ":" in bind_panel:
|
||||||
|
regex, bind_panel_file = bind_panel.split(":")
|
||||||
|
if ">" in bind_section:
|
||||||
|
bind_section = bind_section + bind_panel_file
|
||||||
|
else:
|
||||||
|
bind_section = regex + bind_section + bind_panel_file
|
||||||
|
|
||||||
for name, param in section.items():
|
for name, param in section.items():
|
||||||
if not isinstance(param, dict):
|
if not isinstance(param, dict):
|
||||||
continue
|
continue
|
||||||
print(';'.join([
|
|
||||||
|
bind = param.get('bind')
|
||||||
|
|
||||||
|
if not bind:
|
||||||
|
if bind_section:
|
||||||
|
bind = bind_section
|
||||||
|
else:
|
||||||
|
bind = 'settings'
|
||||||
|
elif bind[-1] == ":" and bind_section and ":" in bind_section:
|
||||||
|
regex, bind_file = bind_section.split(":")
|
||||||
|
if ">" in bind:
|
||||||
|
bind = bind + bind_file
|
||||||
|
else:
|
||||||
|
bind = regex + bind + bind_file
|
||||||
|
if bind == "settings" and param.get('type', 'string') == 'file':
|
||||||
|
bind = 'null'
|
||||||
|
|
||||||
|
print('|'.join([
|
||||||
name,
|
name,
|
||||||
param.get('type', 'string'),
|
param.get('type', 'string'),
|
||||||
param.get('bind', 'settings' if param.get('type', 'string') != 'file' else 'null')
|
bind
|
||||||
]))
|
]))
|
||||||
EOL
|
EOL
|
||||||
)
|
)
|
||||||
for line in $lines; do
|
for line in $lines; do
|
||||||
# Split line into short_setting, type and bind
|
# Split line into short_setting, type and bind
|
||||||
IFS=';' read short_setting type bind <<<"$line"
|
IFS='|' read short_setting type bind <<<"$line"
|
||||||
binds[${short_setting}]="$bind"
|
binds[${short_setting}]="$bind"
|
||||||
types[${short_setting}]="$type"
|
types[${short_setting}]="$type"
|
||||||
file_hash[${short_setting}]=""
|
file_hash[${short_setting}]=""
|
||||||
|
|
|
@ -345,14 +345,14 @@ class ConfigPanel:
|
||||||
"defaults": {"version": 1.0},
|
"defaults": {"version": 1.0},
|
||||||
},
|
},
|
||||||
"panels": {
|
"panels": {
|
||||||
"properties": ["name", "services", "actions", "help"],
|
"properties": ["name", "services", "actions", "help", "bind"],
|
||||||
"defaults": {
|
"defaults": {
|
||||||
"services": [],
|
"services": [],
|
||||||
"actions": {"apply": {"en": "Apply"}},
|
"actions": {"apply": {"en": "Apply"}},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"sections": {
|
"sections": {
|
||||||
"properties": ["name", "services", "optional", "help", "visible"],
|
"properties": ["name", "services", "optional", "help", "visible", "bind"],
|
||||||
"defaults": {
|
"defaults": {
|
||||||
"name": "",
|
"name": "",
|
||||||
"services": [],
|
"services": [],
|
||||||
|
|
Loading…
Add table
Reference in a new issue