- 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.
139 lines
5.6 KiB
Bash
Executable File
139 lines
5.6 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Fix allowances for both WETH9 and WETH10 bridges
|
|
# Usage: ./fix-all-allowances.sh [amount_in_eth]
|
|
|
|
set -euo pipefail
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
SOURCE_PROJECT="/home/intlc/projects/smom-dbis-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"; }
|
|
|
|
source "$SOURCE_PROJECT/.env"
|
|
|
|
RPC_URL="${RPC_URL_138:-http://192.168.11.250:8545}"
|
|
WETH9_ADDRESS="0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2"
|
|
WETH10_ADDRESS="0xf4BB2e28688e89fCcE3c0580D37d36A7672E8A9f"
|
|
WETH9_BRIDGE="${CCIPWETH9_BRIDGE_CHAIN138:-0x89dd12025bfCD38A168455A44B400e913ED33BE2}"
|
|
WETH10_BRIDGE="${CCIPWETH10_BRIDGE_CHAIN138:-0xe0E93247376aa097dB308B92e6Ba36bA015535D0}"
|
|
|
|
AMOUNT="${1:-7.0}" # Default 7 ETH (for 7 chains)
|
|
AMOUNT_WEI=$(cast --to-wei "$AMOUNT" ether 2>/dev/null)
|
|
|
|
DEPLOYER=$(cast wallet address --private-key "$PRIVATE_KEY" 2>/dev/null)
|
|
|
|
log_info "========================================="
|
|
log_info "Fix All Bridge Allowances"
|
|
log_info "========================================="
|
|
log_info ""
|
|
log_info "Amount: $AMOUNT ETH"
|
|
log_info "Deployer: $DEPLOYER"
|
|
log_info ""
|
|
|
|
# Check current allowances
|
|
log_info "Checking current allowances..."
|
|
WETH9_ALLOW=$(cast call "$WETH9_ADDRESS" "allowance(address,address)" "$DEPLOYER" "$WETH9_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
WETH10_ALLOW=$(cast call "$WETH10_ADDRESS" "allowance(address,address)" "$DEPLOYER" "$WETH10_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
|
|
WETH9_ALLOW_ETH=$(echo "scale=6; $WETH9_ALLOW / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
WETH10_ALLOW_ETH=$(echo "scale=6; $WETH10_ALLOW / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
|
|
log_info "WETH9 Allowance: $WETH9_ALLOW_ETH ETH"
|
|
log_info "WETH10 Allowance: $WETH10_ALLOW_ETH ETH"
|
|
log_info ""
|
|
|
|
# Fix WETH9 allowance
|
|
if [ "$WETH9_ALLOW" = "0" ] || [ "$WETH9_ALLOW" = "0x0000000000000000000000000000000000000000000000000000000000000000" ] || (( $(echo "$WETH9_ALLOW_ETH < $AMOUNT" | bc -l 2>/dev/null || echo 1) )); then
|
|
log_info "Fixing WETH9 bridge allowance..."
|
|
CURRENT_NONCE=$(cast nonce "$DEPLOYER" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
|
|
TX_OUTPUT=$(cast send "$WETH9_ADDRESS" \
|
|
"approve(address,uint256)" \
|
|
"$WETH9_BRIDGE" \
|
|
"$AMOUNT_WEI" \
|
|
--rpc-url "$RPC_URL" \
|
|
--private-key "$PRIVATE_KEY" \
|
|
--gas-price 20000000000 \
|
|
--nonce "$CURRENT_NONCE" \
|
|
2>&1 || echo "FAILED")
|
|
|
|
if echo "$TX_OUTPUT" | grep -qE "transactionHash"; then
|
|
HASH=$(echo "$TX_OUTPUT" | grep -oE "transactionHash[[:space:]]+0x[0-9a-fA-F]{64}" | awk '{print $2}')
|
|
log_success "✓ WETH9 approval sent: $HASH"
|
|
sleep 15
|
|
elif echo "$TX_OUTPUT" | grep -q "Known transaction"; then
|
|
log_warn "⚠ WETH9 approval already pending"
|
|
else
|
|
log_error "✗ WETH9 approval failed: $(echo "$TX_OUTPUT" | grep -E "Error" | head -1 || echo "Unknown")"
|
|
fi
|
|
else
|
|
log_success "✓ WETH9 allowance sufficient: $WETH9_ALLOW_ETH ETH"
|
|
fi
|
|
|
|
# Fix WETH10 allowance
|
|
if [ "$WETH10_ALLOW" = "0" ] || [ "$WETH10_ALLOW" = "0x0000000000000000000000000000000000000000000000000000000000000000" ] || (( $(echo "$WETH10_ALLOW_ETH < $AMOUNT" | bc -l 2>/dev/null || echo 1) )); then
|
|
log_info "Fixing WETH10 bridge allowance..."
|
|
CURRENT_NONCE=$(cast nonce "$DEPLOYER" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
|
|
TX_OUTPUT=$(cast send "$WETH10_ADDRESS" \
|
|
"approve(address,uint256)" \
|
|
"$WETH10_BRIDGE" \
|
|
"$AMOUNT_WEI" \
|
|
--rpc-url "$RPC_URL" \
|
|
--private-key "$PRIVATE_KEY" \
|
|
--gas-price 20000000000 \
|
|
--nonce "$CURRENT_NONCE" \
|
|
2>&1 || echo "FAILED")
|
|
|
|
if echo "$TX_OUTPUT" | grep -qE "transactionHash"; then
|
|
HASH=$(echo "$TX_OUTPUT" | grep -oE "transactionHash[[:space:]]+0x[0-9a-fA-F]{64}" | awk '{print $2}')
|
|
log_success "✓ WETH10 approval sent: $HASH"
|
|
sleep 15
|
|
elif echo "$TX_OUTPUT" | grep -q "Known transaction"; then
|
|
log_warn "⚠ WETH10 approval already pending"
|
|
else
|
|
log_error "✗ WETH10 approval failed: $(echo "$TX_OUTPUT" | grep -E "Error" | head -1 || echo "Unknown")"
|
|
fi
|
|
else
|
|
log_success "✓ WETH10 allowance sufficient: $WETH10_ALLOW_ETH ETH"
|
|
fi
|
|
|
|
log_info ""
|
|
log_info "Waiting 30 seconds for confirmations..."
|
|
sleep 30
|
|
|
|
# Verify allowances
|
|
log_info "Verifying allowances..."
|
|
WETH9_ALLOW=$(cast call "$WETH9_ADDRESS" "allowance(address,address)" "$DEPLOYER" "$WETH9_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
WETH10_ALLOW=$(cast call "$WETH10_ADDRESS" "allowance(address,address)" "$DEPLOYER" "$WETH10_BRIDGE" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
|
|
WETH9_ALLOW_ETH=$(echo "scale=6; $WETH9_ALLOW / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
WETH10_ALLOW_ETH=$(echo "scale=6; $WETH10_ALLOW / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
|
|
log_info ""
|
|
log_success "========================================="
|
|
log_success "Allowance Fix Complete!"
|
|
log_success "========================================="
|
|
log_info ""
|
|
log_info "Final Status:"
|
|
log_info " WETH9 Allowance: $WETH9_ALLOW_ETH ETH"
|
|
log_info " WETH10 Allowance: $WETH10_ALLOW_ETH ETH"
|
|
log_info ""
|
|
|
|
if (( $(echo "$WETH9_ALLOW_ETH >= $AMOUNT" | bc -l 2>/dev/null || echo 0) )) && (( $(echo "$WETH10_ALLOW_ETH >= $AMOUNT" | bc -l 2>/dev/null || echo 0) )); then
|
|
log_success "✅ All allowances are sufficient!"
|
|
else
|
|
log_warn "⚠ Some allowances may still be pending. Wait a few minutes and check again."
|
|
fi
|
|
|