services-garbaye/podman-matrix/10_install.sh

65 lines
2.1 KiB
Bash
Raw Normal View History

2021-06-14 10:42:59 +00:00
#!/usr/bin/env bash
ABSDIR="$( dirname "$(readlink -f -- "$0")" )"
source ${ABSDIR}/../functions.sh
source ${ABSDIR}/vars.sh
ensure_pwd_is_scriptdir
ensure_not_root
ensure_pod_not_exists ${pod_name}
ensure_variables_are_defined "$envvars"
if ! podman volume exists ${confvolume} ; then
2021-06-14 10:42:59 +00:00
echo "Error : conf volume ${confvolume} does not exists. Consider running 05_freshinstall.sh if this is the first install."
exit 1
fi
if ! podman volume exists ${dbvolume} ; then
2021-06-14 10:42:59 +00:00
echo "Error : conf volume ${dbvolume} does not exists. Consider running 05_freshinstall.sh if this is the first install."
exit 1
fi
2023-07-29 13:51:24 +00:00
cat <<EOT >> .env
POSTGRES_PASSWORD=${GARBAYE_MATRIX_POSTGRES_PASSWORD}
POSTGRES_USER=synapse
POSTGRES_DB=synapse
2023-07-29 13:51:24 +00:00
POSTGRES_INITDB_ARGS=--encoding=UTF8 --locale=C
EOT
export postgres_image
export postgres_version
export synapse_image
export synapse_version
export listen_if
export listen_port
if ! podman image exists ${synapse_image}:${synapse_version}; then
2022-11-13 13:08:31 +00:00
podman image pull ${synapse_image}:${synapse_version} || exit 1
fi
podman image pull ${postgres_image}:${postgres_version} &&
2023-07-29 13:51:24 +00:00
podman-compose --pod-args="--infra=true --infra-name=${project_name}_infra --share=" --podman-run-args "--requires=${project_name}_infra --env-file .env" up -d &&
2023-08-10 21:32:42 +00:00
end=$((SECONDS+120))
2023-07-29 13:51:24 +00:00
while [ $SECONDS -lt $end ]; do
sleep 1
2023-08-12 11:54:12 +00:00
if check_container_running ${container_name}; then
podman logs ${container_name} 2>&1 | grep -qe 'Preparing for databases' &&
2023-07-29 13:51:24 +00:00
break
else
2023-08-12 11:54:12 +00:00
podman logs ${container_name} 2>&1 | grep -qe 'psycopg2.OperationalError: could not connect to server: Connection refused' &&
podman healthcheck run ${db_container_name} &&
2023-07-29 13:51:24 +00:00
echo "Oops, synapse didn't wait for PostgreSQL, restarting"
2023-08-12 11:54:12 +00:00
podman start ${container_name}
2023-07-29 13:51:24 +00:00
fi
done &&
2023-08-12 11:54:12 +00:00
podman container wait --condition=running ${container_name} &&
2022-02-12 18:09:02 +00:00
echo -n "Waiting for background tasks to end... " &&
2023-08-12 11:54:12 +00:00
( podman container logs --tail=50 -f ${container_name} 2>&1 & ) | grep -q 'No more background updates to do' &&
echo "OK." || retval=false
2022-02-12 18:09:02 +00:00
podman pod stop ${pod_name} &&
2023-08-12 11:54:12 +00:00
echo "Done. Pod stopped."
2023-07-29 13:51:24 +00:00
shred -u .env
2023-08-12 11:54:12 +00:00
eval "$retval"