opentool 0.7.2 → 0.7.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/x402/types.ts","../../src/x402/helpers.ts","../../src/x402/client.ts","../../src/x402/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["import { z } from \"zod\";\n\nexport const X402_VERSION = 1;\nexport const HEADER_X402 = \"X-PAYMENT\";\nexport const HEADER_PAYMENT_RESPONSE = \"X-PAYMENT-RESPONSE\";\n\nexport const x402RequirementSchema = z.object({\n scheme: z.string().min(1),\n network: z.string().min(1),\n maxAmountRequired: z.string().min(1),\n asset: z.string().min(1),\n payTo: z.string().min(1),\n resource: z.string().optional(),\n description: z.string().optional(),\n mimeType: z.string().optional(),\n outputSchema: z.unknown().optional(),\n maxTimeoutSeconds: z.number().int().positive().optional(),\n extra: z.record(z.string(), z.unknown()).nullable().optional(),\n});\n\nexport type X402Requirement = z.infer<typeof x402RequirementSchema>;\n\nexport const x402PaymentHeaderSchema = z.object({\n x402Version: z.number().int().positive(),\n scheme: z.string().min(1),\n network: z.string().min(1),\n correlationId: z.string().optional(),\n payload: z.unknown(),\n});\n\nexport type X402PaymentHeader = z.infer<typeof x402PaymentHeaderSchema>;\n\nexport interface X402RequirementsResponse {\n x402Version: number;\n error?: string;\n accepts: X402Requirement[];\n}\n\nexport interface X402PaymentAttempt {\n type: \"x402\";\n headerName: typeof HEADER_X402;\n raw: string;\n payload: X402PaymentHeader;\n}\n\nexport interface X402VerificationResult {\n success: boolean;\n metadata?: {\n optionId: string;\n verifier: string;\n [key: string]: unknown;\n };\n failure?: {\n reason: string;\n code: string;\n };\n responseHeaders?: Record<string, string>;\n}\n\nexport interface X402FacilitatorConfig {\n url: string;\n verifyPath?: string;\n settlePath?: string;\n apiKeyHeader?: string;\n}\n\nexport interface CurrencySpec {\n decimals: number;\n symbol: string;\n network: string;\n assetAddress: string;\n}\n\nexport const SUPPORTED_CURRENCIES: Record<string, CurrencySpec> = {\n USDC: {\n decimals: 6,\n symbol: \"USDC\",\n network: \"base\",\n assetAddress: \"0x833589fCD6eDb6E08f4c7C37b7b4c6e997E08A43\",\n },\n};\n\nexport const DEFAULT_FACILITATOR: X402FacilitatorConfig = {\n url: \"https://facilitator.x402.rs\",\n verifyPath: \"/verify\",\n settlePath: \"/settle\",\n apiKeyHeader: \"Authorization\",\n};\n","import { z } from \"zod\";\nimport {\n HEADER_X402,\n HEADER_PAYMENT_RESPONSE,\n X402_VERSION,\n x402PaymentHeaderSchema,\n x402RequirementSchema,\n type X402PaymentAttempt,\n type X402Requirement,\n type X402VerificationResult,\n type X402FacilitatorConfig,\n} from \"./types\";\n\nexport interface X402PaymentDefinition {\n amount: string;\n currency: { code: string; symbol: string; decimals: number };\n asset: { symbol: string; network: string; address: string; decimals: number };\n payTo: string;\n resource?: string;\n description?: string;\n scheme: string;\n network: string;\n facilitator: X402FacilitatorConfig;\n metadata?: Record<string, unknown>;\n}\n\nexport function createX402PaymentRequired(\n definition: X402PaymentDefinition\n): Response {\n const requirement = toX402Requirement(definition);\n\n // Build full payment requirements response\n const body = {\n schemaVersion: 1,\n message: definition.description ?? \"Payment required\",\n resource: definition.resource,\n accepts: [\n {\n id: \"x402\",\n title: `Pay ${definition.amount} ${definition.currency.code}`,\n description: definition.description,\n amount: {\n value: definition.amount,\n currency: {\n code: definition.currency.code,\n symbol: definition.currency.symbol,\n decimals: definition.currency.decimals,\n kind: \"crypto\",\n },\n },\n asset: {\n symbol: definition.asset.symbol,\n network: definition.asset.network,\n address: definition.asset.address,\n decimals: definition.asset.decimals,\n standard: \"erc20\",\n },\n payTo: definition.payTo,\n resource: definition.resource,\n proof: {\n mode: \"x402\",\n scheme: definition.scheme,\n network: definition.network,\n version: X402_VERSION,\n facilitator: definition.facilitator,\n verifier: \"x402:facilitator\",\n },\n },\n ],\n metadata: definition.metadata ?? {},\n x402: {\n x402Version: X402_VERSION,\n error: definition.description ?? \"Payment required\",\n accepts: [requirement],\n },\n };\n\n return new Response(JSON.stringify(body), {\n status: 402,\n headers: {\n \"Content-Type\": \"application/json\",\n },\n });\n}\n\nexport function extractX402Attempt(request: Request): X402PaymentAttempt | null {\n const raw = request.headers.get(HEADER_X402);\n if (!raw) {\n return null;\n }\n\n try {\n const payload = decodeJson(raw, x402PaymentHeaderSchema);\n return {\n type: \"x402\",\n headerName: HEADER_X402,\n raw,\n payload,\n };\n } catch {\n return null;\n }\n}\n\nexport async function verifyX402Payment(\n attempt: X402PaymentAttempt,\n definition: X402PaymentDefinition,\n options: {\n settle?: boolean;\n fetchImpl?: typeof fetch;\n } = {}\n): Promise<X402VerificationResult> {\n const fetchImpl = options.fetchImpl ?? fetch;\n const facilitator = definition.facilitator;\n\n const verifierUrl = new URL(\n facilitator.verifyPath ?? \"/verify\",\n ensureTrailingSlash(facilitator.url)\n ).toString();\n\n const requirement = toX402Requirement(definition);\n const headers = buildFacilitatorHeaders(facilitator);\n\n try {\n const verifyResponse = await fetchImpl(verifierUrl, {\n method: \"POST\",\n headers,\n body: JSON.stringify({\n x402Version: attempt.payload.x402Version,\n paymentPayload: attempt.payload,\n paymentRequirements: requirement,\n }),\n });\n\n if (!verifyResponse.ok) {\n return {\n success: false,\n failure: {\n reason: `Facilitator verify request failed: ${verifyResponse.status}`,\n code: \"verification_failed\",\n },\n };\n }\n\n const verifyPayload = (await verifyResponse.json()) as {\n isValid: boolean;\n invalidReason?: string | null;\n };\n\n if (!verifyPayload.isValid) {\n return {\n success: false,\n failure: {\n reason: verifyPayload.invalidReason ?? \"Facilitator verification failed\",\n code: \"verification_failed\",\n },\n };\n }\n\n const responseHeaders: Record<string, string> = {};\n if (options.settle) {\n const settleUrl = new URL(\n facilitator.settlePath ?? \"/settle\",\n ensureTrailingSlash(facilitator.url)\n ).toString();\n\n try {\n const settleResponse = await fetchImpl(settleUrl, {\n method: \"POST\",\n headers,\n body: JSON.stringify({\n x402Version: attempt.payload.x402Version,\n paymentPayload: attempt.payload,\n paymentRequirements: requirement,\n }),\n });\n\n if (settleResponse.ok) {\n const settlePayload = (await settleResponse.json()) as {\n txHash?: string;\n [key: string]: unknown;\n };\n if (settlePayload.txHash) {\n responseHeaders[HEADER_PAYMENT_RESPONSE] = JSON.stringify({\n settled: true,\n txHash: settlePayload.txHash,\n });\n }\n }\n } catch {\n // Settlement failure doesn't fail verification\n }\n }\n\n const result: X402VerificationResult = {\n success: true,\n metadata: {\n optionId: \"x402\",\n verifier: \"x402:facilitator\",\n amount: definition.amount,\n currency: definition.currency.code,\n network: definition.network,\n },\n };\n\n if (Object.keys(responseHeaders).length > 0) {\n result.responseHeaders = responseHeaders;\n }\n\n return result;\n } catch (error) {\n return {\n success: false,\n failure: {\n reason: error instanceof Error ? error.message : \"Unknown error\",\n code: \"verification_failed\",\n },\n };\n }\n}\n\nfunction toX402Requirement(definition: X402PaymentDefinition): X402Requirement {\n const decimals = definition.asset.decimals;\n const units = decimalToBaseUnits(definition.amount, decimals);\n\n return x402RequirementSchema.parse({\n scheme: definition.scheme,\n network: definition.network,\n maxAmountRequired: units,\n asset: definition.asset.address,\n payTo: definition.payTo,\n resource: definition.resource,\n description: definition.description,\n mimeType: \"application/json\",\n maxTimeoutSeconds: 900,\n extra: {\n symbol: definition.asset.symbol,\n currencyCode: definition.currency.code,\n decimals,\n },\n });\n}\n\nfunction decimalToBaseUnits(value: string, decimals: number): string {\n const [whole, fraction = \"\"] = value.split(\".\");\n const sanitizedFraction = fraction.slice(0, decimals);\n const paddedFraction = sanitizedFraction.padEnd(decimals, \"0\");\n const combined = `${whole}${paddedFraction}`.replace(/^0+/, \"\");\n return combined.length > 0 ? combined : \"0\";\n}\n\nfunction decodeJson<T>(value: string, schema: z.ZodSchema<T>): T {\n const base64 = normalizeBase64(value);\n const json = Buffer.from(base64, \"base64\").toString(\"utf-8\");\n const parsed = JSON.parse(json);\n return schema.parse(parsed);\n}\n\nfunction normalizeBase64(input: string): string {\n if (/^[A-Za-z0-9+/=]+$/.test(input)) {\n return input;\n }\n const restored = input.replace(/-/g, \"+\").replace(/_/g, \"/\");\n const paddingNeeded = (4 - (restored.length % 4)) % 4;\n return restored + \"=\".repeat(paddingNeeded);\n}\n\nfunction buildFacilitatorHeaders(facilitator: X402FacilitatorConfig): Record<string, string> {\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n };\n if (facilitator.apiKeyHeader && process.env.X402_FACILITATOR_API_KEY) {\n headers[facilitator.apiKeyHeader] = process.env.X402_FACILITATOR_API_KEY;\n }\n return headers;\n}\n\nfunction ensureTrailingSlash(url: string): string {\n return url.endsWith(\"/\") ? url : `${url}/`;\n}\n\nexport const PAYMENT_HEADERS = [HEADER_X402, HEADER_PAYMENT_RESPONSE] as const;\n","import { createWalletClient, http, type Address, type PrivateKeyAccount, type WalletClient } from \"viem\";\nimport { privateKeyToAccount } from \"viem/accounts\";\nimport { baseSepolia } from \"viem/chains\";\n\nexport interface X402ClientConfig {\n privateKey: `0x${string}`;\n rpcUrl?: string;\n}\n\nexport interface X402PayRequest {\n url: string;\n method?: string;\n body?: unknown;\n headers?: Record<string, string>;\n}\n\nexport interface X402PayResult {\n success: boolean;\n response?: Response;\n error?: string;\n paymentDetails?: {\n amount: string;\n currency: string;\n network: string;\n signature: string;\n };\n}\n\nexport class X402Client {\n private account: PrivateKeyAccount;\n private walletClient: ReturnType<typeof createWalletClient>;\n\n constructor(config: X402ClientConfig) {\n this.account = privateKeyToAccount(config.privateKey);\n\n // Support both base and base-sepolia\n const chain = baseSepolia;\n this.walletClient = createWalletClient({\n account: this.account,\n chain,\n transport: http(config.rpcUrl),\n });\n }\n\n async pay(request: X402PayRequest): Promise<X402PayResult> {\n try {\n // Step 1: Make initial request to get 402 response\n const initialResponse = await fetch(request.url, {\n method: request.method ?? \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n ...request.headers,\n },\n ...(request.body ? { body: JSON.stringify(request.body) } : {}),\n });\n\n // If not 402, return the response directly\n if (initialResponse.status !== 402) {\n return {\n success: initialResponse.ok,\n response: initialResponse,\n };\n }\n\n // Step 2: Parse payment requirements\n const paymentRequirements = await initialResponse.json();\n const x402Requirements = paymentRequirements.x402?.accepts?.[0];\n\n if (!x402Requirements) {\n return {\n success: false,\n error: \"No x402 payment requirements found in 402 response\",\n };\n }\n\n // Step 3: Generate EIP-3009 authorization\n const authorization = await this.signTransferAuthorization({\n from: this.account.address,\n to: x402Requirements.payTo as Address,\n value: BigInt(x402Requirements.maxAmountRequired),\n validAfter: BigInt(Math.floor(Date.now() / 1000)),\n validBefore: BigInt(Math.floor(Date.now() / 1000) + 900), // 15 min\n nonce: `0x${Array.from({ length: 32 }, () =>\n Math.floor(Math.random() * 256).toString(16).padStart(2, '0')\n ).join('')}` as `0x${string}`,\n tokenAddress: x402Requirements.asset as Address,\n });\n\n // Step 4: Build X-PAYMENT header\n const paymentProof = {\n x402Version: 1,\n scheme: x402Requirements.scheme,\n network: x402Requirements.network,\n correlationId: \"\",\n payload: {\n signature: authorization.signature,\n authorization: {\n from: authorization.from,\n to: authorization.to,\n value: authorization.value.toString(),\n validAfter: authorization.validAfter.toString(),\n validBefore: authorization.validBefore.toString(),\n nonce: authorization.nonce,\n },\n },\n };\n\n const paymentHeader = Buffer.from(JSON.stringify(paymentProof)).toString(\"base64\");\n\n // Step 5: Retry request with payment\n const paidResponse = await fetch(request.url, {\n method: request.method ?? \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n \"X-PAYMENT\": paymentHeader,\n ...request.headers,\n },\n ...(request.body ? { body: JSON.stringify(request.body) } : {}),\n });\n\n return {\n success: paidResponse.ok,\n response: paidResponse,\n paymentDetails: {\n amount: x402Requirements.maxAmountRequired,\n currency: x402Requirements.extra?.currencyCode ?? \"USDC\",\n network: x402Requirements.network,\n signature: authorization.signature,\n },\n };\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : String(error),\n };\n }\n }\n\n private async signTransferAuthorization(params: {\n from: Address;\n to: Address;\n value: bigint;\n validAfter: bigint;\n validBefore: bigint;\n nonce: `0x${string}`;\n tokenAddress: Address;\n }) {\n if (!this.walletClient.chain) {\n throw new Error(\"Wallet client chain not configured\");\n }\n\n const domain = {\n name: \"USD Coin\",\n version: \"2\",\n chainId: this.walletClient.chain.id,\n verifyingContract: params.tokenAddress,\n };\n\n const types = {\n TransferWithAuthorization: [\n { name: \"from\", type: \"address\" },\n { name: \"to\", type: \"address\" },\n { name: \"value\", type: \"uint256\" },\n { name: \"validAfter\", type: \"uint256\" },\n { name: \"validBefore\", type: \"uint256\" },\n { name: \"nonce\", type: \"bytes32\" },\n ],\n };\n\n const message = {\n from: params.from,\n to: params.to,\n value: params.value,\n validAfter: params.validAfter,\n validBefore: params.validBefore,\n nonce: params.nonce,\n };\n\n const signature = await this.walletClient.signTypedData({\n account: this.account,\n domain,\n types,\n primaryType: \"TransferWithAuthorization\",\n message,\n });\n\n return {\n signature,\n from: params.from,\n to: params.to,\n value: params.value,\n validAfter: params.validAfter,\n validBefore: params.validBefore,\n nonce: params.nonce,\n };\n }\n\n getAddress(): Address {\n return this.account.address;\n }\n}\n\n// Helper function for quick testing\nexport async function payX402(config: {\n privateKey: `0x${string}`;\n url: string;\n body?: unknown;\n rpcUrl?: string;\n}): Promise<X402PayResult> {\n const client = new X402Client({\n privateKey: config.privateKey,\n ...(config.rpcUrl ? { rpcUrl: config.rpcUrl } : {}),\n });\n\n return client.pay({\n url: config.url,\n body: config.body,\n });\n}\n\nexport interface EIP3009Authorization {\n from: Address;\n to: Address;\n value: bigint;\n validAfter: bigint;\n validBefore: bigint;\n nonce: `0x${string}`;\n}\n\nexport interface X402BrowserClientConfig {\n walletClient: WalletClient;\n chainId: number;\n}\n\nexport class X402BrowserClient {\n private walletClient: WalletClient;\n private chainId: number;\n\n constructor(config: X402BrowserClientConfig) {\n this.walletClient = config.walletClient;\n this.chainId = config.chainId;\n }\n\n async pay(request: X402PayRequest): Promise<X402PayResult> {\n try {\n const initialResponse = await fetch(request.url, {\n method: request.method ?? \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n ...request.headers,\n },\n ...(request.body ? { body: JSON.stringify(request.body) } : {}),\n });\n\n if (initialResponse.status !== 402) {\n return {\n success: initialResponse.ok,\n response: initialResponse,\n };\n }\n\n const paymentRequirements = await initialResponse.json();\n const x402Requirements = paymentRequirements.x402?.accepts?.[0];\n\n if (!x402Requirements) {\n return {\n success: false,\n error: \"No x402 payment requirements found in 402 response\",\n };\n }\n\n const account = this.walletClient.account;\n if (!account) {\n return {\n success: false,\n error: \"No account connected to wallet\",\n };\n }\n\n const authorization: EIP3009Authorization = {\n from: account.address,\n to: x402Requirements.payTo as Address,\n value: BigInt(x402Requirements.maxAmountRequired),\n validAfter: BigInt(Math.floor(Date.now() / 1000)),\n validBefore: BigInt(Math.floor(Date.now() / 1000) + 900),\n nonce: `0x${Array.from({ length: 32 }, () =>\n Math.floor(Math.random() * 256).toString(16).padStart(2, '0')\n ).join('')}` as `0x${string}`,\n };\n\n const signature = await this.signTransferAuthorization(\n authorization,\n x402Requirements.asset as Address\n );\n\n const paymentProof = {\n x402Version: 1,\n scheme: x402Requirements.scheme,\n network: x402Requirements.network,\n correlationId: \"\",\n payload: {\n signature,\n authorization: {\n from: authorization.from,\n to: authorization.to,\n value: authorization.value.toString(),\n validAfter: authorization.validAfter.toString(),\n validBefore: authorization.validBefore.toString(),\n nonce: authorization.nonce,\n },\n },\n };\n\n const paymentHeader = btoa(JSON.stringify(paymentProof));\n\n const paidResponse = await fetch(request.url, {\n method: request.method ?? \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n \"X-PAYMENT\": paymentHeader,\n ...request.headers,\n },\n ...(request.body ? { body: JSON.stringify(request.body) } : {}),\n });\n\n return {\n success: paidResponse.ok,\n response: paidResponse,\n paymentDetails: {\n amount: x402Requirements.maxAmountRequired,\n currency: x402Requirements.extra?.currencyCode ?? \"USDC\",\n network: x402Requirements.network,\n signature,\n },\n };\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : String(error),\n };\n }\n }\n\n private async signTransferAuthorization(\n authorization: EIP3009Authorization,\n tokenAddress: Address\n ): Promise<`0x${string}`> {\n const account = this.walletClient.account;\n if (!account) {\n throw new Error(\"No account connected to wallet\");\n }\n\n const domain = {\n name: \"USD Coin\",\n version: \"2\",\n chainId: this.chainId,\n verifyingContract: tokenAddress,\n };\n\n const types = {\n TransferWithAuthorization: [\n { name: \"from\", type: \"address\" },\n { name: \"to\", type: \"address\" },\n { name: \"value\", type: \"uint256\" },\n { name: \"validAfter\", type: \"uint256\" },\n { name: \"validBefore\", type: \"uint256\" },\n { name: \"nonce\", type: \"bytes32\" },\n ],\n };\n\n const message = {\n from: authorization.from,\n to: authorization.to,\n value: authorization.value,\n validAfter: authorization.validAfter,\n validBefore: authorization.validBefore,\n nonce: authorization.nonce,\n };\n\n return await this.walletClient.signTypedData({\n account,\n domain,\n types,\n primaryType: \"TransferWithAuthorization\",\n message,\n });\n }\n}\n\nexport async function payX402WithWallet(\n walletClient: WalletClient,\n chainId: number,\n request: X402PayRequest\n): Promise<X402PayResult> {\n const client = new X402BrowserClient({ walletClient, chainId });\n return client.pay(request);\n}\n","import {\n createX402PaymentRequired,\n extractX402Attempt,\n verifyX402Payment,\n PAYMENT_HEADERS,\n type X402PaymentDefinition,\n} from \"./helpers\";\nimport {\n SUPPORTED_CURRENCIES,\n DEFAULT_FACILITATOR,\n type X402FacilitatorConfig,\n type X402VerificationResult,\n type CurrencySpec,\n} from \"./types\";\n\nexport interface DefineX402PaymentConfig {\n amount: string | number;\n payTo: string;\n currency?: string;\n message?: string;\n resource?: string;\n network?: string;\n assetAddress?: string;\n scheme?: \"exact\" | \"bounded\";\n facilitator?: string | X402FacilitatorConfig;\n metadata?: Record<string, unknown>;\n}\n\nexport interface X402Payment {\n definition: X402PaymentDefinition;\n metadata?: Record<string, unknown>;\n}\n\nexport interface RequireX402PaymentOptions {\n settle?: boolean;\n fetchImpl?: typeof fetch;\n onFailure?: (result: X402VerificationResult) => Response;\n}\n\nexport interface RequireX402PaymentSuccess {\n payment: {\n optionId: string;\n verifier: string;\n amount: string;\n currency: string;\n network: string;\n };\n headers: Record<string, string>;\n result: X402VerificationResult;\n}\n\nexport type RequireX402PaymentOutcome = Response | RequireX402PaymentSuccess;\n\nconst PAYMENT_CONTEXT_SYMBOL = Symbol.for(\"opentool.x402.context\");\n\nexport class X402PaymentRequiredError extends Error {\n readonly response: Response;\n readonly verification: X402VerificationResult | undefined;\n\n constructor(response: Response, verification?: X402VerificationResult) {\n super(\"X402 Payment required\");\n this.name = \"X402PaymentRequiredError\";\n this.response = response;\n this.verification = verification;\n }\n}\n\nexport type X402PaymentContext = RequireX402PaymentSuccess;\n\nfunction setPaymentContext(request: Request, context: X402PaymentContext): void {\n try {\n Object.defineProperty(request, PAYMENT_CONTEXT_SYMBOL, {\n value: context,\n configurable: true,\n enumerable: false,\n writable: true,\n });\n } catch {\n (request as any)[PAYMENT_CONTEXT_SYMBOL] = context;\n }\n}\n\nexport function getX402PaymentContext(\n request: Request\n): X402PaymentContext | undefined {\n return (request as any)[PAYMENT_CONTEXT_SYMBOL];\n}\n\nexport function defineX402Payment(config: DefineX402PaymentConfig): X402Payment {\n const currencyCode = normalizeCurrency(config.currency);\n const currencySpec = SUPPORTED_CURRENCIES[currencyCode];\n\n if (!currencySpec) {\n throw new Error(`Unsupported currency for x402 payments: ${currencyCode}`);\n }\n\n const network = config.network ?? currencySpec.network;\n const assetAddress = config.assetAddress ?? currencySpec.assetAddress;\n\n if (!network || !assetAddress) {\n throw new Error(\n \"x402 payments require a network and assetAddress; supply them or choose a supported currency.\"\n );\n }\n\n const facilitator = resolveFacilitator(config.facilitator);\n const value = toDecimalString(config.amount);\n\n const definition: X402PaymentDefinition = {\n amount: value,\n currency: {\n code: currencyCode,\n symbol: currencySpec.symbol,\n decimals: currencySpec.decimals,\n },\n asset: {\n symbol: currencySpec.symbol,\n network,\n address: assetAddress,\n decimals: currencySpec.decimals,\n },\n payTo: config.payTo,\n scheme: config.scheme ?? \"exact\",\n network,\n facilitator,\n };\n\n if (config.resource) {\n definition.resource = config.resource;\n }\n if (config.message) {\n definition.description = config.message;\n }\n if (config.metadata) {\n definition.metadata = config.metadata;\n }\n\n const baseMetadata: Record<string, unknown> = {\n amountUSDC: currencyCode === \"USDC\" ? Number(value) : undefined,\n facilitator: \"x402rs\",\n network,\n };\n\n const metadata = config.metadata\n ? { ...baseMetadata, ...config.metadata }\n : baseMetadata;\n\n return {\n definition,\n metadata,\n };\n}\n\nexport async function requireX402Payment(\n request: Request,\n payment: X402Payment | X402PaymentDefinition,\n options: RequireX402PaymentOptions = {}\n): Promise<RequireX402PaymentOutcome> {\n const definition = isX402Payment(payment) ? payment.definition : payment;\n\n const attempt = extractX402Attempt(request);\n if (!attempt) {\n const response = createX402PaymentRequired(definition);\n throw new X402PaymentRequiredError(response);\n }\n\n const verifyOptions: Parameters<typeof verifyX402Payment>[2] = {};\n if (options.settle !== undefined) {\n verifyOptions.settle = options.settle;\n }\n if (options.fetchImpl !== undefined) {\n verifyOptions.fetchImpl = options.fetchImpl;\n }\n\n const verification = await verifyX402Payment(attempt, definition, verifyOptions);\n\n if (!verification.success || !verification.metadata) {\n if (options.onFailure) {\n return options.onFailure(verification);\n }\n const response = createX402PaymentRequired(definition);\n throw new X402PaymentRequiredError(response, verification);\n }\n\n return {\n payment: verification.metadata as {\n optionId: string;\n verifier: string;\n amount: string;\n currency: string;\n network: string;\n },\n headers: verification.responseHeaders ?? {},\n result: verification,\n };\n}\n\nexport function withX402Payment(\n handler: (request: Request) => Promise<Response> | Response,\n payment: X402Payment | X402PaymentDefinition,\n options: RequireX402PaymentOptions = {}\n): (request: Request) => Promise<Response> {\n return async (request: Request): Promise<Response> => {\n const verification = await requireX402Payment(request, payment, options);\n if (verification instanceof Response) {\n return verification;\n }\n\n setPaymentContext(request, verification);\n\n const response = await Promise.resolve(handler(request));\n return applyPaymentHeaders(response, verification.headers);\n };\n}\n\nfunction applyPaymentHeaders(\n response: Response,\n headers: Record<string, string>\n): Response {\n const entries = Object.entries(headers ?? {});\n if (entries.length === 0) {\n return response;\n }\n\n let mutated = false;\n const merged = new Headers(response.headers);\n for (const [key, value] of entries) {\n if (!merged.has(key)) {\n merged.set(key, value);\n mutated = true;\n }\n }\n\n if (!mutated) {\n return response;\n }\n\n return new Response(response.body, {\n status: response.status,\n statusText: response.statusText,\n headers: merged,\n });\n}\n\nfunction isX402Payment(value: unknown): value is X402Payment {\n return (\n !!value &&\n typeof value === \"object\" &&\n \"definition\" in value &&\n (value as X402Payment).definition !== undefined\n );\n}\n\nfunction resolveFacilitator(\n value: string | X402FacilitatorConfig | undefined\n): X402FacilitatorConfig {\n if (!value) {\n return DEFAULT_FACILITATOR;\n }\n if (typeof value === \"string\") {\n return { ...DEFAULT_FACILITATOR, url: value };\n }\n return value;\n}\n\nfunction normalizeCurrency(currency?: string): string {\n return (currency ?? \"USDC\").toUpperCase();\n}\n\nfunction toDecimalString(value: string | number): string {\n return typeof value === \"number\" ? value.toString() : value;\n}\n\nexport { PAYMENT_HEADERS };\nexport type { X402PaymentDefinition, X402VerificationResult, X402FacilitatorConfig, CurrencySpec };\nexport { SUPPORTED_CURRENCIES, DEFAULT_FACILITATOR };\nexport {\n X402Client,\n payX402,\n X402BrowserClient,\n payX402WithWallet,\n type X402ClientConfig,\n type X402PayRequest,\n type X402PayResult,\n type X402BrowserClientConfig,\n type EIP3009Authorization,\n} from \"./client\";\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opentool",
3
- "version": "0.7.2",
3
+ "version": "0.7.3",
4
4
  "description": "OpenTool framework for building serverless MCP tools",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -94,9 +94,9 @@
94
94
  "import": "./dist/index.js",
95
95
  "types": "./dist/index.d.ts"
96
96
  },
97
- "./payment": {
98
- "import": "./dist/payment/index.js",
99
- "types": "./dist/payment/index.d.ts"
97
+ "./x402": {
98
+ "import": "./dist/x402/index.js",
99
+ "types": "./dist/x402/index.d.ts"
100
100
  },
101
101
  "./wallets": {
102
102
  "import": "./dist/wallets/index.js",
@@ -1,487 +0,0 @@
1
- import { z } from 'zod';
2
-
3
- declare const PAYMENT_SCHEMA_VERSION: 1;
4
- declare const paymentSchemaVersionSchema: z.ZodLiteral<1>;
5
- type PaymentSchemaVersion = z.infer<typeof paymentSchemaVersionSchema>;
6
- declare const decimalStringSchema: z.ZodString;
7
- declare const currencySchema: z.ZodObject<{
8
- code: z.ZodPipe<z.ZodString, z.ZodTransform<string, string>>;
9
- symbol: z.ZodOptional<z.ZodString>;
10
- decimals: z.ZodOptional<z.ZodNumber>;
11
- kind: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
12
- fiat: "fiat";
13
- crypto: "crypto";
14
- }>>>;
15
- description: z.ZodOptional<z.ZodString>;
16
- }, z.core.$strip>;
17
- type Currency = z.infer<typeof currencySchema>;
18
- declare const paymentAmountSchema: z.ZodObject<{
19
- value: z.ZodString;
20
- currency: z.ZodObject<{
21
- code: z.ZodPipe<z.ZodString, z.ZodTransform<string, string>>;
22
- symbol: z.ZodOptional<z.ZodString>;
23
- decimals: z.ZodOptional<z.ZodNumber>;
24
- kind: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
25
- fiat: "fiat";
26
- crypto: "crypto";
27
- }>>>;
28
- description: z.ZodOptional<z.ZodString>;
29
- }, z.core.$strip>;
30
- display: z.ZodOptional<z.ZodString>;
31
- }, z.core.$strip>;
32
- type PaymentAmount = z.infer<typeof paymentAmountSchema>;
33
- declare const cryptoAssetSchema: z.ZodObject<{
34
- symbol: z.ZodString;
35
- network: z.ZodOptional<z.ZodString>;
36
- chainId: z.ZodOptional<z.ZodNumber>;
37
- address: z.ZodOptional<z.ZodString>;
38
- decimals: z.ZodOptional<z.ZodNumber>;
39
- standard: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
40
- erc20: "erc20";
41
- spl: "spl";
42
- custom: "custom";
43
- }>>>;
44
- description: z.ZodOptional<z.ZodString>;
45
- }, z.core.$strip>;
46
- type CryptoAsset = z.infer<typeof cryptoAssetSchema>;
47
- declare const facilitatorConfigSchema: z.ZodObject<{
48
- url: z.ZodString;
49
- vendor: z.ZodOptional<z.ZodString>;
50
- verifyPath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
51
- settlePath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
52
- apiKey: z.ZodOptional<z.ZodString>;
53
- apiKeyEnv: z.ZodOptional<z.ZodString>;
54
- apiKeyHeader: z.ZodOptional<z.ZodDefault<z.ZodString>>;
55
- headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
56
- timeoutMs: z.ZodOptional<z.ZodNumber>;
57
- }, z.core.$strip>;
58
- type FacilitatorConfig = z.infer<typeof facilitatorConfigSchema>;
59
- declare const settlementTermsSchema: z.ZodObject<{
60
- windowSeconds: z.ZodOptional<z.ZodNumber>;
61
- targetConfirmations: z.ZodOptional<z.ZodNumber>;
62
- finalityDescription: z.ZodOptional<z.ZodString>;
63
- slaDescription: z.ZodOptional<z.ZodString>;
64
- }, z.core.$strip>;
65
- type SettlementTerms = z.infer<typeof settlementTermsSchema>;
66
- declare const paymentFieldSchema: z.ZodObject<{
67
- key: z.ZodString;
68
- label: z.ZodString;
69
- required: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
70
- description: z.ZodOptional<z.ZodString>;
71
- example: z.ZodOptional<z.ZodString>;
72
- }, z.core.$strip>;
73
- type PaymentField = z.infer<typeof paymentFieldSchema>;
74
- declare const x402ProofSchema: z.ZodObject<{
75
- mode: z.ZodLiteral<"x402">;
76
- scheme: z.ZodString;
77
- network: z.ZodString;
78
- version: z.ZodOptional<z.ZodNumber>;
79
- facilitator: z.ZodOptional<z.ZodObject<{
80
- url: z.ZodString;
81
- vendor: z.ZodOptional<z.ZodString>;
82
- verifyPath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
83
- settlePath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
84
- apiKey: z.ZodOptional<z.ZodString>;
85
- apiKeyEnv: z.ZodOptional<z.ZodString>;
86
- apiKeyHeader: z.ZodOptional<z.ZodDefault<z.ZodString>>;
87
- headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
88
- timeoutMs: z.ZodOptional<z.ZodNumber>;
89
- }, z.core.$strip>>;
90
- verifier: z.ZodOptional<z.ZodString>;
91
- }, z.core.$strip>;
92
- type X402ProofConfig = z.infer<typeof x402ProofSchema>;
93
- declare const directProofSchema: z.ZodObject<{
94
- mode: z.ZodLiteral<"direct">;
95
- proofTypes: z.ZodArray<z.ZodString>;
96
- verifier: z.ZodOptional<z.ZodString>;
97
- instructions: z.ZodOptional<z.ZodString>;
98
- fields: z.ZodOptional<z.ZodArray<z.ZodObject<{
99
- key: z.ZodString;
100
- label: z.ZodString;
101
- required: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
102
- description: z.ZodOptional<z.ZodString>;
103
- example: z.ZodOptional<z.ZodString>;
104
- }, z.core.$strip>>>;
105
- allowsManualReview: z.ZodOptional<z.ZodBoolean>;
106
- }, z.core.$strip>;
107
- type DirectProofConfig = z.infer<typeof directProofSchema>;
108
- declare const paymentProofSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
109
- mode: z.ZodLiteral<"x402">;
110
- scheme: z.ZodString;
111
- network: z.ZodString;
112
- version: z.ZodOptional<z.ZodNumber>;
113
- facilitator: z.ZodOptional<z.ZodObject<{
114
- url: z.ZodString;
115
- vendor: z.ZodOptional<z.ZodString>;
116
- verifyPath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
117
- settlePath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
118
- apiKey: z.ZodOptional<z.ZodString>;
119
- apiKeyEnv: z.ZodOptional<z.ZodString>;
120
- apiKeyHeader: z.ZodOptional<z.ZodDefault<z.ZodString>>;
121
- headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
122
- timeoutMs: z.ZodOptional<z.ZodNumber>;
123
- }, z.core.$strip>>;
124
- verifier: z.ZodOptional<z.ZodString>;
125
- }, z.core.$strip>, z.ZodObject<{
126
- mode: z.ZodLiteral<"direct">;
127
- proofTypes: z.ZodArray<z.ZodString>;
128
- verifier: z.ZodOptional<z.ZodString>;
129
- instructions: z.ZodOptional<z.ZodString>;
130
- fields: z.ZodOptional<z.ZodArray<z.ZodObject<{
131
- key: z.ZodString;
132
- label: z.ZodString;
133
- required: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
134
- description: z.ZodOptional<z.ZodString>;
135
- example: z.ZodOptional<z.ZodString>;
136
- }, z.core.$strip>>>;
137
- allowsManualReview: z.ZodOptional<z.ZodBoolean>;
138
- }, z.core.$strip>], "mode">;
139
- type PaymentProofConfig = z.infer<typeof paymentProofSchema>;
140
- declare const paymentOptionSchema: z.ZodObject<{
141
- id: z.ZodString;
142
- title: z.ZodString;
143
- description: z.ZodOptional<z.ZodString>;
144
- amount: z.ZodObject<{
145
- value: z.ZodString;
146
- currency: z.ZodObject<{
147
- code: z.ZodPipe<z.ZodString, z.ZodTransform<string, string>>;
148
- symbol: z.ZodOptional<z.ZodString>;
149
- decimals: z.ZodOptional<z.ZodNumber>;
150
- kind: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
151
- fiat: "fiat";
152
- crypto: "crypto";
153
- }>>>;
154
- description: z.ZodOptional<z.ZodString>;
155
- }, z.core.$strip>;
156
- display: z.ZodOptional<z.ZodString>;
157
- }, z.core.$strip>;
158
- asset: z.ZodObject<{
159
- symbol: z.ZodString;
160
- network: z.ZodOptional<z.ZodString>;
161
- chainId: z.ZodOptional<z.ZodNumber>;
162
- address: z.ZodOptional<z.ZodString>;
163
- decimals: z.ZodOptional<z.ZodNumber>;
164
- standard: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
165
- erc20: "erc20";
166
- spl: "spl";
167
- custom: "custom";
168
- }>>>;
169
- description: z.ZodOptional<z.ZodString>;
170
- }, z.core.$strip>;
171
- payTo: z.ZodString;
172
- resource: z.ZodOptional<z.ZodString>;
173
- proof: z.ZodDiscriminatedUnion<[z.ZodObject<{
174
- mode: z.ZodLiteral<"x402">;
175
- scheme: z.ZodString;
176
- network: z.ZodString;
177
- version: z.ZodOptional<z.ZodNumber>;
178
- facilitator: z.ZodOptional<z.ZodObject<{
179
- url: z.ZodString;
180
- vendor: z.ZodOptional<z.ZodString>;
181
- verifyPath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
182
- settlePath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
183
- apiKey: z.ZodOptional<z.ZodString>;
184
- apiKeyEnv: z.ZodOptional<z.ZodString>;
185
- apiKeyHeader: z.ZodOptional<z.ZodDefault<z.ZodString>>;
186
- headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
187
- timeoutMs: z.ZodOptional<z.ZodNumber>;
188
- }, z.core.$strip>>;
189
- verifier: z.ZodOptional<z.ZodString>;
190
- }, z.core.$strip>, z.ZodObject<{
191
- mode: z.ZodLiteral<"direct">;
192
- proofTypes: z.ZodArray<z.ZodString>;
193
- verifier: z.ZodOptional<z.ZodString>;
194
- instructions: z.ZodOptional<z.ZodString>;
195
- fields: z.ZodOptional<z.ZodArray<z.ZodObject<{
196
- key: z.ZodString;
197
- label: z.ZodString;
198
- required: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
199
- description: z.ZodOptional<z.ZodString>;
200
- example: z.ZodOptional<z.ZodString>;
201
- }, z.core.$strip>>>;
202
- allowsManualReview: z.ZodOptional<z.ZodBoolean>;
203
- }, z.core.$strip>], "mode">;
204
- settlement: z.ZodOptional<z.ZodObject<{
205
- windowSeconds: z.ZodOptional<z.ZodNumber>;
206
- targetConfirmations: z.ZodOptional<z.ZodNumber>;
207
- finalityDescription: z.ZodOptional<z.ZodString>;
208
- slaDescription: z.ZodOptional<z.ZodString>;
209
- }, z.core.$strip>>;
210
- metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
211
- }, z.core.$strip>;
212
- type PaymentOption = z.infer<typeof paymentOptionSchema>;
213
- declare const paymentRequirementsSchema: z.ZodObject<{
214
- schemaVersion: z.ZodLiteral<1>;
215
- message: z.ZodOptional<z.ZodString>;
216
- title: z.ZodOptional<z.ZodString>;
217
- resource: z.ZodOptional<z.ZodString>;
218
- accepts: z.ZodArray<z.ZodObject<{
219
- id: z.ZodString;
220
- title: z.ZodString;
221
- description: z.ZodOptional<z.ZodString>;
222
- amount: z.ZodObject<{
223
- value: z.ZodString;
224
- currency: z.ZodObject<{
225
- code: z.ZodPipe<z.ZodString, z.ZodTransform<string, string>>;
226
- symbol: z.ZodOptional<z.ZodString>;
227
- decimals: z.ZodOptional<z.ZodNumber>;
228
- kind: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
229
- fiat: "fiat";
230
- crypto: "crypto";
231
- }>>>;
232
- description: z.ZodOptional<z.ZodString>;
233
- }, z.core.$strip>;
234
- display: z.ZodOptional<z.ZodString>;
235
- }, z.core.$strip>;
236
- asset: z.ZodObject<{
237
- symbol: z.ZodString;
238
- network: z.ZodOptional<z.ZodString>;
239
- chainId: z.ZodOptional<z.ZodNumber>;
240
- address: z.ZodOptional<z.ZodString>;
241
- decimals: z.ZodOptional<z.ZodNumber>;
242
- standard: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
243
- erc20: "erc20";
244
- spl: "spl";
245
- custom: "custom";
246
- }>>>;
247
- description: z.ZodOptional<z.ZodString>;
248
- }, z.core.$strip>;
249
- payTo: z.ZodString;
250
- resource: z.ZodOptional<z.ZodString>;
251
- proof: z.ZodDiscriminatedUnion<[z.ZodObject<{
252
- mode: z.ZodLiteral<"x402">;
253
- scheme: z.ZodString;
254
- network: z.ZodString;
255
- version: z.ZodOptional<z.ZodNumber>;
256
- facilitator: z.ZodOptional<z.ZodObject<{
257
- url: z.ZodString;
258
- vendor: z.ZodOptional<z.ZodString>;
259
- verifyPath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
260
- settlePath: z.ZodOptional<z.ZodDefault<z.ZodString>>;
261
- apiKey: z.ZodOptional<z.ZodString>;
262
- apiKeyEnv: z.ZodOptional<z.ZodString>;
263
- apiKeyHeader: z.ZodOptional<z.ZodDefault<z.ZodString>>;
264
- headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
265
- timeoutMs: z.ZodOptional<z.ZodNumber>;
266
- }, z.core.$strip>>;
267
- verifier: z.ZodOptional<z.ZodString>;
268
- }, z.core.$strip>, z.ZodObject<{
269
- mode: z.ZodLiteral<"direct">;
270
- proofTypes: z.ZodArray<z.ZodString>;
271
- verifier: z.ZodOptional<z.ZodString>;
272
- instructions: z.ZodOptional<z.ZodString>;
273
- fields: z.ZodOptional<z.ZodArray<z.ZodObject<{
274
- key: z.ZodString;
275
- label: z.ZodString;
276
- required: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
277
- description: z.ZodOptional<z.ZodString>;
278
- example: z.ZodOptional<z.ZodString>;
279
- }, z.core.$strip>>>;
280
- allowsManualReview: z.ZodOptional<z.ZodBoolean>;
281
- }, z.core.$strip>], "mode">;
282
- settlement: z.ZodOptional<z.ZodObject<{
283
- windowSeconds: z.ZodOptional<z.ZodNumber>;
284
- targetConfirmations: z.ZodOptional<z.ZodNumber>;
285
- finalityDescription: z.ZodOptional<z.ZodString>;
286
- slaDescription: z.ZodOptional<z.ZodString>;
287
- }, z.core.$strip>>;
288
- metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
289
- }, z.core.$strip>>;
290
- metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
291
- fallbackText: z.ZodOptional<z.ZodString>;
292
- }, z.core.$strip>;
293
- type PaymentRequirementsDefinition = z.infer<typeof paymentRequirementsSchema>;
294
- declare const x402PaymentHeaderSchema: z.ZodObject<{
295
- x402Version: z.ZodNumber;
296
- scheme: z.ZodString;
297
- network: z.ZodString;
298
- payload: z.ZodUnknown;
299
- correlationId: z.ZodOptional<z.ZodString>;
300
- }, z.core.$strip>;
301
- type X402PaymentHeader = z.infer<typeof x402PaymentHeaderSchema>;
302
- declare const directPaymentPayloadSchema: z.ZodObject<{
303
- schemaVersion: z.ZodLiteral<1>;
304
- optionId: z.ZodString;
305
- proofType: z.ZodString;
306
- payload: z.ZodUnknown;
307
- metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
308
- }, z.core.$strip>;
309
- type DirectPaymentPayload = z.infer<typeof directPaymentPayloadSchema>;
310
- declare const paymentSuccessMetadataSchema: z.ZodObject<{
311
- optionId: z.ZodString;
312
- verifier: z.ZodOptional<z.ZodString>;
313
- txHash: z.ZodOptional<z.ZodString>;
314
- networkId: z.ZodOptional<z.ZodString>;
315
- amount: z.ZodOptional<z.ZodObject<{
316
- value: z.ZodString;
317
- currency: z.ZodObject<{
318
- code: z.ZodPipe<z.ZodString, z.ZodTransform<string, string>>;
319
- symbol: z.ZodOptional<z.ZodString>;
320
- decimals: z.ZodOptional<z.ZodNumber>;
321
- kind: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
322
- fiat: "fiat";
323
- crypto: "crypto";
324
- }>>>;
325
- description: z.ZodOptional<z.ZodString>;
326
- }, z.core.$strip>;
327
- display: z.ZodOptional<z.ZodString>;
328
- }, z.core.$strip>>;
329
- settledAt: z.ZodOptional<z.ZodString>;
330
- payload: z.ZodOptional<z.ZodUnknown>;
331
- }, z.core.$strip>;
332
- type PaymentSuccessMetadata = z.infer<typeof paymentSuccessMetadataSchema>;
333
- declare const paymentFailureSchema: z.ZodObject<{
334
- reason: z.ZodString;
335
- code: z.ZodOptional<z.ZodDefault<z.ZodEnum<{
336
- unknown: "unknown";
337
- verifier_not_found: "verifier_not_found";
338
- verification_failed: "verification_failed";
339
- invalid_payload: "invalid_payload";
340
- unsupported_option: "unsupported_option";
341
- missing_header: "missing_header";
342
- }>>>;
343
- retryable: z.ZodOptional<z.ZodBoolean>;
344
- detail: z.ZodOptional<z.ZodUnknown>;
345
- }, z.core.$strip>;
346
- type PaymentFailure = z.infer<typeof paymentFailureSchema>;
347
-
348
- declare const HEADER_X402 = "X-PAYMENT";
349
- declare const HEADER_DIRECT = "X-PAYMENT-PROOF";
350
- declare const HEADER_PAYMENT_RESPONSE = "X-PAYMENT-RESPONSE";
351
- declare const x402RequirementSchema: z.ZodObject<{
352
- scheme: z.ZodString;
353
- network: z.ZodString;
354
- maxAmountRequired: z.ZodString;
355
- asset: z.ZodString;
356
- payTo: z.ZodString;
357
- resource: z.ZodOptional<z.ZodString>;
358
- description: z.ZodOptional<z.ZodString>;
359
- mimeType: z.ZodOptional<z.ZodString>;
360
- outputSchema: z.ZodOptional<z.ZodUnknown>;
361
- maxTimeoutSeconds: z.ZodOptional<z.ZodNumber>;
362
- extra: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
363
- }, z.core.$strip>;
364
- type X402Requirement = z.infer<typeof x402RequirementSchema>;
365
- interface X402RequirementsResponse {
366
- x402Version: number;
367
- error?: string;
368
- accepts: X402Requirement[];
369
- }
370
- interface PaymentRequiredBody extends PaymentRequirementsDefinition {
371
- x402?: X402RequirementsResponse;
372
- }
373
- type PaymentAttempt = {
374
- type: "x402";
375
- headerName: typeof HEADER_X402;
376
- raw: string;
377
- payload: X402PaymentHeader;
378
- } | {
379
- type: "direct";
380
- headerName: typeof HEADER_DIRECT;
381
- raw: string;
382
- payload: DirectPaymentPayload;
383
- };
384
- interface ExtractAttemptsResult {
385
- attempts: PaymentAttempt[];
386
- failures: PaymentFailure[];
387
- }
388
- interface PaymentVerificationContext {
389
- attempt: PaymentAttempt;
390
- option: PaymentOption;
391
- definition: PaymentRequirementsDefinition;
392
- settle?: boolean;
393
- }
394
- interface PaymentVerificationResult {
395
- success: boolean;
396
- optionId: string;
397
- attemptType: PaymentAttempt["type"];
398
- metadata?: PaymentSuccessMetadata;
399
- failure?: PaymentFailure;
400
- responseHeaders?: Record<string, string>;
401
- }
402
- type PaymentVerifier = (context: PaymentVerificationContext) => Promise<PaymentVerificationResult>;
403
- interface VerifyPaymentOptions {
404
- definition: PaymentRequirementsDefinition;
405
- request?: Request;
406
- attempts?: PaymentAttempt[];
407
- settle?: boolean;
408
- verifiers?: Record<string, PaymentVerifier>;
409
- fetchImpl?: typeof fetch;
410
- }
411
- declare function createPaymentRequiredBody(definition: PaymentRequirementsDefinition): PaymentRequiredBody;
412
- declare function paymentRequiredResponse(definition: PaymentRequirementsDefinition, init?: ResponseInit): Response;
413
- declare function extractPaymentAttempts(source: Request): ExtractAttemptsResult;
414
- declare function verifyPayment(options: VerifyPaymentOptions): Promise<PaymentVerificationResult>;
415
- declare function createPaymentResponseHeader(metadata: PaymentSuccessMetadata): string;
416
- declare const PAYMENT_HEADERS: {
417
- readonly x402: "X-PAYMENT";
418
- readonly direct: "X-PAYMENT-PROOF";
419
- readonly response: "X-PAYMENT-RESPONSE";
420
- };
421
-
422
- interface DefinedPayment {
423
- definition: PaymentRequirementsDefinition;
424
- verifiers: Record<string, PaymentVerifier>;
425
- metadata?: Record<string, unknown>;
426
- message?: string;
427
- }
428
- interface RequirePaymentOptions {
429
- settle?: boolean;
430
- verifiers?: Record<string, PaymentVerifier>;
431
- fetchImpl?: typeof fetch;
432
- onFailure?: (result: PaymentVerificationResult) => Response;
433
- }
434
- interface RequirePaymentSuccess {
435
- payment: PaymentSuccessMetadata;
436
- headers: Record<string, string>;
437
- optionId: string;
438
- result: PaymentVerificationResult;
439
- }
440
- type RequirePaymentOutcome = Response | RequirePaymentSuccess;
441
- declare class PaymentRequiredError extends Error {
442
- readonly response: Response;
443
- readonly verification: PaymentVerificationResult | undefined;
444
- constructor(response: Response, verification?: PaymentVerificationResult);
445
- }
446
- type PaymentContext = RequirePaymentSuccess;
447
- declare function getPaymentContext(request: Request): PaymentContext | undefined;
448
- declare function withPaymentRequirement(handler: (request: Request) => Promise<Response> | Response, payment: DefinedPayment | PaymentRequirementsDefinition, options?: RequirePaymentOptions): (request: Request) => Promise<Response>;
449
- interface DefinePaymentConfig {
450
- amount: string | number;
451
- payTo: string;
452
- currency?: string;
453
- message?: string;
454
- resource?: string;
455
- acceptedMethods?: ("x402" | "402")[];
456
- acceptedCurrencies?: string[];
457
- chains?: (string | number)[];
458
- facilitator?: "opentool" | "coinbase" | string | X402ProofConfig["facilitator"];
459
- metadata?: Record<string, unknown>;
460
- verifiers?: Record<string, PaymentVerifier>;
461
- x402?: X402Config;
462
- direct?: DirectConfig;
463
- }
464
- interface X402Config {
465
- id?: string;
466
- facilitator?: string | X402ProofConfig["facilitator"];
467
- network?: string;
468
- assetAddress?: string;
469
- scheme?: string;
470
- version?: number;
471
- settlement?: SettlementTerms;
472
- }
473
- interface DirectConfig {
474
- id?: string;
475
- verifierId?: string;
476
- proofType?: string;
477
- token?: string;
478
- verify?: PaymentVerifier;
479
- instructions?: string;
480
- fields?: PaymentField[];
481
- allowsManualReview?: boolean;
482
- settlement?: SettlementTerms;
483
- }
484
- declare function definePayment(config: DefinePaymentConfig): DefinedPayment;
485
- declare function requirePayment(request: Request, payment: DefinedPayment | PaymentRequirementsDefinition, options?: RequirePaymentOptions): Promise<RequirePaymentOutcome>;
486
-
487
- export { type RequirePaymentOutcome as $, paymentFailureSchema as A, type PaymentFailure as B, type Currency as C, type DirectProofConfig as D, type X402Requirement as E, type FacilitatorConfig as F, type X402RequirementsResponse as G, HEADER_PAYMENT_RESPONSE as H, type PaymentRequiredBody as I, type PaymentAttempt as J, type ExtractAttemptsResult as K, type PaymentVerificationContext as L, type PaymentVerificationResult as M, type PaymentVerifier as N, createPaymentRequiredBody as O, PAYMENT_SCHEMA_VERSION as P, paymentRequiredResponse as Q, extractPaymentAttempts as R, type SettlementTerms as S, verifyPayment as T, createPaymentResponseHeader as U, type VerifyPaymentOptions as V, PAYMENT_HEADERS as W, type X402ProofConfig as X, type DefinedPayment as Y, type RequirePaymentOptions as Z, type RequirePaymentSuccess as _, type PaymentSchemaVersion as a, PaymentRequiredError as a0, type PaymentContext as a1, getPaymentContext as a2, withPaymentRequirement as a3, type DefinePaymentConfig as a4, type X402Config as a5, type DirectConfig as a6, definePayment as a7, requirePayment as a8, paymentAmountSchema as b, currencySchema as c, decimalStringSchema as d, type PaymentAmount as e, cryptoAssetSchema as f, type CryptoAsset as g, facilitatorConfigSchema as h, paymentFieldSchema as i, type PaymentField as j, directProofSchema as k, paymentProofSchema as l, type PaymentProofConfig as m, paymentOptionSchema as n, type PaymentOption as o, paymentSchemaVersionSchema as p, paymentRequirementsSchema as q, type PaymentRequirementsDefinition as r, settlementTermsSchema as s, x402PaymentHeaderSchema as t, type X402PaymentHeader as u, directPaymentPayloadSchema as v, type DirectPaymentPayload as w, x402ProofSchema as x, paymentSuccessMetadataSchema as y, type PaymentSuccessMetadata as z };
@@ -1,2 +0,0 @@
1
- export { a4 as DefinePaymentConfig, Y as DefinedPayment, a6 as DirectConfig, W as PAYMENT_HEADERS, a1 as PaymentContext, a0 as PaymentRequiredError, Z as RequirePaymentOptions, $ as RequirePaymentOutcome, _ as RequirePaymentSuccess, a5 as X402Config, a7 as definePayment, a2 as getPaymentContext, a8 as requirePayment, a3 as withPaymentRequirement } from '../index-D_bCF2Bf.js';
2
- import 'zod';