2022-04-02 17:44:57 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# IMPORT GENERIC HELPERS
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
source _common.sh
|
|
|
|
source /usr/share/yunohost/helpers
|
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
#-------------------------------------------------
|
|
|
|
# config_panel.toml settings:
|
2022-08-16 09:47:54 +02:00
|
|
|
|
2024-08-27 20:51:05 +02: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-08-27 20:51:05 +02: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-08-27 20:51:05 +02:00
|
|
|
if [ -z "$admin_email" ]; then
|
|
|
|
admin_email="${admin}@${domain}"
|
|
|
|
ynh_app_setting_set --app=$app --key=admin_email --value="$admin_email"
|
2022-08-16 09:47:54 +02:00
|
|
|
fi
|
2022-05-18 18:11:49 +02:00
|
|
|
|
2024-08-27 20:51:05 +02: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"
|
2024-03-29 00:34:55 +01:00
|
|
|
fi
|
|
|
|
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
# STANDARD UPGRADE STEPS
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
# STOP SYSTEMD SERVICE
|
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Stopping systemd service '$app'..." --weight=5
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_systemd_action --service_name=$app --action="stop" --log_path="$log_file"
|
2024-03-29 00:34:55 +01:00
|
|
|
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
#=================================================
|
|
|
|
# SETUP SYSTEMD
|
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Configuring systemd service '$app'..." --weight=5
|
|
|
|
|
|
|
|
ynh_add_systemd_config --service=$app --template="systemd.service"
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
#=================================================
|
|
|
|
# PYTHON VIRTUALENV
|
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Create and setup Python virtualenv..." --weight=45
|
|
|
|
cp ../conf/requirements.txt "$data_dir/requirements.txt"
|
|
|
|
myynh_setup_python_venv
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
#=================================================
|
|
|
|
# copy config files
|
|
|
|
# ================================================
|
|
|
|
ynh_script_progression --message="Create project configuration files..."
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_add_config --template="gunicorn.conf.py" --destination="$data_dir/gunicorn.conf.py"
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_add_config --template="manage.py" --destination="$data_dir/manage.py"
|
|
|
|
chmod -c +x "$data_dir/manage.py"
|
2024-03-29 00:34:55 +01:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_add_config --template="settings.py" --destination="$data_dir/settings.py"
|
|
|
|
ynh_add_config --template="setup_user.py" --destination="$data_dir/setup_user.py"
|
|
|
|
ynh_add_config --template="urls.py" --destination="$data_dir/urls.py"
|
|
|
|
ynh_add_config --template="wsgi.py" --destination="$data_dir/wsgi.py"
|
2024-03-29 00:34:55 +01:00
|
|
|
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
# MIGRATE PYINVENTORY
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_script_progression --message="migrate/collectstatic/createadmin..." --weight=10
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
cd "$data_dir" || exit
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
# Just for debugging:
|
|
|
|
./manage.py diffsettings
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
./manage.py migrate --no-input
|
|
|
|
./manage.py collectstatic --no-input
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
# Create/update Django superuser (set unusable password, because auth done via SSOwat):
|
|
|
|
./manage.py create_superuser --username="$admin" --email="$(ynh_user_get_info "$admin" mail)"
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
# Check the configuration
|
|
|
|
# This may fail in some cases with errors, etc., but the app works and the user can fix issues later.
|
|
|
|
./manage.py check --deploy || true
|
2022-04-02 17:44:57 +02:00
|
|
|
|
|
|
|
|
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
# SETUP LOGROTATE
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_script_progression --message="Upgrading logrotate configuration..."
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
# Use logrotate to manage app-specific logfile(s)
|
|
|
|
ynh_use_logrotate --logfile="$log_file" --specific_user=$app --non-append
|
2022-04-04 17:18:41 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
#=================================================
|
|
|
|
# GENERIC FINALIZATION
|
|
|
|
#=================================================
|
|
|
|
# SECURE FILES AND DIRECTORIES
|
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Set file permissions..."
|
|
|
|
myynh_fix_file_permissions
|
2022-04-02 17:44:57 +02:00
|
|
|
|
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
# Start the app server via systemd
|
2022-04-02 17:44:57 +02:00
|
|
|
#=================================================
|
2024-08-27 20:51:05 +02:00
|
|
|
ynh_script_progression --message="Starting systemd service '$app'..." --weight=5
|
2022-04-02 17:44:57 +02:00
|
|
|
|
2024-08-27 20:51:05 +02:00
|
|
|
yunohost service add --description $app $app
|
|
|
|
ynh_systemd_action --service_name=$app --action="start" --log_path="$log_file"
|
2022-04-02 17:44:57 +02:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# END OF SCRIPT
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
ynh_script_progression --message="Upgrade of $app completed" --last
|