diff options
| author | magikcypress <cyp@rouquin.me> | 2017-04-19 02:37:40 +0200 |
|---|---|---|
| committer | magikcypress <cyp@rouquin.me> | 2017-04-19 02:37:40 +0200 |
| commit | 82fa072ce64ccf0307a650a66c5d578fb749d40f (patch) | |
| tree | 199279340ca38a02a2f501f080beed2617074225 /scripts/restore | |
| parent | 128aa107baf2bbf713a6af43182e1bc6d9c7a1a7 (diff) | |
| download | mastodon_ynh-82fa072ce64ccf0307a650a66c5d578fb749d40f.tar.gz mastodon_ynh-82fa072ce64ccf0307a650a66c5d578fb749d40f.tar.bz2 mastodon_ynh-82fa072ce64ccf0307a650a66c5d578fb749d40f.zip | |
[fix] Secret key install + backup correct + restore (need test restore)
Diffstat (limited to 'scripts/restore')
| -rw-r--r-- | scripts/restore | 41 |
1 files changed, 36 insertions, 5 deletions
diff --git a/scripts/restore b/scripts/restore index f79ee1c..f754d81 100644 --- a/scripts/restore +++ b/scripts/restore @@ -4,12 +4,19 @@ # Exit on command errors and treat unset variables as an error set -eu -# The parameter $app is the id of the app instance ex: ynhexample__2 -app=$YNH_APP_INSTANCE_NAME - +if [ ! -e .fonctions ]; then + # Get file fonction if not been to the current directory + sudo cp ../settings/scripts/.fonctions ./.fonctions + sudo chmod a+rx .fonctions +fi +# Loads the generic functions usually used in the script +source .fonctions # Source app helpers source /usr/share/yunohost/helpers +# The parameter $app is the id of the app instance ex: ynhexample__2 +app=$YNH_APP_INSTANCE_NAME + # Get old parameter of the app domain=$(ynh_app_setting_get $app domain) path=$(ynh_app_setting_get $app path) @@ -30,7 +37,7 @@ nginx_conf="/etc/nginx/conf.d/${domain}.d/${app}.conf" if [ -f $nginx_conf ]; then ynh_die "The NGINX configuration already exists at '${nginx_conf}'. You should safely delete it before restoring this app." - +fi # Check configuration files php-fpm crontab_conf="/etc/cron.d/${app}" if [ -f $crontab_conf ]; then @@ -55,6 +62,9 @@ if [ -f "${streaming_systemd}" ]; then You should safely delete it before restoring this app." fi +# Create user unix +sudo adduser $app --home /opt/$app --gecos "First Last,RoomNumber,WorkPhone,HomePhone" --disabled-password --disabled-login + # Restore sources & data sudo cp -a ./sources "$final_path" @@ -74,9 +84,12 @@ sudo su -c "psql" postgres <<< \ # Restore db ynh_psql_create_db_without_password "$app" sudo su - postgres <<COMMANDS -pg_dump -U mastodon mastodon_production < ./mastodon_db.sql +pg_dump --role=mastodon -U postgres --no-password mastodon < $YNH_APP_BACKUP_DIR/mastodon_db.sql COMMANDS +# Create symlink for ruby +sudo ln -s /opt/mastodon/.rbenv/versions/2.4.1/bin/ruby /usr/bin/ruby || true + # Restore Mastodon sudo su - $app <<RCOMMANDS cd ~/live @@ -89,5 +102,23 @@ sudo cp -a ./nginx.conf "$nginx_conf" # Restore crontab sudo cp -a ./cron.conf "$crontab_conf" +sudo cp ../conf/mastodon-web.service /etc/systemd/system/mastodon-web.service +sudo chown root: /etc/systemd/system/mastodon-web.service +sudo cp ../conf/mastodon-sidekiq.service /etc/systemd/system/mastodon-sidekiq.service +sudo chown root: /etc/systemd/system/mastodon-sidekiq.service +sudo cp ../conf/mastodon-streaming.service /etc/systemd/system/mastodon-streaming.service +sudo chown root: /etc/systemd/system/mastodon-streaming.service + +sudo systemctl daemon-reload +sudo systemctl enable /etc/systemd/system/mastodon-*.service +sudo systemctl start mastodon-web.service mastodon-sidekiq.service mastodon-streaming.service +# debug +sudo systemctl status mastodon-web.service mastodon-sidekiq.service mastodon-streaming.service + +# Add service YunoHost +sudo yunohost service add mastodon-web +sudo yunohost service add mastodon-sidekiq +sudo yunohost service add mastodon-streaming + # Reload services sudo systemctl reload nginx
\ No newline at end of file |
