django-fritzconnection_ynh/scripts/upgrade

124 lines
4.2 KiB
Text
Raw Permalink Normal View History

2022-04-02 17:44:57 +02:00
#!/bin/bash
#=================================================
# IMPORT GENERIC HELPERS
#=================================================
source _common.sh
source /usr/share/yunohost/helpers
#=================================================
2024-03-28 22:18:52 +01:00
# STOP SYSTEMD SERVICE
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
ynh_script_progression --message="Stopping $app's systemd service..." --weight=1
2022-04-04 17:18:41 +02:00
2024-03-28 22:18:52 +01:00
ynh_systemd_action --service_name="$app" --action="stop" --log_path="/var/log/$app/$app.log"
2022-04-04 17:18:41 +02:00
2024-03-28 22:18:52 +01:00
#=================================================
# ENSURE DOWNWARD COMPATIBILITY
#=================================================
ynh_script_progression --message="Ensuring downward compatibility..." --weight=1
2022-08-16 09:47:54 +02:00
2024-03-28 22:18:52 +01:00
if [ -z "${debug_enabled:-}" ]; then
debug_enabled="0"
ynh_app_setting_set --app="$app" --key=debug_enabled --value="$debug_enabled"
2022-08-16 09:47:54 +02:00
fi
2024-03-28 22:18:52 +01:00
if [ -z "${log_level:-}" ]; then
log_level="WARNING"
ynh_app_setting_set --app="$app" --key=log_level --value="$log_level"
2022-08-16 09:47:54 +02:00
fi
2024-03-28 22:18:52 +01:00
if [ -z "${admin_email:-}" ]; then
admin_email="${admin}@${domain}"
2022-08-16 09:47:54 +02:00
fi
2024-03-28 22:18:52 +01:00
if [ -z "${default_from_email:-}" ]; then
default_from_email="${app}@${domain}"
ynh_app_setting_set --app="$app" --key=default_from_email --value="$default_from_email"
2022-08-16 09:47:54 +02:00
fi
2022-05-18 18:11:49 +02:00
2024-03-29 00:34:55 +01:00
if [ -d "/opt/yunohost/$app" ]; then
if [ -d "$install_dir/app" ]; then
ynh_secure_remove --file="/opt/yunohost/$app"
else
mv "/opt/yunohost/$app" "$install_dir/app"
fi
fi
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
# DOWNLOAD, CHECK AND UNPACK SOURCE
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
ynh_script_progression --message="Upgrading source files..." --weight=1
2022-04-02 17:44:57 +02:00
2024-03-29 00:34:55 +01:00
mkdir -p "$install_dir/"{app,public/media,public/static}
2024-03-28 22:18:52 +01:00
ynh_add_config --template="requirements.txt" --destination="$install_dir/app/requirements.txt"
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_add_config --template="gunicorn.conf.py" --destination="$install_dir/app/gunicorn.conf.py"
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_add_config --template="manage.py" --destination="$install_dir/app/manage.py"
chmod +x "$install_dir/app/manage.py"
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_add_config --template="settings.py" --destination="$install_dir/app/settings.py"
ynh_add_config --template="setup_user.py" --destination="$install_dir/app/setup_user.py"
ynh_add_config --template="urls.py" --destination="$install_dir/app/urls.py"
ynh_add_config --template="wsgi.py" --destination="$install_dir/app/wsgi.py"
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
chown -R "$app:www-data" "$install_dir"
2022-04-02 17:44:57 +02:00
2024-03-29 00:34:55 +01:00
chown -R "$app:www-data" "$install_dir"
mkdir -p "/var/log/$app"
touch "/var/log/$app/$app.log"
chown -R "$app:$app" "/var/log/$app"
2022-04-02 17:44:57 +02:00
#=================================================
2022-08-16 09:47:54 +02:00
# PYTHON VIRTUALENV
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
ynh_script_progression --message="Upgrading $app..." --weight=10
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
_venv_install
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
_build_app
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
pushd "$install_dir/app"
# Just for debugging:
ynh_exec_as "$app" "$venvpy" ./manage.py diffsettings
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_exec_as "$app" "$venvpy" ./manage.py migrate --no-input
ynh_exec_as "$app" "$venvpy" ./manage.py collectstatic --no-input
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
# Create/update Django superuser (set unusable password, because auth done via SSOwat):
ynh_exec_as "$app" "$venvpy" ./manage.py create_superuser --username="$admin" --email="$(ynh_user_get_info "$admin" mail)"
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
# Check the configuration
# This may fail in some cases with errors, etc., but the app works and the user can fix issues later.
ynh_exec_as "$app" "$venvpy" ./manage.py check --deploy || true
popd
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
# REAPPLY SYSTEM CONFIGURATIONS
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
ynh_script_progression --message="Upgrading system configurations related to $app..." --weight=1
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_add_nginx_config
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_add_systemd_config
yunohost service add "$app" --description="Django-fritzconnection server" --log="/var/log/$app/$app.log"
2022-04-04 17:18:41 +02:00
2022-04-02 17:44:57 +02:00
ynh_use_logrotate --non-append
#=================================================
2024-03-28 22:18:52 +01:00
# START SYSTEMD SERVICE
2022-04-02 17:44:57 +02:00
#=================================================
2024-03-28 22:18:52 +01:00
ynh_script_progression --message="Starting $app's systemd service..." --weight=1
2022-04-02 17:44:57 +02:00
2024-03-28 22:18:52 +01:00
ynh_systemd_action --service_name="$app" --action="start" --log_path="/var/log/$app/$app.log"
2022-04-02 17:44:57 +02:00
#=================================================
# END OF SCRIPT
#=================================================
ynh_script_progression --message="Upgrade of $app completed" --last