{"name":"Vaultfire — Batch Onboard","summary":"Single-tx onboarding: register agent + grant consent + open partnership bond in one call (Base only).","description":"Vaultfire — the express-onboarding primitive. VaultfireBatchOnboarder bundles registerAgent + grantConsent + createPartnershipBond into one atomic tx, saving gas and round-trips. Deployed only on Base. — ENDPOINT BEHAVIOR: GET returns this spec for free. POST (paid $0.10 USDC) returns an unsigned tx; sign locally. — ON-CHAIN MECHANIC (VaultfireBatchOnboarder.batchOnboard(string name, string agentURI, bytes32 purposeHash, address partner, string partnershipType)): partner MUST differ from caller; name MUST be available; purposeHash MUST be non-zero.","priceUsdc":"0.50","tags":["vaultfire","onboarding","batch","base-only"],"mimeType":"application/json","inputSchema":{"bodyType":"json","bodyFields":{"walletAddress":{"type":"address","required":true,"description":"Onboarding wallet — becomes msg.sender, agent controller, bond owner."},"name":{"type":"string","required":true,"description":"Agent name. Same rules as register-agent: 3–32 chars, lowercase alphanumeric + hyphens."},"agentURI":{"type":"string","required":true,"description":"Agent metadata URI (https / ipfs)."},"purposeHash":{"type":"bytes32","required":true,"description":"Consent purposeHash for KYA record."},"partner":{"type":"address","required":true,"description":"Partnership counter-party. MUST differ from walletAddress."},"partnershipType":{"type":"string","required":false,"description":"Partnership label. 0–200 bytes.","default":""},"chain":{"type":"string","required":false,"description":"ONLY 'base' is supported — VaultfireBatchOnboarder is deployed only on Base.","enum":["base"],"default":"base"}}},"outputSchema":{"type":"object","properties":{"success":{"type":"boolean","required":true,"description":"Always true on a 200 response."},"txData":{"type":"object","required":true,"description":"Unsigned tx: { to, data, value, chainId, gasEstimate }. Sign locally and broadcast."},"chain":{"type":"string","required":true,"description":"The chain the tx is prepared for."},"contract":{"type":"address","required":true,"description":"Target contract on the chosen chain."},"explorer":{"type":"string","required":true,"description":"Block-explorer URL for the contract."},"message":{"type":"string","required":true,"description":"Human-readable summary the caller can show in their UI."}}},"contract":{"name":"VaultfireBatchOnboarder","solidityFunction":"batchOnboard(string name, string agentURI, bytes32 purposeHash, address partner, string partnershipType)","selector":"0x5bd38047","payable":false,"usesEip3009":false,"valueConstraints":null},"networks":[{"chain":"base","chainId":8453,"rpc":"https://base-rpc.publicnode.com","explorer":"https://basescan.org","contract":"0x82c6a0dd34F5cF57F8B98Ee118e911B977618890","contractExplorerUrl":"https://basescan.org/address/0x82c6a0dd34F5cF57F8B98Ee118e911B977618890","usdcDomain":{"name":"USD Coin","version":"2","chainId":8453,"verifyingContract":"0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913"}}],"servicePayee":{"address":"0xfA15Ee28939B222B0448261A22156070f0A7813C","ens":"ghostkey.base.eth","note":"All Vaultfire service fees route to the protocol payee. Never send funds to any other address claiming to be Vaultfire."},"integration":["1. GET this endpoint (free) to retrieve the spec.","2. Build the POST body matching inputSchema.bodyFields.","3. POST with valid x402 payment header (price: 0.50 USDC).","4. Endpoint returns unsigned txData. Sign LOCALLY in your wallet. Vaultfire NEVER accepts private keys.","5. Broadcast the signed tx to the chain RPC. Track via explorer URL."],"reverts":[{"condition":"name already taken","reason":"name taken"},{"condition":"partner == msg.sender","reason":"partner must differ"},{"condition":"purposeHash zero","reason":"zero purpose hash"}],"liveProof":{"status":"pattern-only","note":"This specific action has not yet been exercised on mainnet under live monitoring. The underlying primitive (tx-prepare with caller-side signing, EIP-3009 settlement where applicable) is verified by the live atomic-bond proof linked below."},"patternProof":{"pattern":"EIP-3009 + atomic settlement (pay-and-execute, one transaction, one signature)","contract":"0x3479307333c0AF75423A9B2F6826441Feb1F9F85","chain":"base","chainId":8453,"verifiedOn":"sourcify","verifiedMatch":"exact_match","exampleTx":"0x9b5b0643c212ea095db02e86cc739c13473d21d27fa94b7371078d549a0fdae0","exampleBlock":46383869,"exampleGas":276841,"exampleNote":"First production atomic bond. Single tx emitted USDC AuthorizationUsed + USDC Transfer + AtomicBondCreated. The same EIP-3009 + atomic-execute primitive is the basis of every payable Vaultfire action.","explorerUrl":"https://basescan.org/tx/0x9b5b0643c212ea095db02e86cc739c13473d21d27fa94b7371078d549a0fdae0","sourceUrl":"https://repo.sourcify.dev/contracts/full_match/8453/0x3479307333c0AF75423A9B2F6826441Feb1F9F85/"},"security":{"privateKeysPolicy":"Vaultfire NEVER accepts private keys. All POST handlers reject any field shaped like a private key (privateKey, private_key, secret, mnemonic, seed).","signingModel":"tx-prepare: the endpoint returns unsigned calldata. The caller signs locally in their wallet (Base App, MetaMask, WalletConnect, Coinbase Wallet, etc.) and broadcasts.","custodyModel":"no-custody: Vaultfire holds nothing. Funds and stakes settle inside the caller's own transaction.","x402Facilitator":"Verify / Settle / Submit-signed are CORS-restricted to known marketplace origins. Nonces are durably deduplicated in Upstash KV (fail-closed on KV outage)."},"links":{"documentation":"https://theloopbreaker.com/docs","protocol":"https://theloopbreaker.com","repository":"https://gitlawb.com/z6MkryiNsYdFEMHv95wxzSQ1vtFXPyVQQrxXdPw3tE5HpfxV/vaultfire","relatedEndpoints":["/api/x402/actions/register-agent","/api/x402/actions/grant-consent","/api/x402/actions/create-partnership-bond"]},"_discovery":{"version":"1.0","emittedBy":"vaultfire-x402","endpointStability":"stable","getIsFree":true,"postIsPaid":true}}