- 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
102 lines
3.3 KiB
Bash
Executable File
102 lines
3.3 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
source "$SCRIPT_DIR/../lib/init.sh"
|
|
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
# 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 "║ EXECUTING ALL DEPLOYMENT PHASES ║"
|
|
echo "╚════════════════════════════════════════════════════════════════╝"
|
|
|
|
# Phase 1: Key Vault Deployment
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
echo "PHASE 1: KEY VAULT DEPLOYMENT"
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
|
|
bash "$SCRIPT_DIR/deploy-keyvaults-only.sh"
|
|
|
|
if [ $? -ne 0 ]; then
|
|
echo "❌ Phase 1 failed. Stopping deployment."
|
|
exit 1
|
|
fi
|
|
|
|
echo "✅ Phase 1 complete. Waiting 10 seconds before Phase 2..."
|
|
sleep 10
|
|
|
|
# Phase 2: Store Node Secrets
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
echo "PHASE 2: STORE NODE SECRETS"
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
|
|
bash "$PROJECT_ROOT/scripts/key-management/store-nodes-in-keyvault.sh"
|
|
|
|
if [ $? -ne 0 ]; then
|
|
echo "❌ Phase 2 failed. Stopping deployment."
|
|
exit 1
|
|
fi
|
|
|
|
echo "✅ Phase 2 complete. Waiting 10 seconds before Phase 3..."
|
|
sleep 10
|
|
|
|
# Phase 3: AKS Cluster Deployment
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
echo "PHASE 3: AKS CLUSTER DEPLOYMENT"
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
|
|
cd "$PROJECT_ROOT/terraform/well-architected/cloud-sovereignty"
|
|
|
|
if [ ! -f "terraform.tfvars.36regions" ]; then
|
|
echo "❌ Error: terraform.tfvars.36regions not found"
|
|
exit 1
|
|
fi
|
|
|
|
# Ensure deploy_aks_clusters is true
|
|
if ! grep -q "deploy_aks_clusters = true" terraform.tfvars.36regions; then
|
|
echo "Updating terraform.tfvars.36regions to enable AKS deployment..."
|
|
sed -i 's/deploy_aks_clusters = false/deploy_aks_clusters = true/' terraform.tfvars.36regions
|
|
fi
|
|
|
|
echo "Running Terraform plan for AKS clusters..."
|
|
terraform plan -var-file=terraform.tfvars.36regions -out=tfplan.aks
|
|
|
|
echo "Applying Terraform plan for AKS clusters..."
|
|
echo "This will deploy AKS clusters across 36 regions with:"
|
|
echo " • 72 system nodes (D2plsv6)"
|
|
echo " • 36 validator nodes (D2psv6)"
|
|
echo "Press Ctrl+C to cancel, or wait 10 seconds to continue..."
|
|
sleep 10
|
|
|
|
terraform apply tfplan.aks
|
|
|
|
if [ $? -ne 0 ]; then
|
|
echo "❌ Phase 3 failed. Check Terraform output above."
|
|
exit 1
|
|
fi
|
|
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
echo "✅ ALL PHASES COMPLETE"
|
|
echo "=" | awk '{printf "%-64s\n", ""}'
|
|
|
|
echo "Next steps:"
|
|
echo " 1. Update enode URLs with actual node IP addresses"
|
|
echo " 2. Deploy Besu validator pods"
|
|
|