dda-backup/infrastructure/docker/image/resources/pg-functions.sh

110 lines
3.5 KiB
Bash
Raw Normal View History

2020-12-31 14:05:56 +00:00
function init-role-repo() {
2021-11-12 08:54:17 +00:00
local command="restic -r ${RESTIC_REPOSITORY}/pg-role -v init"
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}
function init-database-repo() {
2021-11-12 08:54:17 +00:00
local command="restic -r ${RESTIC_REPOSITORY}/pg-database -v init"
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}
function drop-create-db() {
psql -d template1 -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} -U ${POSTGRES_USER} \
--no-password -c "DROP DATABASE \"${POSTGRES_DB}\";"
psql -d template1 -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} -U ${POSTGRES_USER} \
--no-password -c "CREATE DATABASE \"${POSTGRES_DB}\";"
}
function create-pg-pass() {
local pg_host=${POSTGRES_HOST:-localhost}
echo "${pg_host}:${POSTGRES_DB}:${POSTGRES_USER}:${POSTGRES_PASSWORD}" > /root/.pgpass
echo "${POSTGRES_HOST}:template1:${POSTGRES_USER}:${POSTGRES_PASSWORD}" >> /root/.pgpass
chmod 0600 /root/.pgpass
}
function backup-roles() {
local role_prefix="$1"; shift
2021-11-12 10:52:47 +00:00
local command_unlock="restic -v -r ${RESTIC_REPOSITORY}/pg-role unlock --cleanup-cache"
local command_pg_dump="pg_dumpall -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} -U${POSTGRES_USER} --no-password --roles-only | \
grep ${role_prefix} | \
2021-11-12 08:54:17 +00:00
restic -r ${RESTIC_REPOSITORY}/pg-role backup --stdin"
2021-11-12 10:52:47 +00:00
local command_forget="restic -v -r ${RESTIC_REPOSITORY}/pg-role forget --keep-last 1 --keep-within ${RESTIC_DAYS_TO_KEEP}d --prune"
2020-12-31 14:05:56 +00:00
2021-11-12 08:54:17 +00:00
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command_unlock}
${command_pg_dump}
${command_forget}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command_unlock} --cacert ${CERTIFICATE_FILE}
${command_pg_dump} --cacert ${CERTIFICATE_FILE}
${command_forget} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}
function backup-db-dump() {
2021-11-12 10:52:47 +00:00
local command_unlock="restic -v -r ${RESTIC_REPOSITORY}/pg-database unlock --cleanup-cache"
local command_pg_dump="pg_dump -d ${POSTGRES_DB} -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} \
2020-12-31 14:05:56 +00:00
-U ${POSTGRES_USER} --no-password --serializable-deferrable | \
2021-11-12 08:54:17 +00:00
restic -r ${RESTIC_REPOSITORY}/pg-database backup --stdin"
2021-11-12 10:52:47 +00:00
local command_forget="restic -v -r ${RESTIC_REPOSITORY}/pg-database forget --keep-last 1 --keep-within ${RESTIC_DAYS_TO_KEEP}d --prune"
2020-12-31 14:05:56 +00:00
2021-11-12 08:54:17 +00:00
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command_unlock}
${command_pg_dump}
${command_forget}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command_unlock} --cacert ${CERTIFICATE_FILE}
${command_pg_dump} --cacert ${CERTIFICATE_FILE}
${command_forget} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}
function restore-roles() {
2021-11-12 10:52:47 +00:00
local command_unlock="restic -v -r ${RESTIC_REPOSITORY}/pg-role unlock --cleanup-cache"
local command_pg_dump="restic -r ${RESTIC_REPOSITORY}/pg-role dump latest stdin | \
2020-12-31 14:05:56 +00:00
psql -d template1 -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} -U ${POSTGRES_USER} \
2021-11-12 08:54:17 +00:00
--no-password"
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command_unlock}
${command_pg-dump}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command_unlock} --cacert ${CERTIFICATE_FILE}
${command_pg_dump} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}
function restore-db() {
2021-11-12 10:52:47 +00:00
local command_unlock="restic -v -r ${RESTIC_REPOSITORY}/pg-database unlock --cleanup-cache"
local command_pg_dump="restic -r ${RESTIC_REPOSITORY}/pg_database dump latest stdin | \
2020-12-31 14:05:56 +00:00
psql -d ${POSTGRES_DB} -h ${POSTGRES_SERVICE} -p ${POSTGRES_PORT} -U ${POSTGRES_USER} \
2021-11-12 08:54:17 +00:00
--no-password"
if [ -z ${CERTIFICATE_FILE} ];
then
2021-11-12 10:52:47 +00:00
${command_unlock}
${command_pg_dump}
2021-11-12 08:54:17 +00:00
else
2021-11-12 10:52:47 +00:00
${command_unlock} --cacert ${CERTIFICATE_FILE}
${command_pg_dump} --cacert ${CERTIFICATE_FILE}
2021-11-12 08:54:17 +00:00
fi
2020-12-31 14:05:56 +00:00
}