Files
proxmox/scripts/archive/consolidated/list/get-cloudflare-zone-ids.sh
defiQUG fbda1b4beb
Some checks failed
Deploy to Phoenix / deploy (push) Has been cancelled
docs: Ledger Live integration, contract deploy learnings, NEXT_STEPS updates
- ADD_CHAIN138_TO_LEDGER_LIVE: Ledger form done; public code review repo bis-innovations/LedgerLive; init/push commands
- CONTRACT_DEPLOYMENT_RUNBOOK: Chain 138 gas price 1 gwei, 36-addr check, TransactionMirror workaround
- CONTRACT_*: AddressMapper, MirrorManager deployed 2026-02-12; 36-address on-chain check
- NEXT_STEPS_FOR_YOU: Ledger done; steps completable now (no LAN); run-completable-tasks-from-anywhere
- MASTER_INDEX, OPERATOR_OPTIONAL, SMART_CONTRACTS_INVENTORY_SIMPLE: updates
- LEDGER_BLOCKCHAIN_INTEGRATION_COMPLETE: bis-innovations/LedgerLive reference

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-12 15:46:57 -08:00

116 lines
3.8 KiB
Bash
Executable File

#!/usr/bin/env bash
# Get Cloudflare Zone IDs for all domains
# Helps identify zone IDs needed for DNS update script
set -euo pipefail
# Colors
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
NC='\033[0m'
log_info() { echo -e "${BLUE}[INFO]${NC} $1"; }
log_success() { echo -e "${GREEN}[✓]${NC} $1"; }
log_warn() { echo -e "${YELLOW}[⚠]${NC} $1"; }
log_error() { echo -e "${RED}[✗]${NC} $1"; }
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
# Source .env file
if [ -f "$PROJECT_ROOT/.env" ]; then
source "$PROJECT_ROOT/.env" 2>/dev/null || true
else
log_warn ".env file not found - will prompt for credentials"
fi
# Cloudflare authentication
if [ -n "${CLOUDFLARE_API_TOKEN:-}" ]; then
AUTH_HEADER="Authorization: Bearer $CLOUDFLARE_API_TOKEN"
AUTH_METHOD="token"
elif [ -n "${CLOUDFLARE_EMAIL:-}" ] && [ -n "${CLOUDFLARE_API_KEY:-}" ]; then
AUTH_EMAIL="$CLOUDFLARE_EMAIL"
AUTH_KEY="$CLOUDFLARE_API_KEY"
AUTH_METHOD="key"
else
log_error "Missing Cloudflare credentials"
echo ""
echo "Please provide Cloudflare credentials:"
echo "Option 1: API Token (recommended)"
read -p "CLOUDFLARE_API_TOKEN: " CLOUDFLARE_API_TOKEN
AUTH_HEADER="Authorization: Bearer $CLOUDFLARE_API_TOKEN"
AUTH_METHOD="token"
echo ""
fi
# Function to get zone ID
get_zone_id() {
local domain="$1"
if [ "$AUTH_METHOD" = "token" ]; then
local response=$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones?name=${domain}" \
-H "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \
-H "Content-Type: application/json")
else
local response=$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones?name=${domain}" \
-H "X-Auth-Email: $AUTH_EMAIL" \
-H "X-Auth-Key: $AUTH_KEY" \
-H "Content-Type: application/json")
fi
local zone_id=$(echo "$response" | jq -r '.result[0].id // empty' 2>/dev/null || echo "")
local zone_name=$(echo "$response" | jq -r '.result[0].name // empty' 2>/dev/null || echo "")
if [ -n "$zone_id" ] && [ "$zone_id" != "null" ]; then
echo "$zone_id|$zone_name"
else
echo ""
fi
}
echo ""
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo "🔍 Cloudflare Zone ID Lookup"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo ""
DOMAINS=(
"sankofa.nexus"
"d-bis.org"
"mim4u.org"
"defi-oracle.io"
)
echo "Looking up Zone IDs..."
echo ""
for domain in "${DOMAINS[@]}"; do
log_info "Checking: $domain"
result=$(get_zone_id "$domain")
if [ -n "$result" ]; then
zone_id=$(echo "$result" | cut -d'|' -f1)
zone_name=$(echo "$result" | cut -d'|' -f2)
log_success " Zone ID: $zone_id"
log_success " Zone Name: $zone_name"
# Generate .env variable name
var_name=$(echo "$domain" | tr '.-' '_' | tr '[:lower:]' '[:upper:]')
var_name="CLOUDFLARE_ZONE_ID_${var_name}"
echo " Add to .env:"
echo " $var_name=$zone_id"
echo ""
else
log_warn " Zone not found or access denied"
echo ""
fi
done
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
log_info "Add the Zone IDs above to your .env file"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo ""