docker-autopostgresqlbackup/docker-entrypoint.sh

32 lines
1.0 KiB
Bash
Raw Normal View History

2018-01-23 18:01:22 +01:00
#!/bin/sh
2018-01-23 18:12:33 +01:00
# Logic for Password file required
# If PASSWORD_SECRET env var is defined, search for the /run/secrets/${PASSWORD_SECRET} and read the content
# If PASSWORD_SECRET is not defined, use PASSWORD env variable
# The idea, as specified in the software:
# create a file $HOME/.pgpass containing a line like this
# hostname:*:*:dbuser:dbpass
# replace hostname with the value of DBHOST and postgres with
# the value of USERNAME
PASSPHRASE=""
if [ "${PASSWORD_SECRET}" ]; then
if [ -f "/run/secrets/${PASSWORD_SECRET}" ]; then
2018-01-23 18:32:57 +01:00
PASSPHRASE=$(cat /run/secrets/${PASSWORD_SECRET})
2018-01-23 18:12:33 +01:00
else
echo "ERROR: Secret file not found in /run/secrets/${PASSWORD_SECRET}"
echo "Please verify your docker secrets configuration."
exit 1
fi
else
2018-01-23 18:32:57 +01:00
PASSPHRASE=${PASSWORD}
2018-01-23 18:12:33 +01:00
fi
# Create the file
cat <<-EOF > ${HOME}/.pgpass
2018-01-23 18:32:57 +01:00
${DBHOST}:*:*:${USERNAME:-postgres}:${PASSPHRASE}
2018-01-23 18:12:33 +01:00
EOF
# Execute cron with parameters (autopostgresql script is under /etc/cron.daily)
2018-01-23 18:01:22 +01:00
exec cron -f -l ${LOG_LEVEL:-8}