1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/dotclear2_ynh.git synced 2024-09-03 18:26:29 +02:00

Improve admin permissions and setup

This commit is contained in:
tituspijean 2023-10-11 22:55:00 +02:00
parent 76ad8d900b
commit 1a2b8d4dc1
No known key found for this signature in database
GPG key ID: EF3B0D7CC0A94720
3 changed files with 84 additions and 4 deletions

View file

@ -40,9 +40,10 @@ ram.runtime = "50M" # FIXME: replace with an **estimate** minimum ram requiremen
type = "group" type = "group"
default = "visitors" default = "visitors"
[install.admin] [install.init_admin_permission]
type = "user" type = "user"
help.en = "Choose the Dotclear super user. By default, all users in the admin group will be admins of Dotclear." ask.en = "Choose the Dotclear super user."
help.en = "You can later on give admin permission to more users."
[resources] [resources]
[resources.sources.latest] [resources.sources.latest]
@ -65,7 +66,6 @@ ram.runtime = "50M" # FIXME: replace with an **estimate** minimum ram requiremen
main.url = "/" main.url = "/"
admin.url = "/admin" admin.url = "/admin"
admin.show_tile = false admin.show_tile = false
admin.allowed = "admins"
[resources.apt] [resources.apt]
packages = "mariadb-server, php8.2, php8.2-fpm, php8.2-mbstring, php8.2-mysql, php-iconv, php8.2-xml, php8.2-cli, php8.2-intl, php8.2-ldap" packages = "mariadb-server, php8.2, php8.2-fpm, php8.2-mbstring, php8.2-mysql, php-iconv, php8.2-xml, php8.2-cli, php8.2-intl, php8.2-ldap"

77
scripts/config Normal file
View file

@ -0,0 +1,77 @@
#!/bin/bash
#=================================================
# GENERIC STARTING
#=================================================
# IMPORT GENERIC HELPERS
#=================================================
source /usr/share/yunohost/helpers
ynh_abort_if_errors
#=================================================
# SPECIFIC SETTERS FOR TOML SHORT KEYS
#=================================================
set__blogs_list() {
declare -A domain_array
declare -A path_array
for blog in $(echo $blogs_list | sed "s/,/ /"); do
id=$(echo $blog | cut -d@ -f1)
domain=$(echo $blog | cut -d@ -f2 | cut -d/ -f1)
path="/$(echo $blog | cut -d@ -f2 | cut -d/ -f2)"
domain_array+=([$id]=$domain)
path_array+=([$id]=$path)
done
declare -A old_domain_array
declare -A old_path_array
for blog in $(echo ${old[blogs_list]} | sed "s/,/ /"); do
id=$(echo $blog | cut -d@ -f1)
domain=$(echo $blog | cut -d@ -f2 | cut -d/ -f1)
path="/$(echo $blog | cut -d@ -f2 | cut -d/ -f2)"
old_domain_array+=([$id]=$domain)
old_path_array+=([$id]=$path)
done
# https://stackoverflow.com/questions/2312762/compare-difference-of-two-arrays-in-bash
# Get added and removed blogs
added_ids_array=(`echo ${!domain_array[@]} ${!old_domain_array[@]} | tr ' ' '\n' | sort | uniq -u `)
removed_ids_array=(`echo ${!old_domain_array[@]} $!domain_array[@]} | tr ' ' '\n' | sort | uniq -D | uniq `)
for id in $removed_ids_array; do
if [ ynh_permission_exists --permission="$id" ]; then
ynh_permission_delete --permission="$id"
fi
ynh_secure_remove --file="/etc/nginx/conf.d/${old_domain_array[$id]}.d/$app.conf"
done
for id in $domain_array; do
if [ $domain_array[$id] != $old_domain_array[$id] ]; then
mv /etc/nginx/conf.d/${old_domain_array[$id]}.d/$app.conf /etc/nginx/conf.d/${domain_array[$id]}.d/$app.conf
fi
if [ $path_array[$id] != $old_path_array[$id] ]; then
domain=$domain_array[$id]
path=$path_array[$id]
ynh_add_config --template="nginx.conf" --destination="/etc/nginx/conf.d/${domain_array[$id]}.d/$app.conf"
fi
if [ ynh_permission_exists --permission="$id" ]; then
ynh_permission_url --permission="$id" --url="$domain_array[$id]$path_array[$id]"
ynh_permission_url --permission="$id.admin" --url="$domain_array[$id]$path_array[$id]/admin"
else
ynh_permission_create --permission="$id" --url="$domain_array[$id]$path_array[$id]"
ynh_permission_create --permission="$id.admin" --url="$domain_array[$id]$path_array[$id]/admin"
fi
done
ynh_app_setting_set $app blogs_list $blogs_list
}

View file

@ -55,6 +55,8 @@ ynh_script_progression --message="Adding a configuration file..."
php_config=$install_dir/inc/config.php php_config=$install_dir/inc/config.php
admin=$(yunohost user permission info "$app.admin" --output-as json | jq -r '.allowed | .[]')
master_key=$(ynh_string_random --length=30) master_key=$(ynh_string_random --length=30)
ynh_app_setting_set --app=$app --key=master_key --value=$master_key ynh_app_setting_set --app=$app --key=master_key --value=$master_key
@ -62,6 +64,7 @@ cp $php_config.in $php_config
admin_url="${path%/}/admin/" admin_url="${path%/}/admin/"
admin=$(yunohost user permission info "$app.admin" --output-as json | jq -r '.allowed | .[]')
email=$(ynh_user_get_info --username=$admin --key=mail) email=$(ynh_user_get_info --username=$admin --key=mail)
# Config as if we called in admin/install/wizard.php # Config as if we called in admin/install/wizard.php
@ -117,7 +120,7 @@ chown $app:$app "$php_config"
ynh_script_progression --message="Finalizing installation..." --weight=14 ynh_script_progression --message="Finalizing installation..." --weight=14
# Give the admin the proper permission and give temporary admin access to visitors # Give the admin the proper permission and give temporary admin access to visitors
ynh_permission_update --permission="admin" --add="$admin" "visitors" ynh_permission_update --permission="admin" --add="visitors"
firstname=$(ynh_user_get_info --username=$admin --key=firstname) firstname=$(ynh_user_get_info --username=$admin --key=firstname)
lastname=$(ynh_user_get_info --username=$admin --key=lastname) lastname=$(ynh_user_get_info --username=$admin --key=lastname)