| 
									
										
										
										
											2014-10-20 18:55:53 +02:00
										 |  |  | #!/bin/bash | 
					
						
							| 
									
										
										
										
											2015-10-27 16:03:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # GENERIC START | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # IMPORT GENERIC HELPERS | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:11:48 +02:00
										 |  |  | source _common.sh | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | source /usr/share/yunohost/helpers | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # MANAGE SCRIPT FAILURE | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-06-17 17:49:26 +02:00
										 |  |  | # Exit if an error occurs during the execution of the script | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_abort_if_errors | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # RETRIEVE ARGUMENTS FROM THE MANIFEST | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | domain=$YNH_APP_ARG_DOMAIN | 
					
						
							|  |  |  | path_url=$YNH_APP_ARG_PATH | 
					
						
							|  |  |  | admin=$YNH_APP_ARG_ADMIN | 
					
						
							|  |  |  | is_public=$YNH_APP_ARG_IS_PUBLIC | 
					
						
							|  |  |  | language=$YNH_APP_ARG_LANGUAGE | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | password=$YNH_APP_ARG_PASSWORD | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### If it's a multi-instance app, meaning it can be installed several times independently | 
					
						
							|  |  |  | ### The id of the app as stated in the manifest is available as $YNH_APP_ID | 
					
						
							|  |  |  | ### The instance number is available as $YNH_APP_INSTANCE_NUMBER (equals "1", "2", ...) | 
					
						
							|  |  |  | ### The app instance name is available as $YNH_APP_INSTANCE_NAME | 
					
						
							|  |  |  | ###    - the first time the app is installed, YNH_APP_INSTANCE_NAME = ynhexample | 
					
						
							|  |  |  | ###    - the second time the app is installed, YNH_APP_INSTANCE_NAME = ynhexample__2 | 
					
						
							|  |  |  | ###    - ynhexample__{N} for the subsequent installations, with N=3,4, ... | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### The app instance name is probably what interests you most, since this is | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### guaranteed to be unique. This is a good unique identifier to define installation path, | 
					
						
							|  |  |  | ### db names, ... | 
					
						
							| 
									
										
										
										
											2016-03-18 17:31:44 +01:00
										 |  |  | app=$YNH_APP_INSTANCE_NAME | 
					
						
							| 
									
										
										
										
											2014-10-20 18:55:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # CHECK IF THE APP CAN BE INSTALLED WITH THESE ARGS | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Validating installation parameters..." | 
					
						
							| 
									
										
										
										
											2014-10-20 18:55:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 09:14:36 +02:00
										 |  |  | ### If the app uses nginx as web server (written in HTML/PHP in most cases), the final path should be "/var/www/$app". | 
					
						
							|  |  |  | ### If the app provides an internal web server (or uses another application server such as uwsgi), the final path should be "/opt/yunohost/$app" | 
					
						
							| 
									
										
										
										
											2017-08-28 23:55:51 +02:00
										 |  |  | final_path=/var/www/$app | 
					
						
							|  |  |  | test ! -e "$final_path" || ynh_die "This path already contains a folder" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Normalize the url path syntax | 
					
						
							|  |  |  | path_url=$(ynh_normalize_url_path $path_url) | 
					
						
							| 
									
										
										
										
											2016-05-18 22:31:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # Register (book) web path | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_webpath_register $app $domain $path_url | 
					
						
							| 
									
										
										
										
											2014-10-20 18:55:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # STORE SETTINGS FROM MANIFEST | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Storing installation settings..." | 
					
						
							| 
									
										
										
										
											2015-10-27 16:03:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_app_setting_set $app domain $domain | 
					
						
							|  |  |  | ynh_app_setting_set $app path $path_url | 
					
						
							|  |  |  | ynh_app_setting_set $app admin $admin | 
					
						
							|  |  |  | ynh_app_setting_set $app is_public $is_public | 
					
						
							|  |  |  | ynh_app_setting_set $app language $language | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # STANDARD MODIFICATIONS | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # FIND AND OPEN A PORT | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring firewall..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### Use these lines if you have to open a port for the application | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### `ynh_find_port` will find the first available port starting from the given port. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### If you're not using these lines: | 
					
						
							|  |  |  | ###		- Remove the section "CLOSE A PORT" in the remove script | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Find a free port | 
					
						
							|  |  |  | port=$(ynh_find_port 8095) | 
					
						
							|  |  |  | # Open this port | 
					
						
							| 
									
										
										
										
											2019-02-10 15:02:38 +01:00
										 |  |  | ynh_exec_warn_less yunohost firewall allow --no-upnp TCP $port | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_app_setting_set $app port $port | 
					
						
							| 
									
										
										
										
											2015-10-27 16:03:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # INSTALL DEPENDENCIES | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Installing dependencies..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### `ynh_install_app_dependencies` allows you to add any "apt" dependencies to the package. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### Those deb packages will be installed as dependencies of this package. | 
					
						
							|  |  |  | ### If you're not using this helper: | 
					
						
							|  |  |  | ###		- Remove the section "REMOVE DEPENDENCIES" in the remove script | 
					
						
							|  |  |  | ###		- As well as the section "REINSTALL DEPENDENCIES" in the restore script | 
					
						
							|  |  |  | ###		- And the section "UPGRADE DEPENDENCIES" in the upgrade script | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_install_app_dependencies deb1 deb2 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # CREATE A MYSQL DATABASE | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Creating a mysql database..." | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### Use these lines if you need a database for the application. | 
					
						
							|  |  |  | ### `ynh_mysql_setup_db` will create a database, an associated user and a ramdom password. | 
					
						
							|  |  |  | ### The password will be stored as 'mysqlpwd' into the app settings, | 
					
						
							|  |  |  | ### and will be available as $db_pwd | 
					
						
							|  |  |  | ### If you're not using these lines: | 
					
						
							|  |  |  | ###		- Remove the section "BACKUP THE MYSQL DATABASE" in the backup script | 
					
						
							|  |  |  | ###		- Remove also the section "REMOVE THE MYSQL DATABASE" in the remove script | 
					
						
							|  |  |  | ###		- As well as the section "RESTORE THE MYSQL DATABASE" in the restore script | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | db_name=$(ynh_sanitize_dbid $app) | 
					
						
							|  |  |  | ynh_app_setting_set $app db_name $db_name | 
					
						
							|  |  |  | ynh_mysql_setup_db $db_name $db_name | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # DOWNLOAD, CHECK AND UNPACK SOURCE | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Setting up source files..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_setup_source` is used to install an app from a zip or tar.gz file, | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### downloaded from an upstream source, like a git repository. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_setup_source` use the file conf/app.src | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_app_setting_set $app final_path $final_path | 
					
						
							|  |  |  | # Download, check integrity, uncompress and patch the source from app.src | 
					
						
							|  |  |  | ynh_setup_source "$final_path" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # NGINX CONFIGURATION | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring nginx..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_add_nginx_config` will use the file conf/nginx.conf | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Create a dedicated nginx config | 
					
						
							| 
									
										
										
										
											2018-05-27 15:44:58 +02:00
										 |  |  | ynh_add_nginx_config | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # CREATE DEDICATED USER | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring system user..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Create a system user | 
					
						
							|  |  |  | ynh_system_user_create $app | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # PHP-FPM CONFIGURATION | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring php-fpm..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### `ynh_add_fpm_config` is used to set up a PHP config. | 
					
						
							|  |  |  | ### You can remove it if your app doesn't use PHP. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_add_fpm_config` will use the files conf/php-fpm.conf and conf/php-fpm.ini | 
					
						
							|  |  |  | ### If you're not using these lines: | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ###		- You can remove these files in conf/. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ###		- Remove the section "BACKUP THE PHP-FPM CONFIGURATION" in the backup script | 
					
						
							|  |  |  | ###		- Remove also the section "REMOVE PHP-FPM CONFIGURATION" in the remove script | 
					
						
							|  |  |  | ###		- As well as the section "RESTORE THE PHP-FPM CONFIGURATION" in the restore script | 
					
						
							|  |  |  | ###		With the reload at the end of the script. | 
					
						
							|  |  |  | ###		- And the section "PHP-FPM CONFIGURATION" in the upgrade script | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Create a dedicated php-fpm config | 
					
						
							| 
									
										
										
										
											2017-08-28 23:55:51 +02:00
										 |  |  | ynh_add_fpm_config | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # SPECIFIC SETUP | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # ... | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # SETUP SYSTEMD | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring a systemd service..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_systemd_config` is used to configure a systemd script for an app. | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### It can be used for apps that use sysvinit (with adaptation) or systemd. | 
					
						
							|  |  |  | ### Have a look at the app to be sure this app needs a systemd script. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_systemd_config` will use the file conf/systemd.service | 
					
						
							|  |  |  | ### If you're not using these lines: | 
					
						
							|  |  |  | ###		- You can remove those files in conf/. | 
					
						
							|  |  |  | ###		- Remove the section "BACKUP SYSTEMD" in the backup script | 
					
						
							|  |  |  | ###		- Remove also the section "STOP AND REMOVE SERVICE" in the remove script | 
					
						
							|  |  |  | ###		- As well as the section "RESTORE SYSTEMD" in the restore script | 
					
						
							|  |  |  | ###		- And the section "SETUP SYSTEMD" in the upgrade script | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Create a dedicated systemd config | 
					
						
							| 
									
										
										
										
											2018-06-18 00:58:40 +02:00
										 |  |  | ynh_add_systemd_config | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # SETUP APPLICATION WITH CURL | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### Use these lines only if the app installation needs to be finalized through | 
					
						
							|  |  |  | ### web forms. We generally don't want to ask the final user, | 
					
						
							|  |  |  | ### so we're going to use curl to automatically fill the fields and submit the | 
					
						
							|  |  |  | ### forms. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Set right permissions for curl install | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | chown -R $app: $final_path | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # Set the app as temporarily public for curl call | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring ssowat..." | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | ynh_app_setting_set $app skipped_uris "/" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Reload SSOwat config | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | yunohost app ssowatconf | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Reload Nginx | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | systemctl reload nginx | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Installation with curl | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Finalizing install..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_local_curl "/INSTALL_PATH" "key1=value1" "key2=value2" "key3=value3" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | # Remove the public access | 
					
						
							|  |  |  | if [ $is_public -eq 0 ] | 
					
						
							|  |  |  | then | 
					
						
							|  |  |  | 	ynh_app_setting_delete $app skipped_uris | 
					
						
							|  |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # MODIFY A CONFIG FILE | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### `ynh_replace_string` is used to replace a string in a file. | 
					
						
							|  |  |  | ### (It's compatible with sed regular expressions syntax) | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-05 17:48:23 +02:00
										 |  |  | ynh_replace_string "match_string" "replace_string" "$final_path/CONFIG_FILE" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | # STORE THE CONFIG FILE CHECKSUM | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_store_file_checksum` is used to store the checksum of a file. | 
					
						
							|  |  |  | ### That way, during the upgrade script, by using `ynh_backup_if_checksum_is_different`, | 
					
						
							|  |  |  | ### you can make a backup of this file before modifying it again if the admin had modified it. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Calculate and store the config file checksum into the app settings | 
					
						
							|  |  |  | ynh_store_file_checksum "$final_path/CONFIG_FILE" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # GENERIC FINALIZATION | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # SECURE FILES AND DIRECTORIES | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### For security reason, any app should set the permissions to root: before anything else. | 
					
						
							|  |  |  | ### Then, if write authorization is needed, any access should be given only to directories | 
					
						
							|  |  |  | ### that really need such authorization. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | # Set permissions to app files | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | chown -R root: $final_path | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # SETUP LOGROTATE | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Configuring log rotation..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### `ynh_use_logrotate` is used to configure a logrotate configuration for the logs of this app. | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### Use this helper only if there is effectively a log file for this app. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### If you're not using this helper: | 
					
						
							|  |  |  | ###		- Remove the section "BACKUP LOGROTATE" in the backup script | 
					
						
							|  |  |  | ###		- Remove also the section "REMOVE LOGROTATE CONFIGURATION" in the remove script | 
					
						
							|  |  |  | ###		- As well as the section "RESTORE THE LOGROTATE CONFIGURATION" in the restore script | 
					
						
							|  |  |  | ###		- And the section "SETUP LOGROTATE" in the upgrade script | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # Use logrotate to manage application logfile(s) | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | ynh_use_logrotate | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2017-06-17 17:49:26 +02:00
										 |  |  | # ADVERTISE SERVICE IN ADMIN PANEL | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### `yunohost service add` is a CLI yunohost command to add a service in the admin panel. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### You'll find the service in the 'services' section of YunoHost admin panel. | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ### This CLI command would be useless if the app does not have any services (systemd or sysvinit) | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ### If you're not using these lines: | 
					
						
							| 
									
										
										
										
											2018-07-01 09:57:16 +02:00
										 |  |  | ###		- You can remove these files in conf/. | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | ###		- Remove the section "REMOVE SERVICE FROM ADMIN PANEL" in the remove script | 
					
						
							| 
									
										
										
										
											2019-02-04 15:35:33 +01:00
										 |  |  | ###		- As well as the section "ADVERTISE SERVICE IN ADMIN PANEL" in the restore script | 
					
						
							| 
									
										
										
										
											2018-06-28 22:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-28 19:52:26 +01:00
										 |  |  | yunohost service add $app --log "/var/log/$app/$app.log" | 
					
						
							| 
									
										
										
										
											2018-12-07 11:08:41 +01:00
										 |  |  | # if using yunohost version 3.2 or more in the 'manifest.json', a description can be added | 
					
						
							| 
									
										
										
										
											2019-01-28 19:52:26 +01:00
										 |  |  | #yunohost service add $app --description "$app daemon for XXX" --log "/var/log/$app/$app.log" | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # SETUP SSOWAT | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_script_progression --message="Configuring SSOwat..." | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Make app public if necessary | 
					
						
							|  |  |  | if [ $is_public -eq 1 ] | 
					
						
							|  |  |  | then | 
					
						
							|  |  |  | 	# unprotected_uris allows SSO credentials to be passed anyway. | 
					
						
							|  |  |  | 	ynh_app_setting_set $app unprotected_uris "/" | 
					
						
							| 
									
										
										
										
											2014-10-20 18:55:53 +02:00
										 |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-02 18:23:51 +02:00
										 |  |  | #================================================= | 
					
						
							|  |  |  | # RELOAD NGINX | 
					
						
							|  |  |  | #================================================= | 
					
						
							| 
									
										
										
										
											2019-02-13 18:40:20 +01:00
										 |  |  | ynh_print_info "Reloading nginx..." | 
					
						
							| 
									
										
										
										
											2019-02-10 15:02:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-05 18:10:43 +02:00
										 |  |  | systemctl reload nginx | 
					
						
							| 
									
										
										
										
											2019-02-10 15:02:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | # END OF SCRIPT | 
					
						
							|  |  |  | #================================================= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-14 01:35:47 +01:00
										 |  |  | ynh_print_info "Installation of $app completed" |