2018-02-06 14:33:23 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
2018-02-11 00:32:26 +01:00
|
|
|
#=================================================
|
|
|
|
# GENERIC START
|
|
|
|
#=================================================
|
|
|
|
|
2018-02-06 14:33:23 +01:00
|
|
|
# Source YunoHost helpers
|
|
|
|
source /usr/share/yunohost/helpers
|
|
|
|
|
|
|
|
# Stop script if errors
|
|
|
|
ynh_abort_if_errors
|
|
|
|
|
|
|
|
# Import common cmd
|
|
|
|
source ../settings/scripts/experimental_helper.sh
|
|
|
|
source ../settings/scripts/_common.sh
|
|
|
|
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Loading settings..."
|
|
|
|
|
|
|
|
domain=$(ynh_app_setting_get --app $app --key domain)
|
|
|
|
path_url=$(ynh_app_setting_get --app $app --key path)
|
|
|
|
final_path=$(ynh_app_setting_get --app $app --key final_path)
|
|
|
|
db_name=$(ynh_app_setting_get --app $app --key db_name)
|
2018-02-06 14:33:23 +01:00
|
|
|
|
|
|
|
# CHECK IF THE APP CAN BE RESTORED
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_webpath_available --domain $domain --path_url $path_url \
|
|
|
|
|| ynh_die --message "Path not available: ${domain}${path_url}"
|
2018-02-06 14:33:23 +01:00
|
|
|
test ! -d $final_path \
|
2019-11-02 21:19:47 +01:00
|
|
|
|| ynh_die --message "There is already a directory: $final_path "
|
2018-02-06 14:33:23 +01:00
|
|
|
|
2018-02-11 00:32:26 +01:00
|
|
|
#=================================================
|
|
|
|
# STANDARD RESTORATION STEPS
|
|
|
|
#=================================================
|
|
|
|
|
2018-02-06 14:33:23 +01:00
|
|
|
# Define and install dependencies
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Reinstalling dependencies..." --weight=5
|
2018-02-06 14:33:23 +01:00
|
|
|
install_dependance
|
|
|
|
|
|
|
|
# Create the dedicated user (if not existing)
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_system_user_create --username $app
|
2018-02-06 14:33:23 +01:00
|
|
|
|
|
|
|
# Restore all config and data
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Restoring files..." --weight=10
|
2018-02-06 14:33:23 +01:00
|
|
|
ynh_restore
|
|
|
|
|
|
|
|
# RESTORE THE MYSQL DATABASE
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Restoring database..." --weight=3
|
|
|
|
db_pwd=$(ynh_app_setting_get --app $app --key mysqlpwd)
|
|
|
|
ynh_mysql_setup_db --db_user $db_name --db_name $db_name --db_pwd $db_pwd
|
|
|
|
ynh_mysql_connect_as --user $db_name --password $db_pwd --database $db_name < ./db.sql
|
2018-02-06 14:33:23 +01:00
|
|
|
|
2018-02-11 00:32:26 +01:00
|
|
|
#=================================================
|
|
|
|
# GENERIC FINALIZATION
|
|
|
|
#=================================================
|
|
|
|
|
2018-02-06 14:33:23 +01:00
|
|
|
# SECURE FILES AND DIRECTORIES
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Protecting directory..."
|
2018-02-06 14:33:23 +01:00
|
|
|
set_permission
|
|
|
|
|
|
|
|
# SETUP LOGROTATE
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_script_progression --message="Configuring log rotation..."
|
2019-11-04 20:30:33 +01:00
|
|
|
ynh_use_logrotate $final_path/horde --nonappend --specific_user www-data/horde
|
2019-11-02 21:19:47 +01:00
|
|
|
ynh_use_logrotate $final_path/horde/services --append --specific_user www-data/horde
|
|
|
|
ynh_use_logrotate $final_path/horde/services/portal --append --specific_user www-data/horde
|
2018-02-06 14:33:23 +01:00
|
|
|
|
|
|
|
# Reload services
|
|
|
|
systemctl reload php5-fpm
|
|
|
|
systemctl reload nginx
|
2019-11-02 21:19:47 +01:00
|
|
|
|
|
|
|
ynh_script_progression --message="Restoration completed for $app" --last
|