Files
proxmox/scripts/update-all-service-configs.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

154 lines
6.4 KiB
Bash
Executable File

#!/usr/bin/env bash
# Update all service configurations with deployed contract addresses
# Usage: ./update-all-service-configs.sh
set -euo pipefail
# Load IP configuration
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
source "${PROJECT_ROOT}/config/ip-addresses.conf" 2>/dev/null || true
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
PROXMOX_HOST="${PROXMOX_HOST:-192.168.11.10}"
PROXMOX_PASS="${PROXMOX_PASS:-L@kers2010}"
# Contract addresses
ORACLE_PROXY="0x3304b747e565a97ec8ac220b0b6a1f6ffdb837e6"
ORACLE_AGGREGATOR="0x99b3511a2d315a497c8112c1fdd8d508d4b1e506"
CCIP_ROUTER="0x8078A09637e47Fa5Ed34F626046Ea2094a5CDE5e"
CCIP_SENDER="0x105F8A15b819948a89153505762444Ee9f324684"
WETH9="0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2"
WETH10="0xf4BB2e28688e89fCcE3c0580D37d36A7672E8A9f"
# Public-facing: VMID 2201 (8545 HTTP, 8546 WS)
RPC_URL="http://${RPC_PUBLIC_1:-192.168.11.221}:8545"
WS_URL="ws://${RPC_PUBLIC_1:-192.168.11.221}:8546"
CHAIN_ID="138"
# 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}[WARN]${NC} $1"; }
log_error() { echo -e "${RED}[ERROR]${NC} $1"; }
ssh_proxmox() {
sshpass -p "$PROXMOX_PASS" ssh -o StrictHostKeyChecking=no -o ConnectTimeout=5 root@"$PROXMOX_HOST" "$@"
}
log_info "========================================="
log_info "Update All Service Configurations"
log_info "========================================="
log_info ""
# Function to update .env file in container
update_env_file() {
local vmid="$1"
local env_file="$2"
shift 2
local updates="$@"
log_info "Updating $env_file in VMID $vmid..."
ssh_proxmox "pct exec $vmid -- bash -c '
ENV_FILE=\"$env_file\"
mkdir -p \$(dirname \"\$ENV_FILE\")
touch \"\$ENV_FILE\"
$updates
echo \"✓ Updated \$ENV_FILE\"
'" 2>&1 || log_warn "Failed to update $env_file in VMID $vmid"
}
# Oracle Publisher Service (VMID 3500)
if ssh_proxmox "pct list | grep -q '3500'"; then
log_info "Updating Oracle Publisher Service (VMID 3500)..."
update_env_file 3500 "/opt/oracle-publisher/.env" \
"sed -i '/^ORACLE_ADDRESS=/d' \$ENV_FILE; echo \"ORACLE_ADDRESS=$ORACLE_PROXY\" >> \$ENV_FILE" \
"sed -i '/^AGGREGATOR_ADDRESS=/d' \$ENV_FILE; echo \"AGGREGATOR_ADDRESS=$ORACLE_AGGREGATOR\" >> \$ENV_FILE" \
"sed -i '/^RPC_URL=/d' \$ENV_FILE; echo \"RPC_URL=$RPC_URL\" >> \$ENV_FILE" \
"sed -i '/^WS_URL=/d' \$ENV_FILE; echo \"WS_URL=$WS_URL\" >> \$ENV_FILE" \
"sed -i '/^CHAIN_ID=/d' \$ENV_FILE; echo \"CHAIN_ID=$CHAIN_ID\" >> \$ENV_FILE"
log_success "Oracle Publisher Service updated"
else
log_warn "VMID 3500 (Oracle Publisher) not found, skipping..."
fi
# CCIP Monitor Service (VMID 3501)
if ssh_proxmox "pct list | grep -q '3501'"; then
log_info "Updating CCIP Monitor Service (VMID 3501)..."
update_env_file 3501 "/opt/ccip-monitor/.env" \
"sed -i '/^CCIP_ROUTER_ADDRESS=/d' \$ENV_FILE; echo \"CCIP_ROUTER_ADDRESS=$CCIP_ROUTER\" >> \$ENV_FILE" \
"sed -i '/^CCIP_SENDER_ADDRESS=/d' \$ENV_FILE; echo \"CCIP_SENDER_ADDRESS=$CCIP_SENDER\" >> \$ENV_FILE" \
"sed -i '/^RPC_URL=/d' \$ENV_FILE; echo \"RPC_URL=$RPC_URL\" >> \$ENV_FILE" \
"sed -i '/^WS_URL=/d' \$ENV_FILE; echo \"WS_URL=$WS_URL\" >> \$ENV_FILE" \
"sed -i '/^CHAIN_ID=/d' \$ENV_FILE; echo \"CHAIN_ID=$CHAIN_ID\" >> \$ENV_FILE"
log_success "CCIP Monitor Service updated"
else
log_warn "VMID 3501 (CCIP Monitor) not found, skipping..."
fi
# Keeper Service (VMID 3502)
if ssh_proxmox "pct list | grep -q '3502'"; then
log_info "Updating Keeper Service (VMID 3502)..."
update_env_file 3502 "/opt/keeper/.env" \
"sed -i '/^ORACLE_PRICE_FEED=/d' \$ENV_FILE; echo \"ORACLE_PRICE_FEED=$ORACLE_PROXY\" >> \$ENV_FILE" \
"sed -i '/^RPC_URL=/d' \$ENV_FILE; echo \"RPC_URL=$RPC_URL\" >> \$ENV_FILE" \
"sed -i '/^WS_URL=/d' \$ENV_FILE; echo \"WS_URL=$WS_URL\" >> \$ENV_FILE" \
"sed -i '/^CHAIN_ID=/d' \$ENV_FILE; echo \"CHAIN_ID=$CHAIN_ID\" >> \$ENV_FILE"
log_success "Keeper Service updated"
else
log_warn "VMID 3502 (Keeper) not found, skipping..."
fi
# Financial Tokenization Service (VMID 3503)
if ssh_proxmox "pct list | grep -q '3503'"; then
log_info "Updating Financial Tokenization Service (VMID 3503)..."
update_env_file 3503 "/opt/tokenization/.env" \
"sed -i '/^RPC_URL=/d' \$ENV_FILE; echo \"RPC_URL=$RPC_URL\" >> \$ENV_FILE" \
"sed -i '/^WS_URL=/d' \$ENV_FILE; echo \"WS_URL=$WS_URL\" >> \$ENV_FILE" \
"sed -i '/^CHAIN_ID=/d' \$ENV_FILE; echo \"CHAIN_ID=$CHAIN_ID\" >> \$ENV_FILE" \
"sed -i '/^WETH9_ADDRESS=/d' \$ENV_FILE; echo \"WETH9_ADDRESS=$WETH9\" >> \$ENV_FILE" \
"sed -i '/^WETH10_ADDRESS=/d' \$ENV_FILE; echo \"WETH10_ADDRESS=$WETH10\" >> \$ENV_FILE"
log_success "Financial Tokenization Service updated"
else
log_warn "VMID 3503 (Financial Tokenization) not found, skipping..."
fi
# Hyperledger Services
for vmid in 150 151; do
if ssh_proxmox "pct list | grep -q '$vmid'"; then
log_info "Updating Hyperledger Service (VMID $vmid)..."
ssh_proxmox "pct exec $vmid -- bash -c '
if [ -f /opt/firefly/docker-compose.yml ]; then
sed -i \"s|FF_BLOCKCHAIN_RPC=.*|FF_BLOCKCHAIN_RPC=$RPC_URL|\" /opt/firefly/docker-compose.yml
sed -i \"s|FF_BLOCKCHAIN_WS=.*|FF_BLOCKCHAIN_WS=$WS_URL|\" /opt/firefly/docker-compose.yml
echo \"✓ Updated Firefly configuration\"
fi
if [ -f /opt/cacti/docker-compose.yml ]; then
sed -i \"s|BESU_RPC_URL=.*|BESU_RPC_URL=$RPC_URL|\" /opt/cacti/docker-compose.yml
sed -i \"s|BESU_WS_URL=.*|BESU_WS_URL=$WS_URL|\" /opt/cacti/docker-compose.yml
echo \"✓ Updated Cacti configuration\"
fi
'" 2>&1 || log_warn "Failed to update VMID $vmid"
fi
done
log_info ""
log_success "========================================="
log_success "Service Configuration Update Complete!"
log_success "========================================="
log_info ""
log_info "Next steps:"
log_info "1. Restart services to apply new configurations"
log_info "2. Verify services are connecting to contracts"
log_info "3. Check service logs for any errors"
log_info ""