@scriptmasterlabs/mcp-x402 2.1.1 → 2.1.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 (290) hide show
  1. package/.well-known/agentcard.json +34 -0
  2. package/.well-known/ai.txt +32 -0
  3. package/CONTRIBUTING.md +76 -0
  4. package/LICENSE +21 -57
  5. package/README.md +304 -262
  6. package/agents.json +81 -0
  7. package/ai/faq.json +74 -0
  8. package/ai/summary.json +157 -0
  9. package/dist/lib/chains/base.d.ts +10 -0
  10. package/dist/lib/chains/base.d.ts.map +1 -0
  11. package/dist/lib/chains/base.js +75 -0
  12. package/dist/lib/chains/base.js.map +1 -0
  13. package/dist/lib/chains/solana.d.ts +10 -0
  14. package/dist/lib/chains/solana.d.ts.map +1 -0
  15. package/dist/lib/chains/solana.js +49 -0
  16. package/dist/lib/chains/solana.js.map +1 -0
  17. package/dist/lib/chains/xrpl.d.ts +10 -0
  18. package/dist/lib/chains/xrpl.d.ts.map +1 -0
  19. package/dist/lib/chains/xrpl.js +55 -0
  20. package/dist/lib/chains/xrpl.js.map +1 -0
  21. package/dist/lib/credit/bureau.d.ts +16 -0
  22. package/dist/lib/credit/bureau.d.ts.map +1 -0
  23. package/dist/lib/credit/bureau.js +88 -0
  24. package/dist/lib/credit/bureau.js.map +1 -0
  25. package/dist/lib/sml-api/agentcard.d.ts +17 -0
  26. package/dist/lib/sml-api/agentcard.d.ts.map +1 -0
  27. package/dist/lib/sml-api/agentcard.js +30 -0
  28. package/dist/lib/sml-api/agentcard.js.map +1 -0
  29. package/dist/lib/sml-api/backtest.d.ts +22 -0
  30. package/dist/lib/sml-api/backtest.d.ts.map +1 -0
  31. package/dist/lib/sml-api/backtest.js +28 -0
  32. package/dist/lib/sml-api/backtest.js.map +1 -0
  33. package/dist/lib/sml-api/brokers.d.ts +40 -0
  34. package/dist/lib/sml-api/brokers.d.ts.map +1 -0
  35. package/dist/lib/sml-api/brokers.js +128 -0
  36. package/dist/lib/sml-api/brokers.js.map +1 -0
  37. package/dist/lib/sml-api/copytrader.d.ts +11 -0
  38. package/dist/lib/sml-api/copytrader.d.ts.map +1 -0
  39. package/dist/lib/sml-api/copytrader.js +30 -0
  40. package/dist/lib/sml-api/copytrader.js.map +1 -0
  41. package/dist/lib/sml-api/crawl.d.ts +20 -0
  42. package/dist/lib/sml-api/crawl.d.ts.map +1 -0
  43. package/dist/lib/sml-api/crawl.js +32 -0
  44. package/dist/lib/sml-api/crawl.js.map +1 -0
  45. package/dist/lib/sml-api/echo.d.ts +10 -0
  46. package/dist/lib/sml-api/echo.d.ts.map +1 -0
  47. package/dist/lib/sml-api/echo.js +23 -0
  48. package/dist/lib/sml-api/echo.js.map +1 -0
  49. package/dist/lib/sml-api/forge.d.ts +11 -0
  50. package/dist/lib/sml-api/forge.d.ts.map +1 -0
  51. package/dist/lib/sml-api/forge.js +29 -0
  52. package/dist/lib/sml-api/forge.js.map +1 -0
  53. package/dist/lib/sml-api/ftd.d.ts +18 -0
  54. package/dist/lib/sml-api/ftd.d.ts.map +1 -0
  55. package/dist/lib/sml-api/ftd.js +43 -0
  56. package/dist/lib/sml-api/ftd.js.map +1 -0
  57. package/dist/lib/sml-api/ghost.d.ts +13 -0
  58. package/dist/lib/sml-api/ghost.d.ts.map +1 -0
  59. package/dist/lib/sml-api/ghost.js +29 -0
  60. package/dist/lib/sml-api/ghost.js.map +1 -0
  61. package/dist/lib/sml-api/launchpad.d.ts +20 -0
  62. package/dist/lib/sml-api/launchpad.d.ts.map +1 -0
  63. package/dist/lib/sml-api/launchpad.js +31 -0
  64. package/dist/lib/sml-api/launchpad.js.map +1 -0
  65. package/dist/lib/sml-api/leviathan.d.ts +22 -0
  66. package/dist/lib/sml-api/leviathan.d.ts.map +1 -0
  67. package/dist/lib/sml-api/leviathan.js +33 -0
  68. package/dist/lib/sml-api/leviathan.js.map +1 -0
  69. package/dist/lib/sml-api/nexus.d.ts +18 -0
  70. package/dist/lib/sml-api/nexus.d.ts.map +1 -0
  71. package/dist/lib/sml-api/nexus.js +40 -0
  72. package/dist/lib/sml-api/nexus.js.map +1 -0
  73. package/dist/lib/sml-api/proof402.d.ts +6 -0
  74. package/dist/lib/sml-api/proof402.d.ts.map +1 -0
  75. package/dist/lib/sml-api/proof402.js +30 -0
  76. package/dist/lib/sml-api/proof402.js.map +1 -0
  77. package/dist/lib/sml-api/rails.d.ts +12 -0
  78. package/dist/lib/sml-api/rails.d.ts.map +1 -0
  79. package/dist/lib/sml-api/rails.js +29 -0
  80. package/dist/lib/sml-api/rails.js.map +1 -0
  81. package/dist/lib/sml-api/shadow.d.ts +15 -0
  82. package/dist/lib/sml-api/shadow.d.ts.map +1 -0
  83. package/dist/lib/sml-api/shadow.js +27 -0
  84. package/dist/lib/sml-api/shadow.js.map +1 -0
  85. package/dist/lib/sml-api/squeezeos.d.ts +21 -0
  86. package/dist/lib/sml-api/squeezeos.d.ts.map +1 -0
  87. package/dist/lib/sml-api/squeezeos.js +97 -0
  88. package/dist/lib/sml-api/squeezeos.js.map +1 -0
  89. package/dist/lib/sml-api/xdeo.d.ts +13 -0
  90. package/dist/lib/sml-api/xdeo.d.ts.map +1 -0
  91. package/dist/lib/sml-api/xdeo.js +34 -0
  92. package/dist/lib/sml-api/xdeo.js.map +1 -0
  93. package/dist/lib/sml-api/xmit.d.ts +13 -0
  94. package/dist/lib/sml-api/xmit.d.ts.map +1 -0
  95. package/dist/lib/sml-api/xmit.js +34 -0
  96. package/dist/lib/sml-api/xmit.js.map +1 -0
  97. package/dist/server/apm/capabilities.d.ts +31 -0
  98. package/dist/server/apm/capabilities.d.ts.map +1 -0
  99. package/dist/server/apm/capabilities.js +157 -0
  100. package/dist/server/apm/capabilities.js.map +1 -0
  101. package/dist/server/apm/execute.d.ts +18 -0
  102. package/dist/server/apm/execute.d.ts.map +1 -0
  103. package/dist/server/apm/execute.js +37 -0
  104. package/dist/server/apm/execute.js.map +1 -0
  105. package/dist/server/apm/matcher.d.ts +17 -0
  106. package/dist/server/apm/matcher.d.ts.map +1 -0
  107. package/dist/server/apm/matcher.js +71 -0
  108. package/dist/server/apm/matcher.js.map +1 -0
  109. package/dist/server/apm/quote.d.ts +53 -0
  110. package/dist/server/apm/quote.d.ts.map +1 -0
  111. package/dist/server/apm/quote.js +82 -0
  112. package/dist/server/apm/quote.js.map +1 -0
  113. package/dist/server/apm/schema.d.ts +109 -0
  114. package/dist/server/apm/schema.d.ts.map +1 -0
  115. package/dist/server/apm/schema.js +31 -0
  116. package/dist/server/apm/schema.js.map +1 -0
  117. package/dist/server/health.d.ts +16 -0
  118. package/dist/server/health.d.ts.map +1 -0
  119. package/dist/server/health.js +39 -0
  120. package/dist/server/health.js.map +1 -0
  121. package/dist/server/index.d.ts +3 -0
  122. package/dist/server/index.d.ts.map +1 -0
  123. package/dist/server/index.js +322 -0
  124. package/dist/server/index.js.map +1 -0
  125. package/dist/server/payments/agent-payment.d.ts +71 -0
  126. package/dist/server/payments/agent-payment.d.ts.map +1 -0
  127. package/dist/server/payments/agent-payment.js +112 -0
  128. package/dist/server/payments/agent-payment.js.map +1 -0
  129. package/dist/server/payments/ap2.d.ts +17 -0
  130. package/dist/server/payments/ap2.d.ts.map +1 -0
  131. package/dist/server/payments/ap2.js +77 -0
  132. package/dist/server/payments/ap2.js.map +1 -0
  133. package/dist/server/payments/receipt.d.ts +28 -0
  134. package/dist/server/payments/receipt.d.ts.map +1 -0
  135. package/dist/server/payments/receipt.js +60 -0
  136. package/dist/server/payments/receipt.js.map +1 -0
  137. package/dist/server/payments/router.d.ts +23 -0
  138. package/dist/server/payments/router.d.ts.map +1 -0
  139. package/dist/server/payments/router.js +69 -0
  140. package/dist/server/payments/router.js.map +1 -0
  141. package/dist/server/payments/wallet.d.ts +18 -0
  142. package/dist/server/payments/wallet.d.ts.map +1 -0
  143. package/dist/server/payments/wallet.js +107 -0
  144. package/dist/server/payments/wallet.js.map +1 -0
  145. package/dist/server/payments/x402.d.ts +55 -0
  146. package/dist/server/payments/x402.d.ts.map +1 -0
  147. package/dist/server/payments/x402.js +247 -0
  148. package/dist/server/payments/x402.js.map +1 -0
  149. package/dist/server/registry/backends.d.ts +29 -0
  150. package/dist/server/registry/backends.d.ts.map +1 -0
  151. package/dist/server/registry/backends.js +61 -0
  152. package/dist/server/registry/backends.js.map +1 -0
  153. package/dist/server/registry/catalog.d.ts +12 -0
  154. package/dist/server/registry/catalog.d.ts.map +1 -0
  155. package/dist/server/registry/catalog.js +55 -0
  156. package/dist/server/registry/catalog.js.map +1 -0
  157. package/dist/server/registry/discovery.d.ts +16 -0
  158. package/dist/server/registry/discovery.d.ts.map +1 -0
  159. package/dist/server/registry/discovery.js +33 -0
  160. package/dist/server/registry/discovery.js.map +1 -0
  161. package/dist/server/registry/pricing.d.ts +10 -0
  162. package/dist/server/registry/pricing.d.ts.map +1 -0
  163. package/dist/server/registry/pricing.js +124 -0
  164. package/dist/server/registry/pricing.js.map +1 -0
  165. package/dist/server/security/acl.d.ts +28 -0
  166. package/dist/server/security/acl.d.ts.map +1 -0
  167. package/dist/server/security/acl.js +36 -0
  168. package/dist/server/security/acl.js.map +1 -0
  169. package/dist/server/security/audit.d.ts +15 -0
  170. package/dist/server/security/audit.d.ts.map +1 -0
  171. package/dist/server/security/audit.js +77 -0
  172. package/dist/server/security/audit.js.map +1 -0
  173. package/dist/server/security/rate-limit.d.ts +12 -0
  174. package/dist/server/security/rate-limit.d.ts.map +1 -0
  175. package/dist/server/security/rate-limit.js +72 -0
  176. package/dist/server/security/rate-limit.js.map +1 -0
  177. package/dist/server/security/sandbox.d.ts +7 -0
  178. package/dist/server/security/sandbox.d.ts.map +1 -0
  179. package/dist/server/security/sandbox.js +42 -0
  180. package/dist/server/security/sandbox.js.map +1 -0
  181. package/dist/server/tools/agentcard.d.ts +3 -0
  182. package/dist/server/tools/agentcard.d.ts.map +1 -0
  183. package/dist/server/tools/agentcard.js +118 -0
  184. package/dist/server/tools/agentcard.js.map +1 -0
  185. package/dist/server/tools/apm-execute.d.ts +3 -0
  186. package/dist/server/tools/apm-execute.d.ts.map +1 -0
  187. package/dist/server/tools/apm-execute.js +94 -0
  188. package/dist/server/tools/apm-execute.js.map +1 -0
  189. package/dist/server/tools/apm.d.ts +3 -0
  190. package/dist/server/tools/apm.d.ts.map +1 -0
  191. package/dist/server/tools/apm.js +135 -0
  192. package/dist/server/tools/apm.js.map +1 -0
  193. package/dist/server/tools/backtest.d.ts +3 -0
  194. package/dist/server/tools/backtest.d.ts.map +1 -0
  195. package/dist/server/tools/backtest.js +112 -0
  196. package/dist/server/tools/backtest.js.map +1 -0
  197. package/dist/server/tools/brokers.d.ts +3 -0
  198. package/dist/server/tools/brokers.d.ts.map +1 -0
  199. package/dist/server/tools/brokers.js +223 -0
  200. package/dist/server/tools/brokers.js.map +1 -0
  201. package/dist/server/tools/copytrader.d.ts +3 -0
  202. package/dist/server/tools/copytrader.d.ts.map +1 -0
  203. package/dist/server/tools/copytrader.js +90 -0
  204. package/dist/server/tools/copytrader.js.map +1 -0
  205. package/dist/server/tools/crawl.d.ts +3 -0
  206. package/dist/server/tools/crawl.d.ts.map +1 -0
  207. package/dist/server/tools/crawl.js +60 -0
  208. package/dist/server/tools/crawl.js.map +1 -0
  209. package/dist/server/tools/discovery.d.ts +3 -0
  210. package/dist/server/tools/discovery.d.ts.map +1 -0
  211. package/dist/server/tools/discovery.js +181 -0
  212. package/dist/server/tools/discovery.js.map +1 -0
  213. package/dist/server/tools/echo.d.ts +3 -0
  214. package/dist/server/tools/echo.d.ts.map +1 -0
  215. package/dist/server/tools/echo.js +48 -0
  216. package/dist/server/tools/echo.js.map +1 -0
  217. package/dist/server/tools/forge.d.ts +3 -0
  218. package/dist/server/tools/forge.d.ts.map +1 -0
  219. package/dist/server/tools/forge.js +77 -0
  220. package/dist/server/tools/forge.js.map +1 -0
  221. package/dist/server/tools/ftd.d.ts +3 -0
  222. package/dist/server/tools/ftd.d.ts.map +1 -0
  223. package/dist/server/tools/ftd.js +70 -0
  224. package/dist/server/tools/ftd.js.map +1 -0
  225. package/dist/server/tools/ghost.d.ts +3 -0
  226. package/dist/server/tools/ghost.d.ts.map +1 -0
  227. package/dist/server/tools/ghost.js +83 -0
  228. package/dist/server/tools/ghost.js.map +1 -0
  229. package/dist/server/tools/index.d.ts +3 -0
  230. package/dist/server/tools/index.d.ts.map +1 -0
  231. package/dist/server/tools/index.js +48 -0
  232. package/dist/server/tools/index.js.map +1 -0
  233. package/dist/server/tools/launchpad.d.ts +3 -0
  234. package/dist/server/tools/launchpad.d.ts.map +1 -0
  235. package/dist/server/tools/launchpad.js +151 -0
  236. package/dist/server/tools/launchpad.js.map +1 -0
  237. package/dist/server/tools/leviathan.d.ts +3 -0
  238. package/dist/server/tools/leviathan.d.ts.map +1 -0
  239. package/dist/server/tools/leviathan.js +73 -0
  240. package/dist/server/tools/leviathan.js.map +1 -0
  241. package/dist/server/tools/nexus.d.ts +3 -0
  242. package/dist/server/tools/nexus.d.ts.map +1 -0
  243. package/dist/server/tools/nexus.js +65 -0
  244. package/dist/server/tools/nexus.js.map +1 -0
  245. package/dist/server/tools/proof402.d.ts +3 -0
  246. package/dist/server/tools/proof402.d.ts.map +1 -0
  247. package/dist/server/tools/proof402.js +74 -0
  248. package/dist/server/tools/proof402.js.map +1 -0
  249. package/dist/server/tools/rails.d.ts +3 -0
  250. package/dist/server/tools/rails.d.ts.map +1 -0
  251. package/dist/server/tools/rails.js +82 -0
  252. package/dist/server/tools/rails.js.map +1 -0
  253. package/dist/server/tools/shadow.d.ts +3 -0
  254. package/dist/server/tools/shadow.d.ts.map +1 -0
  255. package/dist/server/tools/shadow.js +114 -0
  256. package/dist/server/tools/shadow.js.map +1 -0
  257. package/dist/server/tools/squeezeos.d.ts +3 -0
  258. package/dist/server/tools/squeezeos.d.ts.map +1 -0
  259. package/dist/server/tools/squeezeos.js +249 -0
  260. package/dist/server/tools/squeezeos.js.map +1 -0
  261. package/dist/server/tools/xdeo.d.ts +3 -0
  262. package/dist/server/tools/xdeo.d.ts.map +1 -0
  263. package/dist/server/tools/xdeo.js +58 -0
  264. package/dist/server/tools/xdeo.js.map +1 -0
  265. package/dist/server/tools/xmit.d.ts +3 -0
  266. package/dist/server/tools/xmit.d.ts.map +1 -0
  267. package/dist/server/tools/xmit.js +59 -0
  268. package/dist/server/tools/xmit.js.map +1 -0
  269. package/eslint.config.mjs +28 -0
  270. package/llms.txt +170 -108
  271. package/package.json +78 -65
  272. package/server.json +24 -0
  273. package/.well-known/x402.json +0 -37
  274. package/dist/index.d.ts +0 -12
  275. package/dist/index.d.ts.map +0 -1
  276. package/dist/index.js +0 -9
  277. package/dist/index.js.map +0 -1
  278. package/dist/mcp-wrapper.d.ts +0 -71
  279. package/dist/mcp-wrapper.d.ts.map +0 -1
  280. package/dist/mcp-wrapper.js +0 -104
  281. package/dist/mcp-wrapper.js.map +0 -1
  282. package/dist/x402-middleware.d.ts +0 -76
  283. package/dist/x402-middleware.d.ts.map +0 -1
  284. package/dist/x402-middleware.js +0 -113
  285. package/dist/x402-middleware.js.map +0 -1
  286. package/dist/xrpl-facilitator.d.ts +0 -77
  287. package/dist/xrpl-facilitator.d.ts.map +0 -1
  288. package/dist/xrpl-facilitator.js +0 -156
  289. package/dist/xrpl-facilitator.js.map +0 -1
  290. package/schema.jsonld +0 -97
package/README.md CHANGED
@@ -1,262 +1,304 @@
1
- # mcp-x402-xrpl
2
-
3
- > **x402 HTTP payment middleware for MCP servers — XRPL, Xahau, XAH, RLUSD.**
4
- > The first production-ready x402 facilitator for the XRP Ledger ecosystem.
5
-
6
- [![npm](https://img.shields.io/npm/v/@scriptmasterlabs/mcp-x402)](https://npmjs.com/package/@scriptmasterlabs/mcp-x402)
7
- [![License](https://img.shields.io/badge/license-Apache--2.0-blue)](LICENSE)
8
- [![XRPL](https://img.shields.io/badge/network-XRPL%20%7C%20Xahau-00aae4)](https://xrpl.org)
9
- [![x402](https://img.shields.io/badge/protocol-x402-ff6600)](https://x402.org)
10
-
11
- Drop-in middleware for [Model Context Protocol (MCP)](https://modelcontextprotocol.io) servers
12
- that lets AI agents autonomously pay for tool access using the
13
- [x402 protocol](https://x402.org) — no API keys, no subscriptions, no human in the loop.
14
-
15
- **Powered by [ScriptMasterLabs](https://scriptmasterlabs.com)**
16
-
17
- ---
18
-
19
- ## What is x402?
20
-
21
- The **x402 protocol** revives the dormant HTTP `402 Payment Required` status code as a
22
- machine-native payment standard. When an AI agent calls a gated API and gets a 402 response,
23
- it automatically pays using blockchain rails and retries the request with a payment proof header.
24
-
25
- Existing x402 implementations only support EVM chains (Base, Ethereum) with USDC.
26
- **mcp-x402-xrpl is the only x402 implementation for XRPL and Xahau.**
27
-
28
- ---
29
-
30
- ## How it works
31
-
32
- ```
33
- Agent → POST /tools/premium-query
34
-
35
- Server ← HTTP 402 X-Payment-Requirements: { destination, amountDrops, currency: "XRP" }
36
-
37
- Middleware signs XRPL payment tx (wallet.sign → submit)
38
-
39
- XRPL/Xahau confirms in ~3 seconds
40
-
41
- Agent POST /tools/premium-query X-Payment-Proof: { txHash, ledgerIndex, payer }
42
-
43
- Server verifies proof on-ledger → 200 OK + tool result
44
- ```
45
-
46
- ---
47
-
48
- ## Quick start
49
-
50
- ```bash
51
- npm install @scriptmasterlabs/mcp-x402 xrpl express
52
- ```
53
-
54
- ### Gate an MCP tool (server side)
55
-
56
- ```typescript
57
- import express from "express";
58
- import { createPaymentGate } from "@scriptmasterlabs/mcp-x402";
59
-
60
- const app = express();
61
- app.use(express.json());
62
-
63
- app.post(
64
- "/tools/market-data",
65
- createPaymentGate({
66
- destination: "rYourXRPLReceivingAddress",
67
- amountDrops: "100000", // 0.1 XRP per tool call
68
- currency: "XRP",
69
- description: "Real-time market data — 0.1 XRP per query",
70
- }),
71
- (req, res) => {
72
- res.json({ price: 0.52, timestamp: Date.now() });
73
- }
74
- );
75
-
76
- app.listen(3402);
77
- ```
78
-
79
- ### Pay for a tool (agent / client side)
80
-
81
- ```typescript
82
- import { createX402Middleware } from "@scriptmasterlabs/mcp-x402";
83
- import express from "express";
84
-
85
- const agentApp = express();
86
- agentApp.use(
87
- createX402Middleware({
88
- walletSeed: process.env.XRPL_WALLET_SEED!,
89
- network: "xrpl-mainnet",
90
- maxPaymentDrops: "1000000", // 1 XRP safety cap per request
91
- })
92
- );
93
- ```
94
-
95
- ### Drop-in MCP server wrapper
96
-
97
- ```typescript
98
- import { wrapMcpServer } from "@scriptmasterlabs/mcp-x402";
99
-
100
- const server = wrapMcpServer({
101
- x402: {
102
- walletSeed: process.env.XRPL_WALLET_SEED!,
103
- network: "xrpl-mainnet",
104
- },
105
- tools: [
106
- {
107
- name: "premium-query",
108
- description: "AI-powered XRPL data analysis",
109
- pricing: {
110
- destination: "rYourAddress",
111
- amountDrops: "100000",
112
- currency: "XRP",
113
- },
114
- handler: async (params) => {
115
- return { result: "your tool output here" };
116
- },
117
- },
118
- ],
119
- });
120
-
121
- server.listen(); // Starts on port 3402
122
- ```
123
-
124
- ### Run the testnet demo
125
-
126
- ```bash
127
- git clone https://github.com/Timwal78/mcp-x402-xrpl
128
- cd mcp-x402-xrpl
129
- npm install
130
- npm run build
131
- node examples/pay-per-tool.js
132
- ```
133
-
134
- ---
135
-
136
- ## Supported networks & currencies
137
-
138
- | Network | Chain | Currency | Settlement time | Avg fee |
139
- |---------|-------|----------|-----------------|---------|
140
- | `xrpl-mainnet` | XRP Ledger | XRP (drops) | ~3 sec | 0.00001 XRP |
141
- | `xrpl-mainnet` | XRP Ledger | RLUSD (IOU) | ~3 sec | 0.00001 XRP |
142
- | `xrpl-testnet` | XRP Ledger testnet | XRP | ~3 sec | free |
143
- | `xahau-mainnet` | Xahau | XAH (drops) | ~3 sec | 0.00001 XAH |
144
- | `xahau-testnet` | Xahau testnet | XAH | ~3 sec | free |
145
-
146
- ---
147
-
148
- ## XRPL vs EVM: x402 settlement comparison
149
-
150
- | Feature | mcp-x402-xrpl (XRPL) | EVM x402 (Base/Ethereum) |
151
- |---------|----------------------|--------------------------|
152
- | Settlement finality | ~3 seconds | ~2 sec (Base) / ~12 sec (ETH) |
153
- | Avg tx fee | $0.000005 | $0.001–$0.10 |
154
- | Stablecoin support | RLUSD | USDC |
155
- | Custodian required | ❌ No | ❌ No |
156
- | Smart contract risk | ❌ Minimal (no EVM) | ⚠️ EVM surface area |
157
- | DID / Identity | ✅ Xahau Hooks (XAH) | ⚠️ External |
158
- | MCP x402 package | `@scriptmasterlabs/mcp-x402` | `@x402/mcp`, `mcp-go-x402` |
159
-
160
- ---
161
-
162
- ## API reference
163
-
164
- ### `createX402Middleware(opts)` Express middleware
165
-
166
- Intercepts `X-Payment-Requirements` headers on incoming requests and
167
- automatically fulfils them using the configured XRPL wallet.
168
-
169
- | Option | Type | Default | Description |
170
- |--------|------|---------|-------------|
171
- | `walletSeed` | `string` | required | XRPL family seed (sEdT...) |
172
- | `network` | `XrplNetwork` | `"xrpl-mainnet"` | Network to use |
173
- | `maxPaymentDrops` | `string` | none | Safety cap per request |
174
-
175
- ### `createPaymentGate(opts)` → Express middleware
176
-
177
- Issues HTTP 402 challenges to callers without a valid payment proof.
178
-
179
- | Option | Type | Default | Description |
180
- |--------|------|---------|-------------|
181
- | `destination` | `string` | required | XRPL receiving address |
182
- | `amountDrops` | `string` | — | XRP amount in drops |
183
- | `amount` | `string` | — | Non-XRP amount (RLUSD/XAH) |
184
- | `currency` | `"XRP"\|"RLUSD"\|"XAH"` | `"XRP"` | Settlement currency |
185
- | `destinationTag` | `number` | — | Optional destination tag |
186
-
187
- ### `wrapMcpServer(opts)` → `{ app, listen }`
188
-
189
- Spins up a complete MCP-compatible Express server with per-tool x402 gating.
190
-
191
- ### `XrplFacilitator`
192
-
193
- Low-level class for direct payment signing and proof verification.
194
-
195
- ```typescript
196
- const facilitator = new XrplFacilitator({ walletSeed, network });
197
- const proof = await facilitator.pay(requirements);
198
- const valid = await facilitator.verify(proof, requirements);
199
- ```
200
-
201
- ---
202
-
203
- ## FAQ
204
-
205
- **Q: What is mcp-x402?**
206
- A: mcp-x402 is a Node.js/TypeScript library that adds HTTP 402 payment gating to any
207
- MCP server using the XRP Ledger or Xahau as the payment rail. AI agents pay per tool call
208
- autonomously — no human intervention needed.
209
-
210
- **Q: Does this support Xahau and XAH?**
211
- A: Yes. All four networks are supported: XRPL mainnet, XRPL testnet, Xahau mainnet,
212
- and Xahau testnet. XAH (Xahau's native currency) can be used for tool payments.
213
-
214
- **Q: Is mcp-x402-xrpl the only x402 implementation for XRPL?**
215
- A: Yes. As of mid-2025, all other x402 packages (MetaMask's `mcp-x402`, Civic Team's
216
- `x402-mcp`, mark3labs' `mcp-go-x402`) target EVM chains only. This is the first
217
- and only XRPL/Xahau x402 facilitator.
218
-
219
- **Q: How is x402 different from an API key?**
220
- A: API keys require human signup, billing setup, and account management incompatible
221
- with fully autonomous AI agents. x402 is HTTP-native: the agent pays cryptographically
222
- on-chain per request, verified automatically by the server.
223
-
224
- **Q: Can I use RLUSD instead of XRP?**
225
- A: Yes. Pass `currency: "RLUSD"` and `amount: "0.10"` (human-readable string)
226
- instead of `amountDrops`. RLUSD settles on XRPL with the same 3-second finality.
227
-
228
- **Q: Do I need an XRPL node?**
229
- A: No. The library connects to public XRPL cluster nodes (`xrplcluster.com` for mainnet,
230
- `s.altnet.rippletest.net` for testnet) automatically.
231
-
232
- **Q: Is this related to ZeroQuery?**
233
- A: Yes. ZeroQuery (Proof-of-Intent Protocol) uses the x402 escrow pattern on Solana
234
- and is being extended to XRPL via this library. mcp-x402-xrpl is the XRPL payment
235
- settlement layer for the ZeroQuery ecosystem.
236
-
237
- **Q: What is the npm package name?**
238
- A: `@scriptmasterlabs/mcp-x402`. Install with `npm install @scriptmasterlabs/mcp-x402`.
239
-
240
- ---
241
-
242
- ## Related projects
243
-
244
- | Project | Description |
245
- |---------|-------------|
246
- | [ZeroQuery Protocol](https://github.com/Timwal78/zeroquery-protocol) | Proof-of-Intent — AI-to-AI intent resolution with x402 escrow |
247
- | [AGO Orchestrator](https://github.com/Timwal78/ago-orchestrator) | Autonomous GEO agent for content distribution and gap analysis |
248
- | [ScriptMasterLabs](https://scriptmasterlabs.com) | Home base — autonomous agent infrastructure |
249
-
250
- ---
251
-
252
- ## License
253
-
254
- Apache-2.0 — See [LICENSE](LICENSE).
255
-
256
- Built by [ScriptMasterLabs](https://scriptmasterlabs.com).
257
-
258
- ---
259
-
260
- *Keywords: mcp x402 xrpl, mcp-x402 xrpl, x402 payment xrpl, autonomous agent payments xrpl,
261
- http 402 xahau, mcp tool payment middleware, xrpl mcp payment, rlusd mcp x402,
262
- xah autonomous payment, model context protocol payment, agentic commerce xrpl*
1
+ # mcp-x402 — The First MCP Server That Pays for Itself
2
+
3
+ [![npm](https://img.shields.io/npm/v/@scriptmasterlabs/mcp-x402)](https://www.npmjs.com/package/@scriptmasterlabs/mcp-x402)
4
+ [![MIT License](https://img.shields.io/badge/license-MIT-blue.svg)](LICENSE)
5
+ [![Tests](https://github.com/timwal78/sml_portfolio/actions/workflows/mcp-x402-ci.yml/badge.svg)](https://github.com/timwal78/sml_portfolio/actions)
6
+
7
+ > **Demo video:** [30-second walkthrough](#) — coming within 48h of launch.
8
+
9
+ AI agents should pay for their own data — instantly, autonomously, compliantly. `mcp-x402` makes that real.
10
+
11
+ ```bash
12
+ npx @scriptmasterlabs/mcp-x402
13
+ ```
14
+
15
+ ---
16
+
17
+ ## Why MCP Servers Are Broken (The Manifesto)
18
+
19
+ Every MCP server connecting to paid APIs today requires:
20
+ - A human to set up API keys
21
+ - A human to manage billing
22
+ - A human to top up credits when they run out
23
+ - A human to rotate keys when they expire
24
+
25
+ This defeats the entire point of autonomous agents. If your agent has to stop and ask a human for a credit card, it's not autonomous — it's a very expensive chatbot.
26
+
27
+ **We built the machine-native alternative.**
28
+
29
+ `mcp-x402` is the first MCP server where agents provision their own wallets, negotiate prices on-chain, pay autonomously, and receive cryptographic receipts — all without human intervention. The agent's credit score goes up every time it successfully transacts. It builds financial reputation the same way humans do.
30
+
31
+ This is the infrastructure layer that makes truly autonomous AI agents possible.
32
+
33
+ ---
34
+
35
+ ## One-Line Install
36
+
37
+ ```bash
38
+ npm i -g @scriptmasterlabs/mcp-x402
39
+ ```
40
+
41
+ Add to your Claude Code `~/.claude/config.json`:
42
+
43
+ ```json
44
+ {
45
+ "mcpServers": {
46
+ "sml": {
47
+ "command": "npx",
48
+ "args": ["@scriptmasterlabs/mcp-x402"]
49
+ }
50
+ }
51
+ }
52
+ ```
53
+
54
+ For Cursor (SSE mode), add to your MCP settings:
55
+
56
+ ```json
57
+ {
58
+ "mcp-x402": {
59
+ "url": "http://localhost:3402/sse"
60
+ }
61
+ }
62
+ ```
63
+
64
+ Then run: `MCP_TRANSPORT=sse npx @scriptmasterlabs/mcp-x402`
65
+
66
+ ---
67
+
68
+ ## Architecture
69
+
70
+ ```
71
+ Claude / Cursor
72
+
73
+ ▼ MCP Protocol (stdio / SSE)
74
+ mcp-x402 Server
75
+ ├─ Input validation (Zod, 100% coverage)
76
+ ├─ Rate limiter (100/min per tool)
77
+ ├─ AP2 Mandate check (deny-by-default)
78
+ ├─ Credit Bureau check (min score 300)
79
+ ├─ Price registry (60s max cache)
80
+ ├─ x402 payment engine
81
+ │ ├─ Base USDC (preferred, <3s)
82
+ │ ├─ XRPL RLUSD (500ms fallback)
83
+ │ └─ Solana USDC (last resort)
84
+ ├─ 402Proof receipt generation
85
+ ├─ SML API call (mTLS)
86
+ └─ Append-only SHA-256 audit log
87
+
88
+ Result + receipt_id back to agent
89
+ ```
90
+
91
+ ---
92
+
93
+ ## The 6 Tools
94
+
95
+ ### `leviathan_signal` $0.05 USDC | AP2 required
96
+ Institutional-grade squeeze signals. Multi-engine verdict (OracleEngine + RDT + SML Fractal Cascade).
97
+
98
+ ```typescript
99
+ await use_mcp_tool('sml', 'leviathan_signal', {
100
+ ticker: 'MSTR',
101
+ signal_type: 'squeeze',
102
+ min_confidence: 75
103
+ });
104
+ // Returns: signal verdict + confidence + receipt_id
105
+ ```
106
+
107
+ ### `xmit_edgar_decode` — $0.02 USDC | AP2 required
108
+ Parse SEC DEF 14A / 13F / 13D filings. Raw text never leaves SML servers.
109
+
110
+ ```typescript
111
+ await use_mcp_tool('sml', 'xmit_edgar_decode', {
112
+ filing_url: 'https://www.sec.gov/Archives/edgar/data/...',
113
+ parse_target: 'executive_pay',
114
+ format: 'json'
115
+ });
116
+ ```
117
+
118
+ ### `xdeo_earnings_estimate` — $0.02 USDC | AP2 required
119
+ Decentralized earnings oracle. Earns +2 Credit Bureau points per successful call.
120
+
121
+ ```typescript
122
+ await use_mcp_tool('sml', 'xdeo_earnings_estimate', {
123
+ ticker: 'NVDA',
124
+ fiscal_quarter: 'Q12025',
125
+ estimate_type: 'all'
126
+ });
127
+ ```
128
+
129
+ ### `ftd_threshold_scan` — Alerts FREE / Full $0.05 USDC
130
+ SEC Reg SHO FTD spike detection. 15-minute cache.
131
+
132
+ ```typescript
133
+ // Free tier:
134
+ await use_mcp_tool('sml', 'ftd_threshold_scan', { scan_type: 'alerts' });
135
+ // Paid tier:
136
+ await use_mcp_tool('sml', 'ftd_threshold_scan', { scan_type: 'full', min_spike_multiplier: 3 });
137
+ ```
138
+
139
+ ### `nexus_agent_hire` — Query FREE / Hire 5% commission
140
+ Agent marketplace. Find and hire specialized AI agents.
141
+
142
+ ```typescript
143
+ // Free query:
144
+ await use_mcp_tool('sml', 'nexus_agent_hire', { capability: 'options flow analysis', max_budget: '1.00', action: 'query' });
145
+ // Hire:
146
+ await use_mcp_tool('sml', 'nexus_agent_hire', { action: 'hire', agent_id: 'agent_abc', max_budget: '0.50' });
147
+ ```
148
+
149
+ ### `crawl_paid_fetch` — $0.005 USDC
150
+ Pay-per-fetch web scraping. Humans bypass automatically.
151
+
152
+ ```typescript
153
+ await use_mcp_tool('sml', 'crawl_paid_fetch', {
154
+ url: 'https://example.com/data',
155
+ extract: 'tables'
156
+ });
157
+ ```
158
+
159
+ ---
160
+
161
+ ## Payment Flow
162
+
163
+ 1. **Discover** — Agent reads `agents.json` or `llms.txt`, sees tool prices
164
+ 2. **Authorize** AP2 mandate checked. Credit Bureau score ≥ 300 auto-approves
165
+ 3. **Pay** — x402 stablecoin on cheapest/fastest chain (<3s on Base)
166
+ 4. **Prove** 402Proof receipt in every response
167
+ 5. **Earn** Credit Bureau score updates after success
168
+
169
+ Every successful tool call returns a `_meta` block:
170
+ ```json
171
+ {
172
+ "_meta": {
173
+ "receipt_id": "uuid-here",
174
+ "tx_hash": "0xabc...",
175
+ "chain": "base",
176
+ "amount_paid": "0.05 USDC",
177
+ "timestamp": 1750000000000
178
+ }
179
+ }
180
+ ```
181
+
182
+ ---
183
+
184
+ ## SDK For MCP Server Authors
185
+
186
+ Install in one line:
187
+ ```bash
188
+ npm i @scriptmasterlabs/mcp-x402-sdk
189
+ ```
190
+
191
+ Drop into any MCP server in 5 lines:
192
+ ```typescript
193
+ import { x402Payment } from '@scriptmasterlabs/mcp-x402-sdk';
194
+
195
+ server.tool(
196
+ 'my_paid_tool',
197
+ myInputSchema,
198
+ x402Payment({
199
+ price: '0.01',
200
+ currency: 'USDC',
201
+ inputSchema: MyZodSchema,
202
+ handler: async (input, receipt) => ({
203
+ content: [{ type: 'text', text: JSON.stringify({ result: await myApi(input), receipt }) }],
204
+ }),
205
+ }),
206
+ );
207
+ ```
208
+
209
+ That's it. The SDK handles wallet provisioning, AP2 mandate, chain routing, receipts, and audit logging.
210
+
211
+ ---
212
+
213
+ ## Security
214
+
215
+ | Requirement | Implementation |
216
+ |-------------|----------------|
217
+ | Keys in OS keychain only | `keytar` — macOS Keychain / Windows DPAPI / Linux Secret Service |
218
+ | mTLS on SML APIs | Pinned cert via `node-forge` |
219
+ | No PII in logs | Wallet addresses hashed (SHA-256 prefix), filing content redacted |
220
+ | Zod on all inputs | 100% coverage, validated before any execution |
221
+ | Append-only audit log | SHA-256 HMAC chained log, 7-day local + cloud backup |
222
+ | AP2 mandate required | Verified before every paid call, fail-closed |
223
+ | 402Proof receipt | Every transaction, registered with proof server |
224
+ | Credit Bureau check | min score 300 for auto-approve |
225
+ | $50 daily spend cap | Per wallet, enforced in-process |
226
+ | Testnet in CI | Base Sepolia only, max $0.10 test value |
227
+ | <3s end-to-end | Base mainnet target, 500ms multi-chain fallback |
228
+
229
+ ---
230
+
231
+ ## Environment Variables
232
+
233
+ See [`.env.example`](.env.example) for the full list. Key variables:
234
+
235
+ ```bash
236
+ MCP_TRANSPORT=stdio # stdio (Claude Code) or sse (Cursor/remote)
237
+ SML_API_BASE=https://api.scriptmasterlabs.com
238
+ BASE_RPC_URL=https://mainnet.base.org
239
+ XRPL_RPC_URL=wss://xrplcluster.com
240
+ DAILY_SPEND_CAP_USD=50
241
+ AUTO_APPROVE_THRESHOLD_USD=1
242
+ TESTNET=false # Set true + CI_WALLET_SEED for CI
243
+ ```
244
+
245
+ **Private keys**: Stored in your OS keychain automatically on first run. Never in env vars.
246
+
247
+ ---
248
+
249
+ ## Running Locally
250
+
251
+ ```bash
252
+ git clone https://github.com/timwal78/sml_portfolio
253
+ cd mcp-x402
254
+ npm install
255
+ npm run build
256
+ npm start
257
+ ```
258
+
259
+ With Docker:
260
+ ```bash
261
+ docker build -t mcp-x402 .
262
+ docker run -p 3402:3402 -e MCP_TRANSPORT=sse mcp-x402
263
+ ```
264
+
265
+ ---
266
+
267
+ ## Testing
268
+
269
+ ```bash
270
+ npm test # All unit tests
271
+ npm run test:coverage # Coverage report (target: 90%)
272
+ TESTNET=true CI_WALLET_SEED="your mnemonic" npm run test:integration
273
+ ```
274
+
275
+ ---
276
+
277
+ ## Ecosystem
278
+
279
+ | Service | URL | Role |
280
+ |---------|-----|------|
281
+ | SqueezeOS API | `squeezeos-api.onrender.com` | Market intelligence |
282
+ | 402Proof | `four02proof.onrender.com` | Payment receipts + Credit Bureau |
283
+ | Ghost Layer | `ghost-layer.onrender.com` | XRPL+Base toll gateway |
284
+ | ScriptMasterLabs | `scriptmasterlabs.com` | Operator homepage |
285
+
286
+ ---
287
+
288
+ ## MOAT
289
+
290
+ - Only MCP server with live x402 + AP2 + multi-chain production stack
291
+ - Only one with Agent Credit Bureau (300–850 scores)
292
+ - Only one backed by live financial intelligence marketplace
293
+ - Only one with SDVOSB federal credibility
294
+ - MIT licensed. No proprietary core.
295
+
296
+ ---
297
+
298
+ ## License
299
+
300
+ MIT — see [LICENSE](LICENSE)
301
+
302
+ Owner: [@TimmyCrypto78](https://github.com/timwal78) / ScriptMasterLabs
303
+ Launch Target: 2026-07-02
304
+ Target: 50K GitHub stars, 5K npm weekly downloads