#!/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