Files
proxmox/rpc-translator-138/scripts/complete-all-tasks.sh

146 lines
5.6 KiB
Bash
Raw Normal View History

#!/bin/bash
# Complete all remaining tasks - One script to rule them all
# Usage: ./scripts/complete-all-tasks.sh
set -e
PROXMOX_HOST="192.168.11.11" # r630-01
WEB3SIGNER_IP="192.168.11.111"
WEB3SIGNER_CONTAINER="107"
echo "═══════════════════════════════════════════════════════════════"
echo "🚀 COMPLETING ALL REMAINING TASKS"
echo "═══════════════════════════════════════════════════════════════"
echo ""
# Step 1: Fix permissions
echo "Step 1: Fixing permissions on keystore files..."
ssh root@$PROXMOX_HOST "pct exec $WEB3SIGNER_CONTAINER -- bash -c 'for f in /opt/web3signer/data/keys/*.json; do [ -f \"\$f\" ] && chmod 644 \"\$f\" && echo \" ✅ \$(basename \$f)\"; done'" || {
echo "⚠️ Permission fix failed, continuing..."
}
# Step 2: Verify files
echo ""
echo "Step 2: Verifying files exist..."
ssh root@$PROXMOX_HOST "pct exec $WEB3SIGNER_CONTAINER -- ls -lh /opt/web3signer/data/keys/" || {
echo "⚠️ Could not list files"
}
# Step 3: Restart Web3Signer
echo ""
echo "Step 3: Restarting Web3Signer..."
ssh root@$PROXMOX_HOST "pct exec $WEB3SIGNER_CONTAINER -- systemctl restart web3signer && sleep 5" || {
echo "⚠️ Restart failed"
}
# Step 4: Verify keys loaded
echo ""
echo "Step 4: Verifying keys are loaded..."
sleep 3
KEYS=$(curl -s http://$WEB3SIGNER_IP:9000/api/v1/eth1/publicKeys 2>/dev/null || echo "[]")
if [ "$KEYS" != "[]" ] && [ -n "$KEYS" ]; then
KEY_COUNT=$(echo "$KEYS" | jq '. | length' 2>/dev/null || echo "0")
if [ "$KEY_COUNT" -gt 0 ]; then
echo "✅ SUCCESS: $KEY_COUNT key(s) loaded!"
echo ""
echo "Loaded addresses:"
echo "$KEYS" | jq -r '.[]' | while read addr; do
echo " - $addr"
done
echo ""
ADDRESSES=$(echo "$KEYS" | jq -r '.[]' | tr '\n' ',' | sed 's/,$//')
echo "$ADDRESSES" > /tmp/web3signer-addresses.txt
echo "✅ Addresses saved for allowlist configuration"
else
echo "⚠️ Keys endpoint returned empty array"
exit 1
fi
else
echo "⚠️ No keys loaded yet"
echo "Checking Web3Signer logs..."
ssh root@$PROXMOX_HOST "pct exec $WEB3SIGNER_CONTAINER -- journalctl -u web3signer.service -n 30 --no-pager" 2>&1 | tail -20
exit 1
fi
# Step 5: Configure allowlist
echo ""
echo "Step 5: Configuring wallet allowlist on all translator VMIDs..."
cd "$(dirname "$0")/.."
if [ -f /tmp/web3signer-addresses.txt ]; then
ADDRESSES=$(cat /tmp/web3signer-addresses.txt)
./scripts/configure-wallet-allowlist.sh "$ADDRESSES" || {
echo "⚠️ Allowlist configuration failed"
}
else
echo "⚠️ Addresses file not found"
fi
# Step 6: Verify allowlist
echo ""
echo "Step 6: Verifying allowlist configuration..."
for IP in 192.168.11.240 192.168.11.241 192.168.11.242; do
ALLOWLIST=$(ssh -i ~/.ssh/proxmox_translator -o StrictHostKeyChecking=no root@$IP "grep '^WALLET_ALLOWLIST=' /opt/rpc-translator-138/.env 2>/dev/null | cut -d'=' -f2-" || echo "")
if [ -n "$ALLOWLIST" ] && [ "$ALLOWLIST" != "" ]; then
COUNT=$(echo "$ALLOWLIST" | tr ',' '\n' | wc -l)
echo "$IP: $COUNT address(es) configured"
else
echo " ⚠️ $IP: Not configured"
fi
done
# Step 7: Test transaction signing
echo ""
echo "Step 7: Testing transaction signing..."
ADDRESS=$(echo "$KEYS" | jq -r '.[0]' 2>/dev/null)
if [ -n "$ADDRESS" ] && [ "$ADDRESS" != "null" ]; then
echo "Testing with address: $ADDRESS"
RESULT=$(curl -s -X POST http://192.168.11.240:9545 \
-H 'Content-Type: application/json' \
-d "{\"jsonrpc\":\"2.0\",\"method\":\"eth_sendTransaction\",\"params\":[{\"from\":\"$ADDRESS\",\"to\":\"0x0000000000000000000000000000000000000000\",\"value\":\"0x0\",\"gas\":\"0x5208\"}],\"id\":1}")
if echo "$RESULT" | jq -e '.result' >/dev/null 2>&1; then
TX_HASH=$(echo "$RESULT" | jq -r '.result')
echo " ✅ Transaction submitted successfully!"
echo " Transaction hash: $TX_HASH"
else
ERROR=$(echo "$RESULT" | jq -r '.error.message // .error // "Unknown error"' 2>/dev/null || echo "Unknown error")
echo " ⚠️ Transaction failed: $ERROR"
fi
else
echo " ⚠️ No addresses available for testing"
fi
# Step 8: Verify all services
echo ""
echo "Step 8: Verifying all services..."
./scripts/monitor-services.sh 2>&1 | head -50
# Step 9: Test RPC methods
echo ""
echo "Step 9: Testing RPC methods..."
echo ""
echo "1. eth_chainId:"
curl -s -X POST http://192.168.11.240:9545 \
-H 'Content-Type: application/json' \
-d '{"jsonrpc":"2.0","method":"eth_chainId","params":[],"id":1}' | jq '.'
echo ""
echo "2. Health check:"
curl -s http://192.168.11.240:9545/health | jq '.'
echo ""
echo "═══════════════════════════════════════════════════════════════"
echo "✅ ALL TASKS COMPLETE"
echo "═══════════════════════════════════════════════════════════════"
echo ""
echo "Summary:"
echo " ✅ Permissions fixed"
echo " ✅ Web3Signer restarted"
echo " ✅ Keys loaded: $KEY_COUNT"
echo " ✅ Allowlist configured"
echo " ✅ Services verified"
echo " ✅ RPC methods tested"
echo ""
echo "The RPC Translator 138 is fully operational! 🎉"