1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/leed_ynh.git synced 2024-09-03 19:26:32 +02:00
leed_ynh/scripts/upgrade

171 lines
5.8 KiB
Text
Raw Normal View History

2014-08-17 17:52:31 +02:00
#!/bin/bash
2014-08-18 22:05:31 +02:00
2017-03-01 19:37:00 +01:00
#=================================================
# GENERIC STARTING
#=================================================
# IMPORT GENERIC HELPERS
#=================================================
2016-06-15 23:56:35 +02:00
2017-03-01 19:37:00 +01:00
source .fonctions
2016-12-14 16:08:29 +01:00
source /usr/share/yunohost/helpers
2017-03-01 19:37:00 +01:00
#=================================================
# LOAD SETTINGS
#=================================================
app=$YNH_APP_INSTANCE_NAME
2016-12-14 16:08:29 +01:00
domain=$(ynh_app_setting_get $app domain)
2017-03-01 19:37:00 +01:00
path_url=$(ynh_app_setting_get $app path)
2016-12-14 16:08:29 +01:00
admin=$(ynh_app_setting_get $app admin)
is_public=$(ynh_app_setting_get $app is_public)
final_path=$(ynh_app_setting_get $app final_path)
db_pwd=$(ynh_app_setting_get $app mysqlpwd)
2017-03-01 19:37:00 +01:00
db_name=$(ynh_app_setting_get $app db_name)
#=================================================
# FIX OLD THINGS
#=================================================
2014-08-18 22:05:31 +02:00
2016-06-25 17:57:34 +02:00
if [ -z $final_path ]; then # Si final_path n'est pas renseigné dans app setting
final_path=/var/www/$app
2016-12-14 16:08:29 +01:00
ynh_app_setting_set $app final_path $final_path
2016-06-25 17:57:34 +02:00
fi
2017-03-01 19:37:00 +01:00
if [ -z $db_name ]; then # Si db_name n'est pas renseigné dans app setting
db_name=$(ynh_make_valid_dbid $app)
ynh_app_setting_set $app db_name $db_name
fi
if [ -z "$is_public" ]; then # Raté avec get au lieu de set...
public_check=$(ynh_app_setting_get $app skipped_uris)
if [ -z "$public_check" ]; then # Si skipped_uris est vide, c'était une install publique.
is_public=1
else
is_public=0
fi
ynh_app_setting_set $app is_public $is_public
else
if [ "$is_public" = "Yes" ]; then
ynh_app_setting_set $app is_public 1 # Fixe is_public en booléen
is_public=1
elif [ "$is_public" = "No" ]; then
ynh_app_setting_set $app is_public 0
is_public=0
fi
fi
market=$(ynh_app_setting_get $app market)
if [ "$market" = "Yes" ]; then
ynh_app_setting_set $app market 1 # Fixe market en booléen
elif [ "$market" = "No" ]; then
ynh_app_setting_set $app market 0
fi
2015-11-22 14:37:01 +01:00
2017-03-01 19:37:00 +01:00
#=================================================
# BACKUP BEFORE UPGRADE THEN ACTIVE TRAP
#=================================================
2016-06-15 23:56:35 +02:00
2017-03-01 19:37:00 +01:00
BACKUP_BEFORE_UPGRADE # Backup the current version of the app
ynh_clean_setup () {
BACKUP_FAIL_UPGRADE # restore it if the upgrade fails
}
ynh_check_error # Active trap pour arrêter le script si une erreur est détectée.
2016-06-15 23:56:35 +02:00
2017-03-01 19:37:00 +01:00
#=================================================
# CHECK THE PATH
#=================================================
path_url=$(ynh_normalize_url_path $path_url) # Vérifie et corrige la syntaxe du path.
#=================================================
# STANDARD UPGRADE STEPS
#=================================================
# DOWNLOAD, CHECK AND UNPACK SOURCE
#=================================================
2014-08-18 22:05:31 +02:00
2017-03-01 19:37:00 +01:00
SETUP_SOURCE # Télécharge la source, décompresse et copie dans $final_path
2014-08-18 22:05:31 +02:00
2017-03-01 19:37:00 +01:00
#=================================================
# NGINX CONFIGURATION
#=================================================
# Copie le fichier de config nginx
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf
# Modifie les variables dans le fichier de configuration nginx
sudo sed -i "s@__PATH__@$path_url@g" /etc/nginx/conf.d/$domain.d/$app.conf
2015-11-22 14:37:01 +01:00
sudo sed -i "s@__FINALPATH__@$final_path@g" /etc/nginx/conf.d/$domain.d/$app.conf
2016-06-25 13:08:00 +02:00
sudo sed -i "s@__NAMETOCHANGE__@$app@g" /etc/nginx/conf.d/$domain.d/$app.conf
2015-11-22 14:37:01 +01:00
2017-03-01 19:37:00 +01:00
#=================================================
# CREATE DEDICATED USER
#=================================================
2015-11-22 14:37:01 +01:00
2017-03-01 19:37:00 +01:00
ADD_SYS_USER # Créer un utilisateur système dédié à l'app
#=================================================
# PHP-FPM CONFIGURATION
#=================================================
POOL_FPM # Créer le fichier de configuration du pool php-fpm et le configure.
2014-08-18 22:05:31 +02:00
2017-03-01 19:37:00 +01:00
#=================================================
# SPECIFIC UPGRADE
#=================================================
# RETRIEVE SYNCHRONISATION CODE
#=================================================
2015-11-22 14:37:01 +01:00
2017-03-01 19:37:00 +01:00
code_sync=$(mysql -h localhost -u $db_name -p$db_pwd -s $db_name -e 'SELECT value FROM leed_configuration WHERE `key`="synchronisationCode"' | sed -n 1p)
#=================================================
# SETUP CRON FILE FOR SYNCHRONISATION
#=================================================
2015-11-22 14:37:01 +01:00
sed -i "s@__ADMIN__@$admin@g" ../conf/cron_leed
sed -i "s@__DOMAIN__@$domain@g" ../conf/cron_leed
2017-03-01 19:37:00 +01:00
sed -i "s@__PATH__@$path_url@g" ../conf/cron_leed
2015-11-22 14:37:01 +01:00
sed -i "s@__CODESYNC__@$code_sync@g" ../conf/cron_leed
sudo cp ../conf/cron_leed /etc/cron.d/$app
2017-03-01 19:37:00 +01:00
#=================================================
# SECURING FILES AND DIRECTORIES
#=================================================
# Les fichiers appartiennent à root
sudo chown -R root: $final_path
# www-data doit avoir les droits d'écriture dans plugins, cache et updates
sudo mkdir -p $final_path/cache
sudo chown -R $app $final_path/cache $final_path/plugins $final_path/updates
#=================================================
# UPGRADE WITH CURL
#=================================================
2016-06-25 17:36:49 +02:00
# Vide le cache de leed pour la mise à jour
2016-07-16 13:05:02 +02:00
sudo rm -rf $final_path/cache/*
2016-06-25 13:08:00 +02:00
# Laisse un accès libre pour curl.
2016-12-14 16:08:29 +01:00
ynh_app_setting_set $app unprotected_uris "/"
2016-06-25 13:08:00 +02:00
# Régénère la configuration de SSOwat
sudo yunohost app ssowatconf
# Lance la procédure de mise à jour de leed.
2017-03-01 19:37:00 +01:00
# curl -kL --resolve $domain:443:127.0.0.1 https://$domain$path_url
curl -kL -H "Host: $domain" --resolve $domain:443:127.0.0.1 "https://localhost$path_url"
#=================================================
# GENERIC FINALISATION
#=================================================
# SETUP SSOWAT
#=================================================
2016-06-25 13:08:00 +02:00
2014-08-18 22:05:31 +02:00
# Make app private if necessary
2017-03-01 19:37:00 +01:00
if [ $is_public -eq 0 ];
2014-08-18 22:05:31 +02:00
then
2016-06-25 13:08:00 +02:00
# Retire l'autorisation d'accès à leed
2016-12-14 16:08:29 +01:00
ynh_app_setting_delete $app unprotected_uris
2014-08-18 22:05:31 +02:00
# Rend la page d'actualisation accessible pour le script cron.
2016-12-14 16:08:29 +01:00
ynh_app_setting_set $app skipped_uris "/action.php"
2014-08-18 22:05:31 +02:00
fi
2017-03-01 19:37:00 +01:00
#=================================================
# RELOAD NGINX
#=================================================
2014-08-18 22:05:31 +02:00
sudo service nginx reload