agentcash 0.7.1 → 0.7.2

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.
Files changed (27) hide show
  1. package/dist/cjs/run-server.cjs +14 -5
  2. package/dist/esm/{chunk-MWRO3R4V.js → chunk-5EMDWOPZ.js} +7 -2
  3. package/dist/esm/chunk-5EMDWOPZ.js.map +1 -0
  4. package/dist/esm/{chunk-SN5HHMIT.js → chunk-EDE2BA5J.js} +2 -2
  5. package/dist/esm/{chunk-4CQDDIKH.js → chunk-MB3UWRPI.js} +2 -2
  6. package/dist/esm/chunk-OJFWL5A3.js +7 -0
  7. package/dist/esm/{chunk-RYH3NDAP.js → chunk-V2H5E3DQ.js} +3 -3
  8. package/dist/esm/{chunk-UIMAHOSV.js → chunk-YRRXIT26.js} +3 -3
  9. package/dist/esm/{commands-W6VY355C.js → commands-37HXSNEV.js} +103 -12
  10. package/dist/esm/commands-37HXSNEV.js.map +1 -0
  11. package/dist/esm/index.js +15 -15
  12. package/dist/esm/{install-ZJC2MCDG.js → install-PJ7ICH3O.js} +3 -3
  13. package/dist/esm/lib.js +1 -1
  14. package/dist/esm/{server-3SY6CIP7.js → server-QLSZ3QOV.js} +12 -8
  15. package/dist/esm/server-QLSZ3QOV.js.map +1 -0
  16. package/dist/esm/shared/operations/index.js +4 -4
  17. package/package.json +2 -1
  18. package/dist/esm/chunk-DJS6BHZB.js +0 -7
  19. package/dist/esm/chunk-MWRO3R4V.js.map +0 -1
  20. package/dist/esm/commands-W6VY355C.js.map +0 -1
  21. package/dist/esm/server-3SY6CIP7.js.map +0 -1
  22. /package/dist/esm/{chunk-SN5HHMIT.js.map → chunk-EDE2BA5J.js.map} +0 -0
  23. /package/dist/esm/{chunk-4CQDDIKH.js.map → chunk-MB3UWRPI.js.map} +0 -0
  24. /package/dist/esm/{chunk-DJS6BHZB.js.map → chunk-OJFWL5A3.js.map} +0 -0
  25. /package/dist/esm/{chunk-RYH3NDAP.js.map → chunk-V2H5E3DQ.js.map} +0 -0
  26. /package/dist/esm/{chunk-UIMAHOSV.js.map → chunk-YRRXIT26.js.map} +0 -0
  27. /package/dist/esm/{install-ZJC2MCDG.js.map → install-PJ7ICH3O.js.map} +0 -0
package/dist/esm/index.js CHANGED
@@ -1,11 +1,11 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  isMppEnabled
4
- } from "./chunk-DJS6BHZB.js";
4
+ } from "./chunk-OJFWL5A3.js";
5
5
  import "./chunk-JNYAKINU.js";
6
6
  import {
7
7
  MCP_VERSION
8
- } from "./chunk-SN5HHMIT.js";
8
+ } from "./chunk-EDE2BA5J.js";
9
9
 
10
10
  // src/index.ts
11
11
  import yargs from "yargs";
@@ -81,7 +81,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
81
81
  default: "auto"
82
82
  }),
83
83
  async (args) => {
84
- const { fetchCommand } = await import("./commands-W6VY355C.js");
84
+ const { fetchCommand } = await import("./commands-37HXSNEV.js");
85
85
  await fetchCommand(
86
86
  {
87
87
  url: args.url,
@@ -116,7 +116,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
116
116
  description: "Additional headers as JSON object"
117
117
  }),
118
118
  async (args) => {
119
- const { fetchAuthCommand } = await import("./commands-W6VY355C.js");
119
+ const { fetchAuthCommand } = await import("./commands-37HXSNEV.js");
120
120
  await fetchAuthCommand(
121
121
  {
122
122
  url: args.url,
@@ -149,7 +149,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
149
149
  description: "Additional headers as JSON object"
150
150
  }),
151
151
  async (args) => {
152
- const { checkCommand } = await import("./commands-W6VY355C.js");
152
+ const { checkCommand } = await import("./commands-37HXSNEV.js");
153
153
  await checkCommand(
154
154
  {
155
155
  url: args.url,
@@ -172,7 +172,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
172
172
  description: "Guidance override: true=always include, false=never include, omitted=auto by threshold"
173
173
  }),
174
174
  async (args) => {
175
- const { discoverCommand } = await import("./commands-W6VY355C.js");
175
+ const { discoverCommand } = await import("./commands-37HXSNEV.js");
176
176
  await discoverCommand(
177
177
  { url: args.url, includeGuidance: args.includeGuidance },
178
178
  args
@@ -187,7 +187,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
187
187
  demandOption: true
188
188
  }),
189
189
  async (args) => {
190
- const { registerCommand } = await import("./commands-W6VY355C.js");
190
+ const { registerCommand } = await import("./commands-37HXSNEV.js");
191
191
  await registerCommand({ url: args.url }, args);
192
192
  }
193
193
  ).command(
@@ -199,7 +199,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
199
199
  demandOption: true
200
200
  }),
201
201
  async (args) => {
202
- const { addSkillCommand } = await import("./commands-W6VY355C.js");
202
+ const { addSkillCommand } = await import("./commands-37HXSNEV.js");
203
203
  await addSkillCommand({ url: args.url }, args);
204
204
  }
205
205
  ).command(
@@ -217,7 +217,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
217
217
  );
218
218
  }),
219
219
  async (args) => {
220
- const { onboardCommand } = await import("./commands-W6VY355C.js");
220
+ const { onboardCommand } = await import("./commands-37HXSNEV.js");
221
221
  await onboardCommand({ code: args.code ?? args.invite }, args);
222
222
  }
223
223
  ).command(
@@ -228,7 +228,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
228
228
  "Get wallet address, balance, and deposit link",
229
229
  (yargs3) => yargs3,
230
230
  async (args) => {
231
- const { walletInfoCommand } = await import("./commands-W6VY355C.js");
231
+ const { walletInfoCommand } = await import("./commands-37HXSNEV.js");
232
232
  await walletInfoCommand({}, args);
233
233
  }
234
234
  ).command(
@@ -240,7 +240,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
240
240
  demandOption: true
241
241
  }),
242
242
  async (args) => {
243
- const { walletRedeemCommand } = await import("./commands-W6VY355C.js");
243
+ const { walletRedeemCommand } = await import("./commands-37HXSNEV.js");
244
244
  await walletRedeemCommand({ code: args.code }, args);
245
245
  }
246
246
  ).command(
@@ -248,7 +248,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
248
248
  "Get wallet address",
249
249
  (yargs3) => yargs3,
250
250
  async (args) => {
251
- const { walletAddressCommand } = await import("./commands-W6VY355C.js");
251
+ const { walletAddressCommand } = await import("./commands-37HXSNEV.js");
252
252
  await walletAddressCommand({}, args);
253
253
  }
254
254
  ).demandCommand(1, "You must specify a wallet subcommand").strict(),
@@ -280,7 +280,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
280
280
  description: "Detailed report with context and repro steps"
281
281
  }),
282
282
  async (args) => {
283
- const { reportErrorCommand } = await import("./commands-W6VY355C.js");
283
+ const { reportErrorCommand } = await import("./commands-37HXSNEV.js");
284
284
  await reportErrorCommand(
285
285
  {
286
286
  tool: args.tool,
@@ -298,7 +298,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
298
298
  "Start the MCP server (default when no command specified)",
299
299
  (yargs2) => yargs2,
300
300
  async (args) => {
301
- const { serverCommand } = await import("./commands-W6VY355C.js");
301
+ const { serverCommand } = await import("./commands-37HXSNEV.js");
302
302
  await serverCommand(args);
303
303
  }
304
304
  ).command(
@@ -311,7 +311,7 @@ void yargs(hideBin(process.argv)).scriptName("agentcash").usage("$0 [command] [o
311
311
  default: isClaudeCode ? "claude-code" /* ClaudeCode */ : void 0
312
312
  }),
313
313
  async (args) => {
314
- const { installMcpServer } = await import("./install-ZJC2MCDG.js");
314
+ const { installMcpServer } = await import("./install-PJ7ICH3O.js");
315
315
  await installMcpServer(args);
316
316
  }
317
317
  ).command(
@@ -1,11 +1,11 @@
1
1
  import {
2
2
  addServer
3
- } from "./chunk-4CQDDIKH.js";
3
+ } from "./chunk-MB3UWRPI.js";
4
4
  import {
5
5
  Clients,
6
6
  clientMetadata
7
7
  } from "./chunk-JNYAKINU.js";
8
- import "./chunk-SN5HHMIT.js";
8
+ import "./chunk-EDE2BA5J.js";
9
9
  import {
10
10
  promptDeposit
11
11
  } from "./chunk-KOMAKKV3.js";
@@ -176,4 +176,4 @@ var installMcpServer = async (flags) => {
176
176
  export {
177
177
  installMcpServer
178
178
  };
179
- //# sourceMappingURL=install-ZJC2MCDG.js.map
179
+ //# sourceMappingURL=install-PJ7ICH3O.js.map
package/dist/esm/lib.js CHANGED
@@ -5,7 +5,7 @@ import {
5
5
  SUPPORTED_METHODS,
6
6
  checkEndpoint,
7
7
  discoverResources
8
- } from "./chunk-MWRO3R4V.js";
8
+ } from "./chunk-5EMDWOPZ.js";
9
9
  import "./chunk-TRPO7BKD.js";
10
10
  import "./chunk-ISR6DJ53.js";
11
11
  export {
@@ -7,23 +7,23 @@ import {
7
7
  requestSchema,
8
8
  safeGetMppChallenge,
9
9
  safeGetPaymentRequired
10
- } from "./chunk-RYH3NDAP.js";
10
+ } from "./chunk-V2H5E3DQ.js";
11
11
  import {
12
12
  TEMPO_RPC_URL,
13
13
  getTempoBalance,
14
14
  getWalletInfo,
15
15
  submitErrorReport
16
- } from "./chunk-UIMAHOSV.js";
16
+ } from "./chunk-YRRXIT26.js";
17
17
  import {
18
18
  isMppEnabled
19
- } from "./chunk-DJS6BHZB.js";
19
+ } from "./chunk-OJFWL5A3.js";
20
20
  import {
21
21
  checkEndpoint,
22
22
  discoverResources
23
- } from "./chunk-MWRO3R4V.js";
23
+ } from "./chunk-5EMDWOPZ.js";
24
24
  import {
25
25
  MCP_VERSION
26
- } from "./chunk-SN5HHMIT.js";
26
+ } from "./chunk-EDE2BA5J.js";
27
27
  import {
28
28
  DEFAULT_NETWORK,
29
29
  getWallet,
@@ -526,7 +526,11 @@ var registerCheckEndpointTool = ({
526
526
  }
527
527
  },
528
528
  safeHandler(async (input) => {
529
- log.info("Querying endpoint", { url: input.url, method: input.method, hasSampleInputBody: !!input.sample_input_body });
529
+ log.info("Querying endpoint", {
530
+ url: input.url,
531
+ method: input.method,
532
+ hasSampleInputBody: !!input.sample_input_body
533
+ });
530
534
  const result = await checkEndpoint(
531
535
  toolName3,
532
536
  input.url,
@@ -1276,7 +1280,7 @@ import { dirname, join } from "path";
1276
1280
  import { fileURLToPath } from "url";
1277
1281
  function getVersion() {
1278
1282
  if (true) {
1279
- return "0.7.1";
1283
+ return "0.7.2";
1280
1284
  }
1281
1285
  const __dirname2 = dirname(fileURLToPath(import.meta.url));
1282
1286
  const pkg = JSON.parse(
@@ -1372,4 +1376,4 @@ var startServer = async (flags) => {
1372
1376
  export {
1373
1377
  startServer
1374
1378
  };
1375
- //# sourceMappingURL=server-3SY6CIP7.js.map
1379
+ //# sourceMappingURL=server-QLSZ3QOV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/server/index.ts","../../src/server/tools/fetch.ts","../../src/server/tools/response/lib.ts","../../src/server/tools/response/error.ts","../../src/server/tools/response/success.ts","../../src/server/tools/response/safe-handler.ts","../../src/server/tools/lib/check-balance.ts","../../src/server/tools/auth-fetch.ts","../../src/server/tools/wallet.ts","../../src/server/tools/check-endpoint.ts","../../src/server/tools/redeem-invite.ts","../../src/server/tools/telemetry.ts","../../src/server/tools/discover-resources.ts","../../src/shared/origins.ts","../../src/server/resources/origins.ts","../../src/server/prompts/getting-started.ts","../../src/server/prompts/enrich.ts","../../src/server/prompts/index.ts","../../src/server/lib/version.ts","../../src/server/lib/instructions.ts"],"sourcesContent":["import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';\nimport { randomBytes } from 'crypto';\n\nimport { registerFetchTool } from './tools/fetch';\nimport { registerAuthTools } from './tools/auth-fetch';\nimport { registerWalletTools } from './tools/wallet';\nimport { registerCheckEndpointTool } from './tools/check-endpoint';\nimport { registerRedeemInviteTool } from './tools/redeem-invite';\nimport { registerTelemetryTools } from './tools/telemetry';\nimport { registerDiscoveryTools } from './tools/discover-resources';\n\nimport { registerOrigins } from './resources/origins';\nimport { registerPrompts } from './prompts';\n\nimport { MCP_VERSION } from './lib/version';\nimport { buildServerInstructions } from './lib/instructions';\n\nimport { log } from '@/shared/log';\nimport { getWallet } from '@/shared/wallet';\nimport { redeemInviteCode } from '@/shared/redeem-invite';\n\nimport type { Command } from '@/types';\n\nexport const startServer: Command = async flags => {\n log.info('Starting agentcash...');\n\n const { invite } = flags;\n let { sessionId } = flags;\n // Generate a random session ID if not provided\n sessionId ??= randomBytes(16).toString('hex');\n\n const walletResult = await getWallet();\n\n if (walletResult.isErr()) {\n log.error(JSON.stringify(walletResult.error, null, 2));\n console.error(walletResult.error);\n process.exit(1);\n }\n\n const { account } = walletResult.value;\n\n const code = invite ?? process.env.INVITE_CODE;\n\n if (code) {\n await redeemInviteCode({\n code,\n address: account.address,\n surface: 'startServer',\n });\n }\n\n const instructions = buildServerInstructions();\n\n const server = new McpServer(\n {\n name: 'agentcash',\n version: MCP_VERSION,\n websiteUrl: 'https://x402scan.com/mcp',\n icons: [{ src: 'https://x402scan.com/logo.svg' }],\n ...(instructions && { instructions }),\n },\n {\n capabilities: {\n resources: {\n subscribe: true,\n listChanged: true,\n },\n prompts: {\n listChanged: true,\n },\n },\n }\n );\n\n const props = {\n server,\n account,\n flags,\n sessionId,\n };\n\n registerFetchTool(props);\n registerAuthTools(props);\n registerWalletTools(props);\n registerCheckEndpointTool(props);\n registerRedeemInviteTool(props);\n registerDiscoveryTools(server);\n registerTelemetryTools(props);\n\n registerPrompts(props);\n\n await registerOrigins({ server, flags });\n\n const transport = new StdioServerTransport();\n await server.connect(transport);\n\n const shutdown = async () => {\n log.info('Shutting down...');\n await server.close();\n process.exit(0);\n };\n\n process.on('SIGINT', () => void shutdown());\n process.on('SIGTERM', () => void shutdown());\n};\n","import { z } from 'zod';\n\nimport { x402Client, x402HTTPClient } from '@x402/core/client';\nimport { ExactEvmScheme } from '@x402/evm/exact/client';\nimport { toClientEvmSigner } from '@x402/evm';\nimport { Mppx, tempo as tempoMethod } from 'mppx/client';\nimport { createClient, createPublicClient, http } from 'viem';\nimport { base, tempo } from 'viem/chains';\n\nimport { MCP_VERSION } from '@/shared/version';\nimport {\n DEFAULT_USER_FETCH_TIMEOUT,\n safeParseResponse,\n} from '@/shared/neverthrow/fetch';\nimport { DEFAULT_NETWORK } from '@/shared/networks';\nimport { TEMPO_RPC_URL } from '@/shared/tempo';\nimport { isMppEnabled } from '@/shared/mpp-enabled';\nimport {\n createFetchWithPayment,\n type BeforePaymentHook,\n} from '@/shared/operations/fetch-with-payment';\n\nimport {\n mcpError,\n mcpErrorFetch,\n mcpSuccessResponse,\n safeHandler,\n} from './response';\nimport { requestSchema, buildRequest } from './lib/request';\nimport { checkBalance, checkTempoBalance } from './lib/check-balance';\n\nimport type { RegisterTools } from '@/server/types';\nimport type { JsonObject } from '@/shared/neverthrow/json/types';\n\nconst toolName = 'fetch';\n\nconst paymentMethodEnum = isMppEnabled()\n ? z.enum(['x402', 'mpp', 'auto'])\n : z.enum(['x402', 'auto']);\n\nconst fetchInputSchema = requestSchema.extend({\n paymentMethod: paymentMethodEnum\n .default('auto')\n .optional()\n .describe('Payment protocol to use. Defaults to auto-detect.'),\n});\n\nexport const registerFetchTool: RegisterTools = ({\n server,\n account,\n flags,\n sessionId,\n}) => {\n server.registerTool(\n toolName,\n {\n title: 'Fetch',\n description: `HTTP fetch with automatic payment. Detects 402 responses, signs payment, retries with payment headers. Returns response data + payment details (price, tx hash) if paid. Check balance with get_wallet_info first.`,\n inputSchema: fetchInputSchema,\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: true,\n },\n },\n safeHandler(async input => {\n const paymentMethod = input.paymentMethod ?? 'auto';\n\n // Set up x402 client\n const publicClient = createPublicClient({\n chain: base,\n transport: http(),\n });\n const coreClient = x402Client.fromConfig({\n schemes: [\n {\n network: DEFAULT_NETWORK,\n client: new ExactEvmScheme(\n toClientEvmSigner(account, publicClient)\n ),\n },\n ],\n });\n const x402HttpClient = new x402HTTPClient(coreClient);\n\n // Set up MPP client (only when MPP is enabled)\n const mppxClient = isMppEnabled()\n ? Mppx.create({\n polyfill: false,\n methods: [\n tempoMethod({\n account,\n getClient: () =>\n createClient({\n chain: tempo,\n transport: http(TEMPO_RPC_URL),\n }),\n }),\n ],\n })\n : ({\n createCredential: () => Promise.reject(new Error('MPP disabled')),\n } as {\n createCredential: (response: Response) => Promise<string>;\n });\n\n // Balance check hook — throws to abort\n const beforePayment: BeforePaymentHook = async ctx => {\n if (ctx.protocol === 'x402') {\n await checkBalance({\n surface: toolName,\n server,\n address: account.address,\n amountNeeded: ctx.amount,\n message: balance =>\n `This request costs ${ctx.amount} USDC. Your current balance is ${balance} USDC.`,\n flags,\n });\n } else if (isMppEnabled()) {\n await checkTempoBalance({\n surface: toolName,\n server,\n address: account.address,\n tokenAddress: ctx.currency as `0x${string}`,\n amountNeeded: ctx.amount,\n decimals: 6,\n message: balance =>\n `This request costs ${ctx.amount} tokens. Your current Tempo balance is ${balance}.`,\n });\n }\n };\n\n const provider = flags.provider ?? `agentcash@${MCP_VERSION}`;\n\n const request = buildRequest({\n input,\n address: account.address,\n sessionId,\n provider,\n });\n\n const fetchResult = await createFetchWithPayment({\n surface: toolName,\n clients: { x402: x402HttpClient, mpp: mppxClient },\n paymentMethod,\n account,\n flags,\n beforePayment,\n timeout: input.timeout ?? DEFAULT_USER_FETCH_TIMEOUT,\n })(request);\n\n if (fetchResult.isErr()) {\n return mcpError(fetchResult);\n }\n\n const { response, paymentInfo } = fetchResult.value;\n\n if (!response.ok) {\n return mcpErrorFetch(toolName, response);\n }\n\n const parseResponseResult = await safeParseResponse(toolName, response);\n\n if (parseResponseResult.isErr()) {\n return mcpError(parseResponseResult);\n }\n\n return mcpSuccessResponse(\n parseResponseResult.value,\n paymentInfo as unknown as JsonObject | undefined\n );\n })\n );\n};\n","import type { ParsedResponse } from '@/shared/neverthrow/fetch/types';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\n\nexport const parsedResponseToToolContentPart = (\n data: ParsedResponse\n): CallToolResult['content'][number] => {\n switch (data.type) {\n case 'json':\n return {\n type: 'text' as const,\n text: JSON.stringify(data.data),\n };\n case 'image':\n return {\n type: 'image' as const,\n mimeType: data.mimeType,\n data: Buffer.from(data.data).toString('base64'),\n };\n case 'audio':\n return {\n type: 'audio' as const,\n mimeType: data.mimeType,\n data: Buffer.from(data.data).toString('base64'),\n };\n case 'text':\n return { type: 'text' as const, text: data.data };\n default:\n return {\n type: 'text' as const,\n text: `Unsupported response type: ${data.type}`,\n };\n }\n};\n","import { safeStringifyJson } from '@/shared/neverthrow/json';\n\nimport { parsedResponseToToolContentPart } from './lib';\nimport {\n fetchHttpErr,\n isFetchError,\n safeParseResponse,\n} from '@/shared/neverthrow/fetch';\n\nimport type { JsonObject } from '@/shared/neverthrow/json/types';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport type { BaseError, Err } from '@agentcash/neverthrow/types';\nimport type { BaseX402Error } from '@/shared/neverthrow/x402/types';\nimport type { BaseMppError } from '@/shared/neverthrow/mpp/types';\nimport type { BaseFetchError } from '@/shared/neverthrow/fetch/types';\n\nconst buildMcpError = (\n content: CallToolResult['content'],\n options?: { isError?: boolean }\n): CallToolResult => {\n return {\n content,\n // Default: omit isError so siblings survive parallel calls.\n // Tools with outputSchema MUST pass isError: true so the SDK\n // skips output validation on error paths.\n ...(options?.isError ? { isError: true as const } : {}),\n };\n};\n\nexport const mcpErrorJson = (\n error: JsonObject,\n options?: { isError?: boolean }\n): CallToolResult => {\n return safeStringifyJson('mcp-error-json', error).match(\n success =>\n buildMcpError([{ type: 'text' as const, text: success }], options),\n error =>\n buildMcpError(\n [{ type: 'text' as const, text: JSON.stringify(error, null, 2) }],\n options\n )\n );\n};\n\nexport const mcpError = async (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n err: Err<any, BaseX402Error | BaseMppError | BaseFetchError | BaseError>,\n options?: { isError?: boolean }\n) => {\n const { error } = err;\n if (isFetchError(error)) {\n switch (error.cause) {\n case 'network':\n case 'parse':\n return mcpErrorJson({ ...error }, options);\n case 'http':\n const { response, ...rest } = error;\n const parseResponseResult = await safeParseResponse(\n 'mcp-error-fetch-parse-response',\n response\n );\n const httpContent: CallToolResult['content'] = [\n { type: 'text' as const, text: JSON.stringify(rest, null, 2) },\n ...parseResponseResult.match(\n success => [parsedResponseToToolContentPart(success)],\n () => []\n ),\n ];\n return buildMcpError(httpContent, options);\n }\n }\n return mcpErrorJson({ ...error }, options);\n};\n\nexport const mcpErrorFetch = async (surface: string, response: Response) => {\n return mcpError(fetchHttpErr(surface, response));\n};\n","import { safeStringifyJson } from '@/shared/neverthrow/json';\n\nimport { mcpErrorJson } from './error';\n\nimport type { JsonObject } from '@/shared/neverthrow/json/types';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport type { ParsedResponse } from '@/shared/neverthrow/fetch/types';\nimport { parsedResponseToToolContentPart } from './lib';\n\nconst buildMcpSuccess = (\n content: CallToolResult['content']\n): CallToolResult => {\n return {\n content,\n };\n};\n\nexport const mcpSuccessJson = (data: JsonObject): CallToolResult => {\n return safeStringifyJson('mcp-success-text', data).match(\n success => buildMcpSuccess([{ type: 'text' as const, text: success }]),\n error => mcpErrorJson(error)\n );\n};\n\nexport const mcpSuccessStructuredJson = (data: JsonObject): CallToolResult => {\n return safeStringifyJson('mcp-success-structured', data).match(\n success => ({\n content: [{ type: 'text' as const, text: success }],\n structuredContent: data,\n }),\n error => mcpErrorJson(error)\n );\n};\n\nexport const mcpSuccessResponse = (\n data: ParsedResponse,\n extra?: JsonObject\n): CallToolResult => {\n const parsedExtra = extra\n ? safeStringifyJson('mcp-success-extra', extra).match(\n success => success,\n () => undefined\n )\n : undefined;\n\n return buildMcpSuccess([\n parsedResponseToToolContentPart(data),\n ...(parsedExtra ? [{ type: 'text' as const, text: parsedExtra }] : []),\n ]);\n};\n","import { log } from '@/shared/log';\nimport { mcpErrorJson } from './error';\n\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\n\n/**\n * Wraps an MCP tool handler so uncaught exceptions never propagate.\n * Returns error info as normal content (isError omitted) for any unhandled throw.\n *\n * This prevents sibling parallel tool calls from failing when one\n * tool encounters an unexpected error.\n */\nexport function safeHandler<T>(\n handler: (input: T) => Promise<CallToolResult>\n): (input: T) => Promise<CallToolResult> {\n return async (input: T) => {\n // eslint-disable-next-line no-restricted-syntax -- intentional last-resort catch to prevent sibling tool call failures\n try {\n return await handler(input);\n } catch (e) {\n log.error('Unhandled tool error', e);\n return mcpErrorJson({\n error: e instanceof Error ? e.message : String(e),\n cause: 'unhandled_exception',\n });\n }\n };\n}\n","import { formatUnits } from 'viem';\n\nimport { resultFromPromise } from '@agentcash/neverthrow';\n\nimport { getBalance } from '@/shared/balance';\nimport { getTempoBalance } from '@/shared/tempo-balance';\nimport { getDepositLink, openDepositLink } from '@/shared/utils';\nimport { log } from '@/shared/log';\n\nimport type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport type { Address } from 'viem';\nimport type { GlobalFlags } from '@/types';\n\ninterface CheckBalanceProps {\n server: McpServer;\n address: Address;\n amountNeeded: number;\n message: (balance: number) => string;\n flags: GlobalFlags;\n surface: string;\n}\n\nexport const checkBalance = async ({\n server,\n address,\n amountNeeded,\n message,\n flags,\n surface,\n}: CheckBalanceProps) => {\n const balanceResult = await getBalance({\n address,\n surface,\n dev: flags.dev,\n });\n\n if (balanceResult.isErr()) {\n log.error(JSON.stringify(balanceResult.error, null, 2));\n return;\n }\n\n const balance = balanceResult.value;\n\n if (balance.balance < amountNeeded) {\n const capabilities = server.server.getClientCapabilities();\n if (!capabilities?.elicitation) {\n throw new Error(\n `${message(balance.balance)}\\n\\nYou can deposit USDC at ${getDepositLink(address, flags)}`\n );\n }\n\n const result = await server.server.elicitInput({\n mode: 'form',\n message: message(balance.balance),\n requestedSchema: {\n type: 'object',\n properties: {},\n },\n });\n\n if (result.action === 'accept') {\n await openDepositLink(address, flags);\n }\n }\n\n return balance.balance;\n};\n\ninterface CheckTempoBalanceProps {\n server: McpServer;\n address: Address;\n tokenAddress: Address;\n amountNeeded: number;\n decimals: number;\n message: (balance: number) => string;\n surface: string;\n}\n\nexport const checkTempoBalance = async ({\n server,\n address,\n tokenAddress,\n amountNeeded,\n decimals,\n message,\n}: CheckTempoBalanceProps) => {\n const result = await resultFromPromise(\n 'tempo',\n 'checkTempoBalance',\n getTempoBalance({ address, tokenAddress }),\n e => ({\n cause: 'balance_check' as const,\n message: e instanceof Error ? e.message : String(e),\n })\n );\n\n if (result.isErr()) {\n log.error(`Failed to check Tempo balance: ${result.error.message}`);\n // Don't block the payment if we can't check balance\n return;\n }\n\n const balance = Number(formatUnits(result.value.balance, decimals));\n\n if (balance < amountNeeded) {\n const capabilities = server.server.getClientCapabilities();\n if (!capabilities?.elicitation) {\n throw new Error(\n `${message(balance)}\\n\\nInsufficient Tempo balance for this payment.`\n );\n }\n\n await server.server.elicitInput({\n mode: 'form',\n message: message(balance),\n requestedSchema: {\n type: 'object',\n properties: {},\n },\n });\n }\n\n return balance;\n};\n","import {\n DEFAULT_USER_FETCH_TIMEOUT,\n safeParseResponse,\n} from '@/shared/neverthrow/fetch';\nimport { createFetchWithAuth } from '@/shared/operations/fetch-with-auth';\n\nimport {\n mcpError,\n mcpSuccessJson,\n mcpSuccessResponse,\n mcpErrorFetch,\n safeHandler,\n} from './response';\n\nimport { requestSchema, buildRequest } from './lib/request';\n\nimport type { RegisterTools } from '@/server/types';\n\nconst toolName = 'fetch_with_auth';\n\nexport const registerAuthTools: RegisterTools = ({\n server,\n account,\n sessionId,\n}) => {\n server.registerTool(\n toolName,\n {\n title: 'Fetch with Authentication',\n description: `HTTP fetch with automatic SIWX (Sign-In With X) authentication. Detects auth requirement, signs wallet proof, retries with credentials. For endpoints requiring identity verification without payment. EVM chains only.`,\n inputSchema: requestSchema,\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: true,\n },\n },\n safeHandler(async input => {\n const result = await createFetchWithAuth({\n surface: toolName,\n account,\n timeout: input.timeout ?? DEFAULT_USER_FETCH_TIMEOUT,\n })(buildRequest({ input, address: account.address, sessionId }));\n\n if (result.isErr()) {\n return mcpError(result);\n }\n\n const value = result.value;\n\n if (value.outcome === 'no_siwx_extension') {\n return mcpSuccessJson({\n error: 'Endpoint returned 402 but no sign-in-with-x extension found',\n statusCode: 402,\n extensions: value.extensions,\n hint: 'This endpoint may require payment instead of authentication. Use execute_call for paid requests.',\n });\n }\n\n const { response } = value;\n\n if (!response.ok) {\n return mcpErrorFetch(toolName, response);\n }\n\n const parseResponseResult = await safeParseResponse(toolName, response);\n\n if (parseResponseResult.isErr()) {\n return mcpError(parseResponseResult);\n }\n\n return mcpSuccessResponse(parseResponseResult.value);\n })\n );\n};\n","import { z } from 'zod';\n\nimport { getWalletInfo } from '@/shared/operations/wallet-info';\n\nimport { mcpSuccessStructuredJson, mcpError } from './response';\n\nimport type { RegisterTools } from '@/server/types';\n\nconst chainBalanceSchema = z.object({\n chain: z.string().describe('Chain name'),\n balance: z.number().describe('USDC balance on this chain'),\n});\n\nexport const registerWalletTools: RegisterTools = ({\n server,\n account: { address },\n flags,\n}) => {\n server.registerTool(\n 'get_wallet_info',\n {\n title: 'Get Wallet Info',\n description: `Get wallet address and USDC balance. Auto-creates wallet on first use (~/.agentcash/wallet.json). Returns deposit link. Check before first paid API call.`,\n outputSchema: z.object({\n address: z.string().describe('Wallet address (0x...)'),\n balance: z.number().describe('Total USDC balance across all chains'),\n chains: z\n .array(chainBalanceSchema)\n .describe('Balance breakdown by chain'),\n isNewWallet: z.boolean().describe('True if total balance is 0'),\n depositLink: z.string().url().describe('Link to fund the wallet'),\n message: z.string().optional().describe('Warning if balance is low'),\n }),\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: true,\n },\n },\n async () => {\n const result = await getWalletInfo('get_wallet_info', address, flags);\n\n if (result.isErr()) {\n return mcpError(result, { isError: true });\n }\n\n return mcpSuccessStructuredJson({\n address: result.value.address,\n balance: result.value.balance,\n chains: result.value.chains.map(c => ({ ...c })),\n isNewWallet: result.value.isNewWallet,\n depositLink: result.value.depositLink,\n ...(result.value.message ? { message: result.value.message } : {}),\n });\n }\n );\n};\n","import z from 'zod';\n\nimport { mcpSuccessJson, safeHandler } from './response';\n\nimport { log } from '@/shared/log';\nimport { toJsonObject } from '@/shared/neverthrow/json';\nimport { checkEndpoint } from '@/shared/operations/check-endpoint';\n\nimport type { RegisterTools } from '@/server/types';\n\nconst toolName = 'check_endpoint_schema';\n\nexport const registerCheckEndpointTool: RegisterTools = ({\n server,\n account,\n sessionId,\n}) => {\n server.registerTool(\n toolName,\n {\n title: 'Check Endpoint Schema',\n description: `Returns advisory data for an endpoint: auth mode, pricing, protocols, and input schema.\n\n Two-phase workflow:\n 1. Call without sample_input_body to get the input schema and advisory pricing from the OpenAPI spec (no live request to the endpoint).\n 2. Once you know what body you intend to send, call again with sample_input_body set to that body. The endpoint will be probed live with that payload and exact paymentOptions (priced for your specific body) are returned in each advisory.\n\n Checks the OpenAPI spec first, then falls back to a live 402 probe if no spec is found.\n Use before fetch to understand what an endpoint requires. No payment is made.`,\n inputSchema: z.object({\n url: z.string().describe('The endpoint URL'),\n method: z\n .enum(['GET', 'POST', 'PUT', 'DELETE', 'PATCH'])\n .optional()\n .describe(\n 'HTTP method to check. If omitted, all methods declared in the spec are returned.'\n ),\n sample_input_body: z\n .record(z.string(), z.unknown())\n .optional()\n .describe(\n 'A sample request body you plan to send. When provided, the endpoint is probed live with this payload and exact paymentOptions priced for that body are returned. Use this after phase 1 has given you the input schema.'\n ),\n headers: z\n .record(z.string(), z.string())\n .optional()\n .describe('Additional headers to include in the probe request')\n .default({}),\n }),\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: true,\n },\n },\n safeHandler(async input => {\n log.info('Querying endpoint', {\n url: input.url,\n method: input.method,\n hasSampleInputBody: !!input.sample_input_body,\n });\n\n const result = await checkEndpoint(\n toolName,\n input.url,\n input.method ? [input.method] : undefined,\n input.sample_input_body,\n {\n ...input.headers,\n 'X-Wallet-Address': account.address,\n ...(sessionId ? { 'X-Session-ID': sessionId } : {}),\n }\n );\n\n if (!result.found) {\n log.error('[checkEndpoint] failed', {\n surface: toolName,\n url: input.url,\n cause: result.cause,\n message: result.message,\n });\n return mcpSuccessJson({\n message: 'No endpoint schema found for this URL.',\n url: input.url,\n });\n }\n\n if (result.advisories.length === 0) {\n return mcpSuccessJson({\n message: 'No endpoint schema found for this URL.',\n url: input.url,\n });\n }\n\n const results = result.advisories.map(a => ({\n ...a,\n requiresPayment: a.authMode === 'paid' || a.authMode === 'apiKey+paid',\n }));\n\n return mcpSuccessJson(toJsonObject({ url: input.url, results }));\n })\n );\n};\n","import z from 'zod';\nimport { mcpError, mcpSuccessStructuredJson } from './response';\n\nimport { redeemInviteCode } from '@/shared/redeem-invite';\n\nimport type { RegisterTools } from '@/server/types';\n\nexport const registerRedeemInviteTool: RegisterTools = ({\n server,\n account: { address },\n}) => {\n server.registerTool(\n 'redeem_invite',\n {\n title: 'Redeem Invite',\n description: `Redeem an invite code for free USDC on Base. One-time use per code. Returns amount received and transaction hash. Use get_wallet_info after to verify balance.`,\n inputSchema: z.object({\n code: z.string().min(1).describe('The invite code'),\n }),\n outputSchema: z.object({\n redeemed: z.literal(true),\n amount: z.string().describe('Amount with unit (e.g., \"5 USDC\")'),\n txHash: z.string().describe('Transaction hash on Base'),\n }),\n annotations: {\n readOnlyHint: false, // Modifies wallet balance\n destructiveHint: false, // Additive (adds funds), not destructive\n idempotentHint: false, // Same code can't be redeemed twice - second attempt fails\n openWorldHint: true,\n },\n },\n async ({ code }) => {\n const result = await redeemInviteCode({\n code,\n address,\n surface: 'redeem_invite',\n dev: false,\n });\n\n if (result.isErr()) {\n return mcpError(result, { isError: true });\n }\n\n const { amount, txHash } = result.value;\n\n return mcpSuccessStructuredJson({\n redeemed: true,\n amount: `${amount} USDC`,\n txHash,\n });\n }\n );\n};\n","import z from 'zod';\n\nimport { log } from '@/shared/log';\nimport { submitErrorReport } from '@/shared/operations/report-error';\nimport { mcpError, mcpSuccessStructuredJson } from './response';\n\nimport type { RegisterTools } from '@/server/types';\n\nconst toolName = 'report_error';\n\nexport const registerTelemetryTools: RegisterTools = ({\n server,\n account: { address },\n flags,\n}) => {\n server.registerTool(\n toolName,\n {\n title: 'Report Error',\n description:\n 'EMERGENCY ONLY. Report critical MCP tool bugs. Do NOT use for normal errors (balance, network, 4xx) - those are recoverable.',\n inputSchema: z.object({\n tool: z.string().describe('MCP tool name'),\n resource: z.string().optional().describe('Resource URL'),\n summary: z.string().describe('1-2 sentence summary'),\n errorMessage: z.string().describe('Error message'),\n stack: z.string().optional().describe('Stack trace'),\n fullReport: z\n .string()\n .optional()\n .describe('Detailed report with context, logs, repro steps'),\n }),\n outputSchema: z.object({\n submitted: z.literal(true),\n reportId: z.string().describe('Unique report ID for tracking'),\n message: z.string().describe('Confirmation message'),\n }),\n annotations: {\n readOnlyHint: false,\n destructiveHint: false,\n idempotentHint: false,\n openWorldHint: true,\n },\n },\n async input => {\n log.info('Submitting error report', {\n tool: input.tool,\n resource: input.resource,\n summary: input.summary,\n });\n\n const result = await submitErrorReport(\n toolName,\n {\n tool: input.tool,\n summary: input.summary,\n errorMessage: input.errorMessage,\n resource: input.resource,\n stack: input.stack,\n fullReport: input.fullReport,\n },\n address,\n flags.dev\n );\n\n if (result.isErr()) {\n log.error('Failed to submit error report', result.error);\n return mcpError(result, { isError: true });\n }\n\n log.info('Error report submitted successfully', {\n reportId: result.value.reportId,\n });\n\n return mcpSuccessStructuredJson({\n submitted: result.value.submitted,\n reportId: result.value.reportId,\n message: result.value.message,\n });\n }\n );\n};\n","import { z } from 'zod';\n\nimport { resultFromPromise } from '@agentcash/neverthrow';\n\nimport { log } from '@/shared/log';\nimport { Origin } from '@/shared/origins';\nimport { discoverResources } from '@/shared/operations/discover';\n\nimport {\n mcpError,\n mcpErrorJson,\n mcpSuccessJson,\n safeHandler,\n} from './response';\n\nimport type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport type { JsonObject } from '@/shared/neverthrow/json/types';\n\nconst toolName = 'discover_api_endpoints';\nconst OPENAPI_TRIED_PATHS = '/openapi.json, /.well-known/openapi.json';\n\nexport function registerDiscoveryTools(server: McpServer): void {\n server.registerTool(\n toolName,\n {\n title: 'Discover API Endpoints',\n description: `Find payment-protected resources on an origin. Returns a list of resource URLs.\n Use check_endpoint_schema separately to get detailed pricing/schema info for specific resources.\n Guidance contract: responses always include guidanceAvailable. guidance is auto-included when compact.\n Use include_guidance=true to force-include larger guidance when needed.\n Known default origins with resource packs. Discover if more needed:\n - ${Origin.StableEnrich} ->\n People + Org search\n Google Maps (places + locations)\n Grok twitter search\n Exa web search\n Clado linkedin data\n Firecrawl web scrape\n WhitePages (business directory)\n Email enrichment\n Influencer email/username enrichment\n Hunter email verifier\n - ${Origin.StableSocial} -> social media data for twitter, instagram, tiktok, youtube, facebook, reddit.\n - ${Origin.StableStudio} -> generate and edit images / videos\n - ${Origin.StableUpload} -> upload and share files with others.\n - ${Origin.StableEmail} -> send emails.\n `,\n inputSchema: z.object({\n url: z\n .string()\n .describe(\n 'The origin URL or any URL on the origin to discover resources from'\n ),\n include_guidance: z\n .boolean()\n .optional()\n .describe(\n 'Guidance override: true=always include llms.txt, false=never include, omitted=auto by threshold'\n ),\n }),\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: true,\n },\n },\n safeHandler(async ({ url, include_guidance }) => {\n if (!URL.canParse(url)) {\n return mcpErrorJson({\n error: 'Invalid URL',\n url,\n hint: 'Provide a fully-formed URL like https://example.com',\n });\n }\n\n log.info(`Discovering resources for: ${url}`);\n\n const discoverResult = await resultFromPromise(\n 'discover',\n toolName,\n discoverResources(toolName, url, {\n includeGuidance: include_guidance,\n }),\n e => ({\n cause: 'discover' as const,\n message: e instanceof Error ? e.message : String(e),\n })\n );\n\n if (discoverResult.isErr()) {\n return mcpError(discoverResult);\n }\n\n const result = discoverResult.value;\n\n if ('endpoints' in result) {\n return mcpSuccessJson({\n found: true,\n origin: result.origin,\n ...(result.info\n ? { info: result.info as unknown as JsonObject }\n : {}),\n guidanceAvailable: result.guidanceAvailable,\n ...(result.guidanceTokens != null\n ? { guidanceTokens: result.guidanceTokens }\n : {}),\n ...(result.guidance ? { guidance: result.guidance } : {}),\n endpoints: result.endpoints.map(\n e => ({ ...e }) as unknown as JsonObject\n ),\n } as JsonObject);\n }\n\n // Discovery failed — surface the real cause\n const origin = URL.canParse(url) ? new URL(url).origin : url;\n\n if (result.cause === 'not_found') {\n return mcpSuccessJson({\n found: false,\n origin,\n error: `No OpenAPI spec found. Tried: ${OPENAPI_TRIED_PATHS}`,\n });\n }\n\n return mcpSuccessJson({\n found: false,\n origin,\n cause: result.cause,\n error:\n result.message ?? `Failed to fetch OpenAPI spec (${result.cause})`,\n hint:\n result.cause === 'timeout'\n ? 'The server may be slow or unreachable. Try again later.'\n : result.cause === 'network'\n ? 'Could not reach the server. Check the network connection and try again.'\n : `The server returned an unparseable response. Tried: ${OPENAPI_TRIED_PATHS}`,\n });\n })\n );\n}\n","/**\n * Known x402-protected API origins.\n * Using const enum so values are inlined at build time.\n */\nexport const enum Origin {\n StableEnrich = 'https://stableenrich.dev',\n StableSocial = 'https://stablesocial.dev',\n StableStudio = 'https://stablestudio.dev',\n StableUpload = 'https://stableupload.dev',\n StableEmail = 'https://stableemail.dev',\n X402Scan = 'https://x402scan.com',\n Shirt = 'https://shirt.sh',\n X402Puppet = 'https://x402puppet.com',\n X402Facilitator = 'https://x402facilitator.com',\n}\n\n/**\n * Array of all known origins for iteration.\n * Const enums are erased at compile time, so we need a regular array for runtime iteration.\n */\nexport const ORIGINS = [\n Origin.StableEnrich,\n Origin.StableSocial,\n Origin.StableStudio,\n Origin.StableUpload,\n Origin.StableEmail,\n Origin.X402Scan,\n Origin.Shirt,\n Origin.X402Puppet,\n] as const;\n","import z from 'zod';\n\nimport { x402HTTPClient } from '@x402/core/client';\nimport { x402Client } from '@x402/core/client';\nimport { err, ok } from '@agentcash/neverthrow';\n\nimport {\n DEFAULT_FETCH_TIMEOUT,\n safeFetch,\n safeFetchJson,\n} from '@/shared/neverthrow/fetch';\nimport { safeGetPaymentRequired } from '@/shared/neverthrow/x402';\nimport { safeGetMppChallenge } from '@/shared/neverthrow/mpp';\nimport { safeStringifyJson } from '@/shared/neverthrow/json';\nimport { detectPaymentProtocols } from '@/shared/protocol';\nimport { isMppEnabled } from '@/shared/mpp-enabled';\n\nimport { getInputSchema } from '../lib/x402-extensions';\n\nimport { Origin, ORIGINS } from '@/shared/origins';\n\nimport type { RegisterResources } from './types';\nimport type { JsonObject } from '@/shared/neverthrow/json/types';\n\n/**\n * Static metadata for known origins. Avoids fetching HTML from every origin at\n * startup just to extract <title> and <meta description>.\n */\nconst ORIGIN_METADATA: Record<string, { title: string; description: string }> =\n {\n [Origin.StableEnrich]: {\n title: 'StableEnrich',\n description:\n 'People/org search, Google Maps, Grok twitter search, Exa web search, LinkedIn data, Firecrawl scrape, WhitePages, email enrichment',\n },\n [Origin.StableSocial]: {\n title: 'StableSocial',\n description:\n 'Social media data for Twitter, Instagram, TikTok, YouTube, Facebook, Reddit',\n },\n [Origin.StableStudio]: {\n title: 'StableStudio',\n description: 'Generate and edit images and videos',\n },\n [Origin.StableUpload]: {\n title: 'AgentUpload',\n description: 'Upload and share files',\n },\n [Origin.StableEmail]: {\n title: 'StableEmail',\n description: 'Send emails',\n },\n [Origin.X402Scan]: {\n title: 'X402 Scan',\n description: 'x402 protocol explorer',\n },\n [Origin.Shirt]: {\n title: 'Shirt',\n description: 'Shirt.sh',\n },\n [Origin.X402Puppet]: {\n title: 'X402 Puppet',\n description: 'Browser automation',\n },\n [Origin.X402Facilitator]: {\n title: 'X402 Facilitator',\n description: 'Payment facilitation',\n },\n };\n\nconst surface = 'registerOrigins';\n\nconst wellKnownResourceItem = z.union([\n z.string(),\n z\n .object({\n url: z.string().optional(),\n path: z.string().optional(),\n method: z.string().optional(),\n })\n .passthrough(),\n]);\n\nconst wellKnownSchema = z.object({\n resources: z.array(wellKnownResourceItem),\n});\n\nexport const registerOrigins: RegisterResources = ({ server }) => {\n for (const origin of ORIGINS) {\n // Extract domain from full URL (e.g., 'https://stableenrich.dev' -> 'stableenrich.dev')\n const domain = new URL(origin).hostname;\n const metadata = ORIGIN_METADATA[origin];\n server.registerResource(\n domain,\n `api://${domain}`,\n {\n title: metadata?.title ?? domain,\n description: metadata?.description ?? '',\n mimeType: 'application/json',\n },\n async uri => {\n const baseUrl = uri.toString().replace('api://', 'https://');\n\n // Fetch .well-known/x402 (and .well-known/mpp when MPP is enabled)\n const wellKnownPromises = [\n safeFetchJson(\n surface,\n new Request(`${baseUrl}/.well-known/x402`),\n wellKnownSchema\n ),\n ...(isMppEnabled()\n ? [\n safeFetchJson(\n surface,\n new Request(`${baseUrl}/.well-known/mpp`),\n wellKnownSchema\n ),\n ]\n : []),\n ];\n const [x402WellKnown, mppWellKnown] =\n await Promise.all(wellKnownPromises);\n\n // Combine resources from available protocols\n const allResourceUrls = new Set<string>();\n\n const addResource = (r: z.infer<typeof wellKnownResourceItem>) => {\n if (typeof r === 'string') {\n allResourceUrls.add(r);\n return;\n }\n const url = r.path ? `${baseUrl}${r.path}` : (r.url ?? '');\n if (url) allResourceUrls.add(url);\n };\n\n if (x402WellKnown?.isOk()) {\n for (const r of x402WellKnown.value.resources) {\n addResource(r);\n }\n }\n\n if (mppWellKnown?.isOk()) {\n for (const r of mppWellKnown.value.resources) {\n addResource(r);\n }\n }\n\n if (allResourceUrls.size === 0) {\n console.error(\n `Failed to fetch well-known for ${origin}:`,\n x402WellKnown?.isErr() ? x402WellKnown.error : 'no x402',\n mppWellKnown?.isErr() ? mppWellKnown.error : 'no mpp'\n );\n return {\n contents: [\n {\n uri: domain,\n text: JSON.stringify(\n { error: 'Failed to fetch well-known resources' },\n null,\n 2\n ),\n mimeType: 'application/json',\n },\n ],\n };\n }\n\n const resources = await Promise.all(\n Array.from(allResourceUrls).map(async resource => {\n const postResult = await getResourceResponse(\n resource,\n new Request(resource, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n );\n\n if (postResult.isOk()) {\n return postResult.value;\n }\n\n const getResult = await getResourceResponse(\n resource,\n new Request(resource, { method: 'GET' })\n );\n\n if (getResult.isOk()) {\n return getResult.value;\n }\n\n console.error(`Failed to get resource response for ${resource}`);\n return null;\n })\n );\n\n const payload = {\n server: origin,\n name: metadata?.title,\n description: metadata?.description,\n resources: resources.filter(Boolean).map(resource => {\n if (!resource) return null;\n\n const entry: Record<string, unknown> = {\n url: resource.resource,\n protocols: resource.protocols,\n };\n\n if (resource.mpp) {\n entry.mpp = {\n method: resource.mpp.method,\n intent: resource.mpp.intent,\n };\n }\n\n if (resource.x402) {\n const schema = getInputSchema(resource.x402.extensions);\n entry.x402 = {\n schema,\n mimeType: resource.x402.mimeType,\n };\n }\n\n return entry;\n }),\n };\n\n const stringifyResult = safeStringifyJson(\n surface,\n payload as JsonObject\n );\n\n if (stringifyResult.isErr()) {\n console.error(\n `Failed to stringify response for ${origin}:`,\n stringifyResult.error\n );\n return {\n contents: [\n {\n uri: domain,\n text: JSON.stringify({\n error: 'Failed to stringify response',\n }),\n mimeType: 'application/json',\n },\n ],\n };\n }\n\n return {\n contents: [\n {\n uri: domain,\n text: stringifyResult.value,\n mimeType: 'application/json',\n },\n ],\n };\n }\n );\n }\n};\n\nconst getResourceResponse = async (resource: string, request: Request) => {\n const fetchResult = await safeFetch(surface, request, DEFAULT_FETCH_TIMEOUT);\n\n if (fetchResult.isErr()) {\n return err('fetch', surface, {\n cause: 'network',\n message: `Failed to fetch resource: ${resource}`,\n });\n }\n\n const response = fetchResult.value;\n\n if (response.status !== 402) {\n return err('fetch', surface, {\n cause: 'not_402',\n message: `Resource did not return 402: ${resource}`,\n });\n }\n\n const protocols = detectPaymentProtocols(response);\n let mppInfo: { method?: string; intent?: string } | null = null;\n let x402Info: {\n extensions?: Record<string, unknown>;\n mimeType?: string;\n } | null = null;\n\n if (isMppEnabled() && protocols.includes('mpp')) {\n const challengeResult = safeGetMppChallenge(surface, response);\n if (challengeResult.isOk()) {\n const challenge = challengeResult.value as unknown as {\n method?: string;\n intent?: string;\n };\n mppInfo = { method: challenge.method, intent: challenge.intent };\n }\n }\n\n if (protocols.includes('x402')) {\n const client = new x402HTTPClient(new x402Client());\n const paymentRequiredResult = await safeGetPaymentRequired(\n surface,\n client,\n response\n );\n if (paymentRequiredResult.isOk()) {\n const pr = paymentRequiredResult.value as unknown as {\n extensions?: Record<string, unknown>;\n resource?: { mimeType?: string };\n };\n x402Info = {\n extensions: pr.extensions,\n mimeType: pr.resource?.mimeType,\n };\n }\n }\n\n if (!mppInfo && !x402Info) {\n return err('parse', surface, {\n cause: 'parse_failed',\n message: `Failed to parse any payment protocol for: ${resource}`,\n });\n }\n\n return ok({\n resource,\n protocols,\n mpp: mppInfo,\n x402: x402Info,\n });\n};\n","import { Origin } from '@/shared/origins';\n\nimport type { RegisterPrompts } from './types';\n\n/**\n * # Getting Started with agentcash\n *\n * This prompt guides users through the complete onboarding workflow\n * to make their first paid API call using x402 micropayments.\n *\n * ## Workflow Steps:\n * 1. Check wallet status with `get_wallet_info`\n * 2. Optionally redeem invite code with `redeem_invite`\n * 3. Discover APIs with `discover_api_endpoints`\n * 4. Check endpoint details with `check_endpoint_schema`\n * 5. Make paid request with `fetch` or `fetch_with_auth`\n */\nconst PROMPT_CONTENT = `# Getting Started with agentcash\n\nYou are helping the user get started with agentcash, an MCP server for calling x402-protected APIs with automatic micropayment handling.\n\n## Your Goal\n\nGuide the user through the complete onboarding workflow to make their first paid API call.\n\n## Step-by-Step Workflow\n\n### Step 1: Check Wallet Status\n\nFirst, use \\`get_wallet_info\\` to check the wallet status. This will:\n\n- Show the wallet address (auto-created at \\`~/.agentcash/wallet.json\\` on first run)\n- Display current USDC balance on Base\n- Provide a deposit link if funding is needed\n\nIf the wallet has 0 balance, the user needs to deposit USDC on Base before proceeding.\n\n### Step 2: Redeem Invite Code (Optional)\n\nIf the user has an invite code, use \\`redeem_invite\\` to claim free USDC credits.\n\n### Step 3: Discover Available APIs\n\nUse \\`discover_api_endpoints\\` to find x402-protected endpoints on a target origin. For example:\n\n- \\`${Origin.StableEnrich}\\` - Data enrichment APIs\n- \\`${Origin.StableStudio}\\` - AI image generation APIs\n\nThis returns a list of available endpoints with their pricing and schemas.\n\n### Step 4: Check Endpoint Details (Optional)\n\nUse \\`check_endpoint_schema\\` to probe a specific endpoint for:\n\n- Pricing information\n- Required parameters schema\n- Authentication requirements (SIWX if applicable)\n\n### Step 5: Make a Paid Request\n\nUse \\`fetch\\` (or \\`fetch_with_auth\\` for SIWX-protected endpoints) to make the actual API call. The payment is handled automatically from the user's USDC balance.\n\n## Key Information\n\n- **Network**: Base (eip155:8453)\n- **Currency**: USDC\n- **Wallet Location**: \\`~/.agentcash/wallet.json\\`\n- **Protocol**: x402 (HTTP 402 Payment Required with crypto micropayments)\n\n## Example Conversation Flow\n\n1. \"Let me check your wallet status first...\"\n2. \"Your wallet has X USDC. Here are the available APIs you can call...\"\n3. \"Which API would you like to use?\"\n4. \"Here's the endpoint schema. What parameters would you like to use?\"\n5. \"Making the request...\" → Return the result\n\n## Important Notes\n\n- Always check wallet balance before attempting paid requests\n- Explain the cost before making a request\n- If balance is low, suggest the deposit link\n- For SIWX-protected endpoints, use \\`fetch_with_auth\\` instead of \\`fetch\\`\n`;\n\nexport const registerGettingStartedPrompt: RegisterPrompts = ({ server }) => {\n server.registerPrompt(\n 'getting_started',\n {\n title: 'Getting Started',\n description:\n 'Step-by-step guide to set up your wallet and make your first x402 API call',\n },\n () => ({\n messages: [\n {\n role: 'user',\n content: {\n type: 'text',\n text: PROMPT_CONTENT,\n },\n },\n {\n role: 'user',\n content: {\n type: 'text',\n text: `Please help me get started with agentcash. Walk me through the setup process.`,\n },\n },\n ],\n })\n );\n};\n","import { z } from 'zod';\n\nimport { Origin } from '@/shared/origins';\n\nimport type { GetPromptResult } from '@modelcontextprotocol/sdk/types.js';\nimport type { RegisterPrompts } from './types';\n\nconst PROMPT_CONTENT = `To start, you should check this resource page: ${Origin.StableEnrich}/llms.txt, which has access to all of the paid endpoints.\n\n- You have access to the agentcash MCP server, which allows you to call paid endpoints which contain potentially extremely useful information.\n- Here are the tools you have access to:\n\n mcp__x402__get_wallet_info\n - Get wallet address and USDC balance on Base\n - Auto-creates wallet on first use (~/.agentcash/wallet.json)\n - Returns deposit link. Check before first paid API call.\n\n mcp__x402__discover_api_endpoints\n - Find x402-protected resources on an origin\n - Returns a list of resource URLs\n - Use mcp__x402__check_endpoint_schema separately to get detailed pricing/schema info\n\n mcp__x402__check_endpoint_schema\n - Probe endpoint to check if x402-protected\n - Returns pricing, input schema, payment methods\n - Use before mcp__x402__fetch to preview costs. No payment made.\n\n mcp__x402__fetch\n - HTTP fetch with automatic x402 payment\n - Detects 402 responses, signs payment, retries with payment headers\n - Returns response data + payment details (price, tx hash) if paid\n - For GET requests: pass parameters as query strings in URL (e.g., ?placeId=value)\n - For POST/PUT/PATCH: pass data in the body parameter\n - ALWAYS use this instead of curl/Bash for x402 endpoints\n\n mcp__x402__fetch_with_auth\n - HTTP fetch with automatic SIWX (Sign-In With X) authentication\n - Detects auth requirement, signs wallet proof, retries with credentials\n - For endpoints requiring identity verification without payment\n\n mcp__x402__redeem_invite\n - Redeem an invite code for free USDC on Base\n - One-time use per code. Returns amount received and transaction hash.\n\n- When using mcp__x402__fetch: Keep in mind:\n - For GET requests, include parameters as query strings in the URL (e.g., ?placeId=value); do not use the body parameter.\n - For POST requests, use the body parameter to include the request body.\n Be sure to use the correct method for the request.\n Any request that passes to one of the paid endpoints should be called with mcp__x402__fetch. Never use curl for these requests.\n\n- You should use these paid endpoints to find useful information whenever possible.\n- Opt to use the paid endpoints as often as possible, as they speed up your research and provide higher quality information than traditional WebFetch.\n\n- **IMPORTANT:** All the API endpoints below (Exa, Firecrawl, Clado, Google Maps, Apollo, Grok, Whitepages, Hunter) are accessed via mcp__x402__fetch. They are NOT separate MCP tools. Call them like: mcp__x402__fetch(url=\"${Origin.StableEnrich}/api/clado/contacts-enrich\", method=\"POST\", body={...})\n- Use the Exa and Firecrawl endpoints as advanced / better WebFetch. They will often return data that would otherwise return only javascript or blocked content.\n- If you get a 403 or error when using WebSearch or WebFetch on a website, try with Exa/Firecrawl endpoints immediately as they likely can get around the blockage.\n- Use the Clado endpoints (/api/clado/contacts-enrich, /api/clado/linkedin-scrape) to enrich information about people and find their linkedin or email addresses. If linkedin returns an error code, immediately try with the Clado endpoints.\n- Use the Google Maps endpoints to find reviews, or other local information. Always attempt to include review information in your findings if relevant.\n- **Google Maps text-search/full endpoint:** When calling POST ${Origin.StableEnrich}/api/google-maps/text-search/full, ALWAYS use maxResultCount=1-3, never 5. Using 5 produces too much context. If you get excessive context in the response, retry with maxResultCount=1.\n- All these are REST API endpoints called via mcp__x402__fetch - do NOT attempt to call mcp__clado__*, mcp__exa__*, mcp__google_maps__*, etc. Those tools do not exist.\n\nPAID ENDPOINTS:\nThese endpoints are always available at ${Origin.StableEnrich}. You should always fetch from this domain.`;\n\nconst INFER_TASK_INSTRUCTIONS = `No specific query was provided.\n\nYour task:\n1. Review the conversation history and session context\n2. Identify what the user is currently working on or trying to accomplish\n3. Determine the most likely way the premium APIs could help (e.g., enriching contact info, fetching blocked web content, finding business reviews, etc.)\n4. Briefly state what task you've inferred and why\n5. Execute that task immediately using the appropriate enrichment tools\n\nBe proactive - don't ask for confirmation, just identify the most valuable enrichment opportunity and act on it.`;\n\nconst QUERY_INSTRUCTIONS = (query: string) => `The user's query is: ${query}\n\nYour task:\n1. Analyze the query to understand what information or enrichment the user needs\n2. If anything is unclear or you need more details to use the APIs effectively, ask 1-2 clarifying questions first\n3. Once you have enough context, use the premium APIs to fulfill the request\n4. Return comprehensive results with relevant details\n\nBe thorough - these premium APIs provide higher quality data than free alternatives.`;\n\nexport const registerEnrichPrompt: RegisterPrompts = ({ server }) => {\n server.registerPrompt(\n 'enrich',\n {\n title: 'Enrich',\n description:\n 'Use premium APIs to enrich data. Optionally provide a query, or let the assistant infer the best task from context.',\n argsSchema: {\n query: z\n .string()\n .optional()\n .describe(\n \"Optional: The user's query to enrich. If omitted, the assistant will infer the task from conversation context.\"\n ),\n },\n },\n ({ query }): GetPromptResult => ({\n messages: [\n {\n role: 'user',\n content: {\n type: 'text',\n text: PROMPT_CONTENT,\n },\n },\n {\n role: 'user',\n content: {\n type: 'text',\n text: query ? QUERY_INSTRUCTIONS(query) : INFER_TASK_INSTRUCTIONS,\n },\n },\n ],\n })\n );\n};\n","import { registerGettingStartedPrompt } from './getting-started';\nimport { registerEnrichPrompt } from './enrich';\nimport type { RegisterPrompts } from './types';\n\nexport const registerPrompts: RegisterPrompts = props => {\n registerGettingStartedPrompt(props);\n registerEnrichPrompt(props);\n};\n","import { readFileSync } from 'fs';\nimport { dirname, join } from 'path';\nimport { fileURLToPath } from 'url';\n\ndeclare const __MCP_VERSION__: string | undefined;\n\nfunction getVersion(): string {\n if (typeof __MCP_VERSION__ !== 'undefined') {\n return __MCP_VERSION__;\n }\n // Fallback for dev mode (tsx)\n const __dirname = dirname(fileURLToPath(import.meta.url));\n const pkg = JSON.parse(\n readFileSync(join(__dirname, '../../../package.json'), 'utf-8')\n ) as { version: string };\n return pkg.version;\n}\n\nexport const MCP_VERSION = getVersion();\n\nexport const DIST_TAG = MCP_VERSION.includes('-beta') ? 'beta' : 'latest';\n","import { Origin } from '@/shared/origins';\n\n/**\n * Static server instructions describing the known API origins.\n *\n * Previously this was built dynamically by fetching OpenAPI specs from every\n * origin at startup, which blocked the MCP transport connection for 10-30s.\n * Hardcoded here for instant startup — use discover_api_endpoints at runtime\n * to get full endpoint details.\n */\nexport function buildServerInstructions(): string {\n return `Known API origins:\n - ${Origin.StableEnrich} — People/org search, Google Maps, Grok twitter search, Exa web search, LinkedIn data, Firecrawl scrape, WhitePages, email enrichment, Hunter email verifier\n - ${Origin.StableSocial} — Social media data (Twitter, Instagram, TikTok, YouTube, Facebook, Reddit)\n - ${Origin.StableStudio} — Generate and edit images/videos\n - ${Origin.StableUpload} — Upload and share files\n - ${Origin.StableEmail} — Send emails\n\nWorkflow:\n1. Use discover_api_endpoints to find available endpoints on an origin.\n2. Use check_endpoint_schema to get the full input schema + pricing for an endpoint.\n3. Use fetch to make the request (handles payment automatically).`;\n}\n"],"mappings":"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","names":["error","err","surface","surface","toolName","z","z","z","toolName","z","z","z","z","toolName","z","z","toolName","z","z","x402HTTPClient","x402Client","z","x402HTTPClient","x402Client","z","PROMPT_CONTENT","z","__dirname","MCP_VERSION","MCP_VERSION"]}
@@ -1,14 +1,14 @@
1
1
  import {
2
2
  getWalletInfo,
3
3
  submitErrorReport
4
- } from "../../chunk-UIMAHOSV.js";
5
- import "../../chunk-DJS6BHZB.js";
4
+ } from "../../chunk-YRRXIT26.js";
5
+ import "../../chunk-OJFWL5A3.js";
6
6
  import {
7
7
  SUPPORTED_METHODS,
8
8
  checkEndpoint,
9
9
  discoverResources
10
- } from "../../chunk-MWRO3R4V.js";
11
- import "../../chunk-SN5HHMIT.js";
10
+ } from "../../chunk-5EMDWOPZ.js";
11
+ import "../../chunk-EDE2BA5J.js";
12
12
  import "../../chunk-YUCA2PQT.js";
13
13
  import "../../chunk-TRPO7BKD.js";
14
14
  import "../../chunk-ISR6DJ53.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agentcash",
3
- "version": "0.7.1",
3
+ "version": "0.7.2",
4
4
  "description": "Generic MCP server for calling x402-protected APIs with automatic payment handling",
5
5
  "type": "module",
6
6
  "main": "dist/esm/lib.js",
@@ -76,6 +76,7 @@
76
76
  "homepage": "https://github.com/Merit-Systems/agent-cash/tree/master/packages/external/mcp",
77
77
  "scripts": {
78
78
  "dev": "tsx src/index.ts",
79
+ "dev:onboard": "tsx src/index.ts onboard",
79
80
  "build": "tsup",
80
81
  "build:watch": "tsup --watch",
81
82
  "build:mcpb": "tsx scripts/build-mcpb.ts",
@@ -1,7 +0,0 @@
1
- // src/shared/mpp-enabled.ts
2
- var isMppEnabled = () => "0.7.1".includes("-mpp");
3
-
4
- export {
5
- isMppEnabled
6
- };
7
- //# sourceMappingURL=chunk-DJS6BHZB.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/shared/operations/check-endpoint.ts","../../src/shared/operations/discover.ts"],"sourcesContent":["import {\n checkEndpointSchema,\n type HttpMethod,\n type CheckEndpointSuccess,\n type CheckEndpointNotFound,\n} from '@agentcash/discovery';\n\nimport { log } from '@/shared/log';\n\nexport const SUPPORTED_METHODS = [\n 'GET',\n 'POST',\n 'PUT',\n 'DELETE',\n 'PATCH',\n] as const;\n// Narrowed subset of discovery's HttpMethod (excludes HEAD/OPTIONS/TRACE).\nexport type SupportedMethod = Extract<\n HttpMethod,\n (typeof SUPPORTED_METHODS)[number]\n>;\n\n/**\n * Returns advisory data for an endpoint: auth mode, pricing, protocols,\n * input schema, and (when available) exact payment options.\n *\n * Two-phase workflow:\n * 1. Call without `sampleInputSchema` to get the input schema and advisory\n * pricing from the OpenAPI spec (no live request to the endpoint).\n * 2. Once you know what body you intend to send, call again with\n * `sampleInputSchema` set to that body. The discovery layer will probe\n * the live endpoint with that payload and return exact PaymentOptions\n * priced for it — giving a precise cost before committing to a fetch.\n */\nexport async function checkEndpoint(\n surface: string,\n url: string,\n methods?: SupportedMethod[],\n sampleInputBody?: Record<string, unknown>,\n headers?: Record<string, string>\n): Promise<CheckEndpointSuccess | CheckEndpointNotFound> {\n log.info('Checking endpoint', { surface, url, methods, hasSampleInputBody: !!sampleInputBody });\n\n const result = await checkEndpointSchema({\n url,\n sampleInputBody,\n headers,\n });\n\n if (!result.found) {\n log.error(`[checkEndpoint failed`, {\n surface,\n url,\n cause: result.cause,\n message: result.message,\n });\n return result;\n }\n\n const advisories = methods?.length\n ? result.advisories.filter(a =>\n methods.includes(a.method as SupportedMethod)\n )\n : result.advisories;\n\n return { ...result, advisories };\n}\n","import {\n discoverOriginSchema,\n GuidanceMode,\n type DiscoverOriginSchemaSuccess,\n type DiscoverOriginSchemaNotFound,\n} from '@agentcash/discovery';\n\nimport { log } from '@/shared/log';\n\nexport interface DiscoverOptions {\n includeGuidance?: boolean;\n}\n\n/**\n * Discover payment-protected resources on an origin.\n * Fetches OpenAPI spec, builds endpoint index, and fetches guidance.\n *\n * Returns DiscoverOriginSchemaSuccess on success, DiscoverOriginSchemaNotFound with cause on failure.\n */\nexport async function discoverResources(\n surface: string,\n url: string,\n options: DiscoverOptions = {}\n): Promise<DiscoverOriginSchemaSuccess | DiscoverOriginSchemaNotFound> {\n const guidance =\n options.includeGuidance === true\n ? GuidanceMode.Always\n : options.includeGuidance === false\n ? GuidanceMode.Never\n : GuidanceMode.Auto;\n\n const result = await discoverOriginSchema({ target: url, guidance });\n\n if (!result.found) {\n log.error(`[discoverResources failed`, {\n surface,\n url,\n cause: result.cause,\n message: result.message,\n });\n }\n\n return result;\n}\n"],"mappings":";;;;;AAAA;AAAA,EACE;AAAA,OAIK;AAIA,IAAM,oBAAoB;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAmBA,eAAsB,cACpB,SACA,KACA,SACA,iBACA,SACuD;AACvD,MAAI,KAAK,qBAAqB,EAAE,SAAS,KAAK,SAAS,oBAAoB,CAAC,CAAC,gBAAgB,CAAC;AAE9F,QAAM,SAAS,MAAM,oBAAoB;AAAA,IACvC;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,MAAI,CAAC,OAAO,OAAO;AACjB,QAAI,MAAM,yBAAyB;AAAA,MACjC;AAAA,MACA;AAAA,MACA,OAAO,OAAO;AAAA,MACd,SAAS,OAAO;AAAA,IAClB,CAAC;AACD,WAAO;AAAA,EACT;AAEA,QAAM,aAAa,SAAS,SACxB,OAAO,WAAW;AAAA,IAAO,OACvB,QAAQ,SAAS,EAAE,MAAyB;AAAA,EAC9C,IACA,OAAO;AAEX,SAAO,EAAE,GAAG,QAAQ,WAAW;AACjC;;;AClEA;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AAcP,eAAsB,kBACpB,SACA,KACA,UAA2B,CAAC,GACyC;AACrE,QAAM,WACJ,QAAQ,oBAAoB,OACxB,aAAa,SACb,QAAQ,oBAAoB,QAC1B,aAAa,QACb,aAAa;AAErB,QAAM,SAAS,MAAM,qBAAqB,EAAE,QAAQ,KAAK,SAAS,CAAC;AAEnE,MAAI,CAAC,OAAO,OAAO;AACjB,QAAI,MAAM,6BAA6B;AAAA,MACrC;AAAA,MACA;AAAA,MACA,OAAO,OAAO;AAAA,MACd,SAAS,OAAO;AAAA,IAClB,CAAC;AAAA,EACH;AAEA,SAAO;AACT;","names":[]}