#!/usr/bin/env bash set -euo pipefail # ============================================================================= # deploy-database-dump.sh # Erstellt einen PostgreSQL-Dump und uebertraegt ihn per SFTP auf die # Zielinstanz innerhalb der Hetzner-Infrastruktur. # # Verwendung: ./deploy-database-dump.sh # Beispiel: ./deploy-database-dump.sh pilot1 # ============================================================================= SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" # --- Kontext laden --- source "${SCRIPT_DIR}/ssh_context.sh" "$@" # --- SSH (Key wird geladen, Passphrase einmalig abgefragt) --- setup_ssh # --- Datenbank-URL pruefen --- if [ -z "${DATABASE_URL:-}" ]; then echo "FEHLER: DATABASE_URL ist nicht gesetzt." exit 1 fi # --- Dump erstellen --- BACKUP_DIR="/home/runner/workspace/backups" TIMESTAMP=$(node -e "const d=new Date();console.log(d.toISOString().replace(/[-:]/g,'').replace('T','_').slice(0,15))") DUMP_FILE="${BACKUP_DIR}/datadump_${TARGET}_${TIMESTAMP}.dump" SFTP_TARGET="/uploads/datadump.dump" mkdir -p "${BACKUP_DIR}" echo "" echo "=== Datenbank-Export ===" echo "Target: ${TARGET} (${DOMAIN})" echo "DB: ${DB_NAME}" echo "Ziel: ${DUMP_FILE}" echo "" echo "Starte Datenbank-Export..." pg_dump -Fc -d "$DATABASE_URL" -f "$DUMP_FILE" & DUMP_PID=$! while kill -0 "$DUMP_PID" 2>/dev/null; do if [ -f "$DUMP_FILE" ]; then SIZE=$(du -h "$DUMP_FILE" 2>/dev/null | cut -f1) printf "\r Exportiert: %s ..." "$SIZE" fi sleep 3 done wait "$DUMP_PID" DUMP_EXIT=$? echo "" if [ $DUMP_EXIT -ne 0 ] || [ ! -f "$DUMP_FILE" ]; then echo "FEHLER: Datenbank-Export fehlgeschlagen." exit 1 fi SIZE=$(du -h "$DUMP_FILE" | cut -f1) echo "Export fertig: ${DUMP_FILE} (${SIZE})" sync # --- SFTP-Transfer --- echo "" echo "=== SFTP-Upload ===" echo "Ziel: ${SFTP_HOST}:${SFTP_TARGET}" echo "" sftp -P "${SFTP_PORT}" -i "${KEY_PATH}" "replit-user@${SFTP_HOST}" <&1) if echo "$REMOTE_CHECK" | grep -q "datadump.dump"; then echo "Upload erfolgreich: Datei auf dem Server vorhanden." else echo "FEHLER: Datei wurde nicht auf dem Server gefunden." exit 1 fi echo "" echo "=== Datenbank-Deployment fuer '${TARGET}' abgeschlossen ==="