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>"}'