51 lines
1.2 KiB
Bash
51 lines
1.2 KiB
Bash
#!/bin/bash
|
|
# Database Migration Runner for b0esche.cloud
|
|
# Runs all SQL migrations in order
|
|
|
|
set -e
|
|
|
|
# Check for required environment variable
|
|
if [ -z "$DATABASE_URL" ]; then
|
|
echo "ERROR: DATABASE_URL environment variable not set"
|
|
echo "Example: DATABASE_URL=postgres://user:pass@localhost:5432/dbname"
|
|
exit 1
|
|
fi
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
|
|
echo "=== b0esche.cloud Database Migrations ==="
|
|
echo "Database: $DATABASE_URL"
|
|
echo
|
|
|
|
# Function to run a single migration
|
|
run_migration() {
|
|
local file=$1
|
|
echo "Running: $(basename $file)"
|
|
psql "$DATABASE_URL" -f "$file" -v ON_ERROR_STOP=1
|
|
if [ $? -eq 0 ]; then
|
|
echo "✓ Success"
|
|
else
|
|
echo "✗ Failed"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
# Run migrations in order
|
|
echo "Step 1/4: Initial schema..."
|
|
run_migration "$SCRIPT_DIR/0001_initial.sql"
|
|
|
|
echo
|
|
echo "Step 2/4: Passkeys and authentication..."
|
|
run_migration "$SCRIPT_DIR/0002_passkeys.sql"
|
|
|
|
echo
|
|
echo "Step 3/4: Files and storage..."
|
|
run_migration "$SCRIPT_DIR/0003_files.sql"
|
|
|
|
echo
|
|
echo "Step 4/4: Organization ownership and slug scope..."
|
|
run_migration "$SCRIPT_DIR/0004_org_owner_slug.sql"
|
|
|
|
echo
|
|
echo "=== All migrations completed successfully! ==="
|