#!/usr/bin/env bash # INITIALIZES CONTAINER PACKAGES AND PERMISSIONS export PATH="/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/scripts" # abort if not executed as root if [[ $(id -u) != "0" ]]; then echo "Usage: run ${0##*/} as root" 1>&2 exit 1 fi # regular expressions re='^[0-9]+$' # detect environment case $DOCKER_ENV in prod) export PATH="/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/scripts:/opt/photoprism/bin"; INIT_SCRIPTS="/scripts" CHOWN_DIRS=("/photoprism/storage") CHMOD_DIRS=("/photoprism/storage") ;; develop) export PATH="/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/scripts:/usr/local/go/bin:/go/bin:/opt/photoprism/bin"; INIT_SCRIPTS="/scripts" CHOWN_DIRS=("/photoprism" "/opt/photoprism" "/go" "/tmp/photoprism") CHMOD_DIRS=("/opt/photoprism" "/tmp/photoprism") # Create test TLS certificates. ./scripts/openssl/create-all.sh ;; *) echo "init: unsupported environment $DOCKER_ENV"; exit ;; esac if [[ ${PHOTOPRISM_UID} =~ $re ]] && [[ ${PHOTOPRISM_UID} != "0" ]]; then if [[ ${PHOTOPRISM_GID} =~ $re ]] && [[ ${PHOTOPRISM_GID} != "0" ]]; then CHOWN="${PHOTOPRISM_UID}:${PHOTOPRISM_GID}" else CHOWN="${PHOTOPRISM_UID}" fi if [[ -z ${PHOTOPRISM_DISABLE_CHOWN} ]] || [[ ${PHOTOPRISM_DISABLE_CHOWN} == "false" ]]; then echo "init: updating filesystem permissions" echo "PHOTOPRISM_DISABLE_CHOWN=\"true\" disables permission updates" chown --preserve-root --silent -R "${CHOWN}" "${CHOWN_DIRS[@]}" chmod --preserve-root --silent -R u+rwX "${CHMOD_DIRS[@]}" fi fi # do nothing if PHOTOPRISM_INIT was not set if [[ -z ${PHOTOPRISM_INIT} ]]; then exit fi INIT_LOCK="/scripts/.init-lock" # execute targets via /usr/bin/make if [[ ! -e ${INIT_LOCK} ]]; then for INIT_TARGET in $PHOTOPRISM_INIT; do echo "init: $INIT_TARGET" make -C "$INIT_SCRIPTS" "$INIT_TARGET" done echo 1 >${INIT_LOCK} fi