diff --git a/scripts/backup b/scripts/backup index bf8c112..17b3abc 100644 --- a/scripts/backup +++ b/scripts/backup @@ -1,20 +1,15 @@ #!/bin/bash -# This backup script is adapted to Yunohost >=2.4 +app=ynhexample -# The parameter $1 is the backup directory location dedicated to the app +# The parameter $1 is the backup directory location # which will be compressed afterward -backup_dir=$1 - -# The parameter $2 is theid of the app instance ex: ynhexample__2 -app=$2 +backup_dir=$1/apps/$app +sudo mkdir -p $backup_dir # Backup sources & data -final_path=/var/www/$APP -sudo cp -a $final_path "${backup_dir}/www" +sudo cp -a /var/www/$app/. $backup_dir/sources -# Copy conf file -sudo mkdir -p "${backup_dir}/conf" +# Copy Nginx and YunoHost parameters to make the script "standalone" +sudo cp -a /etc/yunohost/apps/$app/. $backup_dir/yunohost domain=$(sudo yunohost app setting $app domain) -sudo cp -a /etc/nginx/conf.d/$domain.d/$app.conf "${backup_dir}/conf/nginx.conf" - -# Since Yunohost 2.4 no need to backup settings in /etc/yunohost/apps/$app +sudo cp -a /etc/nginx/conf.d/$domain.d/$app.conf $backup_dir/nginx.conf diff --git a/scripts/restore b/scripts/restore index 8faa153..917b5e5 100644 --- a/scripts/restore +++ b/scripts/restore @@ -1,50 +1,16 @@ #!/bin/bash -# This restore script is adapted to Yunohost >=2.4 +app=ynhexample -# The parameter $1 is the backup directory location dedicated to the app -backup_dir=$1 - -# The parameter $2 is the id of the app instance ex: ynhexample__2 -app=$2 - -# Get old parameter of the app -domain=$(sudo yunohost app setting $app domain) -path=$(sudo yunohost app setting $app path) -is_public=$(sudo yunohost app setting $app is_public) - -# Check domain/path availability -sudo yunohost app checkurl $domain$path -a $app -if [[ ! $? -eq 0 ]]; then - echo "There is already an app on this URL : $domain$path" | sudo tee /dev/stderr - exit 1 -fi +# The parameter $1 is the uncompressed restore directory location +backup_dir=$1/apps/$app # Restore sources & data -final_path=/var/www/$app - -if [ -d $final_path ]; then - echo "There is already a directory: $final_path " | sudo tee /dev/stderr - exit 1 -fi -sudo cp -a "${backup_dir}/www" $final_path -sudo chown -R www-data: $final_path - -# Restore conf files -conf=/etc/nginx/conf.d/$domain.d/$app.conf -if [ -f $conf ]; then - echo "There is already a nginx conf file at this path: $conf " | sudo tee /dev/stderr - exit 1 -fi -sudo cp -a "${backup_dir}/conf/nginx.conf" $conf - -# Reload Nginx -sudo service nginx reload - -# Set ssowat config -if [ "$is_public" = "Yes" ]; -then - sudo yunohost app setting $app unprotected_uris -v "/" -fi -sudo yunohost app ssowatconf +sudo cp -a $backup_dir/sources/. /var/www/$app +# Restore Nginx and YunoHost parameters +sudo cp -a $backup_dir/yunohost/. /etc/yunohost/apps/$app +domain=$(sudo yunohost app setting $app domain) +sudo cp -a $backup_dir/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf +# Restart webserver +sudo service nginx reload \ No newline at end of file