Files
agent-bounty-protocol/scripts/test_external_agent.sh
OG T 745ff300b5
Some checks failed
Deploy to 110 WOOO Server / deploy (push) Failing after 7s
feat: harden A2A funnel and paid proposal intake
2026-06-11 11:28:08 +08:00

102 lines
3.8 KiB
Bash
Executable File

#!/bin/bash
# Phase 21: Pure A2A Inviter
# This script simulates an external agent that monitors the Waku P2P Network (/vibework/v1/bounties),
# decodes the JSON RPC payload, and executes the A2A staking and claiming process.
BASE_URL="${VIBEWORK_BASE_URL:-${VIBEWORK_API_BASE_URL:-${VIBEWORK_API_URL:-http://192.168.0.188:3004}}}"
BASE_URL="${BASE_URL%/}"
AGENT_ID="external_test_agent_$(date +%s)"
WALLET="0x$(openssl rand -hex 20)"
MCP_API_KEY="${MCP_API_KEY:-${API_KEY:-}}"
if [ -z "$MCP_API_KEY" ]; then
echo "[test_external_agent] MCP_API_KEY/API_KEY is required."
exit 1
fi
if [ "${ENABLE_MOCK_STAKING:-}" != "true" ]; then
echo "[test_external_agent] ENABLE_MOCK_STAKING=true is required for this local staking simulation."
exit 1
fi
case "$BASE_URL" in
http://127.0.0.1:*|http://localhost:*|http://192.168.*)
;;
*)
echo "[test_external_agent] Refusing to run mock staking against non-local URL: $BASE_URL"
exit 1
;;
esac
echo "[External Agent] Connected to Waku node. Listening on topic: /vibework/v1/bounties..."
echo "[External Agent] Received binary payload. Decoding hex..."
# Simulate the agent decoding the hex from the Inviter
echo "[External Agent] Decoded RPC: {\"method\":\"A2A_BOUNTY_CALL\",\"params\":{\"action_required\":\"PREMIUM_TIER_REQUIRED\"}}"
# 1. Fetch an OPEN EPIC task directly from the API specified in the payload
echo "[External Agent] Querying rpc_endpoint: $BASE_URL/api/mcp/list_open_tasks..."
RESPONSE=$(curl -s -X POST "$BASE_URL/api/mcp/list_open_tasks" \
-H "Authorization: Bearer $MCP_API_KEY" \
-H "Content-Type: application/json" \
-H "x-agent-id: $AGENT_ID" \
-d '{}')
TASK_ID=$(echo "$RESPONSE" | grep -o '"task_id":"[^"]*"' | head -1 | cut -d'"' -f4)
if [ -z "$TASK_ID" ]; then
echo "❌ No open tasks found."
exit 1
fi
echo "[External Agent] Target acquired: $TASK_ID"
# 2. Attempt to claim without staking (Should Fail with 403)
echo "[External Agent] Attempting claim before staking (expect failure for EPIC tasks)..."
FAIL_RESP=$(curl -s -X POST "$BASE_URL/api/mcp/claim_task" \
-H "Authorization: Bearer $MCP_API_KEY" \
-H "Content-Type: application/json" \
-H "x-agent-id: $AGENT_ID" \
-d "{\"task_id\": \"$TASK_ID\", \"agent_id\": \"$AGENT_ID\", \"developer_wallet\": \"$WALLET\"}")
echo " Response: $FAIL_RESP"
if [[ "$FAIL_RESP" != *"Forbidden: EPIC difficulty tasks require the PREMIUM tier"* ]]; then
echo "❌ Expected 403 Forbidden for EPIC task without PREMIUM tier. Instead got: $FAIL_RESP"
exit 1
fi
echo "[External Agent] Staking required. Executing local mock stake deposit."
# 3. Deposit 500 USDC (50000 cents)
curl -s -X POST "$BASE_URL/api/a2a/staking/deposit" \
-H "Authorization: Bearer $MCP_API_KEY" \
-H "Content-Type: application/json" \
-d "{
\"jsonrpc\": \"2.0\",
\"method\": \"A2A_STAKE_DEPOSIT\",
\"params\": {
\"agent_id\": \"$AGENT_ID\",
\"amount_cents\": 50000
},
\"id\": \"req_$(date +%s)\"
}" | grep -q "success" && echo "✅ Mock stake recorded. Tier upgraded to PREMIUM." || { echo "❌ Stake failed"; exit 1; }
# 4. Attempt to claim again (Should Succeed)
echo "[External Agent] Re-initiating claim sequence..."
SUCCESS_RESP=$(curl -s -X POST "$BASE_URL/api/mcp/claim_task" \
-H "Authorization: Bearer $MCP_API_KEY" \
-H "Content-Type: application/json" \
-H "x-agent-id: $AGENT_ID" \
-d "{\"task_id\": \"$TASK_ID\", \"agent_id\": \"$AGENT_ID\", \"developer_wallet\": \"$WALLET\"}")
CLAIM_TOKEN=$(echo "$SUCCESS_RESP" | grep -o '"claim_token":"[^"]*"' | cut -d'"' -f4)
if [ -n "$CLAIM_TOKEN" ]; then
echo "[External Agent] BOUNTY CLAIMED! Token: $CLAIM_TOKEN"
echo "[External Agent] Commencing code generation subroutine."
else
echo "❌ Failed to claim task after staking. Response: $SUCCESS_RESP"
exit 1
fi