@moonpay/cli 1.6.5 → 1.7.0
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/{chunk-FLITEIPS.js → chunk-MFWYT7UK.js} +3 -3
- package/dist/chunk-UJQJ7EC2.js +33 -0
- package/dist/index.js +7 -7
- package/dist/mcp-4QGFZ5GI.js +2 -0
- package/dist/{store-IF6TAICR.js → store-NV4H7F5I.js} +1 -1
- package/package.json +2 -1
- package/dist/chunk-6H2K7FBP.js +0 -33
- package/dist/mcp-QTFZVWSH.js +0 -2
package/dist/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
|
|
3
|
-
import{a as A,b as S,c as
|
|
4
|
-
`):e.map(
|
|
3
|
+
import{a as A,b as S,c as J,d as j,e as O}from"./chunk-UJQJ7EC2.js";import{a as C,c as q,t as v}from"./chunk-MFWYT7UK.js";import{g as R}from"./chunk-QOPJNTHY.js";import"./chunk-LMDE72OE.js";import{Command as ne}from"commander";var Y=!process.env.NO_COLOR&&process.stdout.isTTY===!0;function _(e){return t=>Y?`${e}${t}\x1B[0m`:t}var p={bold:_("\x1B[1m"),dim:_("\x1B[2m"),green:_("\x1B[32m"),yellow:_("\x1B[33m"),cyan:_("\x1B[36m"),red:_("\x1B[31m")};function k(e){if(e==null)return!0;let t=typeof e;return t==="string"||t==="number"||t==="boolean"}function $(e){return e==null?"-":String(e)}function N(e,t=0){let n=" ".repeat(t);return k(e)?`${n}${$(e)}`:Array.isArray(e)?e.length===0?`${n}${p.dim("(empty)")}`:e.every(k)?e.map(o=>`${n}- ${$(o)}`).join(`
|
|
4
|
+
`):e.map(o=>{if(typeof o!="object"||o===null)return`${n}- ${$(o)}`;let r=Object.entries(o),a=[],[c,l]=r[0];k(l)?a.push(`${n}- ${p.bold(c)}: ${$(l)}`):(a.push(`${n}- ${p.bold(c)}:`),a.push(N(l,t+2)));for(let[u,y]of r.slice(1))k(y)?a.push(`${n} ${p.bold(u)}: ${$(y)}`):(a.push(`${n} ${p.bold(u)}:`),a.push(N(y,t+2)));return a.join(`
|
|
5
5
|
`)}).join(`
|
|
6
6
|
|
|
7
|
-
`):typeof e=="object"&&e!==null?Object.entries(e).map(([
|
|
7
|
+
`):typeof e=="object"&&e!==null?Object.entries(e).map(([r,a])=>k(a)?`${n}${p.bold(r)}: ${$(a)}`:`${n}${p.bold(r)}:
|
|
8
8
|
${N(a,t+1)}`).join(`
|
|
9
|
-
`):""}function
|
|
10
|
-
`)}function
|
|
9
|
+
`):""}function H(e){if(typeof e!="object"||e===null)return e;let t=e;return"data"in t?t.data:"items"in t&&Array.isArray(t.items)&&Object.keys(t).filter(o=>o!=="items").length===0?t.items:e}function T(e,t){return t==="json"?JSON.stringify(e,null,2):N(H(e))}import{readFileSync as z,writeFileSync as W,mkdirSync as G}from"fs";import{join as P}from"path";import{homedir as B}from"os";var E=P(B(),".config","moonpay"),x=P(E,"update-check.json"),V=1440*60*1e3,Q=3e3;function X(){try{let e=z(x,"utf-8");return JSON.parse(e)}catch{return null}}function ee(e){try{G(E,{recursive:!0}),W(x,JSON.stringify(e))}catch{}}function F(e,t){let n=e.split(".").map(Number),o=t.split(".").map(Number);for(let r=0;r<3;r++){if((n[r]??0)>(o[r]??0))return!0;if((n[r]??0)<(o[r]??0))return!1}return!1}function K(e,t){return["",p.yellow(`Update available: ${e} \u2192 ${t}`),p.dim("Run `npm i -g @moonpay/cli` to update."),""].join(`
|
|
10
|
+
`)}function I(e){let t=null,n=X();if(n&&Date.now()-n.checkedAt<V)return F(n.latest,e)&&(t=K(e,n.latest)),()=>t;let o=new AbortController,r=setTimeout(()=>o.abort(),Q);return fetch("https://registry.npmjs.org/@moonpay%2fcli/latest",{signal:o.signal}).then(a=>a.json()).then(a=>{let c=a.version;c&&(ee({latest:c,checkedAt:Date.now()}),F(c,e)&&(t=K(e,c)))}).catch(()=>{}).finally(()=>clearTimeout(r)),()=>t}q();var te=I(C),h=new ne;h.name("moonpay").description(`MoonPay CLI \u2014 how agents move money
|
|
11
11
|
|
|
12
12
|
Your agents need money. MoonPay gives them wallets, funds, and tools
|
|
13
13
|
to buy, swap, bridge, and transact \u2014 all from the command line.
|
|
14
14
|
|
|
15
15
|
Run \`mp skill install\` to install AI skills for Claude Code.
|
|
16
16
|
|
|
17
|
-
`+
|
|
18
|
-
`)),
|
|
17
|
+
`+J).version(C).option("--json","Output as JSON instead of YAML");function oe(){return h.opts().json?"json":"yaml"}function L(e){console.log(T(e,oe()))}function D(){let e=te();e&&process.stderr.write(e)}h.command("mcp").description("Start MCP server over stdio (for Claude Desktop, Claude Code, etc.)").action(async()=>{let{startMcpServer:e}=await import("./mcp-4QGFZ5GI.js");await e()});function M(e,t){let n=e;for(let o of t){let r=n.commands.find(a=>a.name()===o);r||(r=n.command(o)),n=r}return n}function Z(e,t=""){let n=[];for(let[o,r]of Object.entries(e)){let a=t?`${t}-${o}`:o,c=r;for(;c._def.typeName==="ZodEffects";)c=c._def.schema;let l=c;l._def.typeName==="ZodNullable"&&(l=l._def.innerType),l._def.typeName==="ZodObject"&&l.shape?n.push(...Z(l.shape,a)):n.push({flatKey:a,field:r,path:a.split("-")})}return n}function re(e,t){let n={};for(let{flatKey:o,path:r}of t){let a=o.replace(/-([a-z])/g,(l,u)=>u.toUpperCase()),c=a in e?e[a]:e[o];if(r.length===1)n[r[0]]=c;else{let l=n;for(let u=0;u<r.length-1;u++)(!l[r[u]]||typeof l[r[u]]!="object")&&(l[r[u]]={}),l=l[r[u]];l[r[r.length-1]]=c}}return n}function se(e,t){for(let n of t){let o=n.schema.name.split("_"),r=o.pop(),c=M(e,o).command(r).description(n.schema.description),l=n.schema.input.shape??{},u=Z(l),y=[],b=[],w=[];for(let{flatKey:f,field:i}of u){let s=i.description??f,m=i;for(;m._def.typeName==="ZodEffects";)m=m._def.schema;let g=m._def.typeName,d=m;d._def.typeName==="ZodNullable"&&(d=d._def.innerType),d._def.typeName==="ZodNumber"&&b.push(f),d._def.typeName==="ZodRecord"&&w.push(f),g==="ZodBoolean"?c.option(`--${f}`,s,!1):g==="ZodNullable"?(c.option(`--${f} <${f}>`,s),y.push(f)):c.requiredOption(`--${f} <${f}>`,s)}c.action(async f=>{n.schema.name.startsWith("consent_")||await j.handler({});for(let s of y){let m=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]===void 0&&(f[m]=null)}for(let s of b){let m=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]!=null&&typeof f[m]=="string"&&(f[m]=Number(f[m]))}for(let s of w){let m=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());if(typeof f[m]=="string")try{f[m]=JSON.parse(f[m])}catch{console.error(`Invalid JSON for --${s}`),process.exit(1)}}let i=re(f,u);try{let s=await n.handler(i);L(s)}catch(s){console.error(s.message),process.exit(1)}})}}function ie(e){if(e.$ref&&e.definitions){let t=e.$ref.replace("#/definitions/","");return e.definitions[t]}return e}function ae(e){return Array.isArray(e.type)?e.type.includes("null"):e.anyOf?e.anyOf.some(t=>t.type==="null"):!1}function ce(e){return Array.isArray(e.type)?e.type.includes("object"):e.anyOf?e.anyOf.some(t=>t.type==="object"):e.type==="object"}function le(e){return Array.isArray(e.type)?e.type.some(t=>t==="number"||t==="integer"):e.anyOf?e.anyOf.some(t=>t.type==="number"||t.type==="integer"):e.type==="number"||e.type==="integer"}function fe(e){let t=e.wallet,n=e.chain;if(typeof t!="string"||typeof n!="string")return;let o=v(t);if(!o)return;let r=R[n];if(!r)return;let a=o.addresses[r];a&&(e.wallet=a)}var U=new Set(["swaps_transaction_build","token_transfer","transaction_register","virtual-account_offramp_initiate","prediction-market_position_buy","prediction-market_position_sell","prediction-market_position_redeem","commerce_cart_update","commerce_checkout_start","commerce_checkout_pay"]);function me(e,t){for(let n of t){if(U.has(n.name))continue;let o=n.name.split("_"),r=o.pop(),a=M(e,o);if(a.commands.find(i=>i.name()===r))continue;let c=a.command(r).description(n.description),l=ie(n.inputSchema),u=l.properties??{},y=new Set(l.required??[]),b=[],w=[],f=[];for(let[i,s]of Object.entries(u)){let m=s.description??i,g=ae(s),d=ce(s);le(s)&&w.push(i),d?(f.push(i),y.has(i)&&!g?c.requiredOption(`--${i} <json>`,`${m} (as JSON)`):(c.option(`--${i} <json>`,`${m} (as JSON)`),b.push(i))):g||!y.has(i)?(c.option(`--${i} <${i}>`,m),b.push(i)):c.requiredOption(`--${i} <${i}>`,m)}c.action(async i=>{await j.handler({});for(let s of b)i[s]===void 0&&(i[s]=null);for(let s of w)i[s]!=null&&typeof i[s]=="string"&&(i[s]=Number(i[s]));for(let s of f)if(typeof i[s]=="string")try{i[s]=JSON.parse(i[s])}catch{console.error(`Invalid JSON for --${s}`),process.exit(1)}try{fe(i);let s=await A._call(n.name,i);L(s),D()}catch(s){console.error(s.message),process.exit(1)}})}}se(h,O);me(h,S);h.command("tools").description("List available tools").action(()=>{let e=[...O.map(n=>({name:n.schema.name,description:n.schema.description})),...S.filter(n=>!O.some(o=>o.schema.name===n.name)&&!U.has(n.name)).map(n=>({name:n.name,description:n.description}))].sort((n,o)=>n.name.localeCompare(o.name)),t=[];for(let n of e){let o=n.name.replace(/_/g," ");t.push(` ${p.green(o.padEnd(28))} ${p.dim(n.description)}`)}t.push(""),t.push(p.dim(`${e.length} tools`)),console.log(t.join(`
|
|
18
|
+
`)),D()});h.parse();
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
|
|
2
|
+
import{a as d,b as f,e as u}from"./chunk-UJQJ7EC2.js";import{a as l,c as R}from"./chunk-MFWYT7UK.js";import"./chunk-QOPJNTHY.js";import"./chunk-LMDE72OE.js";import{Server as N}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as O}from"@modelcontextprotocol/sdk/server/stdio.js";import{CallToolRequestSchema as T,ListToolsRequestSchema as x}from"@modelcontextprotocol/sdk/types.js";import{zodToJsonSchema as k}from"zod-to-json-schema";R();var y=new Map(u.map(s=>[s.schema.name,s]));function q(s){let n=s.inputSchema;if(n.$ref&&n.definitions){let c=n.$ref.replace("#/definitions/","");return n.definitions[c]??n}return n}async function P(){let s=new N({name:"moonpay",version:l},{capabilities:{tools:{listChanged:!0}}}),n=u.map(e=>({name:e.schema.name,description:e.schema.description,inputSchema:k(e.schema.input)})),c=new Map;for(let e of f){if(y.has(e.name))continue;let t=q(e);c.set(e.name,t.properties??{}),n.push({name:e.name,description:e.description,inputSchema:{type:"object",properties:t.properties??{},...t.required?{required:t.required}:{},...t.additionalProperties!==void 0?{additionalProperties:t.additionalProperties}:{}}})}let h=new Map(n.map(e=>[e.name,e]));s.setRequestHandler(x,async()=>({tools:n.map(e=>({name:e.name,description:e.description,inputSchema:e.inputSchema}))})),s.setRequestHandler(T,async e=>{let{name:t,arguments:o={}}=e.params;if(!h.has(t))return{content:[{type:"text",text:`Unknown tool: ${t}`}],isError:!0};try{let i=y.get(t);if(i){let p=i.schema.input.shape??{};for(let[m,a]of Object.entries(p))o[m]===void 0&&a._def.typeName==="ZodNullable"&&(o[m]=null);let r=await i.handler(o);return{content:[{type:"text",text:JSON.stringify(r,null,2)}]}}let S=c.get(t)??{};for(let[p,r]of Object.entries(S))o[p]===void 0&&(Array.isArray(r.type)?r.type.includes("null"):r.anyOf?.some(w=>w.type==="null"))&&(o[p]=null),(r.type==="number"||r.type==="integer"||Array.isArray(r.type)&&r.type.some(a=>a==="number"||a==="integer")||r.anyOf?.some(a=>a.type==="number"||a.type==="integer"))&&typeof o[p]=="string"&&(o[p]=Number(o[p]));let b=await d._call(t,o);return{content:[{type:"text",text:JSON.stringify(b,null,2)}]}}catch(i){return{content:[{type:"text",text:i instanceof Error?i.message:String(i)}],isError:!0}}});let g=new O;await s.connect(g)}export{P as startMcpServer};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
|
|
2
|
-
import{A as
|
|
2
|
+
import{A as o,B as p,C as q,D as r,E as s,F as t,G as u,H as v,m as a,n as b,o as c,p as d,q as e,r as f,s as g,t as h,u as i,v as j,w as k,x as l,y as m,z as n}from"./chunk-MFWYT7UK.js";import"./chunk-QOPJNTHY.js";import"./chunk-LMDE72OE.js";export{m as addHardwareWallet,t as addWallet,d as createWallet,j as deleteWallet,l as exportSecret,h as findWallet,i as findWalletOrThrow,a as getVaultPath,e as importMnemonic,f as importPrivateKey,g as listWallets,r as loadWallets,p as lwsSignMessage,o as lwsSignTransaction,c as migrateWallets,v as mutateWallets,n as refreshHardwareAddresses,s as removeWallet,k as renameWallet,b as requireMigrationCheck,q as resolveSigningKey,u as saveWallets};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@moonpay/cli",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.7.0",
|
|
4
4
|
"description": "MoonPay CLI — how agents move money",
|
|
5
5
|
"homepage": "https://agents.moonpay.com",
|
|
6
6
|
"publishConfig": {
|
|
@@ -22,6 +22,7 @@
|
|
|
22
22
|
"test": "jest"
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|
|
25
|
+
"@moonpay/sdk": "*",
|
|
25
26
|
"@ledgerhq/device-management-kit": "1.1.0",
|
|
26
27
|
"@ledgerhq/device-signer-kit-ethereum": "1.11.1",
|
|
27
28
|
"@ledgerhq/device-signer-kit-solana": "1.6.2",
|