diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml index a7423687..e971e93d 100644 --- a/.gitea/workflows/deploy.yml +++ b/.gitea/workflows/deploy.yml @@ -58,8 +58,8 @@ jobs: ENV_FILE=".env.testing" TRAEFIK_HOST='`testing.klz-cables.com`' NEXT_PUBLIC_BASE_URL="https://testing.klz-cables.com" - DIRECTUS_URL="https://cms-testing.klz-cables.com" - DIRECTUS_HOST='`cms-testing.klz-cables.com`' + DIRECTUS_URL="https://cms.testing.klz-cables.com" + DIRECTUS_HOST='`cms.testing.klz-cables.com`' PROJECT_NAME="klz-cables-testing" IS_PROD="false" GOTIFY_TITLE="๐Ÿงช Testing-Deploy" @@ -83,8 +83,8 @@ jobs: ENV_FILE=".env.staging" TRAEFIK_HOST='`staging.klz-cables.com`' NEXT_PUBLIC_BASE_URL="https://staging.klz-cables.com" - DIRECTUS_URL="https://cms-staging.klz-cables.com" - DIRECTUS_HOST='`cms-staging.klz-cables.com`' + DIRECTUS_URL="https://cms.staging.klz-cables.com" + DIRECTUS_HOST='`cms.staging.klz-cables.com`' PROJECT_NAME="klz-cables-staging" IS_PROD="false" GOTIFY_TITLE="๐Ÿงช Staging-Deploy (Pre-Release)" diff --git a/package.json b/package.json index 7219fb55..3ceec7d1 100644 --- a/package.json +++ b/package.json @@ -68,7 +68,13 @@ "test:og": "vitest run tests/og-image.test.ts", "bootstrap:cms": "DIRECTUS_URL=http://localhost:8055 npx tsx --env-file=.env scripts/setup-directus-branding.ts", "pdf:datasheets": "tsx ./scripts/generate-pdf-datasheets.ts", - "pdf:datasheets:legacy": "tsx ./scripts/generate-pdf-datasheets-pdf-lib.ts" + "pdf:datasheets:legacy": "tsx ./scripts/generate-pdf-datasheets-pdf-lib.ts", + "directus:push:staging": "./scripts/sync-directus.sh push staging", + "directus:pull:staging": "./scripts/sync-directus.sh pull staging", + "directus:push:testing": "./scripts/sync-directus.sh push testing", + "directus:pull:testing": "./scripts/sync-directus.sh pull testing", + "directus:push:prod": "./scripts/sync-directus.sh push production", + "directus:pull:prod": "./scripts/sync-directus.sh pull production" }, "version": "1.0.0" } \ No newline at end of file diff --git a/scripts/sync-directus.sh b/scripts/sync-directus.sh new file mode 100755 index 00000000..61452594 --- /dev/null +++ b/scripts/sync-directus.sh @@ -0,0 +1,120 @@ +#!/bin/bash + +# Configuration +REMOTE_HOST="root@alpha.mintel.me" +REMOTE_DIR="/home/deploy/sites/klz-cables.com" + +# DB Details (matching docker-compose defaults) +DB_USER="directus" +DB_NAME="directus" + +ACTION=$1 +ENV=$2 + +# Help +if [ -z "$ACTION" ] || [ -z "$ENV" ]; then + echo "Usage: ./scripts/sync-directus.sh [push|pull] [testing|staging|production]" + echo "" + echo "Commands:" + echo " push Sync LOCAL data -> REMOTE" + echo " pull Sync REMOTE data -> LOCAL" + echo "" + echo "Environments:" + echo " testing, staging, production" + exit 1 +fi + +# Map Environment to Project Name +case $ENV in + testing) + PROJECT_NAME="klz-cables-testing" + ENV_FILE=".env.testing" + ;; + staging) + PROJECT_NAME="klz-cables-staging" + ENV_FILE=".env.staging" + ;; + production) + PROJECT_NAME="klz-cables-prod" + ENV_FILE=".env.prod" + ;; + *) + echo "โŒ Invalid environment: $ENV. Use testing, staging, or production." + exit 1 + ;; +esac + +# Detect local container +echo "๐Ÿ” Detecting local database..." +# Use a more robust way to find the container if multiple projects exist locally +LOCAL_DB_CONTAINER=$(docker compose ps -q directus-db) +if [ -z "$LOCAL_DB_CONTAINER" ]; then + echo "โŒ Local directus-db container not found. Is it running? (npm run dev)" + exit 1 +fi + +if [ "$ACTION" == "push" ]; then + echo "๐Ÿš€ Pushing Local Data to $ENV ($PROJECT_NAME)..." + + # 1. DB Dump + echo "๐Ÿ“ฆ Dumping local database..." + docker exec "$LOCAL_DB_CONTAINER" pg_dump -U "$DB_USER" --clean --if-exists --no-owner --no-privileges "$DB_NAME" > dump.sql + + # 2. Upload Dump + echo "๐Ÿ“ค Uploading dump to remote server..." + scp dump.sql "$REMOTE_HOST:$REMOTE_DIR/dump.sql" + + # 3. Restore on Remote + echo "๐Ÿ”„ Restoring dump on $ENV..." + REMOTE_DB_CONTAINER=$(ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT_NAME ps -q directus-db") + if [ -z "$REMOTE_DB_CONTAINER" ]; then + echo "โŒ Remote $ENV-db container not found!" + exit 1 + fi + ssh "$REMOTE_HOST" "docker exec -i $REMOTE_DB_CONTAINER psql -U $DB_USER $DB_NAME < $REMOTE_DIR/dump.sql" + + # 4. Sync Uploads + echo "๐Ÿ“ Syncing uploads (Local -> $ENV)..." + # Note: If environments share the same directory, this might overwrite others' files if not careful. + # But since they share the same host directory currently, rsync will update the shared folder. + rsync -avz --progress ./directus/uploads/ "$REMOTE_HOST:$REMOTE_DIR/directus/uploads/" + + # Clean up + rm dump.sql + ssh "$REMOTE_HOST" "rm $REMOTE_DIR/dump.sql" + + echo "โœจ Push to $ENV complete!" + +elif [ "$ACTION" == "pull" ]; then + echo "๐Ÿ“ฅ Pulling $ENV Data to Local..." + + # 1. DB Dump on Remote + echo "๐Ÿ“ฆ Dumping remote database ($ENV)..." + REMOTE_DB_CONTAINER=$(ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT_NAME ps -q directus-db") + if [ -z "$REMOTE_DB_CONTAINER" ]; then + echo "โŒ Remote $ENV-db container not found!" + exit 1 + fi + ssh "$REMOTE_HOST" "docker exec $REMOTE_DB_CONTAINER pg_dump -U $DB_USER --clean --if-exists --no-owner --no-privileges $DB_NAME > $REMOTE_DIR/dump.sql" + + # 2. Download Dump + echo "๐Ÿ“ฅ Downloading dump..." + scp "$REMOTE_HOST:$REMOTE_DIR/dump.sql" dump.sql + + # 3. Restore Locally + echo "๐Ÿ”„ Restoring dump locally..." + docker exec -i "$LOCAL_DB_CONTAINER" psql -U "$DB_USER" "$DB_NAME" < dump.sql + + # 4. Sync Uploads + echo "๐Ÿ“ Syncing uploads ($ENV -> Local)..." + rsync -avz --progress "$REMOTE_HOST:$REMOTE_DIR/directus/uploads/" ./directus/uploads/ + + # Clean up + rm dump.sql + ssh "$REMOTE_HOST" "rm $REMOTE_DIR/dump.sql" + + echo "โœจ Pull to Local complete!" +else + echo "Invalid action: $ACTION. Use push or pull." + exit 1 +fi