2020-12-23 19:53:13 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# IMPORT GENERIC HELPERS
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
source _common.sh
|
|
|
|
source /usr/share/yunohost/helpers
|
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# Install parameters are automatically saved as settings
|
|
|
|
#
|
|
|
|
# Settings are automatically loaded as bash variables
|
|
|
|
# in every app script context, therefore typically these will exist:
|
|
|
|
# - $domain
|
|
|
|
# - $path
|
|
|
|
# - $language
|
|
|
|
# ... etc
|
|
|
|
#
|
|
|
|
# Resources defined in the manifest are provisioned prior to this script
|
|
|
|
# and corresponding settings are also available, such as:
|
|
|
|
# - $install_dir
|
|
|
|
# - $port
|
|
|
|
# - $db_name
|
|
|
|
# ...
|
|
|
|
|
|
|
|
#
|
|
|
|
# $app is the app id (i.e. 'example' for first install,
|
|
|
|
# or 'example__2', '__3', ... for multi-instance installs)
|
|
|
|
#
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# SETTINGS
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Storing installation settings..."
|
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# Logging:
|
|
|
|
log_file="/var/log/$app/$app.log"
|
|
|
|
ynh_app_setting_set --app=$app --key=log_file --value="$log_file"
|
2022-08-14 13:59:26 +02:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# Redis:
|
2020-12-23 19:53:13 +01:00
|
|
|
redis_db=$(ynh_redis_get_free_db)
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=redis_db --value="$redis_db"
|
2022-08-15 09:01:53 +02:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# App settings:
|
|
|
|
ynh_app_setting_set --app=$app --key=default_from_email --value="$default_from_email"
|
|
|
|
ynh_app_setting_set --app=$app --key=admin_email --value="$admin_email"
|
|
|
|
ynh_app_setting_set --app=$app --key=debug_enabled --value="$debug_enabled"
|
|
|
|
ynh_app_setting_set --app=$app --key=log_level --value="$log_level"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
# CHECK IF THE APP CAN BE INSTALLED WITH THESE ARGS
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_script_progression --message="Validating installation parameters..."
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
mkdir -p "$install_dir/media" "$install_dir/static"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
# SETUP LOG FILE
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_script_progression --message="Setup logging..."
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
myynh_setup_log_file
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# Use logrotate to manage application logfile(s)
|
|
|
|
ynh_use_logrotate --logfile="$log_file" --specific_user=$app
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2022-08-14 19:30:06 +02:00
|
|
|
# PYTHON VIRTUALENV
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_script_progression --message="Create and setup Python virtualenv..." --weight=45
|
|
|
|
cp ../conf/requirements.txt "$data_dir/requirements.txt"
|
|
|
|
myynh_setup_python_venv
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# copy config files
|
|
|
|
# ================================================
|
2022-08-24 08:04:05 +02:00
|
|
|
ynh_script_progression --message="Create $app configuration files..."
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_add_config --template="gunicorn.conf.py" --destination="$data_dir/gunicorn.conf.py"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_add_config --template="manage.py" --destination="$data_dir/manage.py"
|
|
|
|
chmod -c +x "$data_dir/manage.py"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +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"
|
2022-08-14 17:22:59 +02:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
touch "$data_dir/local_settings.py"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2021-02-28 10:56:42 +01:00
|
|
|
# MIGRATE / COLLECTSTATIC / CREATEADMIN
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2021-02-28 10:56:42 +01:00
|
|
|
ynh_script_progression --message="migrate/collectstatic/createadmin..." --weight=10
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
cd "$data_dir" || exit
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2022-04-02 20:12:49 +02:00
|
|
|
# Just for debugging:
|
|
|
|
./manage.py diffsettings
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2022-04-02 20:12:49 +02:00
|
|
|
./manage.py migrate --no-input
|
|
|
|
./manage.py collectstatic --no-input
|
2020-12-29 10:51:43 +01:00
|
|
|
|
2022-04-02 20:12:49 +02:00
|
|
|
# Create/update Django superuser (set unusable password, because auth done via SSOwat):
|
2022-08-15 09:17:30 +02:00
|
|
|
./manage.py create_superuser --username="$admin" --email="$(ynh_user_get_info "$admin" mail)"
|
2022-04-02 20:12:49 +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
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# INTEGRATE SERVICE IN YUNOHOST
|
|
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Integrating service in YunoHost..."
|
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
yunohost service add $app
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# GENERIC FINALIZATION
|
|
|
|
#=================================================
|
|
|
|
# SECURE FILES AND DIRECTORIES
|
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_script_progression --message="Set file permissions..."
|
|
|
|
myynh_fix_file_permissions
|
2022-01-19 09:11:23 +01:00
|
|
|
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
|
|
|
# SETUP SYSTEMD
|
|
|
|
#=================================================
|
2022-08-24 08:04:05 +02:00
|
|
|
ynh_script_progression --message="Configuring systemd service '$app'..." --weight=5
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# https://yunohost.org/en/packaging_apps_helpers#ynh-add-systemd-config
|
2022-08-14 17:49:27 +02:00
|
|
|
# https://github.com/YunoHost/yunohost/blob/dev/helpers/systemd
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_add_systemd_config --service=$app --template="systemd.service"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2022-08-15 17:15:24 +02:00
|
|
|
# Start the app server via systemd
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2022-08-24 08:04:05 +02:00
|
|
|
ynh_script_progression --message="Starting systemd service '$app'..." --weight=5
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_systemd_action --service_name=$app --action="start" --log_path="$log_file"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
# NGINX CONFIGURATION
|
2020-12-23 19:53:13 +01:00
|
|
|
#=================================================
|
2023-08-20 17:18:17 +02:00
|
|
|
ynh_script_progression --message="Configuring nginx web server..."
|
2020-12-23 19:53:13 +01:00
|
|
|
|
2023-08-20 17:18:17 +02:00
|
|
|
# Create a dedicated nginx config
|
|
|
|
# https://yunohost.org/en/contribute/packaging_apps/helpers
|
|
|
|
# https://github.com/YunoHost/yunohost/blob/dev/helpers/nginx
|
|
|
|
ynh_add_nginx_config "public_path" "port"
|
2020-12-23 19:53:13 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# END OF SCRIPT
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
ynh_script_progression --message="Installation of $app completed" --last
|