Files
explorer-monorepo/scripts/full-readiness-check.sh
defiQUG 7a7ce770c2 feat(scripts): resolve CCIP/LINK addresses via config inventory
- Add scripts/lib/address-inventory.sh (jq + JSON inventory fallback)
- Wire deployment helper scripts to load_explorer_runtime_env + resolve_address_value
- Persist new LINK to address-inventory.json via persist_inventory_value
- Document config/*.json in config/README.md

Made-with: Cursor
2026-03-27 22:09:32 -07:00

268 lines
10 KiB
Bash
Executable File

#!/usr/bin/env bash
# Full Readiness Check for CCIP Bridge Setup
# Comprehensive validation of all components
set -uo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
source "$PROJECT_ROOT/scripts/lib/address-inventory.sh"
# Colors
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
CYAN='\033[0;36m'
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"; }
log_header() { echo -e "${CYAN}[CHECK]${NC} $1"; }
# Load runtime env plus address inventory.
load_explorer_runtime_env
RPC_URL="${RPC_URL_138:-http://192.168.11.250:8545}"
LINK_TOKEN="$(resolve_address_value LINK_TOKEN LINK_TOKEN 0x73ADaF7dBa95221c080db5631466d2bC54f6a76B)"
WETH9="$(resolve_address_value WETH9_ADDRESS WETH9_ADDRESS 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2)"
WETH10="$(resolve_address_value WETH10_ADDRESS WETH10_ADDRESS 0xf4BB2e28688e89fCcE3c0580D37d36A7672E8A9f)"
WETH9_BRIDGE="$(resolve_address_value CCIPWETH9_BRIDGE CCIPWETH9_BRIDGE 0x971cD9D156f193df8051E48043C476e53ECd4693)"
WETH10_BRIDGE="$(resolve_address_value CCIPWETH10_BRIDGE CCIPWETH10_BRIDGE 0xe0E93247376aa097dB308B92e6Ba36bA015535D0)"
PASSED=0
FAILED=0
WARNINGS=0
check_pass() { ((PASSED++)); log_success "$1"; }
check_fail() { ((FAILED++)); log_error "$1"; }
check_warn() { ((WARNINGS++)); log_warn "$1"; }
echo "╔══════════════════════════════════════════════════════════════╗"
echo "║ FULL READINESS CHECK - CCIP BRIDGE SETUP ║"
echo "╚══════════════════════════════════════════════════════════════╝"
echo ""
# 1. Network Connectivity
log_header "1. Network Connectivity"
BLOCK=$(cast block-number --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$BLOCK" ] && [ "$BLOCK" != "unknown" ] && [ "$BLOCK" != "0" ]; then
check_pass "Network connected (Block: $BLOCK)"
else
check_fail "Network not accessible"
fi
CHAIN_ID=$(cast chain-id --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ "$CHAIN_ID" = "138" ]; then
check_pass "Chain ID correct: 138"
else
check_fail "Chain ID incorrect: $CHAIN_ID (expected 138)"
fi
echo ""
# 2. Account Status
log_header "2. Account Status"
if [ -z "${PRIVATE_KEY:-}" ]; then
check_fail "PRIVATE_KEY not available in effective environment"
ACCOUNT=""
else
ACCOUNT=$(cast wallet address "$PRIVATE_KEY" 2>/dev/null || echo "")
if [ -n "$ACCOUNT" ]; then
check_pass "Account derived: $ACCOUNT"
ETH_BAL=$(cast balance "$ACCOUNT" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
ETH_BAL_ETH=$(cast --from-wei "$ETH_BAL" ether 2>/dev/null || echo "0")
if (( $(echo "$ETH_BAL_ETH >= 0.1" | bc -l 2>/dev/null || echo 1) )); then
check_pass "ETH balance sufficient: $ETH_BAL_ETH ETH"
else
check_fail "ETH balance insufficient: $ETH_BAL_ETH ETH (need 0.1+)"
fi
NONCE=$(cast nonce "$ACCOUNT" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
check_pass "Current nonce: $NONCE"
else
check_fail "Could not derive account from PRIVATE_KEY"
fi
fi
echo ""
# 3. LINK Token Contract
log_header "3. LINK Token Contract"
LINK_CODE=$(cast code "$LINK_TOKEN" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$LINK_CODE" ] && [ "$LINK_CODE" != "0x" ] && [ ${#LINK_CODE} -gt 100 ]; then
check_pass "LINK token deployed at $LINK_TOKEN"
NAME=$(cast call "$LINK_TOKEN" "name()" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$NAME" ] && [ "$NAME" != "0x" ]; then
check_pass "Token name: $NAME"
else
check_warn "Could not read token name"
fi
SYMBOL=$(cast call "$LINK_TOKEN" "symbol()" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$SYMBOL" ] && [ "$SYMBOL" != "0x" ]; then
check_pass "Token symbol: $SYMBOL"
else
check_warn "Could not read token symbol"
fi
else
check_fail "LINK token not found at $LINK_TOKEN"
fi
echo ""
# 4. Account Token Balances
log_header "4. Account Token Balances"
if [ -n "$ACCOUNT" ] && [ -n "$LINK_CODE" ] && [ "$LINK_CODE" != "0x" ]; then
LINK_BAL=$(cast call "$LINK_TOKEN" "balanceOf(address)" "$ACCOUNT" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
LINK_BAL_ETH=$(cast --from-wei "$LINK_BAL" ether 2>/dev/null || echo "0")
if (( $(echo "$LINK_BAL_ETH >= 20" | bc -l 2>/dev/null || echo 0) )); then
check_pass "LINK balance: $LINK_BAL_ETH LINK (sufficient)"
else
check_fail "LINK balance: $LINK_BAL_ETH LINK (need 20+)"
fi
else
check_warn "Cannot check LINK balance (account or token not available)"
fi
WETH9_BAL=$(cast call "$WETH9" "balanceOf(address)" "$ACCOUNT" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
WETH9_BAL_ETH=$(cast --from-wei "$WETH9_BAL" ether 2>/dev/null || echo "0")
check_pass "WETH9 balance: $WETH9_BAL_ETH WETH9"
WETH10_BAL=$(cast call "$WETH10" "balanceOf(address)" "$ACCOUNT" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
WETH10_BAL_ETH=$(cast --from-wei "$WETH10_BAL" ether 2>/dev/null || echo "0")
check_pass "WETH10 balance: $WETH10_BAL_ETH WETH10"
echo ""
# 5. Bridge Contract Status
log_header "5. Bridge Contract Status"
WETH9_BRIDGE_CODE=$(cast code "$WETH9_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$WETH9_BRIDGE_CODE" ] && [ "$WETH9_BRIDGE_CODE" != "0x" ]; then
check_pass "WETH9 Bridge deployed: $WETH9_BRIDGE"
else
check_fail "WETH9 Bridge not found: $WETH9_BRIDGE"
fi
WETH10_BRIDGE_CODE=$(cast code "$WETH10_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
if [ -n "$WETH10_BRIDGE_CODE" ] && [ "$WETH10_BRIDGE_CODE" != "0x" ]; then
check_pass "WETH10 Bridge deployed: $WETH10_BRIDGE"
else
check_fail "WETH10 Bridge not found: $WETH10_BRIDGE"
fi
echo ""
# 6. Bridge LINK Balances
log_header "6. Bridge LINK Balances"
if [ -n "$LINK_CODE" ] && [ "$LINK_CODE" != "0x" ]; then
WETH9_LINK=$(cast call "$LINK_TOKEN" "balanceOf(address)" "$WETH9_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
WETH9_LINK_ETH=$(cast --from-wei "$WETH9_LINK" ether 2>/dev/null || echo "0")
if (( $(echo "$WETH9_LINK_ETH >= 10" | bc -l 2>/dev/null || echo 0) )); then
check_pass "WETH9 Bridge LINK: $WETH9_LINK_ETH LINK (sufficient)"
else
check_fail "WETH9 Bridge LINK: $WETH9_LINK_ETH LINK (need 10+)"
fi
WETH10_LINK=$(cast call "$LINK_TOKEN" "balanceOf(address)" "$WETH10_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
WETH10_LINK_ETH=$(cast --from-wei "$WETH10_LINK" ether 2>/dev/null || echo "0")
if (( $(echo "$WETH10_LINK_ETH >= 10" | bc -l 2>/dev/null || echo 0) )); then
check_pass "WETH10 Bridge LINK: $WETH10_LINK_ETH LINK (sufficient)"
else
check_fail "WETH10 Bridge LINK: $WETH10_LINK_ETH LINK (need 10+)"
fi
else
check_warn "Cannot check bridge LINK balances (LINK token not available)"
fi
echo ""
# 7. Bridge Destination Configuration
log_header "7. Bridge Destination Configuration"
ETHEREUM_SELECTOR="5009297550715157269"
if [ -n "$WETH9_BRIDGE_CODE" ] && [ "$WETH9_BRIDGE_CODE" != "0x" ]; then
DEST=$(cast call "$WETH9_BRIDGE" "destinations(uint64)" "$ETHEREUM_SELECTOR" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
DEST_HEX=$(echo "$DEST" | sed 's/0x//')
DEST_CLEAN=""
if [ ${#DEST_HEX} -ge 128 ]; then
ADDR_HEX=$(echo "$DEST_HEX" | cut -c65-128)
DEST_CLEAN="0x${ADDR_HEX:24:40}"
fi
if [ -n "$DEST_CLEAN" ] && [ "$DEST_CLEAN" != "0x0000000000000000000000000000000000000000" ]; then
check_pass "WETH9 Bridge: Ethereum Mainnet configured ($DEST_CLEAN)"
else
check_fail "WETH9 Bridge: Ethereum Mainnet NOT configured"
fi
fi
if [ -n "$WETH10_BRIDGE_CODE" ] && [ "$WETH10_BRIDGE_CODE" != "0x" ]; then
DEST=$(cast call "$WETH10_BRIDGE" "destinations(uint64)" "$ETHEREUM_SELECTOR" --rpc-url "$RPC_URL" 2>/dev/null || echo "")
DEST_HEX=$(echo "$DEST" | sed 's/0x//')
DEST_CLEAN=""
if [ ${#DEST_HEX} -ge 128 ]; then
ADDR_HEX=$(echo "$DEST_HEX" | cut -c65-128)
DEST_CLEAN="0x${ADDR_HEX:24:40}"
fi
if [ -n "$DEST_CLEAN" ] && [ "$DEST_CLEAN" != "0x0000000000000000000000000000000000000000" ]; then
check_pass "WETH10 Bridge: Ethereum Mainnet configured ($DEST_CLEAN)"
else
check_fail "WETH10 Bridge: Ethereum Mainnet NOT configured"
fi
fi
echo ""
# 8. Configuration Files
log_header "8. Configuration Files"
if [ -f "$PROJECT_ROOT/.env" ]; then
check_pass ".env file exists"
else
check_warn ".env file not found"
fi
if [ -n "${PRIVATE_KEY:-}" ]; then
check_pass "PRIVATE_KEY available in effective environment"
else
check_fail "PRIVATE_KEY not available in effective environment"
fi
if [ -f "$EXPLORER_ADDRESS_INVENTORY_FILE" ] && [ -n "$(inventory_get LINK_TOKEN 2>/dev/null || true)" ]; then
check_pass "LINK_TOKEN configured in address inventory"
else
check_warn "LINK_TOKEN not in address inventory"
fi
echo ""
# 9. Script Availability
log_header "9. Script Availability"
SCRIPTS=(
"force-deploy-link.sh"
"fund-bridge-contracts.sh"
"get-funding-report.sh"
"wrap-and-bridge-to-ethereum.sh"
"check-bridge-config.sh"
)
for script in "${SCRIPTS[@]}"; do
if [ -f "$SCRIPT_DIR/$script" ] && [ -x "$SCRIPT_DIR/$script" ]; then
check_pass "Script available: $script"
else
check_warn "Script missing or not executable: $script"
fi
done
echo ""
# 10. Summary
echo "╔══════════════════════════════════════════════════════════════╗"
echo "║ READINESS CHECK SUMMARY ║"
echo "╚══════════════════════════════════════════════════════════════╝"
echo ""
echo "Passed: $PASSED"
echo "Failed: $FAILED"
echo "Warnings: $WARNINGS"
echo ""
if [ $FAILED -eq 0 ] && [ $WARNINGS -eq 0 ]; then
log_success "✓✓✓ SYSTEM FULLY READY"
exit 0
elif [ $FAILED -eq 0 ]; then
log_warn "⚠ SYSTEM READY WITH WARNINGS"
exit 0
else
log_error "✗ SYSTEM NOT READY - $FAILED critical issues found"
exit 1
fi