- Resolve stash: merge load_deployment_env path with secure-secrets and CR/LF RPC strip - create-pmm-full-mesh-chain138.sh delegates to sync-chain138-pmm-pools-from-json.sh - env.additions.example: canonical PMM pool defaults (cUSDT/USDT per crosscheck) - Include Chain138 scripts, official mirror deploy scaffolding, and prior staged changes Made-with: Cursor
91 lines
2.9 KiB
Bash
Executable File
91 lines
2.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Complete Phase 2 deployment from proxy host
|
|
# Run this script ON the Nginx proxy host (20.160.58.99)
|
|
|
|
set -e
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
cd "$PROJECT_ROOT"
|
|
# Load .env via dotenv (RPC CR/LF trim). Fallback: raw source.
|
|
if [[ -f "$SCRIPT_DIR/../lib/deployment/dotenv.sh" ]]; then
|
|
# shellcheck disable=SC1090
|
|
source "$SCRIPT_DIR/../lib/deployment/dotenv.sh"
|
|
load_deployment_env --repo-root "${PROJECT_ROOT:-$REPO_ROOT}"
|
|
elif [[ -n "${PROJECT_ROOT:-}" && -f "$PROJECT_ROOT/.env" ]]; then
|
|
set -a
|
|
# shellcheck disable=SC1090
|
|
source "$PROJECT_ROOT/.env"
|
|
set +a
|
|
elif [[ -n "${REPO_ROOT:-}" && -f "$REPO_ROOT/.env" ]]; then
|
|
set -a
|
|
# shellcheck disable=SC1090
|
|
source "$REPO_ROOT/.env"
|
|
set +a
|
|
fi
|
|
|
|
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
|
|
echo "Phase 2 Complete Deployment from Proxy Host"
|
|
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
|
|
echo ""
|
|
|
|
# Check if .env exists
|
|
if [ ! -f .env ]; then
|
|
echo "❌ Error: .env file not found"
|
|
echo "Please ensure .env is in $PROJECT_ROOT"
|
|
exit 1
|
|
fi
|
|
|
|
source .env
|
|
|
|
# Verify SSH key
|
|
if [ -z "$SSH_PRIVATE_KEY_PATH" ]; then
|
|
echo "❌ Error: SSH_PRIVATE_KEY_PATH not set in .env"
|
|
exit 1
|
|
fi
|
|
|
|
if [ ! -f "$SSH_PRIVATE_KEY_PATH" ]; then
|
|
echo "❌ Error: SSH key not found: $SSH_PRIVATE_KEY_PATH"
|
|
exit 1
|
|
fi
|
|
|
|
# Set proper permissions
|
|
chmod 600 "$SSH_PRIVATE_KEY_PATH"
|
|
echo "✅ SSH key configured: $SSH_PRIVATE_KEY_PATH"
|
|
|
|
# Step 1: Generate Phase 2 configuration
|
|
echo ""
|
|
echo "Step 1: Generating Phase 2 configuration..."
|
|
./scripts/deployment/generate-phase2-tfvars.sh
|
|
|
|
# Step 2: Initialize Terraform
|
|
echo ""
|
|
echo "Step 2: Initializing Terraform..."
|
|
cd terraform/phases/phase2
|
|
if [ ! -d .terraform ]; then
|
|
terraform init -upgrade > /dev/null 2>&1
|
|
fi
|
|
echo "✅ Terraform initialized"
|
|
|
|
# Step 3: Deploy Phase 2
|
|
echo ""
|
|
echo "Step 3: Deploying Phase 2 to all 5 regions (parallel)..."
|
|
terraform apply -auto-approve
|
|
echo "✅ Phase 2 deployed"
|
|
|
|
# Step 4: Start services
|
|
echo ""
|
|
echo "Step 4: Starting services on all regions (parallel)..."
|
|
cd "$PROJECT_ROOT"
|
|
./terraform/phases/phase2/scripts/start-services.sh all
|
|
|
|
# Step 5: Verify deployment
|
|
echo ""
|
|
echo "Step 5: Verifying deployment..."
|
|
./terraform/phases/phase2/scripts/status.sh all
|
|
|
|
echo ""
|
|
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
|
|
echo "✅ Phase 2 Deployment Complete!"
|
|
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
|