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

[enh] Update backup and restore scripts to fit changes

This commit is contained in:
Jérôme Lebleu 2016-05-14 20:50:26 +02:00
parent b6886dcbec
commit 643223ec31
4 changed files with 96 additions and 74 deletions

View file

@ -10,7 +10,6 @@ the SFTP user.
## TODO ## TODO
* Update `upgrade` script and manage upgrading from current official app * Update `upgrade` script and manage upgrading from current official app
* Update `backup` and `restore` scripts
## Links ## Links

View file

@ -1,22 +1,31 @@
#!/bin/bash #!/bin/bash
# The parameter $1 is the backup directory location dedicated to the app # Exit on command errors and treat unset variables as an error
backup_dir=$1 set -eu
# The parameter $2 is theid of the app instance # Get multi-instances specific variables
app=$2 app=$YNH_APP_INSTANCE_NAME
domain=$(sudo yunohost app setting $app domain) # Source app helpers
path=$(sudo yunohost app setting $app path) . /usr/share/yunohost/helpers
user=$(sudo yunohost app setting $app allowed_users)
is_public=$(sudo yunohost app setting $app is_public) # Retrieve app settings
domain=$(ynh_app_setting_get "$app" domain)
path=$(ynh_app_setting_get "$app" path)
mysql_db=$(ynh_app_setting_get "$app" mysql_db)
# Copy the app files # Copy the app files
final_path=/var/www/$app DESTDIR="/var/www/${app}"
sudo mkdir -p ${backup_dir}/var/www ynh_backup "$DESTDIR" "sources" 1
sudo cp -a $final_path "${backup_dir}/var/www/$app"
# Copy the conf files # Copy the conf files
sudo mkdir -p "${backup_dir}/conf" ynh_backup "/etc/nginx/conf.d/${domain}.d/${app}.conf" "conf/nginx.conf"
sudo cp -a /etc/nginx/conf.d/$domain.d/$app.conf "${backup_dir}/conf/nginx.conf" ynh_backup "/etc/php5/fpm/pool.d/${app}.conf" "conf/php-fpm.conf"
sudo cp -a /etc/php5/fpm/pool.d/$app.conf "${backup_dir}/conf/php-fpm.conf"
# Dump the database
if [[ $mysql_db -eq 1 ]]; then
dbname=$app
dbuser=$app
dbpass=$(ynh_app_setting_get "$app" mysqlpwd)
mysqldump -u "$dbuser" -p"$dbpass" --no-create-db "$dbname" > ./dump.sql
fi

View file

@ -43,7 +43,7 @@ Match User ${user}
AllowTcpForwarding no AllowTcpForwarding no
PermitTunnel no PermitTunnel no
X11Forwarding no X11Forwarding no
##<- ${app}" | sudo tee -a /etc/ssh/sshd_config ##<- ${app}" | sudo tee -a /etc/ssh/sshd_config >/dev/null
# Specify the user and the domain in the home page # Specify the user and the domain in the home page
sed -i "s@{DOMAIN}@${domain}@g" ../sources/www/index.html sed -i "s@{DOMAIN}@${domain}@g" ../sources/www/index.html

View file

@ -1,67 +1,81 @@
#!/bin/bash #!/bin/bash
# This restore script is adapted to Yunohost >=2.4
# The parameter $1 is the backup directory location dedicated to the app set -e
backup_dir=$1
# The parameter $2 is the id of the app instance ex: ynhexample__2 # Get multi-instances specific variables
app=$2 app=$YNH_APP_INSTANCE_NAME
# Get old parameter of the app # Source app helpers
domain=$(sudo yunohost app setting $app domain) . /usr/share/yunohost/helpers
path=$(sudo yunohost app setting $app path)
user=$(sudo yunohost app setting $app allowed_users) # Retrieve old app settings
is_public=$(sudo yunohost app setting $app is_public) domain=$(ynh_app_setting_get "$app" domain)
path=$(ynh_app_setting_get "$app" path)
mysql_db=$(ynh_app_setting_get "$app" mysql_db)
password=$(ynh_app_setting_get "$app" password)
user=$(ynh_app_setting_get "$app" user)
# Check domain/path availability # Check domain/path availability
sudo yunohost app checkurl $domain$path -a $app sudo yunohost app checkurl "${domain}${path}" -a "$app" \
if [[ ! $? -eq 0 ]]; then || exit 1
echo "There is already an app on this URL : $domain$path" | sudo tee /dev/stderr
exit 1 # Check destination directory
DESTDIR="/var/www/$app"
[[ -d $DESTDIR ]] && ynh_die \
"The destination directory '$DESTDIR' already exists.\
You should safely delete it before restoring this app."
# Check configuration files
nginx_conf="/etc/nginx/conf.d/${domain}.d/${app}.conf"
[[ -f $nginx_conf ]] && ynh_die \
"The NGINX configuration already exists at '${nginx_conf}'.
You should safely delete it before restoring this app."
phpfpm_conf="/etc/php5/fpm/pool.d/${app}.conf"
[[ -f $phpfpm_conf ]] && ynh_die \
"The PHP FPM configuration already exists at '${phpfpm_conf}'.
You should safely delete it before restoring this app."
# Create the user account
sudo useradd -c "${app} user account" \
-d "$DESTDIR" -M -g www-data "$user" \
|| ynh_die "Unable to create user account"
sudo chpasswd <<< "${user}:${password}"
# Harden SSH connection for the user
echo "##-> ${app}
# Hardening user connection
Match User ${user}
ChrootDirectory %h
ForceCommand internal-sftp
AllowTcpForwarding no
PermitTunnel no
X11Forwarding no
##<- ${app}" | sudo tee -a /etc/ssh/sshd_config >/dev/null
# Restore the app files
sudo cp -a ./sources "$DESTDIR"
sudo chown -hR "${user}:" "$DESTDIR"
# Home directory of the user need to be owned by root to allow
# SFTP connections
sudo chown root: "$DESTDIR"
# Create and restore the database as needed
if [[ $mysql_db -eq 1 ]]; then
dbname=$app
dbuser=$app
dbpass=$(ynh_app_setting_get "$app" mysqlpwd)
ynh_mysql_create_db "$dbname" "$dbuser" "$dbpass"
[[ -f ./dump.sql ]] \
&& ynh_mysql_connect_as "$dbuser" "$dbpass" "$dbname" < ./dump.sql \
|| echo "No MySQL dump has been found" >&2
fi fi
final_path=/var/www/$app # Restore configuration files
if [ -d $final_path ]; then sudo cp -a ./conf/nginx.conf "$nginx_conf"
echo "There is already a directory: $final_path " | sudo tee /dev/stderr sudo cp -a ./conf/php-fpm.conf "$phpfpm_conf"
exit 1
fi
conf=/etc/nginx/conf.d/$domain.d/$app.conf # Reload services
if [ -f $conf ]; then sudo service php5-fpm reload || true
echo "There is already a nginx conf file at this path: $conf " | sudo tee /dev/stderr sudo service nginx reload || true
exit 1 sudo service sshd reload
fi
phpconf=/etc/php5/fpm/pool.d/$app.conf
if [ -f $phpconf ]; then
echo "There is already a php-fpm conf file at this path: $phpconf " | sudo tee /dev/stderr
exit 1
fi
# Restore sources & data
sudo cp -a "${backup_dir}/var/www/$app" $final_path
# Set permissions
sudo chmod 775 -R $final_path/files
sudo chown -hR www-data:www-data $final_path/files
# Restore conf files
sudo cp -a "${backup_dir}/conf/nginx.conf" $conf
sudo cp -a "${backup_dir}/conf/php-fpm.conf" $phpconf
sudo chown root: $phpconf
sudo chmod 644 $phpconf
# Reload Nginx
sudo service nginx reload
sudo killall php5-fpm || echo "PHP-FPM already killed"
sudo service php5-fpm start
# Set ssowat config
if [ "$is_public" = "Yes" ];
then
sudo yunohost app setting $app unprotected_uris -v "/"
fi
sudo yunohost app setting $app protected_uris -v "/admin"
sudo yunohost app ssowatconf