Files
proxmox/scripts/complete-all-blockscout-setup.sh.bak
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

195 lines
7.4 KiB
Bash
Executable File

#!/bin/bash
# Complete all Blockscout setup tasks - automated and verification
# This script completes all possible automated tasks
set -euo pipefail
PROXMOX_HOST="${PROXMOX_HOST:-192.168.11.10}"
VMID=5000
PASSWORD="L@kers2010"
BLOCKSCOUT_IP="192.168.11.140"
VMID_CLOUDFLARED=102
# 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_section() { echo -e "${CYAN}════════════════════════════════════════${NC}"; }
echo "════════════════════════════════════════════════════════"
echo "Complete Blockscout Setup - All Tasks"
echo "════════════════════════════════════════════════════════"
echo ""
# Find container node
log_info "Step 1: Finding container location..."
CONTAINER_NODE=$(ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"for node in ml110 pve pve2; do \
if pvesh get /nodes/\$node/lxc/$VMID/status/current 2>/dev/null | grep -q status; then \
echo \$node; break; \
fi; \
done" 2>/dev/null || echo "")
if [ -z "$CONTAINER_NODE" ]; then
log_error "Container VMID $VMID not found"
exit 1
fi
log_success "Container found on node: $CONTAINER_NODE"
echo ""
# Step 1: Verify static IP configuration
log_section
log_info "Step 2: Verifying static IP configuration..."
log_section
CURRENT_NET=$(ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"pvesh get /nodes/$CONTAINER_NODE/lxc/$VMID/config --output-format json-pretty 2>/dev/null | grep -o '\"net0\"[^\"]*\"[^\"]*\"' | cut -d'\"' -f4" || echo "")
if echo "$CURRENT_NET" | grep -q "$BLOCKSCOUT_IP"; then
log_success "Static IP configured: $BLOCKSCOUT_IP/24"
else
log_warn "Static IP not configured. Configuring now..."
ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"pvesh set /nodes/$CONTAINER_NODE/lxc/$VMID/config --net0 'name=eth0,bridge=vmbr0,hwaddr=BC:24:11:3C:58:2B,ip=$BLOCKSCOUT_IP/24,gw=192.168.11.1,type=veth' 2>/dev/null" && \
log_success "Static IP configuration updated" && \
log_info "Rebooting container to apply changes..." && \
ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"pvesh create /nodes/$CONTAINER_NODE/lxc/$VMID/status/reboot 2>/dev/null" && \
log_info "Waiting 20 seconds for container to restart..." && \
sleep 20
fi
echo ""
# Step 2: Verify container is running
log_section
log_info "Step 3: Checking container status..."
log_section
STATUS=$(ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"pvesh get /nodes/$CONTAINER_NODE/lxc/$VMID/status/current --output-format json-pretty 2>/dev/null | grep -o '\"status\":\"[^\"]*\"' | cut -d'\"' -f4" || echo "unknown")
if [ "$STATUS" = "running" ]; then
log_success "Container is running"
else
log_warn "Container status: $STATUS"
log_info "Starting container..."
ssh -o StrictHostKeyChecking=no root@"$PROXMOX_HOST" \
"pvesh create /nodes/$CONTAINER_NODE/lxc/$VMID/status/start 2>/dev/null" && \
sleep 10 && \
log_success "Container started"
fi
echo ""
# Step 3: Attempt to set password (may require manual step)
log_section
log_info "Step 4: Setting root password..."
log_section
log_info "Attempting to set password via container console..."
log_warn "Note: Password setting via API is limited. You may need to set it manually via Proxmox Web UI"
# Try to set password using heredoc via pct (if we can access the node)
log_info "Password should be set via Proxmox Web UI:"
echo " 1. Navigate to Container $VMID → Options → Password"
echo " 2. Enter password: $PASSWORD"
echo " 3. Click OK"
echo ""
# Step 4: Verify network connectivity
log_section
log_info "Step 5: Testing network connectivity..."
log_section
log_info "Testing from cloudflared container to Blockscout..."
CONNECTIVITY_TEST=$(curl -s -o /dev/null -w '%{http_code}' --connect-timeout 5 "http://$BLOCKSCOUT_IP:80/health" 2>&1 || echo "000")
if [ "$CONNECTIVITY_TEST" = "200" ] || [ "$CONNECTIVITY_TEST" = "302" ] || [ "$CONNECTIVITY_TEST" = "301" ]; then
log_success "Internal connectivity: HTTP $CONNECTIVITY_TEST"
INTERNAL_OK=true
elif [ "$CONNECTIVITY_TEST" = "502" ]; then
log_warn "HTTP 502 - Service running but may need firewall rule"
INTERNAL_OK=false
else
log_warn "Connectivity test returned: HTTP $CONNECTIVITY_TEST"
log_info "This may indicate firewall blocking or service not ready"
INTERNAL_OK=false
fi
echo ""
# Step 5: Test external connectivity
log_section
log_info "Step 6: Testing external connectivity..."
log_section
EXTERNAL_TEST=$(curl -s -o /dev/null -w '%{http_code}' --connect-timeout 10 "https://explorer.d-bis.org/health" 2>&1 || echo "000")
if [ "$EXTERNAL_TEST" = "200" ]; then
log_success "External connectivity: HTTP 200 ✓"
EXTERNAL_OK=true
elif [ "$EXTERNAL_TEST" = "502" ]; then
log_warn "HTTP 502 - Cloudflare Tunnel can't reach Blockscout"
log_info "Firewall rule needed in Omada Controller"
EXTERNAL_OK=false
elif [ "$EXTERNAL_TEST" = "522" ]; then
log_warn "HTTP 522 - Connection timeout"
EXTERNAL_OK=false
else
log_warn "External test returned: HTTP $EXTERNAL_TEST"
EXTERNAL_OK=false
fi
echo ""
# Final Summary
log_section
echo "════════════════════════════════════════════════════════"
echo "Setup Summary"
echo "════════════════════════════════════════════════════════"
echo ""
echo "✅ Completed Tasks:"
echo " - Static IP configured: $BLOCKSCOUT_IP/24"
echo " - Container status: $STATUS"
echo " - Network configuration verified"
echo ""
if [ "${INTERNAL_OK:-false}" = "false" ] || [ "${EXTERNAL_OK:-false}" = "false" ]; then
echo "⚠️ Manual Actions Required:"
echo ""
if [ "${INTERNAL_OK:-false}" = "false" ]; then
echo "1. Configure Omada Firewall Rule:"
echo " - Access: https://omada.tplinkcloud.com"
echo " - Or run: bash scripts/access-omada-cloud-controller.sh"
echo " - Navigate: Settings → Firewall → Firewall Rules"
echo " - Create allow rule:"
echo " Source: 192.168.11.0/24"
echo " Destination: $BLOCKSCOUT_IP:80"
echo " Protocol: TCP"
echo " Action: Allow"
echo " Priority: High (above deny rules)"
echo ""
fi
echo "2. Set Root Password (if not done):"
echo " - Via Proxmox Web UI: Container $VMID → Options → Password"
echo " - Password: $PASSWORD"
echo ""
fi
echo "📝 Next Steps:"
echo " 1. Set password via Proxmox Web UI (if not done)"
echo " 2. Configure Omada firewall rule (if connectivity fails)"
echo " 3. Verify: bash scripts/complete-blockscout-firewall-fix.sh"
echo ""
echo "════════════════════════════════════════════════════════"