POST /api/skill/nft-portfolioBundled execution of the NFT portfolio workflow — NFT + wallet snapshot: NFT holdings, native balance, and ETH price for a given address in one call. One x402 payment runs 3 underlying tools (nft-holdings, wallet-balance, crypto-price); partial-success per step.
| Field | Type | Description |
|---|---|---|
address * | string | Wallet address (0x…) |
{
"pack": "nft-portfolio",
"args": {
"address": "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
},
"steps": [
{
"slug": "nft-holdings",
"ok": true,
"result": {}
},
{
"slug": "wallet-balance",
"ok": true,
"result": {}
},
{
"slug": "crypto-price",
"ok": true,
"result": {}
}
],
"summary": "3/3 steps succeeded"
}
curl -i -X POST https://agent402.tools/api/skill/nft-portfolio \
-H "Content-Type: application/json" \
-d '{"address":"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"}'
The response is HTTP 402 Payment Required with exact payment requirements. Any x402 v2 client pays automatically and retries:
import { wrapFetchWithPayment } from "@x402/fetch";
import { x402Client } from "@x402/core/client";
import { registerExactEvmScheme } from "@x402/evm/exact/client";
import { privateKeyToAccount } from "viem/accounts";
const client = new x402Client();
registerExactEvmScheme(client, { signer: privateKeyToAccount(KEY) });
const payFetch = wrapFetchWithPayment(fetch, client);
const res = await payFetch("https://agent402.tools/api/skill/nft-portfolio", {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({
"address": "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
}),
});
POST /api/skill/security-auditBundled execution of the Security audit workflow — Enumerate a domain's external attack surface in one workflow: certs, …
POST /api/skill/email-deliverabilityBundled execution of the Email deliverability workflow — Diagnose why a domain's email lands in spam: SPF posture, DMARC…
POST /api/skill/market-briefBundled execution of the Crypto market brief workflow — Quick crypto market snapshot: price for a specific coin, trendin…