#!/bin/bash set -eu #================================================= # GENERIC STARTING #================================================= # MANAGE FAILURE OF THE SCRIPT #================================================= #================================================= # IMPORT GENERIC HELPERS #================================================= source _common.sh source /usr/share/yunohost/helpers #================================================= # LOAD SETTINGS #================================================= app=$YNH_APP_INSTANCE_NAME domain=$(ynh_app_setting_get $app domain) path_url=$(ynh_app_setting_get $app path) is_public=$(ynh_app_setting_get $app is_public) language=$(ynh_app_setting_get $app language) final_path=$(ynh_app_setting_get $app final_path) db_name=$(ynh_app_setting_get $app db_name) #================================================= # CHECK IF THE APP CAN BE RESTORED #================================================= sudo yunohost app checkurl "${domain}${path_url}" -a "$app" \ || ynh_die "Path not available: ${domain}${path_url}" # Mise en commentaire, c'est une mise a jour, le repertoire # existe c'est normal, donc le controle n'est pas judicieux. #test ! -d $final_path \ # || ynh_die "There is already a directory: $final_path " #================================================= # STANDARD RESTORE STEPS #================================================= # RESTORE OF THE NGINX CONFIGURATION #================================================= #conf=/etc/nginx/conf.d/$domain.d/$app.conf #if [ -f $conf ]; then # ynh_die "There is already a nginx conf file at this path: $conf " #fi #sudo cp -a ./nginx.conf $conf #================================================= # RESTORE OF THE MAIN DIR OF THE APP #================================================= # Recuperation du zip contenant les corrections et # le script de maj de la base # il faudrait un numero de version pour le script de # la base. Pour le moment je recupere un fichier sql # update.sql qui passe dans la version superieur. UPDATE_SOURCE_ZIP #================================================= # RESTORE OF THE SQL BDD #================================================= db_pwd=$(ynh_app_setting_get $app mysqlpwd) # il ne faut recreer la base, c'est une maj #ynh_mysql_create_db $db_name $db_name $db_pwd # il faut prendre le script de mise a jour ynh_mysql_connect_as $db_name $db_pwd $db_name < $final_path/db/update.sql #================================================= # RECREATE OF THE DEDICATED USER #================================================= ynh_system_user_create $app # Recreate the dedicated user, if not exist #================================================= # RESTORE USER RIGHTS #================================================= # Les fichiers appartiennent à l'user wordpress, pour permettre les mises à jour. sudo rm -f $final_path/setup.php sudo rm -f $final_path/db/todolist.db sudo chmod o+w $final_path/db/config.php sudo chmod o+w $final_path/tmp/sessions sudo chown -R $app: $final_path #================================================= # SETUP SSOWAT #================================================= ynh_app_setting_set $app unprotected_uris "/" # 0 : pas d'acces publique # 1 : acces publique autorise if [ $is_public -eq 0 ]; then # Retire l'accès public ynh_app_setting_delete $app unprotected_uris fi #================================================= # GENERIC FINALISATION #================================================= # RELOAD NGINX #================================================= sudo systemctl reload nginx sudo yunohost app ssowatconf