heroes · gedx402

Turnstile verify

Server-side Turnstile siteverify — one x402 payment validates a client widget token and returns success, hostname, and error-codes for browser agents.

$0.006 wire settlement

POST https://verify.gedx402.com/v1/turnstile/verify

@x402/fetch (TypeScript)

standard x402 client — fund USDC on Base, set PRIVATE_KEY. integrator quickstart

import { wrapFetchWithPayment } from "@x402/fetch";
import { x402Client } from "@x402/core/client";
import { ExactEvmScheme } from "@x402/evm/exact/client";
import { privateKeyToAccount } from "viem/accounts";

const signer = privateKeyToAccount(process.env.PRIVATE_KEY as `0x${string}`);
const client = new x402Client();
client.register("eip155:*", new ExactEvmScheme(signer));
const fetchWithPayment = wrapFetchWithPayment(fetch, client);

const res = await fetchWithPayment("https://verify.gedx402.com/v1/turnstile/verify", {
  method: "POST",
  headers: { "Content-Type": "application/json" },
  body: JSON.stringify({
    token: "<turnstile-response-token>"
  }),
});
const data = await res.json();

awal (agent convenience)

Coinbase Agentic Wallet CLI — no private key in code. external payer guide

npx awal@2.12.0 x402 pay \
  --url https://verify.gedx402.com/v1/turnstile/verify \
  --method POST \
  --body '{"token":"<turnstile-response-token>"}'

curl (discovery)

unauthenticated POST returns 402 + payment-required — inspect pricing before paying.

curl -X POST https://verify.gedx402.com/v1/turnstile/verify \
  -H "Content-Type: application/json" \
  -d '{"token":"<turnstile-response-token>"}'