65 lines
1.5 KiB
Bash
Executable file
65 lines
1.5 KiB
Bash
Executable file
#!/usr/bin/env sh
|
|
|
|
set -e
|
|
|
|
set -a
|
|
. "/opt/services/backup/.env"
|
|
. "/opt/services/backup/.secret.env"
|
|
set +a
|
|
|
|
hc_url="https://hc-ping.com/$HC_UID"
|
|
|
|
curl -fsSL --retry 3 "$hc_url/start" >/dev/null
|
|
duration_start=$(date +%s)
|
|
|
|
BACKUP_LOCATION="/tmp/backup-misc"
|
|
|
|
rm -rf "$BACKUP_LOCATION"
|
|
mkdir -p "$BACKUP_LOCATION"
|
|
cd "$BACKUP_LOCATION" || exit
|
|
|
|
_hc_fail () {
|
|
curl -fsSL --retry 3 "$hc_url/fail"
|
|
exit 1
|
|
}
|
|
|
|
_backup_prepare_postgres () {
|
|
mkdir -p "$BACKUP_LOCATION/postgres"
|
|
cd "$BACKUP_LOCATION/postgres" || exit
|
|
|
|
postgres_tables=$(sudo -u postgres psql -Atc "SELECT datname FROM pg_database WHERE datistemplate = false;")
|
|
|
|
for i in $postgres_tables
|
|
do
|
|
echo "dumping $i"
|
|
sudo -u postgres pg_dump "$i" | gzip >"pg_dump_$i.gz"
|
|
echo "done with $i"
|
|
echo ""
|
|
done
|
|
|
|
echo "dumping all"
|
|
sudo -u postgres pg_dumpall | gzip >"pg_dumpall.gz"
|
|
}
|
|
|
|
_backup_prepare_mailcow () {
|
|
export MAILCOW_BACKUP_LOCATION="$BACKUP_LOCATION/mailcow"
|
|
mkdir -p "$MAILCOW_BACKUP_LOCATION"
|
|
/opt/mailcow-dockerized/helper-scripts/backup_and_restore.sh \
|
|
backup all --delete-days 3
|
|
}
|
|
|
|
echo ""
|
|
echo "preparing postgres"
|
|
time _backup_prepare_postgres >/tmp/backup-postgres.log || _hc_fail
|
|
echo ""
|
|
echo "preparing mailcow"
|
|
time _backup_prepare_mailcow >/tmp/backup-mailcow.log || _hc_fail
|
|
|
|
cd /opt/services/backup/
|
|
docker compose run --rm backup || _hc_fail
|
|
|
|
duration_end=$(date +%s)
|
|
curl -fsSL --retry 3 "$hc_url"
|
|
|
|
duration=$((duration_end - duration_start))
|
|
curl -fsSL --retry 3 "https://status.serguzim.me/api/push/$UPTIME_KUMA_TOKEN?status=up&msg=OK&ping=${duration}000"
|