chore: cms sync commands

This commit is contained in:
2026-02-10 00:13:42 +01:00
parent da6b8aba64
commit eccc084441
4 changed files with 32 additions and 29 deletions

View File

@@ -13,8 +13,8 @@
"cms:push:infra": "./scripts/sync-directus.sh push infra", "cms:push:infra": "./scripts/sync-directus.sh push infra",
"cms:pull:infra": "./scripts/sync-directus.sh pull infra", "cms:pull:infra": "./scripts/sync-directus.sh pull infra",
"cms:schema:snapshot": "./scripts/cms-snapshot.sh", "cms:schema:snapshot": "./scripts/cms-snapshot.sh",
"cms:schema:snapshot:infra": "./scripts/cms-snapshot.sh infra", "cms:schema:apply": "./scripts/cms-apply.sh local",
"cms:schema:apply": "./scripts/cms-apply.sh", "cms:schema:apply:infra": "./scripts/cms-apply.sh infra",
"dev:infra": "docker-compose up -d directus directus-db", "dev:infra": "docker-compose up -d directus directus-db",
"release": "pnpm build && changeset publish", "release": "pnpm build && changeset publish",
"release:tag": "pnpm build && pnpm -r publish --no-git-checks --access public", "release:tag": "pnpm build && pnpm -r publish --no-git-checks --access public",

Binary file not shown.

View File

@@ -1,9 +1,14 @@
#!/bin/bash #!/bin/bash
ENV=$1 # Configuration
PROJECT="infra-cms"
SCHEMA_PATH="./packages/cms-infra/schema/snapshot.yaml"
CMD_PREFIX="docker-compose -f packages/cms-infra/docker-compose.yml"
REMOTE_HOST="root@infra.mintel.me" REMOTE_HOST="root@infra.mintel.me"
REMOTE_DIR="/opt/infra/directus" REMOTE_DIR="/opt/infra/directus"
ENV=$1
if [ -z "$ENV" ]; then if [ -z "$ENV" ]; then
echo "Usage: ./scripts/cms-apply.sh [local|infra]" echo "Usage: ./scripts/cms-apply.sh [local|infra]"
exit 1 exit 1
@@ -11,38 +16,44 @@ fi
case $ENV in case $ENV in
local) local)
CONTAINER=$(docker compose ps -q directus) # Default to infra-cms package for at-mintel
if [ -z "$CONTAINER" ]; then PROJECT="infra-cms"
echo "❌ Local directus container not found." CMD_PREFIX="docker-compose -f packages/cms-infra/docker-compose.yml"
LOCAL_CONTAINER=$($CMD_PREFIX ps -q $PROJECT)
if [ -z "$LOCAL_CONTAINER" ]; then
echo "❌ Local $PROJECT container not found. Is it running?"
exit 1 exit 1
fi fi
echo "🚀 Applying schema locally..."
docker exec "$CONTAINER" npx directus schema apply /directus/schema/snapshot.yaml --yes echo "🚀 Applying schema to LOCAL $PROJECT..."
docker exec "$LOCAL_CONTAINER" npx directus schema apply -y /directus/schema/snapshot.yaml
;; ;;
infra) infra)
PROJECT_NAME="directus" # 'infra' is the remote production server for at-mintel
PROJECT="directus" # Remote project name is usually 'directus' in docker-compose
echo "📤 Uploading snapshot to $ENV..." echo "📤 Uploading snapshot to REMOTE $ENV..."
# Ensure remote directory exists # Ensure remote directory exists
ssh "$REMOTE_HOST" "mkdir -p $REMOTE_DIR/directus/schema" ssh "$REMOTE_HOST" "mkdir -p $REMOTE_DIR/directus/schema"
scp ./directus/schema/snapshot.yaml "$REMOTE_HOST:$REMOTE_DIR/directus/schema/snapshot.yaml" scp ./packages/cms-infra/schema/snapshot.yaml "$REMOTE_HOST:$REMOTE_DIR/directus/schema/snapshot.yaml"
echo "🔍 Detecting remote container..." echo "🔍 Detecting remote container..."
REMOTE_CONTAINER=$(ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT_NAME ps -q directus") REMOTE_CONTAINER=$(ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT ps -q directus")
if [ -z "$REMOTE_CONTAINER" ]; then if [ -z "$REMOTE_CONTAINER" ]; then
echo "❌ Remote container for $ENV not found." echo "❌ Remote container for $ENV not found."
exit 1 exit 1
fi fi
echo "🚀 Applying schema to $ENV..." echo "🚀 Applying schema to REMOTE $ENV..."
ssh "$REMOTE_HOST" "docker exec $REMOTE_CONTAINER npx directus schema apply /directus/schema/snapshot.yaml --yes" ssh "$REMOTE_HOST" "docker exec $REMOTE_CONTAINER npx directus schema apply -y /directus/schema/snapshot.yaml"
echo "🔄 Restarting Directus to clear cache..." echo "🔄 Restarting remote Directus to clear cache..."
ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT_NAME restart directus" ssh "$REMOTE_HOST" "cd $REMOTE_DIR && docker compose -p $PROJECT restart directus"
;; ;;
*) *)
echo "❌ Invalid environment: $ENV. Only 'local' and 'infra' are supported." echo "❌ Invalid environment: $ENV. Supported: local, infra."
exit 1 exit 1
;; ;;
esac esac

View File

@@ -1,17 +1,9 @@
#!/bin/bash #!/bin/bash
# Configuration # Configuration
PROJECT="directus" PROJECT="infra-cms"
SCHEMA_PATH="./directus/schema/snapshot.yaml" SCHEMA_PATH="./packages/cms-infra/schema/snapshot.yaml"
CMD_PREFIX="" CMD_PREFIX="docker-compose -f packages/cms-infra/docker-compose.yml"
if [ "$1" == "infra" ]; then
PROJECT="infra-cms"
SCHEMA_PATH="./packages/cms-infra/schema/snapshot.yaml"
CMD_PREFIX="docker-compose -f packages/cms-infra/docker-compose.yml"
else
CMD_PREFIX="docker compose"
fi
# Detect local container # Detect local container
LOCAL_CONTAINER=$($CMD_PREFIX ps -q $PROJECT) LOCAL_CONTAINER=$($CMD_PREFIX ps -q $PROJECT)
@@ -21,7 +13,7 @@ if [ -z "$LOCAL_CONTAINER" ]; then
exit 1 exit 1
fi fi
echo "📸 Creating schema snapshot for $PROJECT..." echo "📸 Creating schema snapshot for local $PROJECT..."
# Note: we save it to the mounted volume path inside the container # Note: we save it to the mounted volume path inside the container
docker exec "$LOCAL_CONTAINER" npx directus schema snapshot -y /directus/schema/snapshot.yaml docker exec "$LOCAL_CONTAINER" npx directus schema snapshot -y /directus/schema/snapshot.yaml