@moonpay/cli 1.16.2 → 1.18.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.
@@ -0,0 +1,4 @@
1
+ process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
2
+ import{a as V,b as T,c as G,d as L,h as D,p as Z}from"./chunk-WKRUTTKX.js";import{a as q,f as I}from"./chunk-LMDE72OE.js";import{existsSync as H,readFileSync as N,writeFileSync as he,renameSync as J}from"fs";import{join as S}from"path";import{homedir as ge}from"os";import{randomBytes as we}from"crypto";import*as i from"@open-wallet-standard/core";import Y from"bs58";T();import{z as s}from"zod";var M={"eip155:1":"ethereum","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":"solana","bip122:000000000019d6689c085ae165831e93":"bitcoin","tron:mainnet":"tron","ton:mainnet":"ton","fil:mainnet":"filecoin"},E=s.object({solana:s.string().optional(),ethereum:s.string().optional(),bitcoin:s.string().optional(),tron:s.string().optional(),ton:s.string().optional(),filecoin:s.string().optional()}),Q=["base","arbitrum","polygon","optimism","bnb","avalanche","tempo","tempo-moderato","ethereum-sepolia","base-sepolia","arbitrum-sepolia","polygon-amoy"];function Ie(e){let t={};if(e.solana&&(t.solana=e.solana,t["solana-devnet"]=e.solana),e.ethereum){t.ethereum=e.ethereum;for(let r of Q)t[r]=e.ethereum}return e.bitcoin&&(t.bitcoin=e.bitcoin),e.tron&&(t.tron=e.tron),e.ton&&(t.ton=e.ton),e.filecoin&&(t.filecoin=e.filecoin),t}var X=s.object({name:s.string(),type:s.literal("hd"),mnemonic:s.string().optional(),addresses:E,createdAt:s.string()}),ee=s.object({name:s.string(),type:s.literal("imported"),chain:s.string().optional(),privateKey:s.string().optional(),addresses:E,createdAt:s.string()}),R=s.enum(["ledger"]),$=s.object({name:s.string(),type:s.literal("hardware"),device:R,addresses:E,createdAt:s.string()}),Te=s.discriminatedUnion("type",[X,ee,$]),De=s.object({name:s.string(),type:s.enum(["hd","imported","hardware"]),device:R.optional(),addresses:s.record(s.string(),s.string()),createdAt:s.string()});import{createHash as U}from"crypto";import{HDKey as x}from"@scure/bip32";import{mnemonicToSeedSync as y}from"@scure/bip39";import{keccak_256 as F}from"@noble/hashes/sha3";import{derivePath as _}from"ed25519-hd-key";import*as j from"bitcoinjs-lib";import te from"ecpair";import*as K from"tiny-secp256k1";import{Keypair as re}from"@solana/web3.js";import ne from"bs58";import{WalletContractV5R1 as oe}from"@ton/ton";import{keyPairFromSeed as ie}from"@ton/crypto";import*as O from"@open-wallet-standard/core";var se=te(K);function z(e,t,r=0){switch(t){case"solana":return ae(e,r);case"ethereum":return le(e,r);case"bitcoin":return fe(e,r);case"tron":return pe(e,r);case"ton":return me(e,r);case"filecoin":return ye(e,r);default:throw new Error(`Unsupported key family for derivation: ${t}`)}}function ae(e,t){let r=y(e),n=`m/44'/501'/${t}'/0'`,{key:o}=_(n,Buffer.from(r).toString("hex")),a=re.fromSeed(Uint8Array.from(o));return{privateKey:a.secretKey,address:a.publicKey.toBase58()}}function le(e,t){let r=y(e),n=x.fromMasterSeed(r),o=`m/44'/60'/${t}'/0/0`,a=n.derive(o);if(!a.privateKey)throw new Error("Failed to derive EVM private key");let l=ce(a.publicKey);return{privateKey:a.privateKey,address:l}}function ce(e){let t=K.pointCompress(e,!1),n=F(t.slice(1)).slice(-20),o="0x"+Buffer.from(n).toString("hex");return de(o)}function de(e){let t=e.toLowerCase().replace("0x",""),r=Buffer.from(F(Buffer.from(t,"utf8"))).toString("hex"),n="0x";for(let o=0;o<t.length;o++)n+=parseInt(r[o],16)>=8?t[o].toUpperCase():t[o];return n}function fe(e,t){let r=y(e),n=x.fromMasterSeed(r),o=`m/84'/0'/${t}'/0/0`,a=n.derive(o);if(!a.privateKey)throw new Error("Failed to derive Bitcoin private key");let l=se.fromPrivateKey(Buffer.from(a.privateKey)),{address:f}=j.payments.p2wpkh({pubkey:Buffer.from(l.publicKey)});if(!f)throw new Error("Failed to derive Bitcoin address");return{privateKey:a.privateKey,address:f}}function pe(e,t){let r=y(e),n=x.fromMasterSeed(r),o=`m/44'/195'/${t}'/0/0`,a=n.derive(o);if(!a.privateKey)throw new Error("Failed to derive Tron private key");let l=ue(a.publicKey);return{privateKey:a.privateKey,address:l}}function ue(e){let t=K.pointCompress(e,!1),n=F(t.slice(1)).slice(-20),o=Buffer.concat([Buffer.from([65]),Buffer.from(n)]),a=U("sha256").update(o).digest(),l=U("sha256").update(a).digest(),f=Buffer.concat([o,l.slice(0,4)]);return ne.encode(f)}function me(e,t){let r=y(e),n=`m/44'/607'/${t}'/0'`,{key:o}=_(n,Buffer.from(r).toString("hex")),a=ie(Buffer.from(o)),l=oe.create({publicKey:Buffer.from(a.publicKey)});return{privateKey:a.secretKey,address:l.address.toString({bounceable:!1})}}function ye(e,t){let r=y(e),n=x.fromMasterSeed(r),o=`m/44'/461'/${t}'/0/0`,a=n.derive(o);if(!a.privateKey)throw new Error("Failed to derive Filecoin private key");let l=O.deriveAddress(e,"filecoin",t);return{privateKey:a.privateKey,address:l}}Z();var b=S(ge(),".config","moonpay"),B=S(b,"hardware-wallets.json");function c(){return b}function ve(e){let t={};for(let r of e){let n=M[r.chainId];n&&(t[n]=r.address)}return t}function h(e){let t=ve(e.accounts);if(!t.filecoin)try{let r=i.exportWallet(e.id,null,c());r&&!r.startsWith("{")&&(t.filecoin=i.deriveAddress(r,"filecoin"))}catch{}return{name:e.name,type:"hd",addresses:t,createdAt:e.createdAt}}function m(){if(!H(B))return[];try{return(JSON.parse(N(B,"utf-8")).wallets??[]).map(t=>$.parse(t))}catch{return[]}}function We(e,t){D();let r=S(b,`.tmp.${we(4).toString("hex")}`);he(r,JSON.stringify(t,null,2),{mode:384}),J(r,e)}function g(e){We(B,{wallets:e})}var w=S(b,"wallets.json");function P(){if(H(w)){process.stderr.write(`Migrating legacy wallets...
3
+ `);let{migrated:e,skipped:t}=xe();process.stderr.write(`Migrated ${e} wallet(s), skipped ${t}.
4
+ `)}}function xe(){if(!H(w))throw new Error("No legacy wallets.json found \u2014 nothing to migrate.");let{getEncryptionKey:e}=(L(),I(G)),{decrypt:t,encryptedFileSchema:r}=(T(),I(V)),n=e();if(!n)throw new Error("Encryption key not found. Set MOONPAY_ENCRYPTION_KEY or ensure OS keychain is accessible.");let o=JSON.parse(N(w,"utf-8")),a=r.parse(o),l=t(a,n),f=JSON.parse(l).wallets??[],p=c(),W=m(),C=0,k=0;for(let d of f){try{i.getWallet(d.name,p),k++;continue}catch{}if(W.some(u=>u.name===d.name)){k++;continue}if(d.type==="hardware")W.push({name:d.name,type:"hardware",device:d.device,addresses:d.addresses,createdAt:d.createdAt});else if(d.type==="hd"&&d.mnemonic)i.importWalletMnemonic(d.name,d.mnemonic,null,null,p);else if(d.type==="imported"&&d.privateKey){let u=d.privateKey;if(!/^[0-9a-fA-F]+$/.test(u)){let A=Y.decode(u);u=Buffer.from(A.length===64?A.slice(0,32):A).toString("hex")}i.importWalletPrivateKey(d.name,u,null,p,null,u,u)}C++}return W.length>0&&g(W),J(w,w+".migrated"),{migrated:C,skipped:k}}function Ke(e){P(),v(e);let t=i.createWallet(e,null,24,c());return h(t)}function Se(e,t){v(e);let r=i.importWalletMnemonic(e,t,null,null,c());return h(r)}function be(e,t){return v(e),h(i.importWalletPrivateKey(e,t,null,c()))}function ke(){P();let e=[];try{e=i.listWallets(c())}catch{}return[...e.map(r=>h(r)),...m()]}function Ae(e){P();let t=c();try{let r=i.getWallet(e,t);return h(r)}catch{}try{for(let r of i.listWallets(t))for(let n of r.accounts)if(n.address===e)return h(r)}catch{}for(let r of m()){if(r.name===e)return r;for(let n of Object.values(r.addresses))if(n===e)return r}return null}function nt(e){let t=Ae(e);if(!t)throw new Error(`Wallet "${e}" not found`);return t}function Ee(e){try{i.deleteWallet(e,c());return}catch{}let t=m(),r=t.findIndex(n=>n.name===e);if(r===-1)throw new Error(`Wallet "${e}" not found`);t.splice(r,1),g(t)}function ot(e,t){if(e===t)return;v(t);try{i.getWallet(e,c()),i.renameWallet(e,t,c());return}catch(o){if(o instanceof Error&&!o.message.includes("not found"))throw o}let r=m(),n=r.find(o=>o.name===e);if(!n)throw new Error(`Wallet "${e}" not found`);n.name=t,g(r)}function it(e){return i.exportWallet(e,null,c())}function $e(e){v(e.name);let t=m();t.push(e),g(t)}function st(e,t){let r=m(),n=r.find(o=>o.name===e);if(!n)throw new Error(`Hardware wallet "${e}" not found`);n.addresses=t,g(r)}function at(e,t,r){return i.signTransaction(e,t,r,null,null,c())}function lt(e,t,r,n){return i.signMessage(e,t,r,null,n??null,null,c())}function ct(e,t,r){return i.signTypedData(e,t,r,null,null,c())}async function dt(e,t){if(e.type==="hardware")throw new Error(`Wallet "${e.name}" is a hardware wallet. Signing must happen on the device.`);let{moonpay:r}=await import("./client-FQ3KSDK6.js"),o=(await r.chain.retrieve({chain:t})).keyFamily,a=i.exportWallet(e.name,null,c());if(a.includes(" "))return z(a,o);let l;if(a.startsWith("{")){let p=JSON.parse(a);l=o==="solana"||o==="ton"?p.ed25519:p.secp256k1}else l=a;let f=Uint8Array.from(Buffer.from(l,"hex"));if(o==="solana"&&f.length===32){let p=q("tweetnacl");f=Uint8Array.from(p.sign.keyPair.fromSeed(f).secretKey)}return{privateKey:f,address:e.addresses[o]??""}}var Fe=ke,ft=Ee;function Be(e){if(e.type==="hardware"){$e(e);return}if(e.type==="hd"&&e.mnemonic){Se(e.name,e.mnemonic);return}if(e.type==="imported"&&e.privateKey){let t=e.privateKey;if(t.startsWith("0x"))t=t.slice(2);else if(!/^[0-9a-fA-F]+$/.test(t)){let r=Y.decode(t);t=Buffer.from(r.length===64?r.slice(0,32):r).toString("hex")}be(e.name,t);return}Ke(e.name)}function pt(e){for(let t of e)Be(t)}function ut(e){let t=Fe();e(t),g(t.filter(r=>r.type==="hardware"))}function v(e){try{throw i.getWallet(e,c()),new Error(`Wallet "${e}" already exists`)}catch(t){if(t instanceof Error&&t.message.includes("already exists"))throw t}if(m().some(t=>t.name===e))throw new Error(`Wallet "${e}" already exists`)}export{E as a,Ie as b,R as c,De as d,z as e,c as f,P as g,xe as h,Ke as i,Se as j,be as k,ke as l,Ae as m,nt as n,Ee as o,ot as p,it as q,$e as r,st as s,at as t,lt as u,ct as v,dt as w,Fe as x,ft as y,Be as z,pt as A,ut as B};
@@ -0,0 +1,3 @@
1
+ process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
2
+ import{b as m,d as I}from"./chunk-LMDE72OE.js";var G={};I(G,{decrypt:()=>O,encrypt:()=>k,encryptedFileSchema:()=>T});import{randomBytes as R,scryptSync as v,createCipheriv as $,createDecipheriv as X}from"crypto";import{z as i}from"zod";function k(n,t){let r=R(32),o=v(t,r,D,{N:A,r:F,p:L,maxmem:K}),s=R(12),c=$("aes-256-gcm",o,s),E=Buffer.concat([c.update(n,"utf8"),c.final()]);return{encryption:{cipher:"aes-256-gcm",kdf:"scrypt",kdfparams:{n:A,r:F,p:L},salt:r.toString("base64"),iv:s.toString("base64"),tag:c.getAuthTag().toString("base64")},data:E.toString("base64")}}function O(n,t){let{salt:r,iv:o,tag:s,kdfparams:c}=n.encryption,E=v(t,Buffer.from(r,"base64"),D,{N:c.n,r:c.r,p:c.p,maxmem:K}),x=X("aes-256-gcm",E,Buffer.from(o,"base64"),{authTagLength:16});return x.setAuthTag(Buffer.from(s,"base64")),Buffer.concat([x.update(Buffer.from(n.data,"base64")),x.final()]).toString("utf8")}var A,F,L,D,K,T,P=m(()=>{"use strict";A=2**18,F=8,L=1,D=32,K=512*1024*1024,T=i.object({encryption:i.object({cipher:i.literal("aes-256-gcm"),kdf:i.literal("scrypt"),kdfparams:i.object({n:i.number(),r:i.number(),p:i.number()}),salt:i.string(),iv:i.string(),tag:i.string()}),data:i.string()})});import{readFileSync as W}from"fs";import{join as z}from"path";import{homedir as q}from"os";function en(){if(f!==void 0)return f;try{f=JSON.parse(W(z(q(),".config","moonpay","consent.json"),"utf-8")).agentId??null}catch{f=null}return f??null}function U(){let n={"Content-Type":"application/json",[Z]:Q},t=en();return t&&(n[nn]=t),n}var Q,Z,nn,f,j=m(()=>{"use strict";Q="1.18.0",Z="X-CLI-Version",nn="X-Agent-Id"});import*as e from"fs";import*as Y from"os";import*as g from"path";function d(){e.existsSync(l)||e.mkdirSync(l,{recursive:!0,mode:448})}function B(n,t,r){let o=n+`.tmp.${process.pid}`;e.writeFileSync(o,t,{encoding:"utf-8",mode:r}),e.renameSync(o,n)}function rn(){d();try{let n=e.openSync(u,e.constants.O_CREAT|e.constants.O_EXCL|e.constants.O_WRONLY,384);e.writeSync(n,JSON.stringify({pid:process.pid,ts:Date.now()})),e.closeSync(n)}catch(n){if(n.code!=="EEXIST")throw n;try{let t=JSON.parse(e.readFileSync(u,"utf-8"));if(Date.now()-t.ts<tn)return null}catch{}try{e.unlinkSync(u)}catch{}try{let t=e.openSync(u,e.constants.O_CREAT|e.constants.O_EXCL|e.constants.O_WRONLY,384);e.writeSync(t,JSON.stringify({pid:process.pid,ts:Date.now()})),e.closeSync(t)}catch{return null}}return()=>{try{e.unlinkSync(u)}catch{}}}function V(){if(!e.existsSync(w))return null;try{let n=JSON.parse(e.readFileSync(w,"utf-8"));return n.baseUrl?n:null}catch{return null}}function Dn(){let n=V();return n||(sn(N),N)}function S(){if(!e.existsSync(p))return null;let n=h();if(!n)return null;try{let t=JSON.parse(e.readFileSync(p,"utf-8")),r=T.parse(t),o=O(r,n),s=JSON.parse(o);return!s.accessToken||!s.baseUrl?null:s}catch{return null}}function on(n){let t=b(),r=k(JSON.stringify(n),t);d(),B(p,JSON.stringify(r,null,2),384)}function sn(n){d(),B(w,JSON.stringify(n,null,2),384)}function Kn(){e.existsSync(p)&&e.unlinkSync(p)}function Pn(){let n=V(),t=S();return n?.baseUrl??t?.baseUrl??N.baseUrl}async function cn(n,t,r){let o=await fetch(`${n}/api/tools/${encodeURIComponent(t)}`,{method:"POST",signal:AbortSignal.timeout(15e3),headers:U(),body:JSON.stringify(r)}),s=await o.json();if(!o.ok){let c=s;throw new Error(c?.error??`${t} failed (${o.status})`)}return s}async function an(n){if(!n.refreshToken)throw new Error("No refresh token available");let t=rn();if(!t){await new Promise(o=>setTimeout(o,2e3));let r=S();if(r&&r.expiresAt>Date.now())return r;throw new Error("Token refresh failed (concurrent refresh in progress)")}try{let r=S();if(r&&r.expiresAt>Date.now()+6e4)return r;let o=await cn(n.baseUrl,"refresh",{refreshToken:n.refreshToken}),s={accessToken:o.accessToken,refreshToken:o.refreshToken,expiresAt:o.expiresAt*1e3,baseUrl:n.baseUrl};return on(s),s}finally{t()}}async function Un(){let n=S();if(!n)return null;if(Date.now()>=n.expiresAt-fn){if(n.refreshToken)try{return(await an(n)).accessToken}catch{return null}return null}return n.accessToken}var l,w,p,u,N,tn,fn,H=m(()=>{"use strict";P();J();j();l=g.join(Y.homedir(),".config","moonpay"),w=g.join(l,"config.json"),p=g.join(l,"credentials.json"),u=g.join(l,".credentials.lock"),N={baseUrl:"https://agents.moonpay.com"};tn=3e4;fn=300*1e3});var On={};I(On,{ensureEncryptionKey:()=>b,getEncryptionKey:()=>h});import{execFileSync as C,execSync as un}from"child_process";import{randomBytes as ln}from"crypto";import{existsSync as pn,readFileSync as gn,writeFileSync as dn}from"fs";import{homedir as yn,platform as M}from"os";import{join as mn}from"path";function Sn(n){try{C("security",["delete-generic-password","-s",a,"-a",y],{stdio:"ignore"})}catch{}C("security",["add-generic-password","-s",a,"-a",y,"-w",n],{stdio:"ignore"})}function hn(){try{return C("security",["find-generic-password","-s",a,"-a",y,"-w"],{encoding:"utf-8",stdio:["ignore","pipe","ignore"]}).trim()}catch{return null}}function Cn(n){un(`printf '%s' | secret-tool store --label="${a}" service "${a}" account "${y}"`,{input:n,stdio:["pipe","ignore","ignore"]})}function _n(){try{return C("secret-tool",["lookup","service",a,"account",y],{encoding:"utf-8",stdio:["ignore","pipe","ignore"]}).trim()}catch{return null}}function En(n){d(),dn(_,n,{encoding:"utf-8",mode:384})}function xn(){try{return pn(_)&&gn(_,"utf-8").trim()||null}catch{return null}}function Tn(n){try{let t=M();return t==="darwin"?(Sn(n),!0):t==="linux"?(Cn(n),!0):!1}catch{return!1}}function kn(){let n=M();return n==="darwin"?hn():n==="linux"?_n():null}function h(){let n=process.env.MOONPAY_ENCRYPTION_KEY;return n||(kn()??xn())}function b(){let n=h();if(n)return n;let t=ln(32).toString("hex");return Tn(t)||(En(t),process.stderr.write("Note: Keychain unavailable. Encryption key stored in "+_+`
3
+ `)),t}var a,y,_,J=m(()=>{"use strict";H();a="moonpay-cli",y="encryption-key",_=mn(yn(),".config","moonpay",".encryption-key")});export{G as a,P as b,On as c,J as d,Q as e,U as f,j as g,d as h,Dn as i,S as j,on as k,Kn as l,Pn as m,an as n,Un as o,H as p};
@@ -0,0 +1,2 @@
1
+ process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
2
+ import{b as a,c as b}from"./chunk-6YOIZGHC.js";import"./chunk-WKRUTTKX.js";import"./chunk-LMDE72OE.js";export{a as moonpay,b as resetClient};
@@ -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 p}from"./chunk-SEOEJZOL.js";import"./chunk-KBP3ULPH.js";import{d,e as h}from"./chunk-JLT4XDAY.js";import"./chunk-LMDE72OE.js";function l(n,s){let a=s instanceof d?s:new d(s);return n.interceptors.response.use(t=>t,async t=>{if(!t.response||t.response.status!==402)return Promise.reject(t);let r=t.config;if(!r||!r.headers)return Promise.reject(new Error("Missing axios request configuration"));if(r.__is402Retry)return Promise.reject(t);try{let i;try{let e=t.response,o=c=>{let f=e.headers[c]??e.headers[c.toLowerCase()];return typeof f=="string"?f:void 0},m=e.data;i=a.getPaymentRequiredResponse(o,m)}catch(e){return Promise.reject(new Error(`Failed to parse payment requirements: ${e instanceof Error?e.message:"Unknown error"}`))}let u=await a.handlePaymentRequired(i);if(u){let e={...r};e.headers={...r.headers},Object.entries(u).forEach(([m,c])=>{e.headers.set(m,c)});let o=await n.request(e);if(o.status!==402)return o}let y;try{y=await s.createPaymentPayload(i)}catch(e){return Promise.reject(new Error(`Failed to create payment payload: ${e instanceof Error?e.message:"Unknown error"}`))}let P=a.encodePaymentSignatureHeader(y);return r.__is402Retry=!0,Object.entries(P).forEach(([e,o])=>{r.headers.set(e,o)}),r.headers.set("Access-Control-Expose-Headers","PAYMENT-RESPONSE,X-PAYMENT-RESPONSE"),await n.request(r)}catch(i){return Promise.reject(i)}}),n}function R(n,s){let a=p.fromConfig(s);return l(n,a)}export{h as decodePaymentResponseHeader,l as wrapAxiosWithPayment,R as wrapAxiosWithPaymentFromConfig,p as x402Client,d as x402HTTPClient};
2
+ import"./chunk-KBP3ULPH.js";import{a as p}from"./chunk-SEOEJZOL.js";import{d,e as h}from"./chunk-JLT4XDAY.js";import"./chunk-LMDE72OE.js";function l(n,s){let a=s instanceof d?s:new d(s);return n.interceptors.response.use(t=>t,async t=>{if(!t.response||t.response.status!==402)return Promise.reject(t);let r=t.config;if(!r||!r.headers)return Promise.reject(new Error("Missing axios request configuration"));if(r.__is402Retry)return Promise.reject(t);try{let i;try{let e=t.response,o=c=>{let f=e.headers[c]??e.headers[c.toLowerCase()];return typeof f=="string"?f:void 0},m=e.data;i=a.getPaymentRequiredResponse(o,m)}catch(e){return Promise.reject(new Error(`Failed to parse payment requirements: ${e instanceof Error?e.message:"Unknown error"}`))}let u=await a.handlePaymentRequired(i);if(u){let e={...r};e.headers={...r.headers},Object.entries(u).forEach(([m,c])=>{e.headers.set(m,c)});let o=await n.request(e);if(o.status!==402)return o}let y;try{y=await s.createPaymentPayload(i)}catch(e){return Promise.reject(new Error(`Failed to create payment payload: ${e instanceof Error?e.message:"Unknown error"}`))}let P=a.encodePaymentSignatureHeader(y);return r.__is402Retry=!0,Object.entries(P).forEach(([e,o])=>{r.headers.set(e,o)}),r.headers.set("Access-Control-Expose-Headers","PAYMENT-RESPONSE,X-PAYMENT-RESPONSE"),await n.request(r)}catch(i){return Promise.reject(i)}}),n}function R(n,s){let a=p.fromConfig(s);return l(n,a)}export{h as decodePaymentResponseHeader,l as wrapAxiosWithPayment,R as wrapAxiosWithPaymentFromConfig,p as x402Client,d as x402HTTPClient};
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 J,d as j,e as O}from"./chunk-EBDUG4KJ.js";import{a as C,c as q,u as v}from"./chunk-YJWSYQVX.js";import{g as R}from"./chunk-TPAYGT4L.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(r=>`${n}- ${$(r)}`).join(`
4
- `):e.map(r=>{if(typeof r!="object"||r===null)return`${n}- ${$(r)}`;let s=Object.entries(r),a=[],[c,l]=s[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 s.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(`
3
+ import{a as j,b as J,c as R,d as O}from"./chunk-DSMS3WZQ.js";import{b as C}from"./chunk-6YOIZGHC.js";import{m as v}from"./chunk-NNUDE3AO.js";import{e as S,g as U}from"./chunk-WKRUTTKX.js";import"./chunk-LMDE72OE.js";import{Command as ee}from"commander";var q=!process.env.NO_COLOR&&process.stdout.isTTY===!0;function w(e){return t=>q?`${e}${t}\x1B[0m`:t}var p={bold:w("\x1B[1m"),dim:w("\x1B[2m"),green:w("\x1B[32m"),yellow:w("\x1B[33m"),cyan:w("\x1B[36m"),red:w("\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 s=Object.entries(o),a=[],[c,l]=s[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 s.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
7
  `):typeof e=="object"&&e!==null?Object.entries(e).map(([s,a])=>k(a)?`${n}${p.bold(s)}: ${$(a)}`:`${n}${p.bold(s)}:
8
8
  ${N(a,t+1)}`).join(`
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(r=>r!=="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),r=t.split(".").map(Number);for(let s=0;s<3;s++){if((n[s]??0)>(r[s]??0))return!0;if((n[s]??0)<(r[s]??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 r=new AbortController,s=setTimeout(()=>r.abort(),Q);return fetch("https://registry.npmjs.org/@moonpay%2fcli/latest",{signal:r.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(s)),()=>t}q();var te=I(C),h=new ne;h.name("moonpay").description(`MoonPay CLI \u2014 how agents move money
9
+ `):""}function Y(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 A(e,t){return t==="json"?JSON.stringify(e,null,2):N(Y(e))}import{readFileSync as z,writeFileSync as H,mkdirSync as W}from"fs";import{join as K}from"path";import{homedir as G}from"os";var P=K(G(),".config","moonpay"),x=K(P,"update-check.json"),B=1440*60*1e3,V=3e3;function Q(){try{let e=z(x,"utf-8");return JSON.parse(e)}catch{return null}}function X(e){try{W(P,{recursive:!0}),H(x,JSON.stringify(e))}catch{}}function F(e,t){let n=e.split(".").map(Number),o=t.split(".").map(Number);for(let s=0;s<3;s++){if((n[s]??0)>(o[s]??0))return!0;if((n[s]??0)<(o[s]??0))return!1}return!1}function T(e,t){return["",p.yellow(`Update available: ${e} \u2192 ${t}`),p.dim("Run `npm i -g @moonpay/cli` to update."),""].join(`
10
+ `)}function E(e){let t=null,n=Q();if(n&&Date.now()-n.checkedAt<B)return F(n.latest,e)&&(t=T(e,n.latest)),()=>t;let o=new AbortController,s=setTimeout(()=>o.abort(),V);return fetch("https://registry.npmjs.org/@moonpay%2fcli/latest",{signal:o.signal}).then(a=>a.json()).then(a=>{let c=a.version;c&&(X({latest:c,checkedAt:Date.now()}),F(c,e)&&(t=T(e,c)))}).catch(()=>{}).finally(()=>clearTimeout(s)),()=>t}U();var ne=E(S),h=new ee;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
- `+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-PDPL4XLE.js");await e()});function M(e,t){let n=e;for(let r of t){let s=n.commands.find(a=>a.name()===r);s||(s=n.command(r)),n=s}return n}function Z(e,t=""){let n=[];for(let[r,s]of Object.entries(e)){let a=t?`${t}-${r}`:r,c=s;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:s,path:a.split("-")})}return n}function re(e,t){let n={};for(let{flatKey:r,path:s}of t){let a=r.replace(/-([a-z])/g,(l,u)=>u.toUpperCase()),c=a in e?e[a]:e[r];if(s.length===1)n[s[0]]=c;else{let l=n;for(let u=0;u<s.length-1;u++)(!l[s[u]]||typeof l[s[u]]!="object")&&(l[s[u]]={}),l=l[s[u]];l[s[s.length-1]]=c}}return n}function se(e,t){for(let n of t){let r=n.schema.name.split("_"),s=r.pop(),c=M(e,r).command(s).description(n.schema.description),l=n.schema.input.shape??{},u=Z(l),y=[],b=[],w=[];for(let{flatKey:f,field:i}of u){let o=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}`,o,!1):g==="ZodNullable"?(c.option(`--${f} <${f}>`,o),y.push(f)):c.requiredOption(`--${f} <${f}>`,o)}c.action(async f=>{n.schema.name.startsWith("consent_")||await j.handler({});for(let o of y){let m=o.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]===void 0&&(f[m]=null)}for(let o of b){let m=o.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]!=null&&typeof f[m]=="string"&&(f[m]=Number(f[m]))}for(let o of w){let m=o.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 --${o}`),process.exit(1)}}let i=re(f,u);try{let o=await n.handler(i);L(o)}catch(o){console.error(o instanceof Error?o.message:String(o)),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 r=v(t);if(!r)return;let s=R[n];if(!s)return;let a=r.addresses[s];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 r=n.name.split("_"),s=r.pop(),a=M(e,r);if(a.commands.find(i=>i.name()===s))continue;let c=a.command(s).description(n.description),l=ie(n.inputSchema),u=l.properties??{},y=new Set(l.required??[]),b=[],w=[],f=[];for(let[i,o]of Object.entries(u)){let m=o.description??i,g=ae(o),d=ce(o);le(o)&&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 o of b)i[o]===void 0&&(i[o]=null);for(let o of w)i[o]!=null&&typeof i[o]=="string"&&(i[o]=Number(i[o]));for(let o of f)if(typeof i[o]=="string")try{i[o]=JSON.parse(i[o])}catch{console.error(`Invalid JSON for --${o}`),process.exit(1)}try{fe(i);let o=await A._call(n.name,i);L(o),D()}catch(o){console.error(o instanceof Error?o.message:String(o)),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(r=>r.schema.name===n.name)&&!U.has(n.name)).map(n=>({name:n.name,description:n.description}))].sort((n,r)=>n.name.localeCompare(r.name)),t=[];for(let n of e){let r=n.name.replace(/_/g," ");t.push(` ${p.green(r.padEnd(28))} ${p.dim(n.description)}`)}t.push(""),t.push(p.dim(`${e.length} tools`)),console.log(t.join(`
18
- `)),D()});h.parse();
17
+ `+J).version(S).option("--json","Output as JSON instead of YAML");function te(){return h.opts().json?"json":"yaml"}function D(e){console.log(A(e,te()))}function L(){let e=ne();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-UH5Y6G25.js");await e()});function I(e,t){let n=e;for(let o of t){let s=n.commands.find(a=>a.name()===o);s||(s=n.command(o)),n=s}return n}function Z(e,t=""){let n=[];for(let[o,s]of Object.entries(e)){let a=t?`${t}-${o}`:o,c=s;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:s,path:a.split("-")})}return n}function re(e,t){let n={};for(let{flatKey:o,path:s}of t){let a=o.replace(/-([a-z])/g,(l,u)=>u.toUpperCase()),c=a in e?e[a]:e[o];if(s.length===1)n[s[0]]=c;else{let l=n;for(let u=0;u<s.length-1;u++)(!l[s[u]]||typeof l[s[u]]!="object")&&(l[s[u]]={}),l=l[s[u]];l[s[s.length-1]]=c}}return n}function oe(e,t){for(let n of t){let o=n.schema.name.split("_"),s=o.pop(),c=I(e,o).command(s).description(n.schema.description),l=n.schema.input.shape??{},u=Z(l),y=[],b=[],_=[];for(let{flatKey:f,field:i}of u){let r=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"&&_.push(f),g==="ZodBoolean"?c.option(`--${f}`,r,!1):g==="ZodNullable"?(c.option(`--${f} <${f}>`,r),y.push(f)):c.requiredOption(`--${f} <${f}>`,r)}c.action(async f=>{n.schema.name.startsWith("consent_")||await R.handler({});for(let r of y){let m=r.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]===void 0&&(f[m]=null)}for(let r of b){let m=r.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());f[m]!=null&&typeof f[m]=="string"&&(f[m]=Number(f[m]))}for(let r of _){let m=r.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 --${r}`),process.exit(1)}}let i=re(f,u);try{let r=await n.handler(i);D(r)}catch(r){console.error(r instanceof Error?r.message:String(r)),process.exit(1)}})}}function se(e){if(e.$ref&&e.definitions){let t=e.$ref.replace("#/definitions/","");return e.definitions[t]}return e}function ie(e){return Array.isArray(e.type)?e.type.includes("null"):e.anyOf?e.anyOf.some(t=>t.type==="null"):!1}function ae(e){return Array.isArray(e.type)?e.type.includes("object"):e.anyOf?e.anyOf.some(t=>t.type==="object"):e.type==="object"}function ce(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"}async function le(e){let t=e.wallet,n=e.chain;if(typeof t!="string"||typeof n!="string")return;let o=v(t);if(!o)return;let s;try{s=(await C.chain.retrieve({chain:n})).keyFamily}catch{return}let a=o.addresses[s];a&&(e.wallet=a)}var M=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 fe(e,t){for(let n of t){if(M.has(n.name))continue;let o=n.name.split("_"),s=o.pop(),a=I(e,o);if(a.commands.find(i=>i.name()===s))continue;let c=a.command(s).description(n.description),l=se(n.inputSchema),u=l.properties??{},y=new Set(l.required??[]),b=[],_=[],f=[];for(let[i,r]of Object.entries(u)){let m=r.description??i,g=ie(r),d=ae(r);ce(r)&&_.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 R.handler({});for(let r of b)i[r]===void 0&&(i[r]=null);for(let r of _)i[r]!=null&&typeof i[r]=="string"&&(i[r]=Number(i[r]));for(let r of f)if(typeof i[r]=="string")try{i[r]=JSON.parse(i[r])}catch{console.error(`Invalid JSON for --${r}`),process.exit(1)}try{await le(i);let r=await C._call(n.name,i);D(r),L()}catch(r){console.error(r instanceof Error?r.message:String(r)),process.exit(1)}})}}oe(h,O);fe(h,j);h.command("tools").description("List available tools").action(()=>{let e=[...O.map(n=>({name:n.schema.name,description:n.schema.description})),...j.filter(n=>!O.some(o=>o.schema.name===n.name)&&!M.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
+ `)),L()});h.parse();
@@ -0,0 +1,12 @@
1
+ process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
2
+ import{a as S}from"./chunk-LMDE72OE.js";var b=`Ledger support requires additional packages.
3
+ Run: npm i -g @moonpay/cli --include=optional`;function y(){try{let e=S("@ledgerhq/device-management-kit"),n=S("@ledgerhq/device-transport-kit-node-hid"),i=S("rxjs");return{...e,...n,...i}}catch{throw new Error(b)}}function I(){try{return S("@ledgerhq/device-signer-kit-ethereum")}catch{throw new Error(b)}}function L(){try{return S("@ledgerhq/device-signer-kit-solana")}catch{throw new Error(b)}}var h=null,p=null;function f(){if(!h){let e=y();h=new e.DeviceManagementKitBuilder().addTransport(e.nodeHidTransportFactory).build()}return h}function E(){if(!p)throw new Error("No Ledger device connected. Connect first.");return p}var O={"unlock-device":"ACTION REQUIRED: Unlock your Ledger device by entering your PIN","confirm-open-app":"ACTION REQUIRED: Confirm opening the app on your Ledger device screen","sign-transaction":"ACTION REQUIRED: Review and approve the transaction on your Ledger device screen","sign-personal-message":"ACTION REQUIRED: Review and approve the message on your Ledger device screen","verify-address":"ACTION REQUIRED: Verify the address shown on your Ledger device screen"};async function m(e,n,i=6e4){let{DeviceActionStatus:s}=y();return new Promise((t,a)=>{let u="",c=!1,d=o=>{c||(c=!0,clearTimeout(l),w.unsubscribe(),o())},l=setTimeout(()=>{d(()=>{e.cancel(),a(new Error(`${n} timed out after ${i/1e3}s. Make sure the correct app is open on your Ledger and try again.`))})},i),w=e.observable.subscribe({next:o=>{switch(o.status){case s.Pending:{let r=o.intermediateValue?.requiredUserInteraction??"";if(r&&r!=="none"&&r!==u){u=r;let g=O[r]??r;g&&process.stderr.write(` ${g}
4
+ `)}break}case s.Completed:d(()=>t(o.output));break;case s.Error:d(()=>{let r=o.error,g=r instanceof Error?r.message:r&&typeof r=="object"?r._tag??r.message??JSON.stringify(r):String(r);a(new Error(`${n} failed: ${g}`))});break;case s.Stopped:d(()=>a(new Error(`${n} was cancelled`)));break}},error:o=>d(()=>a(o))})})}async function P(){let e=y(),n=f().startDiscovering({});process.stderr.write(`Scanning for Ledger devices via USB...
5
+ `);let i=await e.firstValueFrom(n.pipe(e.take(1),e.timeout(3e4))).finally(()=>{f().stopDiscovering()}),s=i.deviceModel.model??i.deviceModel.id;process.stderr.write(`Connecting to Ledger ${s}...
6
+ `);let t=f();p=await t.connect({device:i});let a=t.getDeviceSessionState({sessionId:p});return await e.firstValueFrom(a.pipe(e.filter(u=>u.sessionStateType>=1),e.take(1),e.timeout(1e4))),process.stderr.write(`Connected to Ledger ${s}
7
+ `),p}async function U(){if(!p)return null;try{let e=y(),i=f().getDeviceSessionState({sessionId:p}),s=await e.firstValueFrom(i.pipe(e.take(1),e.timeout(3e3)));return s.sessionStateType>=1?s.currentApp?.name??null:null}catch{return null}}var M={evm:"Ethereum",solana:"Solana"};function _(e){let n=String(e);return n.includes("6807")||n.includes("6a15")||n.includes("UnknownDeviceExchangeError")}async function C(e){process.stderr.write(`Installing ${e} app on your Ledger...
8
+ `);let{OpenAppWithDependenciesDeviceAction:n}=y(),i=new n({input:{appName:e}}),t=f().executeDeviceAction({sessionId:E(),deviceAction:i});await m(t,`Install ${e}`,18e4),process.stderr.write(`Installed ${e} app
9
+ `)}async function R(e){let n=M[e];if(!n||await U()===n)return;process.stderr.write(`Opening ${n} app on your Ledger...
10
+ `);let{OpenAppDeviceAction:s}=y(),t=new s({input:{appName:n}}),u=f().executeDeviceAction({sessionId:E(),deviceAction:t});try{await m(u,`Open ${n}`)}catch(c){if(_(c)){await D(),await C(n),await D();return}if(!String(c).includes("isconnect"))throw c}await D()}async function D(){try{await f().disconnect({sessionId:p})}catch{}p=null,await new Promise(e=>setTimeout(e,500)),await P()}function $(e,n=0){switch(e){case"evm":return`44'/60'/${n}'/0/0`;case"solana":return`44'/501'/${n}'/0'`;default:throw new Error(`${e} derivation via Ledger is not supported.`)}}function k(e){return e.startsWith("0x")?e.slice(2):e}function T(e){return e.startsWith("0x")?e:`0x${e}`}async function x(e){let{moonpay:n}=await import("./client-FQ3KSDK6.js"),s=(await n.chain.retrieve({chain:e})).keyFamily;if(s==="bitcoin")throw new Error("Bitcoin address derivation via Ledger is not yet supported.");if(s==="tron")throw new Error("Tron address derivation via Ledger is not supported. The Ethereum signer cannot interact with the Tron Ledger app.");await R(s);let t=$(s),a=E(),u=f();switch(s){case"evm":{let{SignerEthBuilder:c}=I(),l=new c({dmk:u,sessionId:a}).build().getAddress(t,{skipOpenApp:!1});return(await m(l,"Get Ethereum address")).address}case"solana":{let{SignerSolanaBuilder:c}=L(),l=new c({dmk:u,sessionId:a}).build().getAddress(t,{skipOpenApp:!1});return await m(l,"Get Solana address")}default:throw new Error(`Ledger address derivation not supported for ${s}`)}}async function F(){let e={};try{e.ethereum=await x("ethereum")}catch(n){process.stderr.write(`Failed to get Ethereum address: ${n}
11
+ `)}try{e.solana=await x("solana")}catch(n){process.stderr.write(`Failed to get Solana address: ${n}
12
+ `)}if(!e.ethereum&&!e.solana)throw new Error("Could not derive any addresses from Ledger device");return e}async function H(e,n){let{moonpay:i}=await import("./client-FQ3KSDK6.js"),t=(await i.chain.retrieve({chain:e})).keyFamily;if(t==="bitcoin")throw new Error("Bitcoin transaction signing via Ledger is not yet supported. Use a software wallet for Bitcoin transactions.");if(t==="tron")throw new Error("Tron transaction signing via Ledger is not supported. Use a software wallet for Tron transactions.");await R(t);let a=$(t),u=E(),c=f();switch(t){case"evm":{let{SignerEthBuilder:d}=I(),l=new d({dmk:c,sessionId:u}).build(),w=T(n.startsWith("0x")?n:Buffer.from(n,"base64").toString("hex")),o=Uint8Array.from(Buffer.from(k(w),"hex")),r=l.signTransaction(a,o,{skipOpenApp:!1}),g=await m(r,"Sign transaction"),{parseTransaction:v,serializeTransaction:A}=await import("viem"),B=v(w);return{transaction:A(B,{r:T(k(g.r)),s:T(k(g.s)),v:BigInt(g.v)})}}case"solana":{let{SignerSolanaBuilder:d}=L(),l=new d({dmk:c,sessionId:u}).build(),{VersionedTransaction:w}=await import("@solana/web3.js"),o=Uint8Array.from(Buffer.from(n,"base64")),r=w.deserialize(o),g=r.message.serialize(),v=l.signTransaction(a,g,{skipOpenApp:!1}),A=await m(v,"Sign Solana transaction");return r.signatures[0]=A,{transaction:Buffer.from(r.serialize()).toString("base64")}}default:throw new Error(`Ledger transaction signing not supported for ${t}`)}}async function V(e,n){let{moonpay:i}=await import("./client-FQ3KSDK6.js"),t=(await i.chain.retrieve({chain:e})).keyFamily;if(t==="bitcoin")throw new Error("Bitcoin message signing via Ledger is not yet supported. Use a software wallet for Bitcoin message signing.");if(t==="tron")throw new Error("Tron message signing via Ledger is not supported. Use a software wallet for Tron message signing.");await R(t);let a=$(t),u=E(),c=f();switch(t){case"evm":{let{SignerEthBuilder:d}=I(),w=new d({dmk:c,sessionId:u}).build().signMessage(a,n,{skipOpenApp:!1}),o=await m(w,"Sign message"),r=k(o.r),g=k(o.s),v=o.v.toString(16).padStart(2,"0");return{signature:`0x${r}${g}${v}`}}case"solana":{let{SignerSolanaBuilder:d}=L(),l=new d({dmk:c,sessionId:u}).build(),w=Buffer.from(n,"utf8").toString("hex"),o=l.signMessage(a,w,{skipOpenApp:!1}),r=await m(o,"Sign Solana message");return{signature:(await import("bs58")).default.encode(r)}}default:throw new Error(`Ledger message signing not supported for ${t}`)}}async function q(){if(p){try{await f().disconnect({sessionId:p})}catch{}p=null}if(h){try{h.close()}catch{}h=null}}export{P as connectLedger,q as disconnectLedger,x as ledgerGetAddress,F as ledgerGetAllAddresses,V as ledgerSignMessage,H as ledgerSignTransaction};
@@ -0,0 +1,2 @@
1
+ process.noDeprecation = true; import { createRequire as __createRequire } from "module"; const require = __createRequire(import.meta.url);
2
+ import{a as f,d as u}from"./chunk-DSMS3WZQ.js";import{b as d}from"./chunk-6YOIZGHC.js";import"./chunk-NNUDE3AO.js";import{e as l,g as R}from"./chunk-WKRUTTKX.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 n,B as o,C as p,D as q,E as r,F as s,G as t,H as u,I as v,J as w,n as a,o as b,p as c,q as d,r as e,s as f,t as g,u as h,v as i,w as j,x as k,y as l,z as m}from"./chunk-YJWSYQVX.js";import"./chunk-TPAYGT4L.js";import"./chunk-LMDE72OE.js";export{m as addHardwareWallet,u 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,s as loadWallets,c as migrateWallets,w as mutateWallets,p as owsSignMessage,o as owsSignTransaction,q as owsSignTypedData,n as refreshHardwareAddresses,t as removeWallet,k as renameWallet,b as requireMigrationCheck,r as resolveSigningKey,v as saveWallets};
2
+ import{A as v,B as w,f as a,g as b,h as c,i as d,j as e,k as f,l as g,m as h,n as i,o as j,p as k,q as l,r as m,s as n,t as o,u as p,v as q,w as r,x as s,y as t,z as u}from"./chunk-NNUDE3AO.js";import"./chunk-WKRUTTKX.js";import"./chunk-LMDE72OE.js";export{m as addHardwareWallet,u 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,s as loadWallets,c as migrateWallets,w as mutateWallets,p as owsSignMessage,o as owsSignTransaction,q as owsSignTypedData,n as refreshHardwareAddresses,t as removeWallet,k as renameWallet,b as requireMigrationCheck,r as resolveSigningKey,v as saveWallets};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@moonpay/cli",
3
- "version": "1.16.2",
3
+ "version": "1.18.0",
4
4
  "description": "MoonPay CLI — how agents move money",
5
5
  "homepage": "https://agents.moonpay.com",
6
6
  "publishConfig": {