diff --git a/manifest.toml b/manifest.toml index 77e74b2..b3424ff 100644 --- a/manifest.toml +++ b/manifest.toml @@ -6,7 +6,7 @@ id = "flohmarkt" name = "flohmarkt" description.en = "A decentral federated small ads platform" -version = "0.0~ynh1" +version = "0.0~ynh2" maintainers = ["Chris Vogel"] @@ -109,8 +109,8 @@ ram.runtime = "100M" # This will pre-fetch the asset which can then be deployed during the install/upgrade scripts with : # ynh_setup_source --dest_dir="$install_dir" # You can also define other assets than "main" and add --source_id="foobar" in the previous command - url = "https://codeberg.org/flohmarkt/flohmarkt/archive/490a748cc3a6698c8a6400df3fa9cfdcf4fd76da.tar.gz" - sha256 = "45d40fb96c9997502755939d0ba6bac9df39d3ca30d271be01b69202b88839fb" + url = "https://codeberg.org/flohmarkt/flohmarkt/archive/0edd928adb76d72ecad2f768f25a8cc89f0c2eb1.tar.gz" + sha256 = "68978e04077d12c54f1b574c6da11c368c9da37f453e6768520deac88ea21855" # These infos are used by https://github.com/YunoHost/apps/blob/master/tools/autoupdate_app_sources/autoupdate_app_sources.py # to auto-update the previous asset urls and sha256sum + manifest version diff --git a/scripts/install b/scripts/install index a1885cf..b9a971f 100755 --- a/scripts/install +++ b/scripts/install @@ -57,11 +57,6 @@ chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini systemctl restart couchdb systemctl status couchdb -# INTEGRATE SERVICE IN YUNOHOST -# would this work? couchdb brings its own systemd.service... -# ynh_script_progression --message="Integrating service in YunoHost..." --weight=1 -# yunohost service add $app --description="war mal couchdb" --log="/var/log/$app/$app.log" - # get flohmarkt ynh_setup_source --dest_dir="$install_dir/$app/" @@ -105,7 +100,6 @@ ynh_add_config --template="../conf/flohmarkt.conf" --destination="$install_dir/$ # SETUP LOGROTATE ynh_script_progression --message="Configuring log rotation..." --weight=2 # Use logrotate to manage application logfile(s) -# @@ how does this know where the logfiles are? ynh_use_logrotate # NGINX CONFIGURATION @@ -130,6 +124,4 @@ ynh_systemd_action --service_name=$app --action="start" # # Create a dedicated Fail2Ban config # ynh_add_fail2ban_config --logpath="/var/log/couchdb/couchdb.log" --failregex="[warning] .*couch_httpd_auth: Authentication failed for user .+ from " --max_retry=5 -# @@ logrotation - ynh_script_progression --message="Installation of $app completed" --last diff --git a/scripts/upgrade b/scripts/upgrade index 7c5f1a6..33362ef 100644 --- a/scripts/upgrade +++ b/scripts/upgrade @@ -1,90 +1,104 @@ #!/bin/bash -#================================================= -# GENERIC START -#================================================= -# IMPORT GENERIC HELPERS -#================================================= - source _common.sh source /usr/share/yunohost/helpers +# UPGRADE_PACKAGE if only the YunoHost package has changed +# UPGRADE_APP if the upstream app version has changed +# DOWNGRADE +# UPGRADE_SAME upgrade_type=$(ynh_check_app_version_changed) -#================================================= -# NGINX CONFIGURATION -#================================================= -ynh_script_progression --message="Upgrading NGINX web server configuration..." --weight=2 +ynh_script_progression --message="Stopping flohmarkt and CouchDB..." --weight=5 +# stop flohmarkt +ynh_systemd_action --service_name=$app --action="stop" +# stop couchdb +ynh_systemd_action --service_name=couchdb --action="stop" -# Create a dedicated NGINX config -ynh_add_nginx_config +# upgrade couchdb +ynh_script_progression --message="Upgrading CouchDB..." --weight=50 +echo "\ +couchdb couchdb/mode select standalone +couchdb couchdb/mode seen true +couchdb couchdb/bindaddress string 127.0.0.1 +couchdb couchdb/bindaddress seen true +couchdb couchdb/cookie string $couchdb_magic_cookie +couchdb couchdb/adminpass password $password_couchdb_admin +couchdb couchdb/adminpass seen true +couchdb couchdb/adminpass_again password $password_couchdb_admin +couchdb couchdb/adminpass_again seen true" | debconf-set-selections +DEBIAN_FRONTEND=noninteractive # apt-get install -y --force-yes couchdb +ynh_install_extra_app_dependencies \ + --repo="deb https://apache.jfrog.io/artifactory/couchdb-deb/ $(lsb_release -c -s) main" \ + --key="https://couchdb.apache.org/repo/keys.asc" \ + --package="couchdb" -#================================================= -# SPECIFIC UPGRADE -#================================================= -# UPGRADING COUCHDB -#================================================= +# upgrade couchdb config +ynh_script_progression --message="Updating couchdb configuration file..." --weight=1 +ynh_add_config --template="../conf/05-flohmarkt.ini" --destination="/opt/couchdb/etc/local.d/05-flohmarkt.ini" +chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini +chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini -if [ "$upgrade_type" == "UPGRADE_APP" ] -then - ynh_script_progression --message="Upgrading CouchDB..." --weight=50 +# start couchdb to pick up changes +ynh_script_progression --message="Starting couchdb..." --weight=1 +ynh_systemd_action --service_name=couchdb --action="start" +systemctl status couchdb - echo "\ - couchdb couchdb/mode select standalone - couchdb couchdb/mode seen true - couchdb couchdb/bindaddress string 127.0.0.1 - couchdb couchdb/bindaddress seen true - couchdb couchdb/cookie string $password - couchdb couchdb/adminpass password $password - couchdb couchdb/adminpass seen true - couchdb couchdb/adminpass_again password $password - couchdb couchdb/adminpass_again seen true" | debconf-set-selections - DEBIAN_FRONTEND=noninteractive # apt-get install -y --force-yes couchdb +# install upgrade for flohmarkt +ynh_script_progression --message="Upgrading flohmarkt..." --weight=4 +ynh_setup_source --dest_dir="$install_dir/$app/" - ynh_install_extra_app_dependencies \ - --repo="deb https://apache.jfrog.io/artifactory/couchdb-deb/ $(lsb_release -c -s) main" \ - --key="https://couchdb.apache.org/repo/keys.asc" \ - --package="couchdb" -fi +ynh_script_progression --message="Upgrading flohmarkt python dependencies..." --weight=5 +# upgrade python environment / install new dependencies +( + set +o nounset + source "$install_dir/venv/bin/activate" + set -o nounset + set -x + $install_dir/venv/bin/python3 -m ensurepip + $install_dir/venv/bin/pip3 install -r "$install_dir/$app/requirements.txt" +) -#================================================= -# UPDATE A CONFIG FILE -#================================================= -ynh_script_progression --message="Updating a configuration file..." --weight=1 +# upgrade flohmarkt.conf +ynh_script_progression --message="Upgrading flohmarkt configuration..." --weight=1 +ynh_add_config --template="../conf/flohmarkt.conf" --destination="$install_dir/$app/flohmarkt.conf" -ynh_add_config --template="../conf/05-flohmarkt.ini" --destination="$install_dir/etc/local.d/05-flohmarkt.ini" +ynh_script_progression --message="Upgrading flohmarkt couchdb..." --weight=10 +# run initialize_couchdb.py +( + set +o nounset + source "$install_dir/venv/bin/activate" + set -o nounset + cd "$install_dir/$app" + # initialize_couchdb seems to re-try on connect problems endlessly blocking the yunohost api + # give it 45 seconds to finish and then fail + # https://codeberg.org/ChriChri/flohmarkt_ynh/issues/13 + timeout 45 python3 initialize_couchdb.py $password_couchdb_admin $password_couchdb_flohmarkt +) -chmod 750 "$install_dir" -chmod -R o-rwx "$install_dir" -chown -R "$app:$app" "$install_dir" +# systemd service upgrade +ynh_script_progression --message="Upgrading flohmarkt systemd service..." --weight=1 +ynh_add_systemd_config +# INTEGRATE SERVICE IN YUNOHOST +ynh_script_progression --message="Integrating service in YunoHost..." --weight=2 +yunohost service add $app --description="A decentral federated small advertisement platform" --log="/var/log/$app/$app.log" -#================================================= -# GENERIC FINALIZATION -#================================================= -# SETUP LOGROTATE -#================================================= +# upgrade logrotate ynh_script_progression --message="Upgrading logrotate configuration..." --weight=1 - # Use logrotate to manage app-specific logfile(s) ynh_use_logrotate --non-append -#================================================= -# INTEGRATE SERVICE IN YUNOHOST -#================================================= -ynh_script_progression --message="Integrating service in YunoHost..." --weight=2 +# upgrade nginx configuration +ynh_script_progression --message="Upgrading NGINX web server configuration..." --weight=2 +ynh_add_nginx_config -yunohost service add $app --description="A decentral federated small advertisement platform" --log="/var/log/$app/$app.log" - -#================================================= # UPGRADE FAIL2BAN -#================================================= -ynh_script_progression --message="Reconfiguring Fail2Ban..." --weight=3 - +# ynh_script_progression --message="Reconfiguring Fail2Ban..." --weight=3 # Create a dedicated Fail2Ban config -ynh_add_fail2ban_config --logpath="/var/log/couchdb/couchdb.log" --failregex="[warning] .*couch_httpd_auth: Authentication failed for user .+ from " --max_retry=5 +# ynh_add_fail2ban_config --logpath="/var/log/couchdb/couchdb.log" --failregex="[warning] .*couch_httpd_auth: Authentication failed for user .+ from " --max_retry=5 -#================================================= -# END OF SCRIPT -#================================================= +# start flohmarkt +ynh_script_progression --message="Starting flohmarkt..." --weight=3 +ynh_systemd_action --service_name=$app --action="start" --line_match="INFO: Application startup complete." ynh_script_progression --message="Upgrade of $app completed" --last