2016-10-31 14:54:48 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
set -eu -o pipefail
|
|
|
|
|
|
|
|
|
|
if [[ ${EUID} -ne 0 ]]; then
|
|
|
|
|
echo "This script should be run as root." > /dev/stderr
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2016-11-01 18:13:45 +01:00
|
|
|
readonly UPDATER_SERVICE="cloudron-updater"
|
2018-11-15 14:54:12 +01:00
|
|
|
readonly DATETIME=`date '+%Y-%m-%d_%H-%M-%S'`
|
2018-11-30 16:00:47 -08:00
|
|
|
readonly LOG_FILE="/home/yellowtent/platformdata/logs/updater/cloudron-updater-${DATETIME}.log"
|
2016-10-31 14:54:48 +01:00
|
|
|
|
|
|
|
|
if [[ $# == 1 && "$1" == "--check" ]]; then
|
|
|
|
|
echo "OK"
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
|
2018-10-26 09:49:52 -07:00
|
|
|
if [[ $# != 1 ]]; then
|
|
|
|
|
echo "sourceDir argument required"
|
2016-10-31 14:54:48 +01:00
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2018-08-01 15:38:40 -07:00
|
|
|
readonly source_dir="${1}"
|
2016-10-31 14:54:48 +01:00
|
|
|
|
2018-08-01 15:38:40 -07:00
|
|
|
echo "Updating Cloudron with ${source_dir}"
|
2016-10-31 14:54:48 +01:00
|
|
|
|
2018-08-01 15:38:40 -07:00
|
|
|
readonly installer_path="${source_dir}/scripts/installer.sh"
|
2016-12-23 18:28:18 -08:00
|
|
|
|
2016-11-02 10:56:53 +01:00
|
|
|
echo "=> reset service ${UPDATER_SERVICE} status in case it failed"
|
2016-11-02 11:13:12 +01:00
|
|
|
if systemctl reset-failed "${UPDATER_SERVICE}"; then
|
|
|
|
|
echo "=> service has failed earlier"
|
|
|
|
|
fi
|
2016-11-02 10:56:53 +01:00
|
|
|
|
2018-11-15 10:52:31 -08:00
|
|
|
# StandardError will follow StandardOutput in default inherit mode. https://www.freedesktop.org/software/systemd/man/systemd.exec.html
|
2018-11-30 21:18:01 -08:00
|
|
|
echo "=> Run installer.sh as ${UPDATER_SERVICE}."
|
2018-11-15 14:54:12 +01:00
|
|
|
if ! systemd-run --unit "${UPDATER_SERVICE}" -p "StandardOutput=file:${LOG_FILE}" ${installer_path}; then
|
2016-10-31 14:54:48 +01:00
|
|
|
echo "Failed to install cloudron. See ${LOG_FILE} for details"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2016-11-01 18:13:45 +01:00
|
|
|
|
2018-11-30 21:18:01 -08:00
|
|
|
echo "=> service ${UPDATER_SERVICE} started. see logs at ${LOG_FILE}"
|
2016-11-02 11:13:12 +01:00
|
|
|
|
|
|
|
|
while true; do
|
2018-11-30 21:18:01 -08:00
|
|
|
if systemctl is-failed "${UPDATER_SERVICE}" >/dev/null 2>&1; then
|
2016-11-02 11:13:12 +01:00
|
|
|
echo "=> ${UPDATER_SERVICE} has failed"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2018-11-30 21:18:01 -08:00
|
|
|
echo "${UPDATER_SERVICE} is still active. will check in 5 seconds"
|
|
|
|
|
|
2016-11-02 11:13:12 +01:00
|
|
|
sleep 5
|
|
|
|
|
# this loop will stop once the update process stopped the box unit and thus terminating this child process
|
|
|
|
|
done
|