@t402/mcp 2.7.1 → 2.8.1
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.
- package/dist/cjs/index.js +1652 -208
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/server/index.d.ts +41 -0
- package/dist/cjs/server/index.js +1652 -208
- package/dist/cjs/server/index.js.map +1 -1
- package/dist/cjs/tools/index.d.ts +1215 -217
- package/dist/cjs/tools/index.js +1847 -173
- package/dist/cjs/tools/index.js.map +1 -1
- package/dist/esm/{chunk-3PMBXSJ3.mjs → chunk-4DCBAKH2.mjs} +218 -2
- package/dist/esm/chunk-4DCBAKH2.mjs.map +1 -0
- package/dist/esm/{chunk-B7X7H6NV.mjs → chunk-OSPCSAZF.mjs} +1800 -174
- package/dist/esm/chunk-OSPCSAZF.mjs.map +1 -0
- package/dist/esm/index.mjs +2 -2
- package/dist/esm/server/index.d.mts +41 -0
- package/dist/esm/server/index.mjs +2 -2
- package/dist/esm/tools/index.d.mts +1215 -217
- package/dist/esm/tools/index.mjs +94 -1
- package/package.json +15 -15
- package/dist/esm/chunk-3PMBXSJ3.mjs.map +0 -1
- package/dist/esm/chunk-B7X7H6NV.mjs.map +0 -1
|
@@ -7,29 +7,44 @@ import {
|
|
|
7
7
|
__publicField,
|
|
8
8
|
autoPayInputSchema,
|
|
9
9
|
bridgeInputSchema,
|
|
10
|
+
compareNetworkFeesInputSchema,
|
|
10
11
|
erc8004CheckReputationInputSchema,
|
|
11
12
|
erc8004ResolveAgentInputSchema,
|
|
12
13
|
erc8004VerifyWalletInputSchema,
|
|
14
|
+
estimatePaymentFeeInputSchema,
|
|
13
15
|
executeAutoPay,
|
|
14
16
|
executeAutoPayDemo,
|
|
15
17
|
executeBridge,
|
|
18
|
+
executeBridgeFromQuoteInputSchema,
|
|
19
|
+
executeCompareNetworkFees,
|
|
16
20
|
executeErc8004CheckReputation,
|
|
17
21
|
executeErc8004ResolveAgent,
|
|
18
22
|
executeErc8004VerifyWallet,
|
|
23
|
+
executeEstimatePaymentFee,
|
|
24
|
+
executeExecuteBridgeFromQuote,
|
|
25
|
+
executeExecuteBridgeFromQuoteDemo,
|
|
19
26
|
executeGetAllBalances,
|
|
20
27
|
executeGetBalance,
|
|
21
28
|
executeGetBridgeFee,
|
|
29
|
+
executeGetGasPrice,
|
|
30
|
+
executeGetTokenPrice,
|
|
22
31
|
executePay,
|
|
23
32
|
executePayGasless,
|
|
24
33
|
executePaymentPlan,
|
|
25
34
|
executePaymentPlanDemo,
|
|
35
|
+
executeQuoteBridge,
|
|
36
|
+
executeQuoteBridgeDemo,
|
|
26
37
|
executeSmartPay,
|
|
27
38
|
executeSmartPayDemo,
|
|
28
39
|
executeTonBridgeTool,
|
|
40
|
+
executeWdkExecuteSwap,
|
|
41
|
+
executeWdkExecuteSwapDemo,
|
|
29
42
|
executeWdkGetBalances,
|
|
30
43
|
executeWdkGetBalancesDemo,
|
|
31
44
|
executeWdkGetWallet,
|
|
32
45
|
executeWdkGetWalletDemo,
|
|
46
|
+
executeWdkQuoteSwap,
|
|
47
|
+
executeWdkQuoteSwapDemo,
|
|
33
48
|
executeWdkSwap,
|
|
34
49
|
executeWdkSwapDemo,
|
|
35
50
|
executeWdkTransfer,
|
|
@@ -38,14 +53,21 @@ import {
|
|
|
38
53
|
formatAutoPayResult,
|
|
39
54
|
formatBalanceResult,
|
|
40
55
|
formatBridgeFeeResult,
|
|
56
|
+
formatBridgeQuoteResult,
|
|
41
57
|
formatBridgeResult,
|
|
42
58
|
formatErc8004CheckReputationResult,
|
|
43
59
|
formatErc8004ResolveAgentResult,
|
|
44
60
|
formatErc8004VerifyWalletResult,
|
|
61
|
+
formatExecuteSwapResult,
|
|
62
|
+
formatGasPriceResult,
|
|
45
63
|
formatGaslessPaymentResult,
|
|
64
|
+
formatNetworkFeeComparison,
|
|
65
|
+
formatPaymentFeeEstimate,
|
|
46
66
|
formatPaymentPlanResult,
|
|
47
67
|
formatPaymentResult,
|
|
48
68
|
formatSmartPayResult,
|
|
69
|
+
formatSwapQuoteResult,
|
|
70
|
+
formatTokenPriceResult,
|
|
49
71
|
formatWdkBalancesResult,
|
|
50
72
|
formatWdkSwapResult,
|
|
51
73
|
formatWdkTransferResult,
|
|
@@ -53,15 +75,20 @@ import {
|
|
|
53
75
|
getAllBalancesInputSchema,
|
|
54
76
|
getBalanceInputSchema,
|
|
55
77
|
getBridgeFeeInputSchema,
|
|
78
|
+
getGasPriceInputSchema,
|
|
79
|
+
getTokenPriceInputSchema,
|
|
56
80
|
payGaslessInputSchema,
|
|
57
81
|
payInputSchema,
|
|
58
82
|
paymentPlanInputSchema,
|
|
83
|
+
quoteBridgeInputSchema,
|
|
59
84
|
smartPayInputSchema,
|
|
85
|
+
wdkExecuteSwapInputSchema,
|
|
60
86
|
wdkGetBalancesInputSchema,
|
|
61
87
|
wdkGetWalletInputSchema,
|
|
88
|
+
wdkQuoteSwapInputSchema,
|
|
62
89
|
wdkSwapInputSchema,
|
|
63
90
|
wdkTransferInputSchema
|
|
64
|
-
} from "./chunk-
|
|
91
|
+
} from "./chunk-OSPCSAZF.mjs";
|
|
65
92
|
|
|
66
93
|
// src/server/t402Server.ts
|
|
67
94
|
import { Server } from "@modelcontextprotocol/sdk/server/index.js";
|
|
@@ -106,6 +133,19 @@ var T402McpServer = class {
|
|
|
106
133
|
console.error("Warning: Failed to initialize WDK. WDK tools will not be available.");
|
|
107
134
|
}
|
|
108
135
|
}
|
|
136
|
+
/**
|
|
137
|
+
* Clear sensitive data from memory.
|
|
138
|
+
* Should be called on server shutdown to minimize key exposure window.
|
|
139
|
+
*/
|
|
140
|
+
cleanup() {
|
|
141
|
+
if (this.config.privateKey) {
|
|
142
|
+
this.config.privateKey = "";
|
|
143
|
+
}
|
|
144
|
+
if (this.config.seedPhrase) {
|
|
145
|
+
this.config.seedPhrase = "";
|
|
146
|
+
}
|
|
147
|
+
this.wdk = null;
|
|
148
|
+
}
|
|
109
149
|
/**
|
|
110
150
|
* Register TON bridge tools
|
|
111
151
|
*
|
|
@@ -171,6 +211,24 @@ var T402McpServer = class {
|
|
|
171
211
|
return await this.handleSmartPay(args);
|
|
172
212
|
case "t402/paymentPlan":
|
|
173
213
|
return await this.handlePaymentPlan(args);
|
|
214
|
+
// Price and fee tools
|
|
215
|
+
case "t402/getTokenPrice":
|
|
216
|
+
return await this.handleGetTokenPrice(args);
|
|
217
|
+
case "t402/getGasPrice":
|
|
218
|
+
return await this.handleGetGasPrice(args);
|
|
219
|
+
case "t402/estimatePaymentFee":
|
|
220
|
+
return await this.handleEstimatePaymentFee(args);
|
|
221
|
+
case "t402/compareNetworkFees":
|
|
222
|
+
return await this.handleCompareNetworkFees(args);
|
|
223
|
+
// Quote-based tools
|
|
224
|
+
case "t402/quoteBridge":
|
|
225
|
+
return await this.handleQuoteBridge(args);
|
|
226
|
+
case "t402/executeBridgeQuote":
|
|
227
|
+
return await this.handleExecuteBridgeQuote(args);
|
|
228
|
+
case "wdk/quoteSwap":
|
|
229
|
+
return await this.handleWdkQuoteSwap(args);
|
|
230
|
+
case "wdk/executeSwap":
|
|
231
|
+
return await this.handleWdkExecuteSwap(args);
|
|
174
232
|
// ERC-8004 tools
|
|
175
233
|
case "erc8004/resolveAgent":
|
|
176
234
|
return await this.handleErc8004ResolveAgent(args);
|
|
@@ -232,6 +290,28 @@ var T402McpServer = class {
|
|
|
232
290
|
]
|
|
233
291
|
};
|
|
234
292
|
}
|
|
293
|
+
/**
|
|
294
|
+
* Format a confirmation prompt for elicitation
|
|
295
|
+
*/
|
|
296
|
+
formatConfirmation(result) {
|
|
297
|
+
const detailLines = Object.entries(result.details).map(([key, value]) => `- **${key}:** ${value}`).join("\n");
|
|
298
|
+
return {
|
|
299
|
+
content: [
|
|
300
|
+
{
|
|
301
|
+
type: "text",
|
|
302
|
+
text: [
|
|
303
|
+
"## Confirmation Required",
|
|
304
|
+
"",
|
|
305
|
+
result.summary,
|
|
306
|
+
"",
|
|
307
|
+
detailLines,
|
|
308
|
+
"",
|
|
309
|
+
"_Call this tool again with `confirmed: true` to execute._"
|
|
310
|
+
].join("\n")
|
|
311
|
+
}
|
|
312
|
+
]
|
|
313
|
+
};
|
|
314
|
+
}
|
|
235
315
|
/**
|
|
236
316
|
* Handle t402/pay
|
|
237
317
|
*/
|
|
@@ -247,6 +327,9 @@ var T402McpServer = class {
|
|
|
247
327
|
rpcUrl: this.config.rpcUrls?.[input.network],
|
|
248
328
|
demoMode: this.config.demoMode
|
|
249
329
|
});
|
|
330
|
+
if ("needsConfirmation" in result) {
|
|
331
|
+
return this.formatConfirmation(result);
|
|
332
|
+
}
|
|
250
333
|
return {
|
|
251
334
|
content: [
|
|
252
335
|
{
|
|
@@ -283,6 +366,9 @@ var T402McpServer = class {
|
|
|
283
366
|
rpcUrl: this.config.rpcUrls?.[input.network],
|
|
284
367
|
demoMode: this.config.demoMode
|
|
285
368
|
});
|
|
369
|
+
if ("needsConfirmation" in result) {
|
|
370
|
+
return this.formatConfirmation(result);
|
|
371
|
+
}
|
|
286
372
|
return {
|
|
287
373
|
content: [
|
|
288
374
|
{
|
|
@@ -322,6 +408,9 @@ var T402McpServer = class {
|
|
|
322
408
|
rpcUrl: this.config.rpcUrls?.[input.fromChain],
|
|
323
409
|
demoMode: this.config.demoMode
|
|
324
410
|
});
|
|
411
|
+
if ("needsConfirmation" in result) {
|
|
412
|
+
return this.formatConfirmation(result);
|
|
413
|
+
}
|
|
325
414
|
return {
|
|
326
415
|
content: [
|
|
327
416
|
{
|
|
@@ -358,6 +447,9 @@ var T402McpServer = class {
|
|
|
358
447
|
async handleWdkTransfer(args) {
|
|
359
448
|
const input = wdkTransferInputSchema.parse(args);
|
|
360
449
|
const result = this.config.demoMode || !this.wdk ? executeWdkTransferDemo(input) : await executeWdkTransfer(input, this.wdk);
|
|
450
|
+
if ("needsConfirmation" in result) {
|
|
451
|
+
return this.formatConfirmation(result);
|
|
452
|
+
}
|
|
361
453
|
return {
|
|
362
454
|
content: [{ type: "text", text: formatWdkTransferResult(result) }]
|
|
363
455
|
};
|
|
@@ -368,6 +460,9 @@ var T402McpServer = class {
|
|
|
368
460
|
async handleWdkSwap(args) {
|
|
369
461
|
const input = wdkSwapInputSchema.parse(args);
|
|
370
462
|
const result = this.config.demoMode || !this.wdk ? executeWdkSwapDemo(input) : await executeWdkSwap(input, this.wdk);
|
|
463
|
+
if ("needsConfirmation" in result) {
|
|
464
|
+
return this.formatConfirmation(result);
|
|
465
|
+
}
|
|
371
466
|
return {
|
|
372
467
|
content: [{ type: "text", text: formatWdkSwapResult(result) }]
|
|
373
468
|
};
|
|
@@ -378,6 +473,9 @@ var T402McpServer = class {
|
|
|
378
473
|
async handleAutoPay(args) {
|
|
379
474
|
const input = autoPayInputSchema.parse(args);
|
|
380
475
|
const result = this.config.demoMode || !this.wdk ? executeAutoPayDemo(input) : await executeAutoPay(input, this.wdk);
|
|
476
|
+
if ("needsConfirmation" in result) {
|
|
477
|
+
return this.formatConfirmation(result);
|
|
478
|
+
}
|
|
381
479
|
return {
|
|
382
480
|
content: [{ type: "text", text: formatAutoPayResult(result) }]
|
|
383
481
|
};
|
|
@@ -389,6 +487,9 @@ var T402McpServer = class {
|
|
|
389
487
|
async handleSmartPay(args) {
|
|
390
488
|
const input = smartPayInputSchema.parse(args);
|
|
391
489
|
const result = this.config.demoMode || !this.wdk ? executeSmartPayDemo(input) : await executeSmartPay(input, this.wdk);
|
|
490
|
+
if ("needsConfirmation" in result) {
|
|
491
|
+
return this.formatConfirmation(result);
|
|
492
|
+
}
|
|
392
493
|
return {
|
|
393
494
|
content: [{ type: "text", text: formatSmartPayResult(result) }]
|
|
394
495
|
};
|
|
@@ -403,6 +504,111 @@ var T402McpServer = class {
|
|
|
403
504
|
content: [{ type: "text", text: formatPaymentPlanResult(result) }]
|
|
404
505
|
};
|
|
405
506
|
}
|
|
507
|
+
// ---- Price and Fee Tool Handlers ----
|
|
508
|
+
/**
|
|
509
|
+
* Handle t402/getTokenPrice
|
|
510
|
+
*/
|
|
511
|
+
async handleGetTokenPrice(args) {
|
|
512
|
+
const input = getTokenPriceInputSchema.parse(args);
|
|
513
|
+
const result = await executeGetTokenPrice(input, { demoMode: this.config.demoMode });
|
|
514
|
+
return {
|
|
515
|
+
content: [{ type: "text", text: formatTokenPriceResult(result) }]
|
|
516
|
+
};
|
|
517
|
+
}
|
|
518
|
+
/**
|
|
519
|
+
* Handle t402/getGasPrice
|
|
520
|
+
*/
|
|
521
|
+
async handleGetGasPrice(args) {
|
|
522
|
+
const input = getGasPriceInputSchema.parse(args);
|
|
523
|
+
const result = await executeGetGasPrice(input, {
|
|
524
|
+
rpcUrl: this.config.rpcUrls?.[input.network],
|
|
525
|
+
demoMode: this.config.demoMode
|
|
526
|
+
});
|
|
527
|
+
return {
|
|
528
|
+
content: [{ type: "text", text: formatGasPriceResult(result) }]
|
|
529
|
+
};
|
|
530
|
+
}
|
|
531
|
+
/**
|
|
532
|
+
* Handle t402/estimatePaymentFee
|
|
533
|
+
*/
|
|
534
|
+
async handleEstimatePaymentFee(args) {
|
|
535
|
+
const input = estimatePaymentFeeInputSchema.parse(args);
|
|
536
|
+
const result = await executeEstimatePaymentFee(input, {
|
|
537
|
+
rpcUrl: this.config.rpcUrls?.[input.network],
|
|
538
|
+
demoMode: this.config.demoMode
|
|
539
|
+
});
|
|
540
|
+
return {
|
|
541
|
+
content: [{ type: "text", text: formatPaymentFeeEstimate(result) }]
|
|
542
|
+
};
|
|
543
|
+
}
|
|
544
|
+
/**
|
|
545
|
+
* Handle t402/compareNetworkFees
|
|
546
|
+
*/
|
|
547
|
+
async handleCompareNetworkFees(args) {
|
|
548
|
+
const input = compareNetworkFeesInputSchema.parse(args);
|
|
549
|
+
const result = await executeCompareNetworkFees(input, {
|
|
550
|
+
rpcUrls: this.config.rpcUrls,
|
|
551
|
+
demoMode: this.config.demoMode
|
|
552
|
+
});
|
|
553
|
+
return {
|
|
554
|
+
content: [{ type: "text", text: formatNetworkFeeComparison(result) }]
|
|
555
|
+
};
|
|
556
|
+
}
|
|
557
|
+
// ---- Quote-based Tool Handlers ----
|
|
558
|
+
/**
|
|
559
|
+
* Handle t402/quoteBridge
|
|
560
|
+
*/
|
|
561
|
+
async handleQuoteBridge(args) {
|
|
562
|
+
const input = quoteBridgeInputSchema.parse(args);
|
|
563
|
+
const result = this.config.demoMode ? executeQuoteBridgeDemo(input) : await executeQuoteBridge(input, this.config.rpcUrls);
|
|
564
|
+
return {
|
|
565
|
+
content: [{ type: "text", text: formatBridgeQuoteResult(result) }]
|
|
566
|
+
};
|
|
567
|
+
}
|
|
568
|
+
/**
|
|
569
|
+
* Handle t402/executeBridgeQuote
|
|
570
|
+
*/
|
|
571
|
+
async handleExecuteBridgeQuote(args) {
|
|
572
|
+
if (!this.config.privateKey && !this.config.demoMode) {
|
|
573
|
+
throw new Error(
|
|
574
|
+
"Private key not configured. Set T402_PRIVATE_KEY environment variable or enable demo mode."
|
|
575
|
+
);
|
|
576
|
+
}
|
|
577
|
+
const input = executeBridgeFromQuoteInputSchema.parse(args);
|
|
578
|
+
const result = this.config.demoMode ? executeExecuteBridgeFromQuoteDemo(input) : await executeExecuteBridgeFromQuote(input, {
|
|
579
|
+
privateKey: this.config.privateKey || "0x",
|
|
580
|
+
demoMode: this.config.demoMode
|
|
581
|
+
});
|
|
582
|
+
if ("needsConfirmation" in result) {
|
|
583
|
+
return this.formatConfirmation(result);
|
|
584
|
+
}
|
|
585
|
+
return {
|
|
586
|
+
content: [{ type: "text", text: formatBridgeResult(result) }]
|
|
587
|
+
};
|
|
588
|
+
}
|
|
589
|
+
/**
|
|
590
|
+
* Handle wdk/quoteSwap
|
|
591
|
+
*/
|
|
592
|
+
async handleWdkQuoteSwap(args) {
|
|
593
|
+
const input = wdkQuoteSwapInputSchema.parse(args);
|
|
594
|
+
const result = this.config.demoMode || !this.wdk ? executeWdkQuoteSwapDemo(input) : await executeWdkQuoteSwap(input, this.wdk);
|
|
595
|
+
return {
|
|
596
|
+
content: [{ type: "text", text: formatSwapQuoteResult(result) }]
|
|
597
|
+
};
|
|
598
|
+
}
|
|
599
|
+
/**
|
|
600
|
+
* Handle wdk/executeSwap
|
|
601
|
+
*/
|
|
602
|
+
async handleWdkExecuteSwap(args) {
|
|
603
|
+
const input = wdkExecuteSwapInputSchema.parse(args);
|
|
604
|
+
const result = this.config.demoMode || !this.wdk ? executeWdkExecuteSwapDemo(input) : await executeWdkExecuteSwap(input, this.wdk);
|
|
605
|
+
if ("needsConfirmation" in result) {
|
|
606
|
+
return this.formatConfirmation(result);
|
|
607
|
+
}
|
|
608
|
+
return {
|
|
609
|
+
content: [{ type: "text", text: formatExecuteSwapResult(result) }]
|
|
610
|
+
};
|
|
611
|
+
}
|
|
406
612
|
// ---- ERC-8004 Tool Handlers ----
|
|
407
613
|
/**
|
|
408
614
|
* Handle erc8004/resolveAgent
|
|
@@ -449,6 +655,16 @@ var T402McpServer = class {
|
|
|
449
655
|
*/
|
|
450
656
|
async run() {
|
|
451
657
|
await this.initWdk();
|
|
658
|
+
const onExit = () => this.cleanup();
|
|
659
|
+
process.on("exit", onExit);
|
|
660
|
+
process.on("SIGINT", () => {
|
|
661
|
+
onExit();
|
|
662
|
+
process.exit(0);
|
|
663
|
+
});
|
|
664
|
+
process.on("SIGTERM", () => {
|
|
665
|
+
onExit();
|
|
666
|
+
process.exit(0);
|
|
667
|
+
});
|
|
452
668
|
const transport = new StdioServerTransport();
|
|
453
669
|
await this.server.connect(transport);
|
|
454
670
|
console.error("t402 MCP Server running on stdio");
|
|
@@ -515,4 +731,4 @@ export {
|
|
|
515
731
|
createT402McpServer,
|
|
516
732
|
loadConfigFromEnv
|
|
517
733
|
};
|
|
518
|
-
//# sourceMappingURL=chunk-
|
|
734
|
+
//# sourceMappingURL=chunk-4DCBAKH2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/server/t402Server.ts"],"sourcesContent":["/**\n * t402 MCP Server - Main server implementation\n */\n\nimport { Server } from '@modelcontextprotocol/sdk/server/index.js'\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js'\nimport { CallToolRequestSchema, ListToolsRequestSchema } from '@modelcontextprotocol/sdk/types.js'\nimport type { McpServerConfig, SupportedNetwork } from '../types.js'\nimport {\n TOOL_DEFINITIONS,\n WDK_TOOL_DEFINITIONS,\n UNIFIED_TOOL_DEFINITIONS,\n executeGetBalance,\n formatBalanceResult,\n getBalanceInputSchema,\n executeGetAllBalances,\n formatAllBalancesResult,\n getAllBalancesInputSchema,\n executePay,\n formatPaymentResult,\n payInputSchema,\n executePayGasless,\n formatGaslessPaymentResult,\n payGaslessInputSchema,\n executeGetBridgeFee,\n formatBridgeFeeResult,\n getBridgeFeeInputSchema,\n executeBridge,\n formatBridgeResult,\n bridgeInputSchema,\n // WDK tools\n wdkGetWalletInputSchema,\n executeWdkGetWallet,\n executeWdkGetWalletDemo,\n formatWdkWalletResult,\n wdkGetBalancesInputSchema,\n executeWdkGetBalances,\n executeWdkGetBalancesDemo,\n formatWdkBalancesResult,\n wdkTransferInputSchema,\n executeWdkTransfer,\n executeWdkTransferDemo,\n formatWdkTransferResult,\n wdkSwapInputSchema,\n executeWdkSwap,\n executeWdkSwapDemo,\n formatWdkSwapResult,\n autoPayInputSchema,\n executeAutoPay,\n executeAutoPayDemo,\n formatAutoPayResult,\n // Unified tools\n smartPayInputSchema,\n executeSmartPay,\n executeSmartPayDemo,\n formatSmartPayResult,\n paymentPlanInputSchema,\n executePaymentPlan,\n executePaymentPlanDemo,\n formatPaymentPlanResult,\n // Price and fee tools\n getTokenPriceInputSchema,\n executeGetTokenPrice,\n formatTokenPriceResult,\n getGasPriceInputSchema,\n executeGetGasPrice,\n formatGasPriceResult,\n estimatePaymentFeeInputSchema,\n executeEstimatePaymentFee,\n formatPaymentFeeEstimate,\n compareNetworkFeesInputSchema,\n executeCompareNetworkFees,\n formatNetworkFeeComparison,\n // Quote-based tools\n quoteBridgeInputSchema,\n executeQuoteBridge,\n executeQuoteBridgeDemo,\n formatBridgeQuoteResult,\n executeBridgeFromQuoteInputSchema,\n executeExecuteBridgeFromQuote,\n executeExecuteBridgeFromQuoteDemo,\n formatExecuteBridgeFromQuoteResult,\n wdkQuoteSwapInputSchema,\n executeWdkQuoteSwap,\n executeWdkQuoteSwapDemo,\n formatSwapQuoteResult,\n wdkExecuteSwapInputSchema,\n executeWdkExecuteSwap,\n executeWdkExecuteSwapDemo,\n formatExecuteSwapResult,\n // TON bridge tools\n TON_BRIDGE_TOOLS,\n executeTonBridgeTool,\n type TonMcpBridgeConfig,\n // ERC-8004 tools\n ERC8004_TOOL_DEFINITIONS,\n erc8004ResolveAgentInputSchema,\n executeErc8004ResolveAgent,\n formatErc8004ResolveAgentResult,\n erc8004CheckReputationInputSchema,\n executeErc8004CheckReputation,\n formatErc8004CheckReputationResult,\n erc8004VerifyWalletInputSchema,\n executeErc8004VerifyWallet,\n formatErc8004VerifyWalletResult,\n} from '../tools/index.js'\nimport type { T402WDK } from '@t402/wdk'\n\n/**\n * t402 MCP Server\n *\n * Provides payment tools for AI agents via the Model Context Protocol.\n * When a WDK seed phrase is configured, additional wallet management tools are available.\n */\nexport class T402McpServer {\n private server: Server\n private config: McpServerConfig\n private wdk: T402WDK | null = null\n\n constructor(config: McpServerConfig = {}) {\n this.config = config\n this.server = new Server(\n {\n name: 't402',\n version: '1.0.0',\n },\n {\n capabilities: {\n tools: {},\n },\n },\n )\n\n this.setupHandlers()\n }\n\n /**\n * Initialize the WDK instance from seed phrase\n */\n async initWdk(): Promise<void> {\n if (!this.config.seedPhrase) return\n\n try {\n const { T402WDK } = await import('@t402/wdk')\n const rpcUrls: Record<string, string> = {}\n\n if (this.config.rpcUrls) {\n for (const [network, url] of Object.entries(this.config.rpcUrls)) {\n if (url) rpcUrls[network] = url\n }\n }\n\n this.wdk = new T402WDK(this.config.seedPhrase, rpcUrls)\n } catch {\n console.error('Warning: Failed to initialize WDK. WDK tools will not be available.')\n }\n }\n\n /**\n * Clear sensitive data from memory.\n * Should be called on server shutdown to minimize key exposure window.\n */\n cleanup(): void {\n if (this.config.privateKey) {\n this.config.privateKey = ''\n }\n if (this.config.seedPhrase) {\n this.config.seedPhrase = ''\n }\n this.wdk = null\n }\n\n /** TON MCP bridge configuration */\n private tonBridgeConfig: TonMcpBridgeConfig | null = null\n\n /**\n * Register TON bridge tools\n *\n * Enables AI agents to use @ton/mcp tools through the t402 MCP server.\n */\n registerTonBridge(config: TonMcpBridgeConfig): void {\n this.tonBridgeConfig = config\n }\n\n /**\n * Get all tool definitions (base + WDK if configured + unified if enabled + TON bridge if registered)\n */\n private getToolDefinitions() {\n const tools = { ...TOOL_DEFINITIONS, ...ERC8004_TOOL_DEFINITIONS }\n if (this.wdk || this.config.demoMode) {\n Object.assign(tools, WDK_TOOL_DEFINITIONS)\n }\n if (this.config.unifiedMode && (this.wdk || this.config.demoMode)) {\n Object.assign(tools, UNIFIED_TOOL_DEFINITIONS)\n }\n if (this.tonBridgeConfig) {\n Object.assign(tools, TON_BRIDGE_TOOLS)\n }\n return tools\n }\n\n /**\n * Set up MCP request handlers\n */\n private setupHandlers(): void {\n // List available tools\n this.server.setRequestHandler(ListToolsRequestSchema, async () => {\n return {\n tools: Object.values(this.getToolDefinitions()),\n }\n })\n\n // Handle tool calls\n this.server.setRequestHandler(CallToolRequestSchema, async (request) => {\n const { name, arguments: args } = request.params\n\n try {\n switch (name) {\n case 't402/getBalance':\n return await this.handleGetBalance(args)\n\n case 't402/getAllBalances':\n return await this.handleGetAllBalances(args)\n\n case 't402/pay':\n return await this.handlePay(args)\n\n case 't402/payGasless':\n return await this.handlePayGasless(args)\n\n case 't402/getBridgeFee':\n return await this.handleGetBridgeFee(args)\n\n case 't402/bridge':\n return await this.handleBridge(args)\n\n // WDK tools\n case 'wdk/getWallet':\n return await this.handleWdkGetWallet(args)\n\n case 'wdk/getBalances':\n return await this.handleWdkGetBalances(args)\n\n case 'wdk/transfer':\n return await this.handleWdkTransfer(args)\n\n case 'wdk/swap':\n return await this.handleWdkSwap(args)\n\n case 't402/autoPay':\n return await this.handleAutoPay(args)\n\n // Unified tools\n case 't402/smartPay':\n return await this.handleSmartPay(args)\n\n case 't402/paymentPlan':\n return await this.handlePaymentPlan(args)\n\n // Price and fee tools\n case 't402/getTokenPrice':\n return await this.handleGetTokenPrice(args)\n\n case 't402/getGasPrice':\n return await this.handleGetGasPrice(args)\n\n case 't402/estimatePaymentFee':\n return await this.handleEstimatePaymentFee(args)\n\n case 't402/compareNetworkFees':\n return await this.handleCompareNetworkFees(args)\n\n // Quote-based tools\n case 't402/quoteBridge':\n return await this.handleQuoteBridge(args)\n\n case 't402/executeBridgeQuote':\n return await this.handleExecuteBridgeQuote(args)\n\n case 'wdk/quoteSwap':\n return await this.handleWdkQuoteSwap(args)\n\n case 'wdk/executeSwap':\n return await this.handleWdkExecuteSwap(args)\n\n // ERC-8004 tools\n case 'erc8004/resolveAgent':\n return await this.handleErc8004ResolveAgent(args)\n\n case 'erc8004/checkReputation':\n return await this.handleErc8004CheckReputation(args)\n\n case 'erc8004/verifyWallet':\n return await this.handleErc8004VerifyWallet(args)\n\n // TON bridge tools\n case 'ton/getBalance':\n case 'ton/transfer':\n case 'ton/getJettonBalance':\n case 'ton/swapJettons':\n case 'ton/getTransactionStatus':\n return await this.handleTonBridgeTool(name, args)\n\n default:\n throw new Error(`Unknown tool: ${name}`)\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n return {\n content: [\n {\n type: 'text' as const,\n text: `Error: ${message}`,\n },\n ],\n isError: true,\n }\n }\n })\n }\n\n /**\n * Handle t402/getBalance\n */\n private async handleGetBalance(args: unknown) {\n const input = getBalanceInputSchema.parse(args)\n const result = await executeGetBalance(input, this.config.rpcUrls)\n return {\n content: [\n {\n type: 'text' as const,\n text: formatBalanceResult(result),\n },\n ],\n }\n }\n\n /**\n * Handle t402/getAllBalances\n */\n private async handleGetAllBalances(args: unknown) {\n const input = getAllBalancesInputSchema.parse(args)\n const result = await executeGetAllBalances(input, this.config.rpcUrls)\n return {\n content: [\n {\n type: 'text' as const,\n text: formatAllBalancesResult(result),\n },\n ],\n }\n }\n\n /**\n * Format a confirmation prompt for elicitation\n */\n private formatConfirmation(result: {\n needsConfirmation: true\n summary: string\n details: Record<string, string>\n }) {\n const detailLines = Object.entries(result.details)\n .map(([key, value]) => `- **${key}:** ${value}`)\n .join('\\n')\n return {\n content: [\n {\n type: 'text' as const,\n text: [\n '## Confirmation Required',\n '',\n result.summary,\n '',\n detailLines,\n '',\n '_Call this tool again with `confirmed: true` to execute._',\n ].join('\\n'),\n },\n ],\n }\n }\n\n /**\n * Handle t402/pay\n */\n private async handlePay(args: unknown) {\n if (!this.config.privateKey && !this.config.demoMode) {\n throw new Error(\n 'Private key not configured. Set T402_PRIVATE_KEY environment variable or enable demo mode.',\n )\n }\n\n const input = payInputSchema.parse(args)\n const result = await executePay(input, {\n privateKey: this.config.privateKey || '0x',\n rpcUrl: this.config.rpcUrls?.[input.network as SupportedNetwork],\n demoMode: this.config.demoMode,\n })\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [\n {\n type: 'text' as const,\n text: formatPaymentResult(result),\n },\n ],\n }\n }\n\n /**\n * Handle t402/payGasless\n */\n private async handlePayGasless(args: unknown) {\n if (!this.config.privateKey && !this.config.demoMode) {\n throw new Error(\n 'Private key not configured. Set T402_PRIVATE_KEY environment variable or enable demo mode.',\n )\n }\n\n if (!this.config.bundlerUrl && !this.config.demoMode) {\n throw new Error(\n 'Bundler URL not configured. Set T402_BUNDLER_URL environment variable or enable demo mode.',\n )\n }\n\n if (!this.config.paymasterUrl && !this.config.demoMode) {\n throw new Error(\n 'Paymaster URL not configured. Set T402_PAYMASTER_URL environment variable or enable demo mode.',\n )\n }\n\n const input = payGaslessInputSchema.parse(args)\n const result = await executePayGasless(input, {\n privateKey: this.config.privateKey || '0x',\n bundlerUrl: this.config.bundlerUrl || '',\n paymasterUrl: this.config.paymasterUrl || '',\n rpcUrl: this.config.rpcUrls?.[input.network as SupportedNetwork],\n demoMode: this.config.demoMode,\n })\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [\n {\n type: 'text' as const,\n text: formatGaslessPaymentResult(result),\n },\n ],\n }\n }\n\n /**\n * Handle t402/getBridgeFee\n */\n private async handleGetBridgeFee(args: unknown) {\n const input = getBridgeFeeInputSchema.parse(args)\n const result = await executeGetBridgeFee(input, this.config.rpcUrls)\n return {\n content: [\n {\n type: 'text' as const,\n text: formatBridgeFeeResult(result),\n },\n ],\n }\n }\n\n /**\n * Handle t402/bridge\n */\n private async handleBridge(args: unknown) {\n if (!this.config.privateKey && !this.config.demoMode) {\n throw new Error(\n 'Private key not configured. Set T402_PRIVATE_KEY environment variable or enable demo mode.',\n )\n }\n\n const input = bridgeInputSchema.parse(args)\n const result = await executeBridge(input, {\n privateKey: this.config.privateKey || '0x',\n rpcUrl: this.config.rpcUrls?.[input.fromChain as SupportedNetwork],\n demoMode: this.config.demoMode,\n })\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [\n {\n type: 'text' as const,\n text: formatBridgeResult(result),\n },\n ],\n }\n }\n\n // ---- WDK Tool Handlers ----\n\n /**\n * Handle wdk/getWallet\n */\n private async handleWdkGetWallet(args: unknown) {\n wdkGetWalletInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkGetWalletDemo()\n : await executeWdkGetWallet({}, this.wdk)\n\n return {\n content: [{ type: 'text' as const, text: formatWdkWalletResult(result) }],\n }\n }\n\n /**\n * Handle wdk/getBalances\n */\n private async handleWdkGetBalances(args: unknown) {\n const input = wdkGetBalancesInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkGetBalancesDemo()\n : await executeWdkGetBalances(input, this.wdk)\n\n return {\n content: [{ type: 'text' as const, text: formatWdkBalancesResult(result) }],\n }\n }\n\n /**\n * Handle wdk/transfer\n */\n private async handleWdkTransfer(args: unknown) {\n const input = wdkTransferInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkTransferDemo(input)\n : await executeWdkTransfer(input, this.wdk)\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatWdkTransferResult(result) }],\n }\n }\n\n /**\n * Handle wdk/swap\n */\n private async handleWdkSwap(args: unknown) {\n const input = wdkSwapInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkSwapDemo(input)\n : await executeWdkSwap(input, this.wdk)\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatWdkSwapResult(result) }],\n }\n }\n\n /**\n * Handle t402/autoPay\n */\n private async handleAutoPay(args: unknown) {\n const input = autoPayInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeAutoPayDemo(input)\n : await executeAutoPay(input, this.wdk)\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatAutoPayResult(result) }],\n }\n }\n\n // ---- Unified Tool Handlers ----\n\n /**\n * Handle t402/smartPay\n */\n private async handleSmartPay(args: unknown) {\n const input = smartPayInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeSmartPayDemo(input)\n : await executeSmartPay(input, this.wdk)\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatSmartPayResult(result) }],\n }\n }\n\n /**\n * Handle t402/paymentPlan\n */\n private async handlePaymentPlan(args: unknown) {\n const input = paymentPlanInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executePaymentPlanDemo(input)\n : await executePaymentPlan(input, this.wdk)\n\n return {\n content: [{ type: 'text' as const, text: formatPaymentPlanResult(result) }],\n }\n }\n\n // ---- Price and Fee Tool Handlers ----\n\n /**\n * Handle t402/getTokenPrice\n */\n private async handleGetTokenPrice(args: unknown) {\n const input = getTokenPriceInputSchema.parse(args)\n const result = await executeGetTokenPrice(input, { demoMode: this.config.demoMode })\n return {\n content: [{ type: 'text' as const, text: formatTokenPriceResult(result) }],\n }\n }\n\n /**\n * Handle t402/getGasPrice\n */\n private async handleGetGasPrice(args: unknown) {\n const input = getGasPriceInputSchema.parse(args)\n const result = await executeGetGasPrice(input, {\n rpcUrl: this.config.rpcUrls?.[input.network as SupportedNetwork],\n demoMode: this.config.demoMode,\n })\n return {\n content: [{ type: 'text' as const, text: formatGasPriceResult(result) }],\n }\n }\n\n /**\n * Handle t402/estimatePaymentFee\n */\n private async handleEstimatePaymentFee(args: unknown) {\n const input = estimatePaymentFeeInputSchema.parse(args)\n const result = await executeEstimatePaymentFee(input, {\n rpcUrl: this.config.rpcUrls?.[input.network as SupportedNetwork],\n demoMode: this.config.demoMode,\n })\n return {\n content: [{ type: 'text' as const, text: formatPaymentFeeEstimate(result) }],\n }\n }\n\n /**\n * Handle t402/compareNetworkFees\n */\n private async handleCompareNetworkFees(args: unknown) {\n const input = compareNetworkFeesInputSchema.parse(args)\n const result = await executeCompareNetworkFees(input, {\n rpcUrls: this.config.rpcUrls,\n demoMode: this.config.demoMode,\n })\n return {\n content: [{ type: 'text' as const, text: formatNetworkFeeComparison(result) }],\n }\n }\n\n // ---- Quote-based Tool Handlers ----\n\n /**\n * Handle t402/quoteBridge\n */\n private async handleQuoteBridge(args: unknown) {\n const input = quoteBridgeInputSchema.parse(args)\n\n const result = this.config.demoMode\n ? executeQuoteBridgeDemo(input)\n : await executeQuoteBridge(input, this.config.rpcUrls)\n\n return {\n content: [{ type: 'text' as const, text: formatBridgeQuoteResult(result) }],\n }\n }\n\n /**\n * Handle t402/executeBridgeQuote\n */\n private async handleExecuteBridgeQuote(args: unknown) {\n if (!this.config.privateKey && !this.config.demoMode) {\n throw new Error(\n 'Private key not configured. Set T402_PRIVATE_KEY environment variable or enable demo mode.',\n )\n }\n\n const input = executeBridgeFromQuoteInputSchema.parse(args)\n\n const result = this.config.demoMode\n ? executeExecuteBridgeFromQuoteDemo(input)\n : await executeExecuteBridgeFromQuote(input, {\n privateKey: this.config.privateKey || '0x',\n demoMode: this.config.demoMode,\n })\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatExecuteBridgeFromQuoteResult(result) }],\n }\n }\n\n /**\n * Handle wdk/quoteSwap\n */\n private async handleWdkQuoteSwap(args: unknown) {\n const input = wdkQuoteSwapInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkQuoteSwapDemo(input)\n : await executeWdkQuoteSwap(input, this.wdk)\n\n return {\n content: [{ type: 'text' as const, text: formatSwapQuoteResult(result) }],\n }\n }\n\n /**\n * Handle wdk/executeSwap\n */\n private async handleWdkExecuteSwap(args: unknown) {\n const input = wdkExecuteSwapInputSchema.parse(args)\n\n const result =\n this.config.demoMode || !this.wdk\n ? executeWdkExecuteSwapDemo(input)\n : await executeWdkExecuteSwap(input, this.wdk)\n\n if ('needsConfirmation' in result) {\n return this.formatConfirmation(result)\n }\n\n return {\n content: [{ type: 'text' as const, text: formatExecuteSwapResult(result) }],\n }\n }\n\n // ---- ERC-8004 Tool Handlers ----\n\n /**\n * Handle erc8004/resolveAgent\n */\n private async handleErc8004ResolveAgent(args: unknown) {\n const input = erc8004ResolveAgentInputSchema.parse(args)\n const result = await executeErc8004ResolveAgent(input, this.config.rpcUrls)\n return {\n content: [{ type: 'text' as const, text: formatErc8004ResolveAgentResult(result) }],\n }\n }\n\n /**\n * Handle erc8004/checkReputation\n */\n private async handleErc8004CheckReputation(args: unknown) {\n const input = erc8004CheckReputationInputSchema.parse(args)\n const result = await executeErc8004CheckReputation(input, this.config.rpcUrls)\n return {\n content: [{ type: 'text' as const, text: formatErc8004CheckReputationResult(result) }],\n }\n }\n\n /**\n * Handle erc8004/verifyWallet\n */\n private async handleErc8004VerifyWallet(args: unknown) {\n const input = erc8004VerifyWalletInputSchema.parse(args)\n const result = await executeErc8004VerifyWallet(input, this.config.rpcUrls)\n return {\n content: [{ type: 'text' as const, text: formatErc8004VerifyWalletResult(result) }],\n }\n }\n\n // ---- TON Bridge Tool Handler ----\n\n /**\n * Handle TON bridge tool calls\n */\n private async handleTonBridgeTool(name: string, args: unknown) {\n if (!this.tonBridgeConfig) {\n throw new Error('TON bridge not configured. Call registerTonBridge() to enable TON tools.')\n }\n\n return executeTonBridgeTool(name, (args ?? {}) as Record<string, unknown>, this.tonBridgeConfig)\n }\n\n /**\n * Start the server using stdio transport\n */\n async run(): Promise<void> {\n // Initialize WDK if seed phrase is configured\n await this.initWdk()\n\n // Register cleanup on process exit to clear sensitive data from memory\n const onExit = () => this.cleanup()\n process.on('exit', onExit)\n process.on('SIGINT', () => { onExit(); process.exit(0) })\n process.on('SIGTERM', () => { onExit(); process.exit(0) })\n\n const transport = new StdioServerTransport()\n await this.server.connect(transport)\n console.error('t402 MCP Server running on stdio')\n }\n}\n\n/**\n * Create a new t402 MCP server instance\n */\nexport function createT402McpServer(config?: McpServerConfig): T402McpServer {\n return new T402McpServer(config)\n}\n\n/**\n * Load configuration from environment variables\n */\nexport function loadConfigFromEnv(): McpServerConfig {\n const config: McpServerConfig = {}\n\n // Private key\n if (process.env.T402_PRIVATE_KEY) {\n config.privateKey = process.env.T402_PRIVATE_KEY\n }\n\n // Demo mode\n if (process.env.T402_DEMO_MODE === 'true') {\n config.demoMode = true\n }\n\n // ERC-4337 configuration\n if (process.env.T402_BUNDLER_URL) {\n config.bundlerUrl = process.env.T402_BUNDLER_URL\n }\n if (process.env.T402_PAYMASTER_URL) {\n config.paymasterUrl = process.env.T402_PAYMASTER_URL\n }\n\n // WDK configuration\n if (process.env.T402_WDK_SEED_PHRASE) {\n config.seedPhrase = process.env.T402_WDK_SEED_PHRASE\n }\n if (process.env.T402_WDK_CHAINS) {\n config.wdkChains = process.env.T402_WDK_CHAINS.split(',').map((c) => c.trim())\n }\n\n // Unified mode\n if (process.env.T402_UNIFIED_MODE === 'true') {\n config.unifiedMode = true\n }\n\n // Custom RPC URLs\n const rpcUrls: Partial<Record<SupportedNetwork, string>> = {}\n const networks: SupportedNetwork[] = [\n 'ethereum',\n 'base',\n 'arbitrum',\n 'optimism',\n 'polygon',\n 'avalanche',\n 'ink',\n 'berachain',\n 'unichain',\n ]\n\n for (const network of networks) {\n const envVar = `T402_RPC_${network.toUpperCase()}`\n if (process.env[envVar]) {\n rpcUrls[network] = process.env[envVar]\n }\n }\n\n if (Object.keys(rpcUrls).length > 0) {\n config.rpcUrls = rpcUrls\n }\n\n // TON MCP bridge configuration\n if (process.env.T402_TON_MCP_ENDPOINT) {\n config.tonMcpEndpoint = process.env.T402_TON_MCP_ENDPOINT\n }\n if (process.env.T402_TON_API_KEY) {\n config.tonApiKey = process.env.T402_TON_API_KEY\n }\n\n return config\n}\n"],"mappings":"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","names":[]}
|