django_example_ynh/scripts/install

157 lines
5.4 KiB
Text
Raw Permalink Normal View History

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"
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
#=================================================
# 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
#=================================================
# MIGRATE / COLLECTSTATIC / CREATEADMIN
2020-12-23 19:53:13 +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
# Just for debugging:
./manage.py diffsettings
2020-12-23 19:53:13 +01:00
./manage.py migrate --no-input
./manage.py collectstatic --no-input
# 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)"
# 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