Files
proxmox/scripts/setup-cloudflared-vmid2400.sh
defiQUG cb47cce074 Complete markdown files cleanup and organization
- Organized 252 files across project
- Root directory: 187 → 2 files (98.9% reduction)
- Moved configuration guides to docs/04-configuration/
- Moved troubleshooting guides to docs/09-troubleshooting/
- Moved quick start guides to docs/01-getting-started/
- Moved reports to reports/ directory
- Archived temporary files
- Generated comprehensive reports and documentation
- Created maintenance scripts and guides

All files organized according to established standards.
2026-01-06 01:46:25 -08:00

221 lines
8.5 KiB
Bash
Executable File

#!/usr/bin/env bash
# Setup Cloudflared Tunnel for ThirdWeb RPC Node (VMID 2400)
# This script installs Cloudflared and configures it to connect to Cloudflare Tunnel
#
# Usage: ./scripts/setup-cloudflared-vmid2400.sh <TUNNEL_TOKEN>
# Example: ./scripts/setup-cloudflared-vmid2400.sh eyJhIjoiNTJhZDU3YTcxNjcxYzVmYzAwOWVkZjA3NDQ2NTgxOTYiLCJ0Ijoi...
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
# Configuration
VMID=2400
PROXMOX_HOST="${PROXMOX_HOST:-192.168.11.10}"
HOSTNAME="thirdweb-rpc-1"
IP="192.168.11.240"
# 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"; }
# Check if token provided
if [[ $# -eq 0 ]]; then
log_error "Tunnel token required!"
echo ""
echo "Usage: $0 <TUNNEL_TOKEN>"
echo ""
echo "Get your token from Cloudflare Dashboard:"
echo " 1. Go to: https://one.dash.cloudflare.com/"
echo " 2. Navigate to: Zero Trust → Networks → Tunnels"
echo " 3. Click: Create a tunnel"
echo " 4. Select: Cloudflared"
echo " 5. Name: thirdweb-rpc-2400"
echo " 6. Copy the token shown"
echo ""
exit 1
fi
TUNNEL_TOKEN="$1"
log_info "═══════════════════════════════════════════════════════════"
log_info " SETTING UP CLOUDFLARE TUNNEL FOR VMID 2400"
log_info "═══════════════════════════════════════════════════════════"
echo ""
log_info "VMID: $VMID"
log_info "Hostname: $HOSTNAME"
log_info "IP: $IP"
log_info "Proxmox Host: $PROXMOX_HOST"
echo ""
# Check SSH access
log_info "Checking SSH access to $PROXMOX_HOST..."
if ! ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} "echo 'SSH OK'" &>/dev/null; then
log_error "Cannot access $PROXMOX_HOST via SSH"
log_error "Please ensure:"
log_error " 1. SSH key is set up"
log_error " 2. Host is reachable"
log_error " 3. Root access is available"
exit 1
fi
log_success "SSH access confirmed"
# Check container status
log_info "Checking container status..."
CONTAINER_STATUS=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct status $VMID 2>/dev/null | awk '{print \$2}'" 2>/dev/null || echo "unknown")
if [[ "$CONTAINER_STATUS" != "running" ]]; then
log_warn "Container $VMID is not running (status: $CONTAINER_STATUS)"
log_info "Attempting to start container..."
ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} "pct start $VMID" || {
log_error "Failed to start container $VMID"
exit 1
}
sleep 5
log_success "Container started"
else
log_success "Container is running"
fi
# Install cloudflared
log_info "Checking cloudflared installation..."
if ! ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- command -v cloudflared >/dev/null 2>&1"; then
log_info "Installing cloudflared..."
ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- bash -c 'apt update -qq && apt install -y wget && cd /tmp && wget -q https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64.deb && dpkg -i cloudflared-linux-amd64.deb || apt install -f -y'" || {
log_error "Failed to install cloudflared"
exit 1
}
log_success "cloudflared installed"
else
log_success "cloudflared already installed"
fi
# Verify cloudflared version
CLOUDFLARED_VERSION=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- cloudflared --version 2>&1 | head -1" || echo "unknown")
log_info "cloudflared version: $CLOUDFLARED_VERSION"
# Install tunnel service
log_info "Installing tunnel service with token..."
INSTALL_OUTPUT=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- cloudflared service install \"$TUNNEL_TOKEN\" 2>&1" || echo "INSTALL_FAILED")
if echo "$INSTALL_OUTPUT" | grep -q -E "successfully|installed|Service installed"; then
log_success "Tunnel service installed"
elif echo "$INSTALL_OUTPUT" | grep -q -E "already installed|exists"; then
log_warn "Tunnel service may already be installed"
else
log_warn "Installation output: $INSTALL_OUTPUT"
# Continue - service might already be installed
fi
# Enable and start service
log_info "Enabling and starting cloudflared service..."
ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- systemctl enable cloudflared" || log_warn "Failed to enable service (may already be enabled)"
ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- systemctl start cloudflared" || {
log_error "Failed to start cloudflared service"
exit 1
}
# Wait for service to start
sleep 5
# Check service status
log_info "Checking cloudflared service status..."
SERVICE_STATUS=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- systemctl is-active cloudflared 2>/dev/null || echo 'inactive'")
if [[ "$SERVICE_STATUS" == "active" ]]; then
log_success "Cloudflared service is running"
else
log_warn "Cloudflared service status: $SERVICE_STATUS"
log_info "Checking logs for issues..."
ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- journalctl -u cloudflared -n 20 --no-pager" || true
fi
# Get tunnel information
log_info "Getting tunnel information..."
TUNNEL_LIST=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- cloudflared tunnel list 2>&1" || echo "")
if echo "$TUNNEL_LIST" | grep -q -E "NAME|ID"; then
echo ""
log_info "Tunnel list:"
echo "$TUNNEL_LIST" | head -10
echo ""
else
log_warn "Could not retrieve tunnel list"
fi
# Check tunnel configuration
log_info "Checking tunnel configuration..."
TUNNEL_CONFIG=$(ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no root@${PROXMOX_HOST} \
"pct exec $VMID -- cat /etc/cloudflared/config.yml 2>/dev/null || echo 'Config not found'")
if [[ "$TUNNEL_CONFIG" != "Config not found" ]] && [[ -n "$TUNNEL_CONFIG" ]]; then
log_info "Tunnel config exists"
echo "$TUNNEL_CONFIG" | head -20
echo ""
else
log_warn "Tunnel config file not found (this is normal for token-based installation)"
fi
# Summary
echo ""
log_success "═══════════════════════════════════════════════════════════"
log_success " CLOUDFLARE TUNNEL SETUP COMPLETE"
log_success "═══════════════════════════════════════════════════════════"
echo ""
log_info "Next steps:"
echo ""
echo "1. Configure Tunnel Route in Cloudflare Dashboard:"
echo " - Go to: https://one.dash.cloudflare.com/"
echo " - Navigate to: Zero Trust → Networks → Tunnels"
echo " - Click on your tunnel name"
echo " - Click: Configure"
echo " - Go to: Public Hostname tab"
echo " - Click: Add a public hostname"
echo " - Configure:"
echo " Subdomain: rpc.public-0138"
echo " Domain: defi-oracle.io"
echo " Service Type: HTTP"
echo " URL: http://127.0.0.1:8545"
echo " - Click: Save hostname"
echo ""
echo "2. Configure DNS Record in Cloudflare:"
echo " - Go to: DNS → Records"
echo " - Select domain: defi-oracle.io"
echo " - Click: Add record"
echo " - Configure:"
echo " Type: CNAME"
echo " Name: rpc.public-0138"
echo " Target: <your-tunnel-id>.cfargotunnel.com"
echo " Proxy: 🟠 Proxied (orange cloud)"
echo " TTL: Auto"
echo " - Click: Save"
echo ""
echo "3. Verify Setup:"
echo " - Wait 1-2 minutes for DNS propagation"
echo " - Test: curl -k https://rpc.public-0138.defi-oracle.io \\"
echo " -X POST -H 'Content-Type: application/json' \\"
echo " -d '{\"jsonrpc\":\"2.0\",\"method\":\"eth_blockNumber\",\"params\":[],\"id\":1}'"
echo ""
log_info "For detailed instructions, see: docs/04-configuration/THIRDWEB_RPC_CLOUDFLARE_SETUP.md"
echo ""