diff --git a/scripts/backup b/scripts/backup index 3d1459f..3c6b807 100644 --- a/scripts/backup +++ b/scripts/backup @@ -6,7 +6,6 @@ # Source app helpers source /usr/share/yunohost/helpers - source .fonctions # Retrieve app settings domain=$(ynh_app_setting_get "$app" domain) diff --git a/scripts/remove b/scripts/remove index 8d91dd1..e722734 100644 --- a/scripts/remove +++ b/scripts/remove @@ -5,7 +5,48 @@ # Source app helpers source /usr/share/yunohost/helpers - source .fonctions + +REMOVE_NGINX_CONF () { # Suppression de la configuration nginx + if [ -e "/etc/nginx/conf.d/$domain.d/$app.conf" ]; then # Delete nginx config + echo "Delete nginx config" + sudo rm "/etc/nginx/conf.d/$domain.d/$app.conf" + fi +} + +REMOVE_FPM_CONF () { # Suppression de la configuration du pool php-fpm + if [ -e "/etc/php5/fpm/pool.d/$app.conf" ]; then # Delete fpm config + echo "Delete fpm config" + sudo rm "/etc/php5/fpm/pool.d/$app.conf" + fi +} + +SECURE_REMOVE () { # Suppression de dossier avec vérification des variables + chaine="$1" # L'argument doit être donné entre quotes simple '', pour éviter d'interpréter les variables. + no_var=0 + while (echo "$chaine" | grep -q '\$') # Boucle tant qu'il y a des $ dans la chaine + do + no_var=1 + global_var=$(echo "$chaine" | cut -d '$' -f 2) # Isole la première variable trouvée. + only_var=\$$(expr "$global_var" : '\([A-Za-z0-9_]*\)') # Isole complètement la variable en ajoutant le $ au début et en gardant uniquement le nom de la variable. Se débarrasse$ + real_var=$(eval "echo ${only_var}") # `eval "echo ${var}` permet d'interpréter une variable contenue dans une variable. + if test -z "$real_var" || [ "$real_var" = "/" ]; then + echo "Variable $only_var is empty, suppression of $chaine cancelled." >&2 + return 1 + fi + chaine=$(echo "$chaine" | sed "s@$only_var@$real_var@") # remplace la variable par sa valeur dans la chaine. + done + if [ "$no_var" -eq 1 ] + then + if [ -e "$chaine" ]; then + echo "Delete directory $chaine" + sudo rm -r "$chaine" + fi + return 0 + else + echo "No detected variable." >&2 + return 1 + fi +} # Retrieve arguments dbuser=$app diff --git a/scripts/restore b/scripts/restore index 7fd25f2..06d71dc 100644 --- a/scripts/restore +++ b/scripts/restore @@ -8,7 +8,6 @@ # Source app helpers source /usr/share/yunohost/helpers - source .fonctions # Retrieve old app settings domain=$(ynh_app_setting_get "$app" domain)