mirror of
https://github.com/YunoHost-Apps/spip_ynh.git
synced 2024-09-03 20:25:59 +02:00
Mieux traiter la suppression de l'app
This commit is contained in:
parent
a6a9fe30e4
commit
00cad842f2
2 changed files with 25 additions and 6 deletions
|
@ -165,13 +165,31 @@ REMOVE_LOGROTATE_CONF () { # Suppression de la configuration de logrotate
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
REMOVE_APP_DIR () { # Suppression du dossier de l'application
|
SECURE_REMOVE () { # Suppression de dossier avec vérification des variables
|
||||||
if test -n "$app"
|
chaine="$1" # L'argument doit être donné entre quotes simple '', pour éviter d'interpréter les variables.
|
||||||
then # Supprime le dossier seulement si $app n'est pas vide.
|
no_var=0
|
||||||
if [ -e "/var/www/$app" ]; then # Delete final_path
|
while (echo "$chaine" | grep -q '\$') # Boucle tant qu'il y a des $ dans la chaine
|
||||||
echo "Delete app dir"
|
do
|
||||||
sudo rm -r "/var/www/$app"
|
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 surtout du / et d'un éventuel chemin derrière.
|
||||||
|
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
|
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
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@ domain=$(ynh_app_setting_set $app domain)
|
||||||
REMOVE_BDD $app # Suppression de la base de donnée et de l'utilisateur associé.
|
REMOVE_BDD $app # Suppression de la base de donnée et de l'utilisateur associé.
|
||||||
|
|
||||||
REMOVE_APP_DIR # Suppression du dossier de l'application
|
REMOVE_APP_DIR # Suppression du dossier de l'application
|
||||||
|
SECURE_REMOVE '/var/www/$app' # Suppression du dossier de l'application
|
||||||
|
|
||||||
REMOVE_NGINX_CONF # Suppression de la configuration nginx
|
REMOVE_NGINX_CONF # Suppression de la configuration nginx
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue