2017-04-10 04:55:10 +02:00
#!/bin/bash
2018-05-01 20:43:05 +02:00
#=================================================
# IMPORT GENERIC HELPERS
#=================================================
2017-04-10 04:55:10 +02:00
2021-04-10 00:18:53 +02:00
# Keep this path for calling _common.sh inside the execution's context of backup and restore scripts
2019-03-19 23:16:12 +01:00
source ../settings/scripts/_common.sh
2024-02-22 19:45:40 +01:00
source ../settings/scripts/ynh_add_swap
2019-04-06 16:08:48 +02:00
source /usr/share/yunohost/helpers
2018-05-01 20:43:05 +02:00
#=================================================
2024-03-24 20:52:46 +01:00
# INSTALL DEPENDENCIES
2018-05-01 20:43:05 +02:00
#=================================================
2024-03-24 20:52:46 +01:00
ynh_script_progression --message="Reinstalling Ruby..." --weight=1
ynh_exec_warn_less ynh_install_ruby --ruby_version="$ruby_version"
2018-05-01 20:43:05 +02:00
2024-03-24 20:52:46 +01:00
ynh_script_progression --message="Reinstalling NodeJS..." --weight=1
ynh_exec_warn_less ynh_install_nodejs --nodejs_version="$nodejs_version"
2018-05-01 20:43:05 +02:00
#=================================================
2019-08-11 15:58:52 +02:00
# ADD SWAP IF NEEDED
2018-05-01 20:43:05 +02:00
#=================================================
2022-01-23 20:06:35 +01:00
ynh_script_progression --message="Adding swap if needed..." --weight=1
2017-04-19 02:37:40 +02:00
2020-05-26 13:18:02 +02:00
total_memory=$(ynh_get_ram --total)
2019-08-11 15:58:52 +02:00
swap_needed=0
2017-05-06 22:30:44 +02:00
2024-02-22 22:04:18 +01:00
if [ $total_memory -lt $memory_needed ]; then
2019-08-11 15:58:52 +02:00
# Need a minimum of 8Go of memory
2024-02-22 22:04:18 +01:00
swap_needed=$(($memory_needed - $total_memory))
2019-08-11 15:58:52 +02:00
fi
2017-05-06 22:30:44 +02:00
2022-01-23 20:06:35 +01:00
ynh_script_progression --message="Adding $swap_needed Mo to swap..." --weight=1
2017-05-06 22:30:44 +02:00
2019-08-11 15:58:52 +02:00
ynh_add_swap --size=$swap_needed
2017-05-06 22:30:44 +02:00
2018-05-01 20:43:05 +02:00
#=================================================
2021-04-10 00:18:53 +02:00
# RESTORE THE APP MAIN DIR
2018-05-01 20:43:05 +02:00
#=================================================
2024-03-24 20:52:46 +01:00
ynh_script_progression --message="Restoring the app main directory..." --weight=1
2021-04-10 00:18:53 +02:00
2024-03-24 20:52:46 +01:00
ynh_restore_file --origin_path="$install_dir"
2017-05-06 22:30:44 +02:00
2024-03-24 20:52:46 +01:00
chmod -R o-rwx "$install_dir"
chown -R "$app:www-data" "$install_dir"
2022-01-10 19:28:30 +01:00
#=================================================
# RESTORE THE POSTGRESQL DATABASE
#=================================================
2024-03-24 20:52:46 +01:00
ynh_script_progression --message="Restoring the PostgreSQL database..." --weight=1
2022-01-10 19:28:30 +01:00
ynh_psql_execute_as_root --sql="ALTER USER $db_user CREATEDB;"
2024-03-24 20:52:46 +01:00
ynh_psql_connect_as --user="$db_user" --password="$db_pwd" --database="$db_name" < ./db.sql
2019-08-11 15:58:52 +02:00
2019-04-06 16:08:48 +02:00
#=================================================
2024-02-22 19:45:40 +01:00
# BUILD APP
2019-04-06 16:08:48 +02:00
#=================================================
2024-03-24 20:52:46 +01:00
ynh_script_progression --message="Rebuilding app..." --weight=1
2019-03-21 20:34:35 +01:00
2024-02-22 19:45:40 +01:00
pushd "$install_dir/live"
2021-03-08 00:45:35 +01:00
ynh_use_ruby
2024-02-22 19:45:40 +01:00
ynh_gem update --system
2021-03-08 00:45:35 +01:00
ynh_gem install bundler --no-document
2024-03-24 20:52:46 +01:00
ynh_exec_as "$app" "$ynh_ruby_load_path" "$ld_preload" bin/bundle install --redownload -j"$(nproc)"
2024-02-15 09:46:11 +01:00
2024-03-24 20:52:46 +01:00
ynh_use_nodejs
2024-05-17 23:52:48 +02:00
# This export might be removed in yunohost 12
export COREPACK_ENABLE_DOWNLOAD_PROMPT=0
2024-02-15 09:46:11 +01:00
corepack enable
2024-05-19 20:52:58 +02:00
COREPACK_ENABLE_DOWNLOAD_PROMPT=0 yarn install
2024-02-15 09:46:11 +01:00
popd
2018-05-01 20:43:05 +02:00
#=================================================
2024-02-22 19:45:40 +01:00
# RESTORE THE PHP-FPM CONFIGURATION
2018-05-01 20:43:05 +02:00
#=================================================
2024-02-22 19:45:40 +01:00
ynh_script_progression --message="Restoring system configurations related to $app..." --weight=1
2018-06-21 04:48:02 +02:00
2024-02-22 19:45:40 +01:00
ynh_restore_file --origin_path="/etc/nginx/conf.d/$domain.d/$app.conf"
2018-05-01 20:43:05 +02:00
2019-05-10 16:34:57 +02:00
ynh_restore_file --origin_path="/etc/systemd/system/$app-web.service"
ynh_restore_file --origin_path="/etc/systemd/system/$app-sidekiq.service"
ynh_restore_file --origin_path="/etc/systemd/system/$app-streaming.service"
2021-02-17 19:22:07 +01:00
systemctl enable "$app-web" "$app-sidekiq" "$app-streaming" --quiet
2018-05-01 20:43:05 +02:00
2021-04-10 00:18:53 +02:00
yunohost service add "$app-web" --description="$app web service"
yunohost service add "$app-sidekiq" --description="$app sidekiq service"
yunohost service add "$app-streaming" --description="$app streaming service"
2018-06-21 04:48:02 +02:00
2024-02-22 19:45:40 +01:00
ynh_restore_file --origin_path="/etc/cron.d/$app"
2018-11-07 05:12:21 +01:00
2024-03-24 20:52:46 +01:00
ynh_restore_file --origin_path="/var/log/$app/"
2023-08-01 04:15:46 +02:00
ynh_restore_file --origin_path="/etc/logrotate.d/$app"
2018-11-07 05:12:21 +01:00
2019-05-10 16:34:57 +02:00
#=================================================
2024-02-22 21:03:26 +01:00
# RELOAD NGINX AND THE APP SERVICE
2018-05-01 20:43:05 +02:00
#=================================================
2024-02-22 19:45:40 +01:00
ynh_script_progression --message="Reloading NGINX web server and $app's service..." --weight=1
2018-11-07 05:12:21 +01:00
2024-03-24 20:52:46 +01:00
ynh_systemd_action --service_name="${app}-web" --action="start" --log_path="/var/log/$app/$app-web.log" --line_match="Listening on"
ynh_systemd_action --service_name="${app}-sidekiq" --action="start" --log_path="/var/log/$app/$app-sidekiq.log" --line_match="Schedules Loaded"
ynh_systemd_action --service_name="${app}-streaming" --action="start" --log_path="/var/log/$app/$app-streaming.log" --line_match="Streaming API now listening"
2018-05-01 20:43:05 +02:00
2019-05-10 16:34:57 +02:00
ynh_systemd_action --service_name=nginx --action=reload
2019-03-18 04:22:38 +01:00
#=================================================
# END OF SCRIPT
#=================================================
2024-02-22 19:45:40 +01:00
ynh_script_progression --message="Restoration completed for $app" --last