@moonpay/cli 0.9.3 → 0.10.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-2KI3H3A7.js → chunk-6BZGX2LH.js} +1 -1
- package/dist/chunk-QWDPWCRM.js +33 -0
- package/dist/index.js +6 -6
- package/dist/{mcp-YZE6ZZRA.js → mcp-QTYN7WQA.js} +1 -1
- package/dist/{store-TCMIGPOP.js → store-V4WUIEXL.js} +1 -1
- package/package.json +1 -1
- package/skills/moonpay-commerce/SKILL.md +100 -0
- package/dist/chunk-HH5BMFIU.js +0 -30
package/dist/index.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
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 R,b as S,c as T,d as j,e as k}from"./chunk-
|
|
4
|
-
`):e.map(r=>{if(typeof r!="object"||r===null)return`${n}- ${
|
|
3
|
+
import{a as R,b as S,c as T,d as j,e as k}from"./chunk-QWDPWCRM.js";import{a as C,h as A,n as v,u as J}from"./chunk-6BZGX2LH.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 O(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 O(e)?`${n}${_(e)}`:Array.isArray(e)?e.length===0?`${n}${p.dim("(empty)")}`:e.every(O)?e.map(r=>`${n}- ${_(r)}`).join(`
|
|
4
|
+
`):e.map(r=>{if(typeof r!="object"||r===null)return`${n}- ${_(r)}`;let o=Object.entries(r),a=[],[c,f]=o[0];O(f)?a.push(`${n}- ${p.bold(c)}: ${_(f)}`):(a.push(`${n}- ${p.bold(c)}:`),a.push(N(f,t+2)));for(let[m,y]of o.slice(1))O(y)?a.push(`${n} ${p.bold(m)}: ${_(y)}`):(a.push(`${n} ${p.bold(m)}:`),a.push(N(y,t+2)));return a.join(`
|
|
5
5
|
`)}).join(`
|
|
6
6
|
|
|
7
|
-
`):typeof e=="object"&&e!==null?Object.entries(e).map(([o,a])=>
|
|
8
|
-
${
|
|
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 F(e,t){return t==="json"?JSON.stringify(e,null,2):
|
|
7
|
+
`):typeof e=="object"&&e!==null?Object.entries(e).map(([o,a])=>O(a)?`${n}${p.bold(o)}: ${_(a)}`:`${n}${p.bold(o)}:
|
|
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 F(e,t){return t==="json"?JSON.stringify(e,null,2):N(H(e))}import{readFileSync as z,writeFileSync as W,mkdirSync as B}from"fs";import{join as E}from"path";import{homedir as G}from"os";var x=E(G(),".config","moonpay"),I=E(x,"update-check.json"),V=1440*60*1e3,Q=3e3;function X(){try{let e=z(I,"utf-8");return JSON.parse(e)}catch{return null}}function ee(e){try{B(x,{recursive:!0}),W(I,JSON.stringify(e))}catch{}}function K(e,t){let n=e.split(".").map(Number),r=t.split(".").map(Number);for(let o=0;o<3;o++){if((n[o]??0)>(r[o]??0))return!0;if((n[o]??0)<(r[o]??0))return!1}return!1}function P(e,t){return["",p.yellow(`Update available: ${e} \u2192 ${t}`),p.dim("Run `npm i -g @moonpay/cli` to update."),""].join(`
|
|
10
10
|
`)}function L(e){let t=null,n=X();if(n&&Date.now()-n.checkedAt<V)return K(n.latest,e)&&(t=P(e,n.latest)),()=>t;let r=new AbortController,o=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()}),K(c,e)&&(t=P(e,c)))}).catch(()=>{}).finally(()=>clearTimeout(o)),()=>t}var te=L(C),h=new ne;h.name("moonpay").description(`MoonPay CLI \u2014 the crypto onramp for AI agents
|
|
11
11
|
|
|
12
12
|
Your agents need money. MoonPay gives them wallets, funds, and tools
|
|
@@ -14,5 +14,5 @@ ${_(a,t+1)}`).join(`
|
|
|
14
14
|
|
|
15
15
|
Run \`mp skill install\` to install AI skills for Claude Code.
|
|
16
16
|
|
|
17
|
-
`+T).version(C).option("--json","Output as JSON instead of YAML");function re(){return h.opts().json?"json":"yaml"}function D(e){console.log(F(e,re()))}function U(){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-
|
|
17
|
+
`+T).version(C).option("--json","Output as JSON instead of YAML");function re(){return h.opts().json?"json":"yaml"}function D(e){console.log(F(e,re()))}function U(){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-QTYN7WQA.js");await e()});function M(e,t){let n=e;for(let r of t){let o=n.commands.find(a=>a.name()===r);o||(o=n.command(r)),n=o}return n}function Z(e,t=""){let n=[];for(let[r,o]of Object.entries(e)){let a=t?`${t}-${r}`:r,c=o;for(;c._def.typeName==="ZodEffects";)c=c._def.schema;let f=c;f._def.typeName==="ZodNullable"&&(f=f._def.innerType),f._def.typeName==="ZodObject"&&f.shape?n.push(...Z(f.shape,a)):n.push({flatKey:a,field:o,path:a.split("-")})}return n}function oe(e,t){let n={};for(let{flatKey:r,path:o}of t){let a=r.replace(/-([a-z])/g,(f,m)=>m.toUpperCase()),c=a in e?e[a]:e[r];if(o.length===1)n[o[0]]=c;else{let f=n;for(let m=0;m<o.length-1;m++)(!f[o[m]]||typeof f[o[m]]!="object")&&(f[o[m]]={}),f=f[o[m]];f[o[o.length-1]]=c}}return n}function se(e,t){for(let n of t){let r=n.schema.name.split("_"),o=r.pop(),c=M(e,r).command(o).description(n.schema.description),f=n.schema.input.shape??{},m=Z(f),y=[],b=[],w=[];for(let{flatKey:u,field:i}of m){let s=i.description??u,l=i;for(;l._def.typeName==="ZodEffects";)l=l._def.schema;let g=l._def.typeName,d=l;d._def.typeName==="ZodNullable"&&(d=d._def.innerType),d._def.typeName==="ZodNumber"&&b.push(u),d._def.typeName==="ZodRecord"&&w.push(u),g==="ZodBoolean"?c.option(`--${u}`,s,!1):g==="ZodNullable"?(c.option(`--${u} <${u}>`,s),y.push(u)):c.requiredOption(`--${u} <${u}>`,s)}c.action(async u=>{n.schema.name.startsWith("consent_")||await j.handler({});for(let s of y){let l=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());u[l]===void 0&&(u[l]=null)}for(let s of b){let l=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());u[l]!=null&&typeof u[l]=="string"&&(u[l]=Number(u[l]))}for(let s of w){let l=s.replace(/-([a-z])/g,(g,d)=>d.toUpperCase());if(typeof u[l]=="string")try{u[l]=JSON.parse(u[l])}catch{console.error(`Invalid JSON for --${s}`),process.exit(1)}}let i=oe(u,m);try{let s=await n.handler(i);D(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 r=J(t);if(!r)return;let o=v[n];if(!o)return;let a=r.addresses[o];a&&(e.wallet=a)}var q=new Set(["swaps_transaction_build","token_transfer","transaction_register","virtual-account_offramp_initiate","prediction-market_position_buy","prediction-market_position_sell","commerce_cart_update","commerce_checkout_start","commerce_checkout_pay"]);function ue(e,t){for(let n of t){if(q.has(n.name))continue;let r=n.name.split("_"),o=r.pop(),a=M(e,r);if(a.commands.find(i=>i.name()===o))continue;let c=a.command(o).description(n.description),f=ie(n.inputSchema),m=f.properties??{},y=new Set(f.required??[]),b=[],w=[],u=[];for(let[i,s]of Object.entries(m)){let l=s.description??i,g=ae(s),d=ce(s);le(s)&&w.push(i),d?(u.push(i),y.has(i)&&!g?c.requiredOption(`--${i} <json>`,`${l} (as JSON)`):(c.option(`--${i} <json>`,`${l} (as JSON)`),b.push(i))):g||!y.has(i)?(c.option(`--${i} <${i}>`,l),b.push(i)):c.requiredOption(`--${i} <${i}>`,l)}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 u)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=A(),l=await R(s,n.name,i);D(l),U()}catch(s){console.error(s.message),process.exit(1)}})}}se(h,k);ue(h,S);h.command("tools").description("List available tools").action(()=>{let e=[...k.map(n=>({name:n.schema.name,description:n.schema.description})),...S.filter(n=>!k.some(r=>r.schema.name===n.name)&&!q.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
18
|
`)),U()});h.parse();
|
|
@@ -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 d,b as y,e as l}from"./chunk-
|
|
2
|
+
import{a as d,b as y,e as l}from"./chunk-QWDPWCRM.js";import{a as u,h as f}from"./chunk-6BZGX2LH.js";import{Server as x}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as N}from"@modelcontextprotocol/sdk/server/stdio.js";import{CallToolRequestSchema as T,ListToolsRequestSchema as v}from"@modelcontextprotocol/sdk/types.js";import{zodToJsonSchema as q}from"zod-to-json-schema";var h=new Map(l.map(s=>[s.schema.name,s]));function A(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 J(){let s=new x({name:"moonpay",version:u},{capabilities:{tools:{listChanged:!0}}}),n=l.map(e=>({name:e.schema.name,description:e.schema.description,inputSchema:q(e.schema.input)})),c=new Map;for(let e of y){if(h.has(e.name))continue;let t=A(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 g=new Map(n.map(e=>[e.name,e]));s.setRequestHandler(v,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(!g.has(t))return{content:[{type:"text",text:`Unknown tool: ${t}`}],isError:!0};try{let i=h.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 b=c.get(t)??{};for(let[p,r]of Object.entries(b))o[p]===void 0&&(Array.isArray(r.type)?r.type.includes("null"):r.anyOf?.some(R=>R.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 w=f(),O=await d(w,t,o);return{content:[{type:"text",text:JSON.stringify(O,null,2)}]}}catch(i){return{content:[{type:"text",text:i instanceof Error?i.message:String(i)}],isError:!0}}});let S=new N;await s.connect(S)}export{J 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{r as a,s as b,t as c,u as d,v as e,w as f,x as g,y as h}from"./chunk-
|
|
2
|
+
import{r as a,s as b,t as c,u as d,v as e,w as f,x as g,y as h}from"./chunk-6BZGX2LH.js";export{f as addWallet,d as findWallet,e as findWalletOrThrow,a as loadWallets,c as mutateWallets,g as removeWallet,h as resolveSigningKey,b as saveWallets};
|
package/package.json
CHANGED
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moonpay-commerce
|
|
3
|
+
description: Browse Shopify stores, search products, manage a cart, and checkout with crypto via Solana Pay. No login required.
|
|
4
|
+
tags: [commerce, shopping]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Shop with crypto
|
|
8
|
+
|
|
9
|
+
## Goal
|
|
10
|
+
|
|
11
|
+
Browse Solana Pay-enabled Shopify stores, add items to a cart, and pay with crypto. The entire flow runs from the CLI — no browser needed.
|
|
12
|
+
|
|
13
|
+
## Commands
|
|
14
|
+
|
|
15
|
+
### List stores
|
|
16
|
+
|
|
17
|
+
```bash
|
|
18
|
+
mp commerce store list
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
### Search products
|
|
22
|
+
|
|
23
|
+
```bash
|
|
24
|
+
mp commerce product search --store <store> --query <search-term>
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
### Get product details
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
mp commerce product retrieve --store <store> --productId <product-id>
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### Add item to cart
|
|
34
|
+
|
|
35
|
+
```bash
|
|
36
|
+
mp commerce cart add \
|
|
37
|
+
--store <store> \
|
|
38
|
+
--variantId <variant-id> \
|
|
39
|
+
--quantity <number> \
|
|
40
|
+
--cartId <cart-id> # omit to create a new cart
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
### View cart
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
mp commerce cart retrieve --store <store> --cartId <cart-id>
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
### Remove item from cart
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
mp commerce cart remove --store <store> --cartId <cart-id> --lineId <line-id>
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
### Checkout and pay
|
|
56
|
+
|
|
57
|
+
```bash
|
|
58
|
+
mp commerce checkout \
|
|
59
|
+
--wallet <wallet-name> \
|
|
60
|
+
--store <store> \
|
|
61
|
+
--cartId <cart-id> \
|
|
62
|
+
--chain solana \
|
|
63
|
+
--email <buyer-email> \
|
|
64
|
+
--firstName <first> \
|
|
65
|
+
--lastName <last> \
|
|
66
|
+
--address <street-address> \
|
|
67
|
+
--city <city> \
|
|
68
|
+
--postalCode <zip> \
|
|
69
|
+
--country <country-name>
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
## Example flow
|
|
73
|
+
|
|
74
|
+
1. Browse stores: `mp commerce store list`
|
|
75
|
+
2. Search: `mp commerce product search --store ryder.id --query "ryder"`
|
|
76
|
+
3. Add to cart: `mp commerce cart add --store ryder.id --variantId "gid://shopify/ProductVariant/51751218774319" --quantity 1`
|
|
77
|
+
4. Check cart: `mp commerce cart retrieve --store ryder.id --cartId <id-from-step-3>`
|
|
78
|
+
5. Checkout: `mp commerce checkout --wallet main --store ryder.id --cartId <id> --chain solana --email buyer@example.com --firstName John --lastName Doe --address "123 Main St" --city Amsterdam --postalCode 1011 --country Netherlands`
|
|
79
|
+
|
|
80
|
+
## How it works
|
|
81
|
+
|
|
82
|
+
1. Stores expose a Shopify MCP endpoint for browsing and cart management
|
|
83
|
+
2. `cart add` creates or updates a cart (no auth needed, cart ID is the handle)
|
|
84
|
+
3. `checkout` calls the API to start a Helio payment, signs the transaction locally, and submits
|
|
85
|
+
4. Helio pays gas — the buyer only pays the item price in USDC
|
|
86
|
+
5. Returns a transaction signature and order confirmation URL
|
|
87
|
+
|
|
88
|
+
## Tips
|
|
89
|
+
|
|
90
|
+
- Run `cart add` multiple times to add different items — pass the `--cartId` from the first call
|
|
91
|
+
- Use `product search` to find variant IDs — each variant has a Shopify GID
|
|
92
|
+
- The `--country` flag takes full country names (e.g. "United States", "Netherlands")
|
|
93
|
+
- Checkout takes 30-90 seconds — the API automates the Shopify checkout flow
|
|
94
|
+
- Currently supports Solana chain only for payment
|
|
95
|
+
|
|
96
|
+
## Related skills
|
|
97
|
+
|
|
98
|
+
- **moonpay-auth** — Set up a local wallet for signing
|
|
99
|
+
- **moonpay-check-wallet** — Check USDC balance before checkout
|
|
100
|
+
- **moonpay-swap-tokens** — Swap tokens to get USDC for payment
|