101 lines
3.0 KiB
Bash
Executable File
101 lines
3.0 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -eu -o pipefail
|
|
|
|
if [[ ${EUID} -ne 0 ]]; then
|
|
echo "This script should be run as root." > /dev/stderr
|
|
exit 1
|
|
fi
|
|
|
|
readonly BOX_SRC_DIR=/home/yellowtent/box
|
|
readonly DATA_DIR=/home/yellowtent/data
|
|
readonly CLOUDRON_CONF=/home/yellowtent/configs/cloudron.conf
|
|
|
|
readonly script_dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
readonly json="${script_dir}/../../node_modules/.bin/json"
|
|
readonly curl="curl --fail --connect-timeout 20 --retry 10 --retry-delay 2 --max-time 300"
|
|
|
|
readonly is_update=$([[ -f "${CLOUDRON_CONF}" ]] && echo "yes" || echo "no")
|
|
|
|
# create a provision file for testing. %q escapes args. %q is reused as much as necessary to satisfy $@
|
|
(echo -e "#!/bin/bash\n"; printf "%q " "${script_dir}/installer.sh" "$@") > /home/yellowtent/provision.sh
|
|
chmod +x /home/yellowtent/provision.sh
|
|
|
|
arg_source_tarball_url=""
|
|
arg_data=""
|
|
arg_data_file=""
|
|
|
|
args=$(getopt -o "" -l "sourcetarballurl:,data:,data-file:" -n "$0" -- "$@")
|
|
eval set -- "${args}"
|
|
|
|
while true; do
|
|
case "$1" in
|
|
--sourcetarballurl) arg_source_tarball_url="$2";;
|
|
--data) arg_data="$2";;
|
|
--data-file) arg_data_file="$2";;
|
|
--) break;;
|
|
*) echo "Unknown option $1"; exit 1;;
|
|
esac
|
|
|
|
shift 2
|
|
done
|
|
|
|
if [[ ! -z ${arg_data_file} ]]; then
|
|
arg_data=$(cat "${arg_data_file}")
|
|
fi
|
|
|
|
box_src_tmp_dir=$(mktemp -dt box-src-XXXXXX)
|
|
echo "Downloading box code from ${arg_source_tarball_url} to ${box_src_tmp_dir}"
|
|
|
|
for try in `seq 1 10`; do
|
|
if $curl -L "${arg_source_tarball_url}" | tar -zxf - -C "${box_src_tmp_dir}"; then break; fi
|
|
echo "Failed to download source tarball, trying again"
|
|
sleep 5
|
|
done
|
|
|
|
if [[ ${try} -eq 10 ]]; then
|
|
echo "Release tarball download failed"
|
|
exit 3
|
|
fi
|
|
|
|
# ensure ownership baked into the tarball is overwritten
|
|
chown -R root.root "${box_src_tmp_dir}"
|
|
|
|
for try in `seq 1 10`; do
|
|
# for reasons unknown, the dtrace package will fail. but rebuilding second time will work
|
|
|
|
# We need --unsafe-perm as we run as root and the folder is owned by root,
|
|
# however by default npm drops privileges for npm rebuild
|
|
# https://docs.npmjs.com/misc/config#unsafe-perm
|
|
if cd "${box_src_tmp_dir}" && npm rebuild --unsafe-perm; then break; fi
|
|
echo "Failed to rebuild, trying again"
|
|
sleep 5
|
|
done
|
|
|
|
if [[ ${try} -eq 10 ]]; then
|
|
echo "npm rebuild failed"
|
|
exit 4
|
|
fi
|
|
|
|
if [[ "${is_update}" == "yes" ]]; then
|
|
echo "Setting up update splash screen"
|
|
"${box_src_tmp_dir}/setup/splashpage.sh" --data "${arg_data}" # show splash from new code
|
|
${BOX_SRC_DIR}/setup/stop.sh # stop the old code
|
|
fi
|
|
|
|
# ensure we are not inside the source directory, which we will remove now
|
|
cd /root
|
|
|
|
# switch the codes
|
|
rm -rf "${BOX_SRC_DIR}"
|
|
mv "${box_src_tmp_dir}" "${BOX_SRC_DIR}"
|
|
chown -R yellowtent.yellowtent "${BOX_SRC_DIR}"
|
|
|
|
# create a start file for testing. %q escapes args
|
|
(echo -e "#!/bin/bash\n"; printf "%q " "${BOX_SRC_DIR}/setup/start.sh" --data "${arg_data}") > /home/yellowtent/setup_start.sh
|
|
chmod +x /home/yellowtent/setup_start.sh
|
|
|
|
echo "Calling box setup script"
|
|
"${BOX_SRC_DIR}/setup/start.sh" --data "${arg_data}"
|
|
|