#!/usr/bin/env bash set -e wait_for_postgres() { attempt_num=1 max_attempts=5 echo "Waiting for PostgreSQL to start..." host="${PAPERLESS_DBHOST:=localhost}" port="${PAPERLESS_DBPORT:=5342}" while [ ! "$(pg_isready -h $host -p $port)" ]; do if [ $attempt_num -eq $max_attempts ]; then echo "Unable to connect to database." exit 1 else echo "Attempt $attempt_num failed! Trying again in 5 seconds..." fi attempt_num=$(("$attempt_num" + 1)) sleep 5 done } wait_for_redis() { # We use a Python script to send the Redis ping # instead of installing redis-tools just for 1 thing if ! python3 /sbin/wait-for-redis.py; then exit 1 fi } migrations() { ( # flock is in place to prevent multiple containers from doing migrations # simultaneously. This also ensures that the db is ready when the command # of the current container starts. flock 200 echo "Apply database migrations..." python3 manage.py migrate ) 200>/usr/src/paperless/data/migration_lock } search_index() { index_version=1 index_version_file=/usr/src/paperless/data/.index_version if [[ (! -f "$index_version_file") || $(<$index_version_file) != "$index_version" ]]; then echo "Search index out of date. Updating..." python3 manage.py document_index reindex echo $index_version | tee $index_version_file >/dev/null fi } superuser() { if [[ -n "${PAPERLESS_ADMIN_USER}" ]]; then python3 manage.py manage_superuser fi } do_work() { if [[ -n "${PAPERLESS_DBHOST}" ]]; then wait_for_postgres fi wait_for_redis migrations search_index superuser } do_work