| 
									
										
										
										
											2014-11-04 09:47:50 +01:00
										 |  |  | #!/bin/bash | 
					
						
							| 
									
										
										
										
											2015-10-27 16:03:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # GENERIC START | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # IMPORT GENERIC HELPERS | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2014-11-04 09:47:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-26 21:21:43 +01:00
										 |  |  | #Keep this path for calling _common.sh inside the execution's context of backup and restore scripts | 
					
						
							| 
									
										
										
										
											2018-07-17 00:02:52 +02:00
										 |  |  | source ../settings/scripts/_common.sh | 
					
						
							| 
									
										
										
										
											2016-06-14 14:11:00 +02:00
										 |  |  | source /usr/share/yunohost/helpers | 
					
						
							| 
									
										
										
										
											2016-05-18 22:31:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # MANAGE SCRIPT FAILURE | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ynh_clean_setup () { | 
					
						
							|  |  |  | 	#### Remove this function if there's nothing to clean before calling the remove script. | 
					
						
							|  |  |  | 	true | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | # Exit if an error occurs during the execution of the script | 
					
						
							|  |  |  | ynh_abort_if_errors | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # LOAD SETTINGS | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Loading settings..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | app=$YNH_APP_INSTANCE_NAME | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | 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) | 
					
						
							| 
									
										
										
										
											2019-05-02 21:04:03 +02:00
										 |  |  | db_user=$db_name | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # CHECK IF THE APP CAN BE RESTORED | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Validating restoration parameters..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2016-05-18 22:31:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_webpath_available --domain=$domain --path_url=$path_url \ | 
					
						
							|  |  |  | 	|| ynh_die --message="Path not available: ${domain}${path_url}" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | test ! -d $final_path \ | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | 	|| ynh_die --message="There is already a directory: $final_path " | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # STANDARD RESTORATION STEPS | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # RESTORE THE NGINX CONFIGURATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="/etc/nginx/conf.d/$domain.d/$app.conf" | 
					
						
							| 
									
										
										
										
											2015-10-04 22:57:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # RESTORE THE APP MAIN DIR | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Restoring the app main directory..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="$final_path" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # RECREATE THE DEDICATED USER | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Recreating the dedicated system user..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # Create the dedicated user (if not existing) | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_system_user_create --username=$app | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # RESTORE USER RIGHTS | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2015-10-04 22:57:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # Restore permissions on app files | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | chown -R root: $final_path | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # RESTORE THE PHP-FPM CONFIGURATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="/etc/php/7.0/fpm/pool.d/$app.conf" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # RESTORE FAIL2BAN CONFIGURATION | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | ynh_script_progression --message="Restoring the fail2ban configuration..." --time --weight=1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ynh_restore_file "/etc/fail2ban/jail.d/$app.conf" | 
					
						
							|  |  |  | ynh_restore_file "/etc/fail2ban/filter.d/$app.conf" | 
					
						
							|  |  |  | ynh_systemd_action --action=restart --service_name=fail2ban | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # SPECIFIC RESTORATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # REINSTALL DEPENDENCIES | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Reinstalling dependencies..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # Define and install dependencies | 
					
						
							| 
									
										
										
										
											2019-03-05 23:11:52 +01:00
										 |  |  | ynh_install_app_dependencies $pkg_dependencies | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-07 17:17:26 +01:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # RESTORE THE MYSQL DATABASE | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Restoring the MySQL database..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2019-02-07 17:17:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | db_pwd=$(ynh_app_setting_get --app=$app --key=mysqlpwd) | 
					
						
							| 
									
										
										
										
											2019-05-02 21:04:03 +02:00
										 |  |  | ynh_mysql_setup_db --db_user=$db_user --db_name=$db_name --db_pwd=$db_pwd | 
					
						
							|  |  |  | ynh_mysql_connect_as --user=$db_user --password=$db_pwd --database=$db_name < ./db.sql | 
					
						
							| 
									
										
										
										
											2019-02-07 17:17:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-01-24 01:52:51 +01:00
										 |  |  | # RESTORE SYSTEMD | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Restoring the systemd configuration..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="/etc/systemd/system/$app.service" | 
					
						
							| 
									
										
										
										
											2019-01-24 01:52:51 +01:00
										 |  |  | systemctl enable $app.service | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-11-27 19:39:16 +01:00
										 |  |  | # INTEGRATE SERVICE IN YUNOHOST | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-27 19:39:16 +01:00
										 |  |  | yunohost service add $app --description "A short description of the app" --log "/var/log/$app/$app.log" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-02 20:44:22 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # START SYSTEMD SERVICE | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | ynh_script_progression --message="Starting a systemd service..." --time --weight=1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ynh_systemd_action --service_name=$app --action="start" --log_path="/var/log/$app/$app.log" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # RESTORE THE CRON FILE | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="/etc/cron.d/$app" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | # RESTORE THE LOGROTATE CONFIGURATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 00:32:39 +02:00
										 |  |  | ynh_restore_file --origin_path="/etc/logrotate.d/$app" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 18:10:46 +02:00
										 |  |  | # GENERIC FINALIZATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # RELOAD NGINX AND PHP-FPM | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Reloading nginx web server and php-fpm..." --time --weight=1 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:37:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_systemd_action --service_name=php7.0-fpm --action=reload | 
					
						
							|  |  |  | ynh_systemd_action --service_name=nginx --action=reload | 
					
						
							| 
									
										
										
										
											2019-02-10 15:02:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # END OF SCRIPT | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 19:58:47 +02:00
										 |  |  | ynh_script_progression --message="Restoration completed for $app" --time --last |