#!/bin/bash #================================================= # GENERIC START #================================================= # IMPORT GENERIC HELPERS #================================================= if [ ! -e _common.sh ]; then # Get the _common.sh file if it's not in the current directory cp ../settings/scripts/_common.sh ./_common.sh chmod a+rx _common.sh fi source _common.sh source /usr/share/yunohost/helpers ynh_abort_if_errors #================================================= # LOAD SETTINGS #================================================= app=$YNH_APP_INSTANCE_NAME domain=$(ynh_app_setting_get "$app" domain) path_url=$(ynh_app_setting_get "$app" path) final_path=$(ynh_app_setting_get "$app" final_path) db_name=$(ynh_app_setting_get "$app" db_name) db_pwd=$(ynh_app_setting_get "$app" psqlpwd) #================================================= # CHECK IF THE APP CAN BE RESTORED #================================================= # Check web path availability ynh_webpath_available "$domain" "$path_url" test ! -e "$final_path" || ynh_die "This path already contains a folder" #================================================= # STANDARD RESTORATION STEPS #================================================= # RESTORE THE NGINX CONFIGURATION #================================================= ynh_restore_file "/etc/nginx/conf.d/$domain.d/$app.conf" #================================================= # RESTORE THE APP MAIN DIR #================================================= ynh_restore_file "$final_path" #================================================= # RECREATE THE DEDICATED USER #================================================= # Create the dedicated user (if not existing) ynh_system_user_create "$app" "/home/$app" # Allow bash for our user, so he can use hub chsh --shell /bin/bash "$app" #================================================= # RESTORE USER RIGHTS #================================================= # Restore permissions on app files chown -R "$app": "$final_path" #================================================= # SPECIFIC RESTORATION #================================================= # REINSTALL DEPENDENCIES #================================================= ynh_install_app_dependencies libxml2-dev libxslt-dev libfreetype6-dev \ libjpeg-dev libz-dev libyaml-dev python3-dev python3-pip python3-virtualenv \ postgresql libpq-dev uwsgi uwsgi-plugin-python3 memcached \ mailutils python-celery-common virtualenv redis-server #================================================= # RESTORE THE PostgreSQL DATABASE #================================================= ynh_psql_test_if_first_run ynh_psql_create_db "$db_name" "$db_name" "$db_pwd" ynh_psql_execute_file_as_root ./db.sql "$db_name" #================================================= # RESTORE THE UWSGI MECANICS #================================================= ynh_restore_file "/etc/systemd/system/uwsgi-app@.service" # make sure the folder for sockets exists and set authorizations mkdir -p /var/run/uwsgi/ chown root:www-data /var/run/uwsgi/ chmod -R 775 /var/run/uwsgi/ # make sure the folder for logs exists and set authorizations mkdir -p /var/log/uwsgi/app/ chown root:www-data /var/log/uwsgi/app/ chmod -R 775 /var/log/uwsgi/app/ #================================================= # RESTORE Weblate service #================================================= usermod --append --groups www-data "$app" ynh_restore_file "/etc/uwsgi/apps-available/$app.ini" systemctl daemon-reload systemctl enable "uwsgi-app@$app.service" # Add as a service yunohost service add "uwsgi-app@$app.service" --log "/var/log/uwsgi/app/$app" ynh_restore_file "/etc/systemd/system/$app-celery.service" #================================================= # RESTORE THE CRON FILE #================================================= ynh_restore_file "/etc/cron.d/$app" #================================================= # RESTORE THE HUB BINARY FILE #================================================= ynh_restore_file "/usr/bin/hub" #================================================= # GENERIC FINALIZATION #================================================= # Start weblate #================================================= systemctl start "$app-celery.service" systemctl start "uwsgi-app@$app.service" #================================================= # RELOAD NGINX & uwsgi #================================================= systemctl reload nginx