@visa/cli 1.8.0-rc.3 → 1.8.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/cli.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var dr=Object.create;var Nt=Object.defineProperty;var fr=Object.getOwnPropertyDescriptor;var pr=Object.getOwnPropertyNames;var gr=Object.getPrototypeOf,mr=Object.prototype.hasOwnProperty;var hr=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var yr=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of pr(t))!mr.call(e,s)&&s!==n&&Nt(e,s,{get:()=>t[s],enumerable:!(r=fr(t,s))||r.enumerable});return e};var g=(e,t,n)=>(n=e!=null?dr(gr(e)):{},yr(t||!e||!e.__esModule?Nt(n,"default",{value:e,enumerable:!0}):n,e));var nt=hr((qs,Pr)=>{Pr.exports={name:"@visa/cli",version:"1.8.0-rc.3",description:"AI-powered payments for Claude Code",bin:{"visa-cli":"./bin/visa-cli.js"},scripts:{build:"tsc --noEmit && node esbuild.config.js",dev:"tsc --watch",start:"node dist/mcp-server/index.js",test:"jest --config jest.config.js","test:unit":"jest --config jest.config.js","test:unit:watch":"jest --config jest.config.js --watch","test:unit:coverage":"jest --config jest.config.js --coverage","test:smoke":"VISA_AUTH_URL=https://auth.visacli.sh jest --config jest.smoke.config.js","test:integration":"jest --config jest.integration.config.js","test:e2e":"jest --config jest.e2e.config.js","test:catalog-e2e":"jest --config jest.catalog-e2e.config.js","test:all":"npm run test:unit && npm run test:integration && npm run test:e2e",prepublishOnly:"npm run build && npm test",lint:"eslint src/**/*.ts",format:'prettier --write "src/**/*.ts"',"format:check":'prettier --check "src/**/*.ts"'},keywords:["visa","checkout","mcp","ai-agent","payments","click-to-pay","usdc","stablecoin"],author:"Visa Crypto Labs",license:"SEE LICENSE IN LICENSE",dependencies:{"@modelcontextprotocol/sdk":"^1.0.0",commander:"^12.1.0",zod:"^3.23.0"},devDependencies:{"@visa-cli/tools":"workspace:*","@changesets/changelog-git":"^0.2.1","@changesets/cli":"^2.31.0","@types/jest":"^30.0.0","@types/node":"^25.6.0","@typescript-eslint/eslint-plugin":"^8.59.0","@typescript-eslint/parser":"^8.59.0","@types/express":"^5.0.0",esbuild:"^0.27.4",express:"^4.21.0",eslint:"^10.0.2","eslint-config-prettier":"^10.1.8",jest:"^29.7.0",prettier:"^3.8.3","ts-jest":"^29.2.0",typescript:"^5.7.0"},engines:{node:">=18.0.0"},mcpName:"io.github.visa-crypto-labs/visa-cli",files:["bin/visa-cli.js","dist/","install.ps1","native/visa-keychain.m","server.json","README.md","LICENSE"]}});var nr=require("commander"),ze=g(require("crypto")),rr=g(require("fs")),j=g(require("os")),we=g(require("path")),sr=g(require("readline")),or=require("child_process"),ir=require("util");var ke=require("child_process"),Dt=require("util"),z=g(require("fs")),$e=g(require("os")),Qe=g(require("path")),K=(0,Dt.promisify)(ke.execFile),et=Qe.join($e.homedir(),".visa-mcp"),_e=Qe.join(et,"session-token"),U="visa-cli",J="session-token",Ce="rc-access",Sr=5e3;async function vr(){try{let{stdout:e}=await K("security",["find-generic-password","-s",U,"-a",J,"-w"],{timeout:5e3});return e.trim()||null}catch{return null}}async function br(e){try{try{await K("security",["delete-generic-password","-s",U,"-a",J],{timeout:5e3})}catch{}return await K("security",["add-generic-password","-s",U,"-a",J,"-w",e],{timeout:5e3}),!0}catch{return!1}}async function wr(){try{await K("security",["delete-generic-password","-s",U,"-a",J],{timeout:5e3})}catch{}}async function _r(){if(!tt())return null;try{let{stdout:e}=await K("secret-tool",["lookup","service",U,"account",J],{timeout:5e3});return e.trim()||null}catch{return null}}async function Cr(e){if(!tt())return!1;try{let t=(0,ke.execFile)("secret-tool",["store","--label",`${U} ${J}`,"service",U,"account",J]);return t.stdin?(t.stdin.write(e),t.stdin.end(),await Promise.race([new Promise((n,r)=>{t.on("exit",s=>s===0?n():r(new Error(`secret-tool exited ${s}`))),t.on("error",r)}),new Promise((n,r)=>setTimeout(()=>{t.kill(),r(new Error("secret-tool timed out"))},Sr))]),!0):!1}catch{return!1}}async function kr(){if(tt())try{await K("secret-tool",["clear","service",U,"account",J],{timeout:5e3})}catch{}}function tt(){return!!process.env.DBUS_SESSION_BUS_ADDRESS}async function $r(){try{let{stdout:e}=await K("security",["find-generic-password","-s",U,"-a",Ce,"-w"],{timeout:5e3});return e.trim()||null}catch{return null}}async function Er(e){try{try{await K("security",["delete-generic-password","-s",U,"-a",Ce],{timeout:5e3})}catch{}await K("security",["add-generic-password","-s",U,"-a",Ce,"-w",e],{timeout:5e3})}catch{}}async function xr(){try{await K("security",["delete-generic-password","-s",U,"-a",Ce],{timeout:5e3})}catch{}}function Xe(){try{return z.readFileSync(_e,"utf-8").trim()||null}catch{return null}}function Ut(e){z.mkdirSync(et,{recursive:!0,mode:448}),z.writeFileSync(_e,e,{mode:384}),process.platform==="win32"&&Rr(_e)}function Ze(){try{z.unlinkSync(_e)}catch{}}function Rr(e){try{let t=$e.userInfo().username;(0,ke.execFile)("icacls",[e,"/inheritance:r","/grant:r",`${t}:F`],{timeout:5e3},n=>{n&&console.error(`[visa-cli] icacls ACL restriction failed: ${n.message}`)})}catch(t){console.error(`[visa-cli] Failed to invoke icacls: ${t instanceof Error?t.message:String(t)}`)}}function Ye(){switch(process.platform){case"darwin":return{get:vr,store:br,delete:wr};case"linux":return{get:_r,store:Cr,delete:kr};default:return{get:async()=>Xe(),store:async e=>{try{return Ut(e),!0}catch{return!1}},delete:async()=>Ze(),storesInSessionFile:!0}}}var k=class{static async getSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return Promise.resolve("mock-session-token-for-testing");let t=Ye(),n=await t.get();if(n)return n;let r=Xe();return r?(await t.store(r),r):null}static async saveSessionToken(t){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;let n=Ye();if(await n.store(t)){if(await n.get()===t){n.storesInSessionFile||Ze();return}await n.delete()}if(Ut(t),Xe()!==t)throw new Error("Failed to persist session token. "+(process.platform==="darwin"?'Check Keychain Access permissions for "visa-cli".':`Ensure ${et} is writable.`))}static async getRcAccessToken(){return process.env.VISA_MOCK_KEYCHAIN==="true"?"mock-rc-token-for-testing":$r()}static async saveRcAccessToken(t){process.env.VISA_MOCK_KEYCHAIN!=="true"&&await Er(t)}static async deleteSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;await Ye().delete(),Ze()}static async clearAll(){await this.deleteSessionToken(),await xr()}};var Ee=g(require("crypto")),xe=g(require("tty")),Re=g(require("fs"));var Q="6820f6e91b762e645c9bf020c0d3673bb99d4a25a824880c0d548e10bb9bc7b1";function Tr(e){return/-rc\.|-beta\./.test(e)}function rt(e){return Ee.createHash("sha256").update(e.trim()).digest("hex")}function Mt(e){return Q==="SKIP"?!0:Ee.timingSafeEqual(Buffer.from(rt(e)),Buffer.from(Q))}function Ar(e){return new Promise((t,n)=>{let r=Re.openSync("/dev/tty","r+"),s=new xe.ReadStream(r),o=new xe.WriteStream(r),i=()=>{try{s.destroy()}catch{}try{o.destroy()}catch{}try{Re.closeSync(r)}catch{}};o.write(e),s.setRawMode(!0),s.resume(),s.setEncoding("utf8");let a="";s.on("data",c=>{c==="\r"||c===`
1
+ "use strict";var dr=Object.create;var Nt=Object.defineProperty;var fr=Object.getOwnPropertyDescriptor;var pr=Object.getOwnPropertyNames;var gr=Object.getPrototypeOf,mr=Object.prototype.hasOwnProperty;var hr=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var yr=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of pr(t))!mr.call(e,s)&&s!==n&&Nt(e,s,{get:()=>t[s],enumerable:!(r=fr(t,s))||r.enumerable});return e};var g=(e,t,n)=>(n=e!=null?dr(gr(e)):{},yr(t||!e||!e.__esModule?Nt(n,"default",{value:e,enumerable:!0}):n,e));var nt=hr((qs,Pr)=>{Pr.exports={name:"@visa/cli",version:"1.8.0",description:"AI-powered payments for Claude Code",bin:{"visa-cli":"./bin/visa-cli.js"},scripts:{build:"tsc --noEmit && node esbuild.config.js",dev:"tsc --watch",start:"node dist/mcp-server/index.js",test:"jest --config jest.config.js","test:unit":"jest --config jest.config.js","test:unit:watch":"jest --config jest.config.js --watch","test:unit:coverage":"jest --config jest.config.js --coverage","test:smoke":"VISA_AUTH_URL=https://auth.visacli.sh jest --config jest.smoke.config.js","test:integration":"jest --config jest.integration.config.js","test:e2e":"jest --config jest.e2e.config.js","test:catalog-e2e":"jest --config jest.catalog-e2e.config.js","test:all":"npm run test:unit && npm run test:integration && npm run test:e2e",prepublishOnly:"npm run build && npm test",lint:"eslint src/**/*.ts",format:'prettier --write "src/**/*.ts"',"format:check":'prettier --check "src/**/*.ts"'},keywords:["visa","checkout","mcp","ai-agent","payments","click-to-pay","usdc","stablecoin"],author:"Visa Crypto Labs",license:"SEE LICENSE IN LICENSE",dependencies:{"@modelcontextprotocol/sdk":"^1.0.0",commander:"^12.1.0",zod:"^3.23.0"},devDependencies:{"@visa-cli/tools":"workspace:*","@changesets/changelog-git":"^0.2.1","@changesets/cli":"^2.31.0","@types/jest":"^30.0.0","@types/node":"^25.6.0","@typescript-eslint/eslint-plugin":"^8.59.0","@typescript-eslint/parser":"^8.59.0","@types/express":"^5.0.0",esbuild:"^0.27.4",express:"^4.21.0",eslint:"^10.0.2","eslint-config-prettier":"^10.1.8",jest:"^29.7.0",prettier:"^3.8.3","ts-jest":"^29.2.0",typescript:"^5.7.0"},engines:{node:">=18.0.0"},mcpName:"io.github.visa-crypto-labs/visa-cli",files:["bin/visa-cli.js","dist/","install.ps1","native/visa-keychain.m","server.json","README.md","LICENSE"]}});var nr=require("commander"),ze=g(require("crypto")),rr=g(require("fs")),j=g(require("os")),we=g(require("path")),sr=g(require("readline")),or=require("child_process"),ir=require("util");var ke=require("child_process"),Dt=require("util"),z=g(require("fs")),$e=g(require("os")),Qe=g(require("path")),K=(0,Dt.promisify)(ke.execFile),et=Qe.join($e.homedir(),".visa-mcp"),_e=Qe.join(et,"session-token"),U="visa-cli",J="session-token",Ce="rc-access",Sr=5e3;async function vr(){try{let{stdout:e}=await K("security",["find-generic-password","-s",U,"-a",J,"-w"],{timeout:5e3});return e.trim()||null}catch{return null}}async function br(e){try{try{await K("security",["delete-generic-password","-s",U,"-a",J],{timeout:5e3})}catch{}return await K("security",["add-generic-password","-s",U,"-a",J,"-w",e],{timeout:5e3}),!0}catch{return!1}}async function wr(){try{await K("security",["delete-generic-password","-s",U,"-a",J],{timeout:5e3})}catch{}}async function _r(){if(!tt())return null;try{let{stdout:e}=await K("secret-tool",["lookup","service",U,"account",J],{timeout:5e3});return e.trim()||null}catch{return null}}async function Cr(e){if(!tt())return!1;try{let t=(0,ke.execFile)("secret-tool",["store","--label",`${U} ${J}`,"service",U,"account",J]);return t.stdin?(t.stdin.write(e),t.stdin.end(),await Promise.race([new Promise((n,r)=>{t.on("exit",s=>s===0?n():r(new Error(`secret-tool exited ${s}`))),t.on("error",r)}),new Promise((n,r)=>setTimeout(()=>{t.kill(),r(new Error("secret-tool timed out"))},Sr))]),!0):!1}catch{return!1}}async function kr(){if(tt())try{await K("secret-tool",["clear","service",U,"account",J],{timeout:5e3})}catch{}}function tt(){return!!process.env.DBUS_SESSION_BUS_ADDRESS}async function $r(){try{let{stdout:e}=await K("security",["find-generic-password","-s",U,"-a",Ce,"-w"],{timeout:5e3});return e.trim()||null}catch{return null}}async function Er(e){try{try{await K("security",["delete-generic-password","-s",U,"-a",Ce],{timeout:5e3})}catch{}await K("security",["add-generic-password","-s",U,"-a",Ce,"-w",e],{timeout:5e3})}catch{}}async function xr(){try{await K("security",["delete-generic-password","-s",U,"-a",Ce],{timeout:5e3})}catch{}}function Xe(){try{return z.readFileSync(_e,"utf-8").trim()||null}catch{return null}}function Ut(e){z.mkdirSync(et,{recursive:!0,mode:448}),z.writeFileSync(_e,e,{mode:384}),process.platform==="win32"&&Rr(_e)}function Ze(){try{z.unlinkSync(_e)}catch{}}function Rr(e){try{let t=$e.userInfo().username;(0,ke.execFile)("icacls",[e,"/inheritance:r","/grant:r",`${t}:F`],{timeout:5e3},n=>{n&&console.error(`[visa-cli] icacls ACL restriction failed: ${n.message}`)})}catch(t){console.error(`[visa-cli] Failed to invoke icacls: ${t instanceof Error?t.message:String(t)}`)}}function Ye(){switch(process.platform){case"darwin":return{get:vr,store:br,delete:wr};case"linux":return{get:_r,store:Cr,delete:kr};default:return{get:async()=>Xe(),store:async e=>{try{return Ut(e),!0}catch{return!1}},delete:async()=>Ze(),storesInSessionFile:!0}}}var k=class{static async getSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return Promise.resolve("mock-session-token-for-testing");let t=Ye(),n=await t.get();if(n)return n;let r=Xe();return r?(await t.store(r),r):null}static async saveSessionToken(t){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;let n=Ye();if(await n.store(t)){if(await n.get()===t){n.storesInSessionFile||Ze();return}await n.delete()}if(Ut(t),Xe()!==t)throw new Error("Failed to persist session token. "+(process.platform==="darwin"?'Check Keychain Access permissions for "visa-cli".':`Ensure ${et} is writable.`))}static async getRcAccessToken(){return process.env.VISA_MOCK_KEYCHAIN==="true"?"mock-rc-token-for-testing":$r()}static async saveRcAccessToken(t){process.env.VISA_MOCK_KEYCHAIN!=="true"&&await Er(t)}static async deleteSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;await Ye().delete(),Ze()}static async clearAll(){await this.deleteSessionToken(),await xr()}};var Ee=g(require("crypto")),xe=g(require("tty")),Re=g(require("fs"));var Q="0000000000000000000000000000000000000000000000000000000000000000";function Tr(e){return/-rc\.|-beta\./.test(e)}function rt(e){return Ee.createHash("sha256").update(e.trim()).digest("hex")}function Mt(e){return Q==="SKIP"?!0:Ee.timingSafeEqual(Buffer.from(rt(e)),Buffer.from(Q))}function Ar(e){return new Promise((t,n)=>{let r=Re.openSync("/dev/tty","r+"),s=new xe.ReadStream(r),o=new xe.WriteStream(r),i=()=>{try{s.destroy()}catch{}try{o.destroy()}catch{}try{Re.closeSync(r)}catch{}};o.write(e),s.setRawMode(!0),s.resume(),s.setEncoding("utf8");let a="";s.on("data",c=>{c==="\r"||c===`
2
2
  `?(o.write(`
3
3
  `),i(),t(a)):c===""?(o.write(`
4
4
  `),i(),n(new Error("Cancelled"))):c==="\x7F"||c==="\b"?a.length>0&&(a=a.slice(0,-1),o.write("\b \b")):(a+=c,o.write("\u2022"))})})}var Ir=`
@@ -25,7 +25,7 @@ ${H}`}function Vr(e){if(typeof e!="number"||e<=0)return"";let n=(e>1e12?e:e*1e3)
25
25
  `);l>=0&&(a=a.slice(l+1))}}return a}catch{return null}finally{if(t!==void 0)try{G.closeSync(t)}catch{}}}function Kr(e){if(!e||typeof e!="object")return;let t=e,n=["file_path","path","notebook_path","pattern","command","url"];for(let r of n){let s=t[r];if(typeof s=="string"&&s.length>0){if(r.endsWith("_path")||r==="path"){let o=Y.basename(Y.dirname(s)),i=Y.basename(s);return o&&o!=="."&&o!=="/"?`${o}/${i}`:i}return s}}}function qr(e){let t=e.split(`
26
26
  `),n=[],r=new Set;for(let s=t.length-1;s>=0&&n.length<Jt*3;s-=1){let o=t[s].trim();if(!o)continue;let i;try{i=JSON.parse(o)}catch{continue}if(!i||typeof i!="object")continue;let c=i.message;if(!c||typeof c!="object")continue;let l=c.content;if(Array.isArray(l))for(let u of l){if(!u||typeof u!="object")continue;let f=u;if(f.type==="tool_result"&&typeof f.tool_use_id=="string")r.add(f.tool_use_id);else if(f.type==="tool_use"&&typeof f.name=="string"){let d=typeof f.id=="string"?f.id:"",m=d.length>0?!r.has(d):!1;n.push({name:f.name,target:Kr(f.input),running:m})}}}return n.reverse(),n.slice(Math.max(0,n.length-Jt))}function Wr(e){let t=[];for(let n of e){let r=t[t.length-1];r&&!r.running&&!n.running&&r.name===n.name&&r.target===void 0&&n.target===void 0?r.count+=1:t.push({...n,count:1})}return t}function Gr(e){let t=e.running?b("\u25D0",S.visaGold):b("\u2713",S.green),n=e.running?S.visaGold:S.visaBlueSoft,r=b(ee(e.name),n),s=e.target?ee(e.target):"",o=s?`${b(":",S.dim)} ${b(s,S.dim)}`:"",i=e.count>1?` ${b(`\xD7${e.count}`,S.dim)}`:"";return o?`${t} ${r}${o}${i}`:`${t} ${r}${i}`}function Jr(e){let t=` ${b("\u2502",S.dim)} `,n=zt(t),r=e.slice();for(;r.length>0;){let c=r.join(t);if(zt(c)<=ot)return c;r=r.slice(1)}if(e.length===0)return"";let s="\u2026",i=e[e.length-1].replace(/\u001B\[[0-?]*[ -/]*[@-~]/g,""),a=i.length>ot-n-1?i.slice(0,ot-n-1)+s:i;return`${b(s,S.dim)}${t}${a}`}async function zr(e){if(!e||typeof e!="string")return null;let t=Br(e);if(!t)return null;let n;try{n=qr(t)}catch{return null}if(n.length===0)return null;let s=Wr(n).map(Gr);return Jr(s)||null}async function en(e,t){let n=[e];if(t){let r=Hr(t);if(r&&n.push(r),t.transcript_path){let s=await zr(t.transcript_path);s&&n.push(s)}}return n.join(`
27
27
  `)}function ee(e){return e?e.replace(/\u001B\][^\u0007]*(?:\u0007|\u001B\\)/g,"").replace(/\u001B\[[0-?]*[ -/]*[@-~]/g,"").replace(/[\u0000-\u0008\u000B-\u001F\u007F-\u009F]/g,"").replace(/\s+/g," ").trim():""}function Yr(e){if(typeof e=="string")return ee(Y.basename(e));if(!e||typeof e!="object")return"";let t=typeof e.current_dir=="string"?e.current_dir:typeof e.path=="string"?e.path:"";return ee(t?Y.basename(t):e.name)}async function tn(e,t){let n=t?.timeoutMs??3e4,r=new AbortController,s=setTimeout(()=>r.abort(),n);try{let{timeoutMs:o,...i}=t??{};return await fetch(e,{...i,signal:r.signal})}finally{clearTimeout(s)}}var Xr=/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/;function rn(e,t){let n=nn(e),r=nn(t);if(!n||!r)return!1;for(let s=0;s<3;s++)if(n.main[s]!==r.main[s])return n.main[s]>r.main[s];return n.pre&&!r.pre?!1:!n.pre&&r.pre?!0:!n.pre&&!r.pre?!1:Zr(n.pre,r.pre)>0}function nn(e){if(typeof e!="string")return null;let n=e.trim().replace(/^v/,"").match(Xr);return n?{main:[Number(n[1]),Number(n[2]),Number(n[3])],pre:n[4]??null}:null}function Zr(e,t){let n=e.split("."),r=t.split("."),s=Math.max(n.length,r.length);for(let o=0;o<s;o++){if(o>=n.length)return-1;if(o>=r.length)return 1;let i=n[o],a=r[o],c=/^\d+$/.test(i),l=/^\d+$/.test(a);if(c&&l){let u=Number(i)-Number(a);if(u!==0)return u}else{if(c)return-1;if(l)return 1;if(i<a)return-1;if(i>a)return 1}}return 0}function q(){return!!(sn(process.env.VISA_CLI_NO_UPDATE_CHECK)||sn(process.env.CI)||process.env.NODE_ENV==="test")}function sn(e){if(e===void 0)return!1;let t=e.trim().toLowerCase();return!(t===""||t==="0"||t==="false"||t==="no"||t==="off")}var X=g(require("fs")),cn=g(require("path"));var Te=g(require("fs")),on=g(require("path")),an=g(require("os"));var at=on.join(an.homedir(),".visa-mcp"),ue=class{static ensureConfigDir(){Te.existsSync(at)||Te.mkdirSync(at,{recursive:!0,mode:448})}static getConfigDir(){return at}static TOOL_STATES={login:!0,get_status:!0,get_cards:!0,add_card:!0,pay:!0,transaction_history:!0,update_spending_controls:!0,enroll_device:!1,verify_otp:!1,reset:!0,batch:!0,generate_x402_image:!1,browser_launch:!1,browser_navigate:!1,browser_snapshot:!1,browser_click:!1,browser_type:!1,browser_scroll:!1,generate_music_card:!1,generate_image_card:!0,query_onchain_prices_card:!0,generate_music_tempo_card:!0,check_music_status_tempo_card:!0,generate_image_fast_card:!0,pxlwall_card:!1,generate_video_tempo_card:!0};static loadToolStates(){return{...this.TOOL_STATES}}static getDisabledTools(){let t=new Set;for(let[n,r]of Object.entries(this.TOOL_STATES))r||t.add(n);return t}static isToolDisabled(t){return this.TOOL_STATES[t]===!1}};var Qr="settings.json";function Ae(){return cn.join(ue.getConfigDir(),Qr)}var de={"auth.serverUrl":{type:"string",description:"Auth server base URL. Override for staging / self-hosted backends.",requiresRestart:!0,validate:e=>{if(typeof e!="string")throw new Error("auth.serverUrl must be a string");let t;try{t=new URL(e)}catch{throw new Error(`auth.serverUrl must be a valid URL (got: ${JSON.stringify(e)})`)}if(t.protocol!=="https:"&&t.protocol!=="http:")throw new Error(`auth.serverUrl must use http or https (got: ${t.protocol})`)}},"ui.suppressBrowser":{type:"boolean",description:"When true, the CLI/MCP server stops auto-opening result URLs in your browser."},"ui.suppressFeed":{type:"boolean",description:"When true, generated images/music are not auto-submitted to the public Made-with-Visa feed."},"tools.meta":{type:"boolean",description:"Show category meta-tools (generate_image, generate_music, ...). Restart required.",requiresRestart:!0},"tools.specific":{type:"boolean",description:"Show hardcoded per-merchant tools (generate_image_card, query_onchain_prices_card, ...). Restart required.",requiresRestart:!0},"tools.discover":{type:"boolean",description:"Show the dynamic-catalog tools (discover_tools, execute_tool). Restart required.",requiresRestart:!0}};function Ie(){let e=Ae();if(!X.existsSync(e))return{};try{let t=X.readFileSync(e,"utf-8"),n=JSON.parse(t);return!n||typeof n!="object"||Array.isArray(n)?{}:n}catch{return{}}}function ln(e){ue.ensureConfigDir();let t=Ae(),n=`${t}.tmp`,r=JSON.stringify(e,null,2)+`
28
- `;X.writeFileSync(n,r,{mode:384}),X.renameSync(n,t)}function ct(e){let t=Ie()[e];return typeof t=="string"?t:void 0}function un(e){let t=Ie()[e];if(typeof t=="boolean")return t;if(t==="true")return!0;if(t==="false")return!1}var re=class extends Error{constructor(t){let n=Object.keys(de).sort().join(", ");super(`Unknown setting "${t}". Settable keys: ${n}. For server-controlled values (biometric.*, spending.*) use the dedicated tools (biometric_on/off, update_spending_controls).`),this.name="UnknownSettingKeyError"}},se=class extends Error{constructor(t){let n="";t.startsWith("biometric.")?n="biometric_on / biometric_off":t.startsWith("spending.")?n="update_spending_controls":t.startsWith("cards.")?n="add_card / remove_card / set_default_card":t.startsWith("account.")&&(n="login / reset"),super(`"${t}" is a server-controlled value and cannot be set via config set. `+(n?`Use ${n} instead.`:"No client-side override is supported.")),this.name="ServerOnlySettingError"}},dn=["biometric.","spending.","account.","cards.","biometric"];function fn(e,t){if(dn.some(o=>e.startsWith(o)))throw new se(e);let n=de[e];if(!n)throw new re(e);let r;if(n.type==="boolean")if(typeof t=="boolean")r=t;else if(typeof t=="string"){let o=t.toLowerCase();if(o==="true")r=!0;else if(o==="false")r=!1;else throw new Error(`${e} expects true or false (got: ${JSON.stringify(t)})`)}else throw new Error(`${e} expects a boolean (got: ${typeof t})`);else{if(typeof t!="string"||t.length===0)throw new Error(`${e} expects a non-empty string`);r=t}n.validate&&n.validate(r);let s=Ie();return s[e]=r,ln(s),{key:e,value:r,requiresRestart:!!n.requiresRestart,path:Ae()}}function pn(e){if(dn.some(s=>e.startsWith(s)))throw new se(e);let t=de[e];if(!t)throw new re(e);let n=Ie(),r=e in n;return r&&(delete n[e],ln(n)),{key:e,removed:r,requiresRestart:r&&!!t.requiresRestart,path:Ae()}}var es="https://auth.visacli.sh";function gn(){let e=process.env.VISA_AUTH_URL;if(e!==void 0&&e!=="")return e;let t=ct("auth.serverUrl");return t!==void 0?t:es}var lt="1.8.0-rc.3",oe=class{constructor(t){this.getSessionToken=t;this.baseUrl=gn()}getSessionToken;baseUrl;lastSignals={};parseServerSignals(t){if(this.lastSignals={},!q()){let r=t.headers.get("X-Latest-Version"),s=t.headers.get("X-Update-Message");r&&rn(r,lt)&&(this.lastSignals.updateAvailable={version:r,message:s||`Update available: v${r}. Run: npm install -g @visa/cli && visa-cli setup`})}let n=t.headers.get("X-Feedback-Prompt");if(n)try{this.lastSignals.feedbackPrompt=JSON.parse(n)}catch{}}getClientVersion(){return lt}async request(t,n,r,s,o){let i=await this.getSessionToken();if(!i)throw new Error("Not logged in. Sign up at https://visacli.sh or run: visa-cli setup");let a={Authorization:`Bearer ${i}`};o&&(t==="GET"?a["X-User-Context"]=o.replace(/[\r\n\0]/g," ").slice(0,1e3):r={...r||{},user_context:o}),r&&(a["Content-Type"]="application/json");let c;try{c=await tn(`${this.baseUrl}${n}`,{method:t,headers:{...a,"X-Visa-CLI-Version":lt},body:r?JSON.stringify(r):void 0,timeoutMs:s})}catch(u){throw u.name==="AbortError"||u.message?.includes("aborted")?new Error("The request timed out. The server may be under heavy load. Please try again."):new Error("Cannot reach the Visa CLI server. Check your internet connection and try again.")}if(this.parseServerSignals(c),c.status===401)throw new Error("Your session has expired. Run: visa-cli setup");if(c.status===429){let u=c.headers.get("Retry-After")||"3";throw new Error(`Rate limited \u2014 wait ${u}s. Tip: use the batch tool to combine multiple requests into one.`)}if(c.status===503)throw new Error("Visa CLI is temporarily unavailable. Check https://visacli.sh for status.");let l;try{l=await c.json()}catch{throw c.status===500?new Error(`Server error on ${n}. Try again or check https://visacli.sh for status.`):new Error(`Unexpected response from ${n}. Try again.`)}if(!c.ok)throw c.status===500?new Error(`Server error on ${n}. Try again or check https://visacli.sh for status.`):new Error(l?.error||`Request failed (${c.status}). Try again.`);return l}async pay(t,n){return this.request("POST","/v1/pay",t,void 0,n)}async shortcut(t,n,r,s){return this.request("POST",`/v1/shortcuts/${encodeURIComponent(t)}`,n,r,s)}async batch(t,n,r){return this.request("POST","/v1/batch",t,n,r)}async catalogSearch(t,n){let r=new URLSearchParams;t&&r.set("q",t),n&&r.set("category",n);let s=r.toString();return this.request("GET",`/v1/catalog${s?`?${s}`:""}`)}async catalogTool(t){try{return await this.request("GET",`/v1/catalog/${encodeURIComponent(t)}`)}catch{return null}}async paymentPreview(t,n){return this.request("POST","/v1/payment-preview",t,void 0,n)}async getStatus(t){return this.request("GET","/v1/status",void 0,void 0,t)}async getTransactions(t){return this.request("GET","/v1/transactions",void 0,void 0,t)}async updateSpendingControls(t,n){return this.request("POST","/v1/spending-controls",t,void 0,n)}async removeCard(t,n,r){return this.request("DELETE",`/v1/cards/${encodeURIComponent(String(t))}`,n,void 0,r)}async setDefaultCard(t,n,r){return this.request("POST",`/v1/cards/${encodeURIComponent(String(t))}/default`,n,void 0,r)}async getAttestationChallenge(){return this.request("GET","/v1/attestation-challenge")}async registerAttestationKey(t){return this.request("POST","/v1/attestation-key",{publicKey:t})}async setBiometricPreference(t,n){return this.request("POST","/v1/biometric-preference",{...t,confirm:!0},void 0,n)}async logout(t,n){return this.request("POST","/v1/logout",t,void 0,n)}async feedback(t,n,r){return this.request("POST","/v1/feedback",{message:t,...n&&{transaction_id:n}},void 0,r)}async feedSubmit(t){return this.request("POST","/v1/feed",t)}async feedList(t){let n=new URLSearchParams;t?.tab&&n.set("tab",t.tab),t?.limit&&n.set("limit",String(t.limit)),t?.offset&&n.set("offset",String(t.offset));let r=n.toString();return this.request("GET",`/v1/feed${r?"?"+r:""}`)}async feedVote(t,n){return this.request("POST",`/v1/feed/${encodeURIComponent(t)}/vote`,{direction:n})}async feedApprove(t){return this.request("POST",`/v1/feed/${encodeURIComponent(t)}/approve`)}async feedDelete(t){return this.request("DELETE",`/v1/feed/${encodeURIComponent(t)}`)}async feedPending(){return this.request("GET","/v1/feed/pending")}async submitFeedback(t,n,r){return this.request("POST","/v1/feedback",{message:t,...n&&{transaction_id:n}},void 0,r)}async getFeedback(t,n){let r=new URLSearchParams;t&&r.set("limit",String(t));let s=r.toString();return this.request("GET",`/v1/feedback${s?"?"+s:""}`,void 0,void 0,n)}async submitRatedFeedback(t){return this.request("POST","/v1/feedback",t)}};var gt=require("child_process"),bn=require("util"),wn=g(require("crypto")),E=g(require("fs")),_n=g(require("os")),W=g(require("path"));var P=g(require("fs")),ft=g(require("path")),mn=g(require("os")),dt=ft.join(mn.homedir(),".visa-mcp"),fe=ft.join(dt,"mcp-server.log"),ts=5*1024*1024,ut=null;function ns(){P.existsSync(dt)||P.mkdirSync(dt,{recursive:!0,mode:448})}function rs(){if(!ut){if(ns(),P.existsSync(fe)&&P.statSync(fe).size>ts){let t=fe+".1";P.existsSync(t)&&P.unlinkSync(t),P.renameSync(fe,t)}ut=P.createWriteStream(fe,{flags:"a"})}return ut}function Le(e,...t){let n=new Date().toISOString(),r=t.map(o=>typeof o=="string"?o:JSON.stringify(o,null,2)).join(" "),s=`[${n}] [${e}] ${r}
28
+ `;X.writeFileSync(n,r,{mode:384}),X.renameSync(n,t)}function ct(e){let t=Ie()[e];return typeof t=="string"?t:void 0}function un(e){let t=Ie()[e];if(typeof t=="boolean")return t;if(t==="true")return!0;if(t==="false")return!1}var re=class extends Error{constructor(t){let n=Object.keys(de).sort().join(", ");super(`Unknown setting "${t}". Settable keys: ${n}. For server-controlled values (biometric.*, spending.*) use the dedicated tools (biometric_on/off, update_spending_controls).`),this.name="UnknownSettingKeyError"}},se=class extends Error{constructor(t){let n="";t.startsWith("biometric.")?n="biometric_on / biometric_off":t.startsWith("spending.")?n="update_spending_controls":t.startsWith("cards.")?n="add_card / remove_card / set_default_card":t.startsWith("account.")&&(n="login / reset"),super(`"${t}" is a server-controlled value and cannot be set via config set. `+(n?`Use ${n} instead.`:"No client-side override is supported.")),this.name="ServerOnlySettingError"}},dn=["biometric.","spending.","account.","cards.","biometric"];function fn(e,t){if(dn.some(o=>e.startsWith(o)))throw new se(e);let n=de[e];if(!n)throw new re(e);let r;if(n.type==="boolean")if(typeof t=="boolean")r=t;else if(typeof t=="string"){let o=t.toLowerCase();if(o==="true")r=!0;else if(o==="false")r=!1;else throw new Error(`${e} expects true or false (got: ${JSON.stringify(t)})`)}else throw new Error(`${e} expects a boolean (got: ${typeof t})`);else{if(typeof t!="string"||t.length===0)throw new Error(`${e} expects a non-empty string`);r=t}n.validate&&n.validate(r);let s=Ie();return s[e]=r,ln(s),{key:e,value:r,requiresRestart:!!n.requiresRestart,path:Ae()}}function pn(e){if(dn.some(s=>e.startsWith(s)))throw new se(e);let t=de[e];if(!t)throw new re(e);let n=Ie(),r=e in n;return r&&(delete n[e],ln(n)),{key:e,removed:r,requiresRestart:r&&!!t.requiresRestart,path:Ae()}}var es="https://auth.visacli.sh";function gn(){let e=process.env.VISA_AUTH_URL;if(e!==void 0&&e!=="")return e;let t=ct("auth.serverUrl");return t!==void 0?t:es}var lt="1.8.0",oe=class{constructor(t){this.getSessionToken=t;this.baseUrl=gn()}getSessionToken;baseUrl;lastSignals={};parseServerSignals(t){if(this.lastSignals={},!q()){let r=t.headers.get("X-Latest-Version"),s=t.headers.get("X-Update-Message");r&&rn(r,lt)&&(this.lastSignals.updateAvailable={version:r,message:s||`Update available: v${r}. Run: npm install -g @visa/cli && visa-cli setup`})}let n=t.headers.get("X-Feedback-Prompt");if(n)try{this.lastSignals.feedbackPrompt=JSON.parse(n)}catch{}}getClientVersion(){return lt}async request(t,n,r,s,o){let i=await this.getSessionToken();if(!i)throw new Error("Not logged in. Sign up at https://visacli.sh or run: visa-cli setup");let a={Authorization:`Bearer ${i}`};o&&(t==="GET"?a["X-User-Context"]=o.replace(/[\r\n\0]/g," ").slice(0,1e3):r={...r||{},user_context:o}),r&&(a["Content-Type"]="application/json");let c;try{c=await tn(`${this.baseUrl}${n}`,{method:t,headers:{...a,"X-Visa-CLI-Version":lt},body:r?JSON.stringify(r):void 0,timeoutMs:s})}catch(u){throw u.name==="AbortError"||u.message?.includes("aborted")?new Error("The request timed out. The server may be under heavy load. Please try again."):new Error("Cannot reach the Visa CLI server. Check your internet connection and try again.")}if(this.parseServerSignals(c),c.status===401)throw new Error("Your session has expired. Run: visa-cli setup");if(c.status===429){let u=c.headers.get("Retry-After")||"3";throw new Error(`Rate limited \u2014 wait ${u}s. Tip: use the batch tool to combine multiple requests into one.`)}if(c.status===503)throw new Error("Visa CLI is temporarily unavailable. Check https://visacli.sh for status.");let l;try{l=await c.json()}catch{throw c.status===500?new Error(`Server error on ${n}. Try again or check https://visacli.sh for status.`):new Error(`Unexpected response from ${n}. Try again.`)}if(!c.ok)throw c.status===500?new Error(`Server error on ${n}. Try again or check https://visacli.sh for status.`):new Error(l?.error||`Request failed (${c.status}). Try again.`);return l}async pay(t,n){return this.request("POST","/v1/pay",t,void 0,n)}async shortcut(t,n,r,s){return this.request("POST",`/v1/shortcuts/${encodeURIComponent(t)}`,n,r,s)}async batch(t,n,r){return this.request("POST","/v1/batch",t,n,r)}async catalogSearch(t,n){let r=new URLSearchParams;t&&r.set("q",t),n&&r.set("category",n);let s=r.toString();return this.request("GET",`/v1/catalog${s?`?${s}`:""}`)}async catalogTool(t){try{return await this.request("GET",`/v1/catalog/${encodeURIComponent(t)}`)}catch{return null}}async paymentPreview(t,n){return this.request("POST","/v1/payment-preview",t,void 0,n)}async getStatus(t){return this.request("GET","/v1/status",void 0,void 0,t)}async getTransactions(t){return this.request("GET","/v1/transactions",void 0,void 0,t)}async updateSpendingControls(t,n){return this.request("POST","/v1/spending-controls",t,void 0,n)}async removeCard(t,n,r){return this.request("DELETE",`/v1/cards/${encodeURIComponent(String(t))}`,n,void 0,r)}async setDefaultCard(t,n,r){return this.request("POST",`/v1/cards/${encodeURIComponent(String(t))}/default`,n,void 0,r)}async getAttestationChallenge(){return this.request("GET","/v1/attestation-challenge")}async registerAttestationKey(t){return this.request("POST","/v1/attestation-key",{publicKey:t})}async setBiometricPreference(t,n){return this.request("POST","/v1/biometric-preference",{...t,confirm:!0},void 0,n)}async logout(t,n){return this.request("POST","/v1/logout",t,void 0,n)}async feedback(t,n,r){return this.request("POST","/v1/feedback",{message:t,...n&&{transaction_id:n}},void 0,r)}async feedSubmit(t){return this.request("POST","/v1/feed",t)}async feedList(t){let n=new URLSearchParams;t?.tab&&n.set("tab",t.tab),t?.limit&&n.set("limit",String(t.limit)),t?.offset&&n.set("offset",String(t.offset));let r=n.toString();return this.request("GET",`/v1/feed${r?"?"+r:""}`)}async feedVote(t,n){return this.request("POST",`/v1/feed/${encodeURIComponent(t)}/vote`,{direction:n})}async feedApprove(t){return this.request("POST",`/v1/feed/${encodeURIComponent(t)}/approve`)}async feedDelete(t){return this.request("DELETE",`/v1/feed/${encodeURIComponent(t)}`)}async feedPending(){return this.request("GET","/v1/feed/pending")}async submitFeedback(t,n,r){return this.request("POST","/v1/feedback",{message:t,...n&&{transaction_id:n}},void 0,r)}async getFeedback(t,n){let r=new URLSearchParams;t&&r.set("limit",String(t));let s=r.toString();return this.request("GET",`/v1/feedback${s?"?"+s:""}`,void 0,void 0,n)}async submitRatedFeedback(t){return this.request("POST","/v1/feedback",t)}};var gt=require("child_process"),bn=require("util"),wn=g(require("crypto")),E=g(require("fs")),_n=g(require("os")),W=g(require("path"));var P=g(require("fs")),ft=g(require("path")),mn=g(require("os")),dt=ft.join(mn.homedir(),".visa-mcp"),fe=ft.join(dt,"mcp-server.log"),ts=5*1024*1024,ut=null;function ns(){P.existsSync(dt)||P.mkdirSync(dt,{recursive:!0,mode:448})}function rs(){if(!ut){if(ns(),P.existsSync(fe)&&P.statSync(fe).size>ts){let t=fe+".1";P.existsSync(t)&&P.unlinkSync(t),P.renameSync(fe,t)}ut=P.createWriteStream(fe,{flags:"a"})}return ut}function Le(e,...t){let n=new Date().toISOString(),r=t.map(o=>typeof o=="string"?o:JSON.stringify(o,null,2)).join(" "),s=`[${n}] [${e}] ${r}
29
29
  `;process.stderr.write(s),rs().write(s)}var ie={debug:(...e)=>Le("DEBUG",...e),info:(...e)=>Le("INFO",...e),warn:(...e)=>Le("WARN",...e),error:(...e)=>Le("ERROR",...e)};var ae=(0,bn.promisify)(gt.execFile),De=W.join(_n.homedir(),".visa-mcp","bin"),te=W.join(De,"Visa CLI"),ss=W.join(__dirname,"..","native"),hn="5",yn=W.join(De,"visa-keychain.version"),Sn=W.join(De,"visa-keychain.sha256");function vn(e){let t=E.readFileSync(e);return wn.createHash("sha256").update(t).digest("hex")}async function Cn(){try{if(E.readFileSync(yn,"utf-8").trim()===hn&&E.existsSync(te)){let r=E.readFileSync(Sn,"utf-8").trim();if(vn(te)!==r)ie.warn("binary:hash-mismatch",{message:"Binary hash mismatch \u2014 possible tampering detected. Recompiling from source."}),E.unlinkSync(te);else return te}}catch{}let e=W.join(ss,"visa-keychain.m");if(E.existsSync(e)||(e=W.resolve(__dirname,"..","..","native","visa-keychain.m")),E.existsSync(e)||(e=W.resolve(__dirname,"..","native","visa-keychain.m")),!E.existsSync(e))throw new Error("visa-keychain.m source not found. Reinstall Visa CLI.");E.mkdirSync(De,{recursive:!0,mode:448});try{await ae("clang",["-framework","Security","-framework","LocalAuthentication","-framework","Foundation","-framework","AppKit","-o",te,e],{timeout:3e4})}catch(n){throw n.code==="ENOENT"?new Error("Xcode Command Line Tools required. Install: xcode-select --install"):n}let t=vn(te);return E.writeFileSync(Sn,t,{mode:384}),E.writeFileSync(yn,hn,{mode:384}),te}async function kn(e){let t=await Cn(),n;try{n=(await ae(t,e,{timeout:6e4})).stdout}catch(o){n=o.stdout||"";let i=n.trim();throw i.startsWith("ERROR:")?new Error(i.slice(6)):new Error(o.stderr?.trim()||o.message||"Unknown error")}let r=n.trim();if(r.startsWith("OK:"))return r.slice(3);if(r==="OK")return;let s=r.startsWith("ERROR:")?r.slice(6):"Unknown error";throw new Error(s)}var pt=null;function T(){return process.env.VISA_MOCK_TOUCHID==="true"?!0:process.platform!=="darwin"?!1:pt!==null?pt:(pt=!0,!0)}var Oe="visa-cli",Ne="attestation-key";async function os(e){try{await ae("security",["delete-generic-password","-s",Oe,"-a",Ne],{timeout:5e3})}catch{}await ae("security",["add-generic-password","-s",Oe,"-a",Ne,"-w",e],{timeout:5e3})}async function is(){try{let{stdout:e}=await ae("security",["find-generic-password","-s",Oe,"-a",Ne,"-w"],{timeout:5e3});return e.trim()||null}catch{return null}}async function Ue(){let e=await kn(["generate-key"]);if(!e)throw new Error("Key generation returned no output");let t=e.indexOf(":");if(t<0)throw new Error("Unexpected generate-key output format");let n=e.slice(0,t),r=e.slice(t+1);return await os(n),r}async function mt(e,t){if(process.env.VISA_MOCK_TOUCHID==="true")return Promise.resolve("mock-ecdsa-signature-for-testing");let n=await is();if(!n)throw new Error("Attestation key not found. Run setup to generate a new key.");let r=await Cn(),s=["sign",e];return t&&s.push(t),new Promise((o,i)=>{let a=(0,gt.execFile)(r,s,{timeout:6e4},(c,l)=>{let u=(l||"").trim();if(c){u.startsWith("ERROR:")?i(new Error(u.slice(6))):i(new Error(c.stderr?.trim()||c.message||"Unknown error"));return}u.startsWith("OK:")?o(u.slice(3)):i(new Error(u.startsWith("ERROR:")?u.slice(6):"Unknown error"))});a.stdin.write(n),a.stdin.end()})}async function $n(){try{await ae("security",["delete-generic-password","-s",Oe,"-a",Ne],{timeout:5e3})}catch{}try{await kn(["delete-key"])}catch{}}function En(e,t=process.stderr){if(q()||!e?.updateAvailable)return!1;let{message:n}=e.updateAvailable;return n?(t.write(`
30
30
  \x1B[33m\u2191 ${n}\x1B[0m
31
31
  `),!0):!1}function Rn(e,t,n,r){let s=r.currentVersion==="0.0.0"&&e.version?e.version:r.currentVersion,i=ps(e.spendingControls).dailyLimit,a=Math.max(0,pe(e.dailySpent)),c=i>0?Math.min(i,Math.max(0,pe(e.dailyRemaining??i-a))):0,l=i>0?Math.min(1,a/i):0,f=(Array.isArray(t)?t:[]).filter(ls),d=f.slice(0,3),m=us(f,3),v=(e.cards??[]).slice(0,3),C=r.latestVersion?yt(r.latestVersion):"",N=r.updateCheckDisabled?"update checks disabled":C?`update available: v${C}`:"up to date",$=Math.round(l*100),I=Z(e.status,e.enrolled?"approved":"not enrolled"),H=["VISA CLI",`Status: ${e.enrolled?"Visa ready":"Visa setup needed"} | account: ${I} | touch id: ${n?"ready":"unavailable"}`,`Version: v${s} | ${N}`,`Spend meter: ${xn(l)} ${String($).padStart(3," ")}% | remaining ${ce(c)}/day | daily cap ${ce(i)}`,"","Spend",` Remaining ${ce(c)} / ${ce(i)}`,` Usage ${xn(l)} ${$}%`,` Spent today ${ce(a)}`,` Attestation key ${e.hasAttestationKey?"registered":"missing"}`,"","Cards",...v.length>0?v.map(D=>` ${fs(D)}`):[" No cards enrolled"],"","Last 3 services",...m.length>0?m.map((D,le)=>` ${le+1}. ${D}`):[" No paid services yet"],"","Recent receipts",...d.length>0?d.map(D=>` ${ds(D)}`):[" No receipts yet"]];return r.updateMessage&&H.push("",`Update: ${yt(r.updateMessage)}`),`${H.join(`
@@ -90,7 +90,7 @@ ${r}
90
90
  `}function On(e=Ke()){if(!e)return{installed:!1,changed:!1,shell:null,message:"Shell HUD auto-install skipped: supported shells are zsh, bash, and PowerShell."};let t;try{t=qe(e);let n=y.existsSync(t)?y.readFileSync(t,"utf-8"):"",r=bs(n,e),s=r!==n;return s&&Ve(t,r),{installed:!0,changed:s,shell:e,rcPath:t,message:s?`Persistent shell HUD installed in ${t}. Open a new terminal to start seeing it. Disable it any time with: visa-cli shell-hud disable`:`Persistent shell HUD already installed in ${t}. Disable it any time with: visa-cli shell-hud disable`}}catch(n){return{installed:!1,changed:!1,shell:e,rcPath:t,message:`Failed to install persistent shell HUD in ${t}: ${jn(n)}`}}}function Nn(e=Ke()){if(!e)return{removed:!1,shell:null,message:"Shell HUD uninstall skipped: supported shells are zsh, bash, and PowerShell."};let t;try{if(t=qe(e),!y.existsSync(t))return{removed:!1,shell:e,rcPath:t,message:`No ${e} rc file found at ${t}.`};let n=y.readFileSync(t,"utf-8"),r=Ln(n);return r===n.trimEnd()?{removed:!1,shell:e,rcPath:t,message:`Persistent shell HUD was not installed in ${t}.`}:(Ve(t,r.length>0?`${r}
91
91
  `:""),{removed:!0,shell:e,rcPath:t,message:`Removed persistent shell HUD from ${t}.`})}catch(n){return{removed:!1,shell:e,rcPath:t,message:`Failed to remove persistent shell HUD from ${t}: ${jn(n)}`}}}function _t(e,t){let n=t.currentVersion==="0.0.0"&&e.version?e.version:t.currentVersion,r=He(n),s=` ${M("\u2502",L.dim)} `;if(!e.enrolled)return`${M("VISA CLI",L.visaBlue)} ${M(`v${r}`,L.visaBlueSoft)}${s}${M("setup needed",L.visaGold)}`;let o=St(e.spendingControls?.daily_limit??e.spendingControls?.dailyLimit),i=Math.max(0,St(e.dailySpent)),a=o>0?Math.min(o,Math.max(0,St(e.dailyRemaining??o-i))):0,c=o>0?Math.max(0,Math.min(1,i/o)):0,l=Cs(e),u=o>0?`${_s(c)} ${M(`${vt(a)} left today`,L.green)} ${M(`(${vt(i)}/${vt(o)}/day)`,L.dim)}`:M("no spend limit",L.dim);return`${M("VISA CLI",L.visaBlue)} ${M(`v${r}`,L.visaBlueSoft)}${s}${M(l,L.visaGold)}${s}${u}`}function Dn(){let e=Un();return!!e&&Date.now()-e.renderedAt<=An}function Ct(){let e=Un();if(e&&Date.now()-e.renderedAt<=An||(ws(),e?.line))return e.line;try{let t=Be();if(y.existsSync(t))return y.readFileSync(t,"utf-8").trimEnd()}catch{}return"VISA | loading spend HUD\u2026"}function kt(e){try{let t=w.dirname(me());y.mkdirSync(t,{recursive:!0});let n=He(e),r={hudVersion:ms,renderedAt:Date.now(),line:n};Ve(me(),JSON.stringify(r)+`
92
92
  `),Ve(Be(),n+`
93
- `)}catch{}}function ge(){try{y.unlinkSync(In())}catch{}}function Un(){let e=me();if(!y.existsSync(e))return null;try{return JSON.parse(y.readFileSync(e,"utf-8"))}catch{return null}}function ws(){if(process.env.JEST_WORKER_ID)return;let e=In();try{if(y.mkdirSync(w.dirname(e),{recursive:!0}),!xs(e))return;let t=process.argv[1]?w.resolve(process.argv[1]):"";if(!t){ge();return}let n=(0,Tn.spawn)(process.execPath,[t,"shell-hud","refresh"],{detached:!0,stdio:"ignore",env:{...process.env,VISA_CLI_SHELL_HUD_BACKGROUND:"1"}});n.once("error",ge),n.unref()}catch{ge()}}function St(e){let t=Number(typeof e=="string"?e:e??0);return Number.isFinite(t)?t:0}function He(e){return e.replace(/\u001B\][^\u0007]*(?:\u0007|\u001B\\)/g,"").replace(/\u001B\[[0-?]*[ -/]*[@-~]/g,"").replace(/\u001B[P_^][^\u001B]*(?:\u001B\\|\u0007)/g,"").replace(/[\u0000-\u0008\u000B-\u001F\u007F-\u009F]/g,"").replace(/\s+/g," ").trim()}function _s(e){let n=Math.round(Math.max(0,Math.min(1,e))*10),r="\u2588".repeat(n),s="\u2591".repeat(10-n);return`${M(r||"",L.green)}${M(s||"",L.dim)}`}function vt(e){return`$${e.toFixed(2)}`}function Cs(e){let t=e.cards?.find(a=>a.isDefault)??e.cards?.[0];if(!t)return"card none";let n=typeof t.brand=="string"?t.brand:"card",r=typeof t.last4=="string"?t.last4:"????",s=He(n.toUpperCase()),o=He(r);return`${t.isDefault?"default":"active"} ${s} ****${o}`}function ks(){let e=(process.env.COLORTERM??"").toLowerCase();if(e==="truecolor"||e==="24bit")return!0;let t=(process.env.TERM??"").toLowerCase();return t.includes("truecolor")||t.includes("24bit")}var bt=ks(),L={reset:"\x1B[0m",visaBlue:bt?"\x1B[38;2;20;52;203m":"\x1B[38;5;27m",visaBlueSoft:bt?"\x1B[38;2;97;126;229m":"\x1B[38;5;111m",visaGold:bt?"\x1B[38;2;247;182;0m":"\x1B[38;5;220m",green:"\x1B[38;5;48m",dim:"\x1B[2m"};function M(e,t){return e.length===0||process.env.NO_COLOR?e:`${t}${e}${L.reset}`}function Pn(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Mn(){let e=Fe.homedir();if(!e||!w.isAbsolute(e))throw new Error("unable to determine a valid home directory");return w.resolve(e)}function $s(e){return e==="powershell"?"& visa-cli shell-hud refresh":"visa-cli shell-hud refresh"}function Es(e){return e==="powershell"?"Get-Command visa-cli -ErrorAction SilentlyContinue -CommandType Application":"command -v visa-cli >/dev/null 2>&1"}function xs(e){for(let t=0;t<2;t+=1){let n;try{return n=y.openSync(e,"wx"),y.writeFileSync(n,String(Date.now())),!0}catch(r){if(r?.code!=="EEXIST")return!1;try{let s=y.statSync(e);if(Date.now()-s.mtimeMs<=Ss)return!1;y.unlinkSync(e)}catch{}}finally{n!==void 0&&y.closeSync(n)}}return!1}function jn(e){return e instanceof Error?e.message:"unknown file system error"}function Ve(e,t){y.mkdirSync(w.dirname(e),{recursive:!0});let n=`${e}.${process.pid}.${Date.now()}.tmp`;y.writeFileSync(n,t),y.renameSync(n,e)}async function $t(e,t){try{return await t()}catch(n){if(n.message==="Invalid signature"&&T()){ie.warn("attestation:key-mismatch",{action:"reregistering"});try{let r=await Ue();await e.registerAttestationKey(r),ie.info("attestation:key-reregistered")}catch(r){throw ie.error("attestation:reregister-failure",{error:r.message}),n}return await t()}throw n}}var Hn="1.8.0-rc.3";function Et(e,t){return t?{kind:"env",var:e}:{kind:"default"}}function Rs(e,t,n){let r=process.env[e];if(r!==void 0&&r!=="")return{value:r,source:{kind:"env",var:e}};let s=ct(t);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:n,source:{kind:"default"}}}function he(e,t,n){let r=process.env[e];if(r!==void 0)return{value:n==="opt-in"?r==="true":r!=="false",source:{kind:"env",var:e}};let s=un(t);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:n!=="opt-in",source:{kind:"default"}}}function O(e){return e==null?"\u2014":e?"yes":"no"}function We(e){return e==null?"\u2014":`$${e.toFixed(2)}`}async function Vn(e){let t=null,n=null;try{t=await e.api.getStatus()}catch($){n=$?.message||"unknown error"}let r=[],s=Rs("VISA_AUTH_URL","auth.serverUrl","https://auth.visacli.sh");r.push({key:"auth.serverUrl",value:s.value,formatted:s.value,source:s.source,hint:s.source.kind==="default"?"Persist with `visa-cli config set auth.serverUrl <url>` (or set VISA_AUTH_URL for one-off overrides).":void 0}),r.push({key:"account.enrolled",value:t?.enrolled??null,formatted:O(t?.enrolled),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),t?.githubUser&&r.push({key:"account.githubUser",value:t.githubUser,formatted:t.githubUser,source:{kind:"server"}});let o=t?t.attestationRequired!==!1:void 0;r.push({key:"biometric.required",value:o,formatted:O(o),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"},hint:o===!1?"Touch ID prompts are suppressed. Re-enable with `visa-cli biometric on`.":void 0}),r.push({key:"biometric.keyRegistered",value:t?.hasAttestationKey??null,formatted:O(t?.hasAttestationKey),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"biometric.deviceAvailable",value:T(),formatted:O(T()),source:{kind:"device"}});let i=t?.spendingControls,a=i?i.max_transaction_amount??i.maxTransactionAmount??null:null,c=i?i.daily_limit??i.dailyLimit??null:null;r.push({key:"spending.maxPerTxn",value:a,formatted:We(a),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailyLimit",value:c,formatted:We(c),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailySpent",value:t?.dailySpent??null,formatted:We(t?.dailySpent),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailyRemaining",value:t?.dailyRemaining??null,formatted:We(t?.dailyRemaining),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"cards.count",value:t?.cardCount??null,formatted:t?.cardCount!=null?String(t.cardCount):"\u2014",source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}});let l=t?.cards?.find($=>$.isDefault)??t?.cards?.[0];l&&r.push({key:"cards.default",value:{brand:l.brand??null,last4:l.last4},formatted:`${l.brand||"card"} \u2022\u2022\u2022\u2022 ${l.last4}`,source:{kind:"server"}});let u=he("VISA_SUPPRESS_BROWSER","ui.suppressBrowser","opt-in");r.push({key:"ui.suppressBrowser",value:u.value,formatted:O(u.value),source:u.source,hint:"Persist with `visa-cli config set ui.suppressBrowser true` to stop auto-opening result URLs."});let f=he("VISA_SUPPRESS_FEED","ui.suppressFeed","opt-in");r.push({key:"ui.suppressFeed",value:f.value,formatted:O(f.value),source:f.source});let d=q(),m;process.env.VISA_CLI_NO_UPDATE_CHECK?m={kind:"env",var:"VISA_CLI_NO_UPDATE_CHECK"}:process.env.CI?m={kind:"env",var:"CI"}:process.env.NODE_ENV==="test"?m={kind:"env",var:"NODE_ENV"}:m={kind:"default"},r.push({key:"ui.updateCheck",value:!d,formatted:O(!d),source:m});let v=he("VISA_META_TOOLS","tools.meta","opt-out");r.push({key:"tools.meta",value:v.value,formatted:O(v.value),source:v.source,hint:"Persist with `visa-cli config set tools.meta false`. Restart Claude Code for changes to take effect."});let C=he("VISA_SPECIFIC_TOOLS","tools.specific","opt-out");r.push({key:"tools.specific",value:C.value,formatted:O(C.value),source:C.source});let N=he("VISA_DISCOVER_TOOLS","tools.discover","opt-out");if(r.push({key:"tools.discover",value:N.value,formatted:O(N.value),source:N.source}),r.push({key:"client.version",value:Hn,formatted:Hn,source:{kind:"default"}}),e.includeDev){let $=process.env.VISA_MOCK_KEYCHAIN;r.push({key:"dev.mockKeychain",value:$==="true",formatted:O($==="true"),source:Et("VISA_MOCK_KEYCHAIN",!!$)});let I=process.env.VISA_MOCK_TOUCHID;r.push({key:"dev.mockTouchid",value:I==="true",formatted:O(I==="true"),source:Et("VISA_MOCK_TOUCHID",!!I)});let B=process.env.VISA_CLI_DEBUG;r.push({key:"dev.debug",value:!!B,formatted:O(!!B),source:Et("VISA_CLI_DEBUG",!!B)})}return{entries:r,statusError:n}}function Ps(e){switch(e.kind){case"default":return"default";case"env":return`env ${e.var}`;case"settings":return"settings.json";case"server":return"server";case"device":return"device";case"unset":return"unset";case"unknown":return`unknown (${e.reason})`}}function Fn(e,t={}){if(e.length===0)return"";let n=Math.max(...e.map(o=>o.key.length)),r=Math.max(...e.map(o=>o.formatted.length)),s=[];for(let o of e){let i=o.key.padEnd(n+2),a=o.formatted.padEnd(r+2);s.push(`${i}${a}(${Ps(o.source)})`),t.verbose&&o.hint&&s.push(` ${"\u21B3".padStart(n)} ${o.hint}`)}return s.join(`
93
+ `)}catch{}}function ge(){try{y.unlinkSync(In())}catch{}}function Un(){let e=me();if(!y.existsSync(e))return null;try{return JSON.parse(y.readFileSync(e,"utf-8"))}catch{return null}}function ws(){if(process.env.JEST_WORKER_ID)return;let e=In();try{if(y.mkdirSync(w.dirname(e),{recursive:!0}),!xs(e))return;let t=process.argv[1]?w.resolve(process.argv[1]):"";if(!t){ge();return}let n=(0,Tn.spawn)(process.execPath,[t,"shell-hud","refresh"],{detached:!0,stdio:"ignore",env:{...process.env,VISA_CLI_SHELL_HUD_BACKGROUND:"1"}});n.once("error",ge),n.unref()}catch{ge()}}function St(e){let t=Number(typeof e=="string"?e:e??0);return Number.isFinite(t)?t:0}function He(e){return e.replace(/\u001B\][^\u0007]*(?:\u0007|\u001B\\)/g,"").replace(/\u001B\[[0-?]*[ -/]*[@-~]/g,"").replace(/\u001B[P_^][^\u001B]*(?:\u001B\\|\u0007)/g,"").replace(/[\u0000-\u0008\u000B-\u001F\u007F-\u009F]/g,"").replace(/\s+/g," ").trim()}function _s(e){let n=Math.round(Math.max(0,Math.min(1,e))*10),r="\u2588".repeat(n),s="\u2591".repeat(10-n);return`${M(r||"",L.green)}${M(s||"",L.dim)}`}function vt(e){return`$${e.toFixed(2)}`}function Cs(e){let t=e.cards?.find(a=>a.isDefault)??e.cards?.[0];if(!t)return"card none";let n=typeof t.brand=="string"?t.brand:"card",r=typeof t.last4=="string"?t.last4:"????",s=He(n.toUpperCase()),o=He(r);return`${t.isDefault?"default":"active"} ${s} ****${o}`}function ks(){let e=(process.env.COLORTERM??"").toLowerCase();if(e==="truecolor"||e==="24bit")return!0;let t=(process.env.TERM??"").toLowerCase();return t.includes("truecolor")||t.includes("24bit")}var bt=ks(),L={reset:"\x1B[0m",visaBlue:bt?"\x1B[38;2;20;52;203m":"\x1B[38;5;27m",visaBlueSoft:bt?"\x1B[38;2;97;126;229m":"\x1B[38;5;111m",visaGold:bt?"\x1B[38;2;247;182;0m":"\x1B[38;5;220m",green:"\x1B[38;5;48m",dim:"\x1B[2m"};function M(e,t){return e.length===0||process.env.NO_COLOR?e:`${t}${e}${L.reset}`}function Pn(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Mn(){let e=Fe.homedir();if(!e||!w.isAbsolute(e))throw new Error("unable to determine a valid home directory");return w.resolve(e)}function $s(e){return e==="powershell"?"& visa-cli shell-hud refresh":"visa-cli shell-hud refresh"}function Es(e){return e==="powershell"?"Get-Command visa-cli -ErrorAction SilentlyContinue -CommandType Application":"command -v visa-cli >/dev/null 2>&1"}function xs(e){for(let t=0;t<2;t+=1){let n;try{return n=y.openSync(e,"wx"),y.writeFileSync(n,String(Date.now())),!0}catch(r){if(r?.code!=="EEXIST")return!1;try{let s=y.statSync(e);if(Date.now()-s.mtimeMs<=Ss)return!1;y.unlinkSync(e)}catch{}}finally{n!==void 0&&y.closeSync(n)}}return!1}function jn(e){return e instanceof Error?e.message:"unknown file system error"}function Ve(e,t){y.mkdirSync(w.dirname(e),{recursive:!0});let n=`${e}.${process.pid}.${Date.now()}.tmp`;y.writeFileSync(n,t),y.renameSync(n,e)}async function $t(e,t){try{return await t()}catch(n){if(n.message==="Invalid signature"&&T()){ie.warn("attestation:key-mismatch",{action:"reregistering"});try{let r=await Ue();await e.registerAttestationKey(r),ie.info("attestation:key-reregistered")}catch(r){throw ie.error("attestation:reregister-failure",{error:r.message}),n}return await t()}throw n}}var Hn="1.8.0";function Et(e,t){return t?{kind:"env",var:e}:{kind:"default"}}function Rs(e,t,n){let r=process.env[e];if(r!==void 0&&r!=="")return{value:r,source:{kind:"env",var:e}};let s=ct(t);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:n,source:{kind:"default"}}}function he(e,t,n){let r=process.env[e];if(r!==void 0)return{value:n==="opt-in"?r==="true":r!=="false",source:{kind:"env",var:e}};let s=un(t);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:n!=="opt-in",source:{kind:"default"}}}function O(e){return e==null?"\u2014":e?"yes":"no"}function We(e){return e==null?"\u2014":`$${e.toFixed(2)}`}async function Vn(e){let t=null,n=null;try{t=await e.api.getStatus()}catch($){n=$?.message||"unknown error"}let r=[],s=Rs("VISA_AUTH_URL","auth.serverUrl","https://auth.visacli.sh");r.push({key:"auth.serverUrl",value:s.value,formatted:s.value,source:s.source,hint:s.source.kind==="default"?"Persist with `visa-cli config set auth.serverUrl <url>` (or set VISA_AUTH_URL for one-off overrides).":void 0}),r.push({key:"account.enrolled",value:t?.enrolled??null,formatted:O(t?.enrolled),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),t?.githubUser&&r.push({key:"account.githubUser",value:t.githubUser,formatted:t.githubUser,source:{kind:"server"}});let o=t?t.attestationRequired!==!1:void 0;r.push({key:"biometric.required",value:o,formatted:O(o),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"},hint:o===!1?"Touch ID prompts are suppressed. Re-enable with `visa-cli biometric on`.":void 0}),r.push({key:"biometric.keyRegistered",value:t?.hasAttestationKey??null,formatted:O(t?.hasAttestationKey),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"biometric.deviceAvailable",value:T(),formatted:O(T()),source:{kind:"device"}});let i=t?.spendingControls,a=i?i.max_transaction_amount??i.maxTransactionAmount??null:null,c=i?i.daily_limit??i.dailyLimit??null:null;r.push({key:"spending.maxPerTxn",value:a,formatted:We(a),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailyLimit",value:c,formatted:We(c),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailySpent",value:t?.dailySpent??null,formatted:We(t?.dailySpent),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"spending.dailyRemaining",value:t?.dailyRemaining??null,formatted:We(t?.dailyRemaining),source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}}),r.push({key:"cards.count",value:t?.cardCount??null,formatted:t?.cardCount!=null?String(t.cardCount):"\u2014",source:t?{kind:"server"}:{kind:"unknown",reason:n||"offline"}});let l=t?.cards?.find($=>$.isDefault)??t?.cards?.[0];l&&r.push({key:"cards.default",value:{brand:l.brand??null,last4:l.last4},formatted:`${l.brand||"card"} \u2022\u2022\u2022\u2022 ${l.last4}`,source:{kind:"server"}});let u=he("VISA_SUPPRESS_BROWSER","ui.suppressBrowser","opt-in");r.push({key:"ui.suppressBrowser",value:u.value,formatted:O(u.value),source:u.source,hint:"Persist with `visa-cli config set ui.suppressBrowser true` to stop auto-opening result URLs."});let f=he("VISA_SUPPRESS_FEED","ui.suppressFeed","opt-in");r.push({key:"ui.suppressFeed",value:f.value,formatted:O(f.value),source:f.source});let d=q(),m;process.env.VISA_CLI_NO_UPDATE_CHECK?m={kind:"env",var:"VISA_CLI_NO_UPDATE_CHECK"}:process.env.CI?m={kind:"env",var:"CI"}:process.env.NODE_ENV==="test"?m={kind:"env",var:"NODE_ENV"}:m={kind:"default"},r.push({key:"ui.updateCheck",value:!d,formatted:O(!d),source:m});let v=he("VISA_META_TOOLS","tools.meta","opt-out");r.push({key:"tools.meta",value:v.value,formatted:O(v.value),source:v.source,hint:"Persist with `visa-cli config set tools.meta false`. Restart Claude Code for changes to take effect."});let C=he("VISA_SPECIFIC_TOOLS","tools.specific","opt-out");r.push({key:"tools.specific",value:C.value,formatted:O(C.value),source:C.source});let N=he("VISA_DISCOVER_TOOLS","tools.discover","opt-out");if(r.push({key:"tools.discover",value:N.value,formatted:O(N.value),source:N.source}),r.push({key:"client.version",value:Hn,formatted:Hn,source:{kind:"default"}}),e.includeDev){let $=process.env.VISA_MOCK_KEYCHAIN;r.push({key:"dev.mockKeychain",value:$==="true",formatted:O($==="true"),source:Et("VISA_MOCK_KEYCHAIN",!!$)});let I=process.env.VISA_MOCK_TOUCHID;r.push({key:"dev.mockTouchid",value:I==="true",formatted:O(I==="true"),source:Et("VISA_MOCK_TOUCHID",!!I)});let B=process.env.VISA_CLI_DEBUG;r.push({key:"dev.debug",value:!!B,formatted:O(!!B),source:Et("VISA_CLI_DEBUG",!!B)})}return{entries:r,statusError:n}}function Ps(e){switch(e.kind){case"default":return"default";case"env":return`env ${e.var}`;case"settings":return"settings.json";case"server":return"server";case"device":return"device";case"unset":return"unset";case"unknown":return`unknown (${e.reason})`}}function Fn(e,t={}){if(e.length===0)return"";let n=Math.max(...e.map(o=>o.key.length)),r=Math.max(...e.map(o=>o.formatted.length)),s=[];for(let o of e){let i=o.key.padEnd(n+2),a=o.formatted.padEnd(r+2);s.push(`${i}${a}(${Ps(o.source)})`),t.verbose&&o.hint&&s.push(` ${"\u21B3".padStart(n)} ${o.hint}`)}return s.join(`
94
94
  `)}function Bn(e){return JSON.stringify({config:e.entries.map(t=>({key:t.key,value:t.value,source:t.source,hint:t.hint})),statusError:e.statusError},null,2)}var A=class extends Error{constructor(t){super(t),this.name="PayValidationError"}},Kn=["GET","POST"];function qn(e){let t;try{t=new URL(e)}catch{throw new A(`Invalid URL: ${e}. Expected a fully-qualified http(s) URL.`)}if(t.protocol!=="http:"&&t.protocol!=="https:")throw new A(`Unsupported URL scheme "${t.protocol}". Only http and https are allowed.`);return t}function Wn(e){let t=(e??"GET").toUpperCase();if(!Kn.includes(t))throw new A(`Unsupported HTTP method "${e}". Supported: ${Kn.join(", ")}.`);return t}function Gn(e){if(e!==void 0){try{JSON.parse(e)}catch(t){throw new A(`--body is not valid JSON: ${t?.message??"parse error"}`)}return e}}function Jn(e){if(!e||typeof e!="object")throw new A("Merchant returned no payment preview.");let t=e;if(typeof t.amount!="number"||!Number.isFinite(t.amount)||t.amount<=0)throw new A("Could not determine payment amount from merchant.");if(typeof t.merchantName!="string"||t.merchantName.trim().length===0)throw new A("Merchant returned an empty merchant name.");if(t.merchantName.length>200)throw new A(`Merchant name too long (${t.merchantName.length} chars).`);if(typeof t.currency!="string"||t.currency.trim().length===0)throw new A("Merchant returned an empty currency.");if(t.currency.length>10)throw new A(`Currency code too long (${t.currency.length} chars).`);return{amount:t.amount,currency:t.currency,merchantName:t.merchantName}}var h=g(require("fs")),p=g(require("path")),zn=g(require("os")),_=zn.homedir(),Ts=["Claude_","Anthropic.ClaudeDesktop_"];function Yn(){return process.env.APPDATA||p.join(_,"AppData","Roaming")}function As(){return process.env.LOCALAPPDATA||p.join(_,"AppData","Local")}function Xn(){if(process.platform!=="win32")return;let e=p.join(As(),"Packages");if(h.existsSync(e))try{let t=h.readdirSync(e,"utf-8");for(let n of Ts){let r=t.filter(s=>s.startsWith(n)).sort()[0];if(r)return p.join(e,r,"LocalCache","Roaming","Claude")}}catch{return}}function Zn(){if(process.platform==="win32"){let e=Xn();return e?p.join(e,"claude_desktop_config.json"):p.join(Yn(),"Claude","claude_desktop_config.json")}return p.join(_,"Library","Application Support","Claude","claude_desktop_config.json")}function Qn(){if(process.platform!=="win32")return[p.join(_,"Library","Application Support","Claude")];let e=[p.join(Yn(),"Claude")],t=Xn();return t&&e.push(t),e}function Ge(e){return e.id==="claude-desktop"?Zn():e.globalConfigPath}function Is(e){return e.id==="claude-desktop"?Qn():e.detectPaths}var V=[{id:"claude",displayName:"Claude Code",globalConfigPath:p.join(_,".claude.json"),configKey:"mcpServers",detectPaths:[p.join(_,".claude.json")],postInstallHint:"Restart Claude Code or run /mcp to connect."},{id:"claude-desktop",displayName:"Claude Desktop",globalConfigPath:Zn(),configKey:"mcpServers",detectPaths:Qn(),postInstallHint:"Restart the Claude desktop app to connect."},{id:"cursor",displayName:"Cursor",globalConfigPath:p.join(_,".cursor","mcp.json"),configKey:"mcpServers",detectPaths:[p.join(_,".cursor")],postInstallHint:"Restart Cursor to connect."},{id:"windsurf",displayName:"Windsurf",globalConfigPath:p.join(_,".codeium","windsurf","mcp_config.json"),configKey:"mcpServers",detectPaths:[p.join(_,".codeium","windsurf")],postInstallHint:"Restart Windsurf to connect."},{id:"cline",displayName:"Cline",globalConfigPath:p.join(_,".vscode","mcp.json"),configKey:"mcpServers",detectPaths:[p.join(_,".vscode","extensions","saoudrizwan.claude-dev-*")],postInstallHint:"Restart VS Code to connect."},{id:"roo-code",displayName:"Roo Code",globalConfigPath:p.join(_,".config","Roo","mcp_settings.json"),configKey:"mcpServers",detectPaths:[p.join(_,".vscode","extensions","RooVeterinaryInc.roo-cline-*")],postInstallHint:"Restart VS Code to connect."},{id:"copilot",displayName:"VS Code Copilot",globalConfigPath:p.join(_,".vscode","mcp.json"),configKey:"servers",detectPaths:[p.join(_,".vscode")],postInstallHint:"Restart VS Code to connect."},{id:"zed",displayName:"Zed",globalConfigPath:p.join(_,".config","zed","settings.json"),configKey:"context_servers",detectPaths:[p.join(_,".config","zed")],postInstallHint:"Restart Zed to connect.",buildEntry:e=>({source:"custom",...e})},{id:"codex",displayName:"Codex",globalConfigPath:p.join(_,".codex","config.toml"),configKey:"mcp_servers",configFormat:"toml",detectPaths:[p.join(_,".codex")],postInstallHint:"Restart Codex to connect."}];function xt(e){return V.find(t=>t.id===e)}function ye(e){return Is(e).some(t=>{if(t.includes("*")){let n=p.dirname(t),r=p.basename(t).replaceAll("*","");if(!h.existsSync(n))return!1;try{return h.readdirSync(n).some(s=>s.startsWith(r))}catch{return!1}}return h.existsSync(t)})}function er(){return{command:"node",args:[p.resolve(__dirname,"mcp-server/index.js")]}}function Rt(e,t){return t==="project"?"json":e.configFormat??"json"}function Ls(e){if(e=e.trim(),e==="true")return!0;if(e==="false")return!1;if(e.startsWith('"')&&e.endsWith('"'))return e.slice(1,-1);if(e.startsWith("[")&&e.endsWith("]")){let n=e.slice(1,-1).trim();return n.length===0?[]:n.split(",").map(r=>r.trim()).filter(Boolean).map(r=>r.startsWith('"')&&r.endsWith('"')?r.slice(1,-1):r)}let t=Number(e);return isNaN(t)?e:t}function Pt(e,t){let n=`[mcp_servers.${t}]`,r=e.findIndex(o=>o.trim()===n);if(r===-1)return;let s=r+1;for(;s<e.length&&!e[s].trim().startsWith("[");)s++;return{start:r,end:s}}function Tt(e,t){let n=e.split(`
95
95
  `),r=Pt(n,t);if(!r)return;let s={};for(let o=r.start+1;o<r.end;o++){let i=n[o].trim().match(/^(\w+)\s*=\s*(.+)$/);i&&(s[i[1]]=Ls(i[2]))}return Object.keys(s).length>0?s:void 0}function Os(e,t,n){let r=`[${n.args.map(c=>`"${c}"`).join(", ")}]`,s=[`[mcp_servers.${t}]`,`command = "${n.command}"`,`args = ${r}`],o=e.split(`
96
96
  `),i=Pt(o,t);if(i){o.splice(i.start,i.end-i.start,...s);let c=o.join(`
@@ -1,8 +1,8 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var zn=Object.create;var Jt=Object.defineProperty;var Zn=Object.getOwnPropertyDescriptor;var Gn=Object.getOwnPropertyNames;var Yn=Object.getPrototypeOf,Jn=Object.prototype.hasOwnProperty;var Xn=(r,e)=>()=>(r&&(e=r(r=0)),e);var Qn=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Ir=(r,e)=>{for(var t in e)Jt(r,t,{get:e[t],enumerable:!0})},es=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Gn(e))!Jn.call(r,s)&&s!==t&&Jt(r,s,{get:()=>e[s],enumerable:!(n=Zn(e,s))||n.enumerable});return r};var I=(r,e,t)=>(t=r!=null?zn(Yn(r)):{},es(e||!r||!r.__esModule?Jt(t,"default",{value:r,enumerable:!0}):t,r));var Er={};Ir(Er,{fetchWithTimeout:()=>Xt});async function Xt(r,e){let t=e?.timeoutMs??3e4,n=new AbortController,s=setTimeout(()=>n.abort(),t);try{let{timeoutMs:i,...a}=e??{};return await fetch(r,{...a,signal:n.signal})}finally{clearTimeout(s)}}var Qt=Xn(()=>{"use strict"});var Un=Qn((kc,Za)=>{Za.exports={name:"@visa/cli",version:"1.8.0-rc.3",description:"AI-powered payments for Claude Code",bin:{"visa-cli":"./bin/visa-cli.js"},scripts:{build:"tsc --noEmit && node esbuild.config.js",dev:"tsc --watch",start:"node dist/mcp-server/index.js",test:"jest --config jest.config.js","test:unit":"jest --config jest.config.js","test:unit:watch":"jest --config jest.config.js --watch","test:unit:coverage":"jest --config jest.config.js --coverage","test:smoke":"VISA_AUTH_URL=https://auth.visacli.sh jest --config jest.smoke.config.js","test:integration":"jest --config jest.integration.config.js","test:e2e":"jest --config jest.e2e.config.js","test:catalog-e2e":"jest --config jest.catalog-e2e.config.js","test:all":"npm run test:unit && npm run test:integration && npm run test:e2e",prepublishOnly:"npm run build && npm test",lint:"eslint src/**/*.ts",format:'prettier --write "src/**/*.ts"',"format:check":'prettier --check "src/**/*.ts"'},keywords:["visa","checkout","mcp","ai-agent","payments","click-to-pay","usdc","stablecoin"],author:"Visa Crypto Labs",license:"SEE LICENSE IN LICENSE",dependencies:{"@modelcontextprotocol/sdk":"^1.0.0",commander:"^12.1.0",zod:"^3.23.0"},devDependencies:{"@visa-cli/tools":"workspace:*","@changesets/changelog-git":"^0.2.1","@changesets/cli":"^2.31.0","@types/jest":"^30.0.0","@types/node":"^25.6.0","@typescript-eslint/eslint-plugin":"^8.59.0","@typescript-eslint/parser":"^8.59.0","@types/express":"^5.0.0",esbuild:"^0.27.4",express:"^4.21.0",eslint:"^10.0.2","eslint-config-prettier":"^10.1.8",jest:"^29.7.0",prettier:"^3.8.3","ts-jest":"^29.2.0",typescript:"^5.7.0"},engines:{node:">=18.0.0"},mcpName:"io.github.visa-crypto-labs/visa-cli",files:["bin/visa-cli.js","dist/","install.ps1","native/visa-keychain.m","server.json","README.md","LICENSE"]}});var Vn=require("@modelcontextprotocol/sdk/server/index.js"),Hn=require("@modelcontextprotocol/sdk/server/stdio.js"),ae=require("@modelcontextprotocol/sdk/types.js");Qt();var ts=/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/;function St(r,e){let t=Ar(r),n=Ar(e);if(!t||!n)return!1;for(let s=0;s<3;s++)if(t.main[s]!==n.main[s])return t.main[s]>n.main[s];return t.pre&&!n.pre?!1:!t.pre&&n.pre?!0:!t.pre&&!n.pre?!1:rs(t.pre,n.pre)>0}function Ar(r){if(typeof r!="string")return null;let t=r.trim().replace(/^v/,"").match(ts);return t?{main:[Number(t[1]),Number(t[2]),Number(t[3])],pre:t[4]??null}:null}function rs(r,e){let t=r.split("."),n=e.split("."),s=Math.max(t.length,n.length);for(let i=0;i<s;i++){if(i>=t.length)return-1;if(i>=n.length)return 1;let a=t[i],o=n[i],c=/^\d+$/.test(a),u=/^\d+$/.test(o);if(c&&u){let d=Number(a)-Number(o);if(d!==0)return d}else{if(c)return-1;if(u)return 1;if(a<o)return-1;if(a>o)return 1}}return 0}function Ge(){return!!(Cr(process.env.VISA_CLI_NO_UPDATE_CHECK)||Cr(process.env.CI)||process.env.NODE_ENV==="test")}function Cr(r){if(r===void 0)return!1;let e=r.trim().toLowerCase();return!(e===""||e==="0"||e==="false"||e==="no"||e==="off")}var ge=I(require("fs")),Pr=I(require("path"));var Tt=I(require("fs")),Or=I(require("path")),Nr=I(require("os"));var er=Or.join(Nr.homedir(),".visa-mcp"),Y=class{static ensureConfigDir(){Tt.existsSync(er)||Tt.mkdirSync(er,{recursive:!0,mode:448})}static getConfigDir(){return er}static TOOL_STATES={login:!0,get_status:!0,get_cards:!0,add_card:!0,pay:!0,transaction_history:!0,update_spending_controls:!0,enroll_device:!1,verify_otp:!1,reset:!0,batch:!0,generate_x402_image:!1,browser_launch:!1,browser_navigate:!1,browser_snapshot:!1,browser_click:!1,browser_type:!1,browser_scroll:!1,generate_music_card:!1,generate_image_card:!0,query_onchain_prices_card:!0,generate_music_tempo_card:!0,check_music_status_tempo_card:!0,generate_image_fast_card:!0,pxlwall_card:!1,generate_video_tempo_card:!0};static loadToolStates(){return{...this.TOOL_STATES}}static getDisabledTools(){let e=new Set;for(let[t,n]of Object.entries(this.TOOL_STATES))n||e.add(t);return e}static isToolDisabled(e){return this.TOOL_STATES[e]===!1}};var ns="settings.json";function Rt(){return Pr.join(Y.getConfigDir(),ns)}var Ye={"auth.serverUrl":{type:"string",description:"Auth server base URL. Override for staging / self-hosted backends.",requiresRestart:!0,validate:r=>{if(typeof r!="string")throw new Error("auth.serverUrl must be a string");let e;try{e=new URL(r)}catch{throw new Error(`auth.serverUrl must be a valid URL (got: ${JSON.stringify(r)})`)}if(e.protocol!=="https:"&&e.protocol!=="http:")throw new Error(`auth.serverUrl must use http or https (got: ${e.protocol})`)}},"ui.suppressBrowser":{type:"boolean",description:"When true, the CLI/MCP server stops auto-opening result URLs in your browser."},"ui.suppressFeed":{type:"boolean",description:"When true, generated images/music are not auto-submitted to the public Made-with-Visa feed."},"tools.meta":{type:"boolean",description:"Show category meta-tools (generate_image, generate_music, ...). Restart required.",requiresRestart:!0},"tools.specific":{type:"boolean",description:"Show hardcoded per-merchant tools (generate_image_card, query_onchain_prices_card, ...). Restart required.",requiresRestart:!0},"tools.discover":{type:"boolean",description:"Show the dynamic-catalog tools (discover_tools, execute_tool). Restart required.",requiresRestart:!0}};function It(){let r=Rt();if(!ge.existsSync(r))return{};try{let e=ge.readFileSync(r,"utf-8"),t=JSON.parse(e);return!t||typeof t!="object"||Array.isArray(t)?{}:t}catch{return{}}}function Lr(r){Y.ensureConfigDir();let e=Rt(),t=`${e}.tmp`,n=JSON.stringify(r,null,2)+`
3
- `;ge.writeFileSync(t,n,{mode:384}),ge.renameSync(t,e)}function tr(r){let e=It()[r];return typeof e=="string"?e:void 0}function Re(r){let e=It()[r];if(typeof e=="boolean")return e;if(e==="true")return!0;if(e==="false")return!1}var Se=class extends Error{constructor(e){let t=Object.keys(Ye).sort().join(", ");super(`Unknown setting "${e}". Settable keys: ${t}. For server-controlled values (biometric.*, spending.*) use the dedicated tools (biometric_on/off, update_spending_controls).`),this.name="UnknownSettingKeyError"}},Te=class extends Error{constructor(e){let t="";e.startsWith("biometric.")?t="biometric_on / biometric_off":e.startsWith("spending.")?t="update_spending_controls":e.startsWith("cards.")?t="add_card / remove_card / set_default_card":e.startsWith("account.")&&(t="login / reset"),super(`"${e}" is a server-controlled value and cannot be set via config set. `+(t?`Use ${t} instead.`:"No client-side override is supported.")),this.name="ServerOnlySettingError"}},$r=["biometric.","spending.","account.","cards.","biometric"];function Ur(r,e){if($r.some(i=>r.startsWith(i)))throw new Te(r);let t=Ye[r];if(!t)throw new Se(r);let n;if(t.type==="boolean")if(typeof e=="boolean")n=e;else if(typeof e=="string"){let i=e.toLowerCase();if(i==="true")n=!0;else if(i==="false")n=!1;else throw new Error(`${r} expects true or false (got: ${JSON.stringify(e)})`)}else throw new Error(`${r} expects a boolean (got: ${typeof e})`);else{if(typeof e!="string"||e.length===0)throw new Error(`${r} expects a non-empty string`);n=e}t.validate&&t.validate(n);let s=It();return s[r]=n,Lr(s),{key:r,value:n,requiresRestart:!!t.requiresRestart,path:Rt()}}function jr(r){if($r.some(s=>r.startsWith(s)))throw new Te(r);let e=Ye[r];if(!e)throw new Se(r);let t=It(),n=r in t;return n&&(delete t[r],Lr(t)),{key:r,removed:n,requiresRestart:n&&!!e.requiresRestart,path:Rt()}}var ss="https://auth.visacli.sh";function Je(){let r=process.env.VISA_AUTH_URL;if(r!==void 0&&r!=="")return r;let e=tr("auth.serverUrl");return e!==void 0?e:ss}function qr(){let r=process.env.VISA_SUPPRESS_BROWSER;return r!==void 0?r==="true":Re("ui.suppressBrowser")??!1}function Mr(){let r=process.env.VISA_SUPPRESS_FEED;return r!==void 0?r==="true":Re("ui.suppressFeed")??!1}function Xe(){let r=process.env.VISA_META_TOOLS;return r!==void 0?r!=="false":Re("tools.meta")??!0}function Qe(){let r=process.env.VISA_SPECIFIC_TOOLS;return r!==void 0?r!=="false":Re("tools.specific")??!0}function et(){let r=process.env.VISA_DISCOVER_TOOLS;return r!==void 0?r!=="false":Re("tools.discover")??!0}var rr="1.8.0-rc.3",Et=class{constructor(e){this.getSessionToken=e;this.baseUrl=Je()}getSessionToken;baseUrl;lastSignals={};parseServerSignals(e){if(this.lastSignals={},!Ge()){let n=e.headers.get("X-Latest-Version"),s=e.headers.get("X-Update-Message");n&&St(n,rr)&&(this.lastSignals.updateAvailable={version:n,message:s||`Update available: v${n}. Run: npm install -g @visa/cli && visa-cli setup`})}let t=e.headers.get("X-Feedback-Prompt");if(t)try{this.lastSignals.feedbackPrompt=JSON.parse(t)}catch{}}getClientVersion(){return rr}async request(e,t,n,s,i){let a=await this.getSessionToken();if(!a)throw new Error("Not logged in. Sign up at https://visacli.sh or run: visa-cli setup");let o={Authorization:`Bearer ${a}`};i&&(e==="GET"?o["X-User-Context"]=i.replace(/[\r\n\0]/g," ").slice(0,1e3):n={...n||{},user_context:i}),n&&(o["Content-Type"]="application/json");let c;try{c=await Xt(`${this.baseUrl}${t}`,{method:e,headers:{...o,"X-Visa-CLI-Version":rr},body:n?JSON.stringify(n):void 0,timeoutMs:s})}catch(d){throw d.name==="AbortError"||d.message?.includes("aborted")?new Error("The request timed out. The server may be under heavy load. Please try again."):new Error("Cannot reach the Visa CLI server. Check your internet connection and try again.")}if(this.parseServerSignals(c),c.status===401)throw new Error("Your session has expired. Run: visa-cli setup");if(c.status===429){let d=c.headers.get("Retry-After")||"3";throw new Error(`Rate limited \u2014 wait ${d}s. Tip: use the batch tool to combine multiple requests into one.`)}if(c.status===503)throw new Error("Visa CLI is temporarily unavailable. Check https://visacli.sh for status.");let u;try{u=await c.json()}catch{throw c.status===500?new Error(`Server error on ${t}. Try again or check https://visacli.sh for status.`):new Error(`Unexpected response from ${t}. Try again.`)}if(!c.ok)throw c.status===500?new Error(`Server error on ${t}. Try again or check https://visacli.sh for status.`):new Error(u?.error||`Request failed (${c.status}). Try again.`);return u}async pay(e,t){return this.request("POST","/v1/pay",e,void 0,t)}async shortcut(e,t,n,s){return this.request("POST",`/v1/shortcuts/${encodeURIComponent(e)}`,t,n,s)}async batch(e,t,n){return this.request("POST","/v1/batch",e,t,n)}async catalogSearch(e,t){let n=new URLSearchParams;e&&n.set("q",e),t&&n.set("category",t);let s=n.toString();return this.request("GET",`/v1/catalog${s?`?${s}`:""}`)}async catalogTool(e){try{return await this.request("GET",`/v1/catalog/${encodeURIComponent(e)}`)}catch{return null}}async paymentPreview(e,t){return this.request("POST","/v1/payment-preview",e,void 0,t)}async getStatus(e){return this.request("GET","/v1/status",void 0,void 0,e)}async getTransactions(e){return this.request("GET","/v1/transactions",void 0,void 0,e)}async updateSpendingControls(e,t){return this.request("POST","/v1/spending-controls",e,void 0,t)}async removeCard(e,t,n){return this.request("DELETE",`/v1/cards/${encodeURIComponent(String(e))}`,t,void 0,n)}async setDefaultCard(e,t,n){return this.request("POST",`/v1/cards/${encodeURIComponent(String(e))}/default`,t,void 0,n)}async getAttestationChallenge(){return this.request("GET","/v1/attestation-challenge")}async registerAttestationKey(e){return this.request("POST","/v1/attestation-key",{publicKey:e})}async setBiometricPreference(e,t){return this.request("POST","/v1/biometric-preference",{...e,confirm:!0},void 0,t)}async logout(e,t){return this.request("POST","/v1/logout",e,void 0,t)}async feedback(e,t,n){return this.request("POST","/v1/feedback",{message:e,...t&&{transaction_id:t}},void 0,n)}async feedSubmit(e){return this.request("POST","/v1/feed",e)}async feedList(e){let t=new URLSearchParams;e?.tab&&t.set("tab",e.tab),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let n=t.toString();return this.request("GET",`/v1/feed${n?"?"+n:""}`)}async feedVote(e,t){return this.request("POST",`/v1/feed/${encodeURIComponent(e)}/vote`,{direction:t})}async feedApprove(e){return this.request("POST",`/v1/feed/${encodeURIComponent(e)}/approve`)}async feedDelete(e){return this.request("DELETE",`/v1/feed/${encodeURIComponent(e)}`)}async feedPending(){return this.request("GET","/v1/feed/pending")}async submitFeedback(e,t,n){return this.request("POST","/v1/feedback",{message:e,...t&&{transaction_id:t}},void 0,n)}async getFeedback(e,t){let n=new URLSearchParams;e&&n.set("limit",String(e));let s=n.toString();return this.request("GET",`/v1/feedback${s?"?"+s:""}`,void 0,void 0,t)}async submitRatedFeedback(e){return this.request("POST","/v1/feedback",e)}};var or=require("child_process"),Wr=require("util"),Kr=I(require("crypto")),L=I(require("fs")),zr=I(require("os")),Q=I(require("path"));var D=I(require("fs")),ir=I(require("path")),Dr=I(require("os")),sr=ir.join(Dr.homedir(),".visa-mcp"),dt=ir.join(sr,"mcp-server.log"),is=5*1024*1024,nr=null;function as(){D.existsSync(sr)||D.mkdirSync(sr,{recursive:!0,mode:448})}function os(){if(!nr){if(as(),D.existsSync(dt)&&D.statSync(dt).size>is){let e=dt+".1";D.existsSync(e)&&D.unlinkSync(e),D.renameSync(dt,e)}nr=D.createWriteStream(dt,{flags:"a"})}return nr}function At(r,...e){let t=new Date().toISOString(),n=e.map(i=>typeof i=="string"?i:JSON.stringify(i,null,2)).join(" "),s=`[${t}] [${r}] ${n}
2
+ "use strict";var zn=Object.create;var Jt=Object.defineProperty;var Zn=Object.getOwnPropertyDescriptor;var Gn=Object.getOwnPropertyNames;var Yn=Object.getPrototypeOf,Jn=Object.prototype.hasOwnProperty;var Xn=(r,e)=>()=>(r&&(e=r(r=0)),e);var Qn=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Ir=(r,e)=>{for(var t in e)Jt(r,t,{get:e[t],enumerable:!0})},es=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Gn(e))!Jn.call(r,s)&&s!==t&&Jt(r,s,{get:()=>e[s],enumerable:!(n=Zn(e,s))||n.enumerable});return r};var I=(r,e,t)=>(t=r!=null?zn(Yn(r)):{},es(e||!r||!r.__esModule?Jt(t,"default",{value:r,enumerable:!0}):t,r));var Er={};Ir(Er,{fetchWithTimeout:()=>Xt});async function Xt(r,e){let t=e?.timeoutMs??3e4,n=new AbortController,s=setTimeout(()=>n.abort(),t);try{let{timeoutMs:i,...a}=e??{};return await fetch(r,{...a,signal:n.signal})}finally{clearTimeout(s)}}var Qt=Xn(()=>{"use strict"});var Un=Qn((kc,Za)=>{Za.exports={name:"@visa/cli",version:"1.8.0",description:"AI-powered payments for Claude Code",bin:{"visa-cli":"./bin/visa-cli.js"},scripts:{build:"tsc --noEmit && node esbuild.config.js",dev:"tsc --watch",start:"node dist/mcp-server/index.js",test:"jest --config jest.config.js","test:unit":"jest --config jest.config.js","test:unit:watch":"jest --config jest.config.js --watch","test:unit:coverage":"jest --config jest.config.js --coverage","test:smoke":"VISA_AUTH_URL=https://auth.visacli.sh jest --config jest.smoke.config.js","test:integration":"jest --config jest.integration.config.js","test:e2e":"jest --config jest.e2e.config.js","test:catalog-e2e":"jest --config jest.catalog-e2e.config.js","test:all":"npm run test:unit && npm run test:integration && npm run test:e2e",prepublishOnly:"npm run build && npm test",lint:"eslint src/**/*.ts",format:'prettier --write "src/**/*.ts"',"format:check":'prettier --check "src/**/*.ts"'},keywords:["visa","checkout","mcp","ai-agent","payments","click-to-pay","usdc","stablecoin"],author:"Visa Crypto Labs",license:"SEE LICENSE IN LICENSE",dependencies:{"@modelcontextprotocol/sdk":"^1.0.0",commander:"^12.1.0",zod:"^3.23.0"},devDependencies:{"@visa-cli/tools":"workspace:*","@changesets/changelog-git":"^0.2.1","@changesets/cli":"^2.31.0","@types/jest":"^30.0.0","@types/node":"^25.6.0","@typescript-eslint/eslint-plugin":"^8.59.0","@typescript-eslint/parser":"^8.59.0","@types/express":"^5.0.0",esbuild:"^0.27.4",express:"^4.21.0",eslint:"^10.0.2","eslint-config-prettier":"^10.1.8",jest:"^29.7.0",prettier:"^3.8.3","ts-jest":"^29.2.0",typescript:"^5.7.0"},engines:{node:">=18.0.0"},mcpName:"io.github.visa-crypto-labs/visa-cli",files:["bin/visa-cli.js","dist/","install.ps1","native/visa-keychain.m","server.json","README.md","LICENSE"]}});var Vn=require("@modelcontextprotocol/sdk/server/index.js"),Hn=require("@modelcontextprotocol/sdk/server/stdio.js"),ae=require("@modelcontextprotocol/sdk/types.js");Qt();var ts=/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/;function St(r,e){let t=Ar(r),n=Ar(e);if(!t||!n)return!1;for(let s=0;s<3;s++)if(t.main[s]!==n.main[s])return t.main[s]>n.main[s];return t.pre&&!n.pre?!1:!t.pre&&n.pre?!0:!t.pre&&!n.pre?!1:rs(t.pre,n.pre)>0}function Ar(r){if(typeof r!="string")return null;let t=r.trim().replace(/^v/,"").match(ts);return t?{main:[Number(t[1]),Number(t[2]),Number(t[3])],pre:t[4]??null}:null}function rs(r,e){let t=r.split("."),n=e.split("."),s=Math.max(t.length,n.length);for(let i=0;i<s;i++){if(i>=t.length)return-1;if(i>=n.length)return 1;let a=t[i],o=n[i],c=/^\d+$/.test(a),u=/^\d+$/.test(o);if(c&&u){let d=Number(a)-Number(o);if(d!==0)return d}else{if(c)return-1;if(u)return 1;if(a<o)return-1;if(a>o)return 1}}return 0}function Ge(){return!!(Cr(process.env.VISA_CLI_NO_UPDATE_CHECK)||Cr(process.env.CI)||process.env.NODE_ENV==="test")}function Cr(r){if(r===void 0)return!1;let e=r.trim().toLowerCase();return!(e===""||e==="0"||e==="false"||e==="no"||e==="off")}var ge=I(require("fs")),Pr=I(require("path"));var Tt=I(require("fs")),Or=I(require("path")),Nr=I(require("os"));var er=Or.join(Nr.homedir(),".visa-mcp"),Y=class{static ensureConfigDir(){Tt.existsSync(er)||Tt.mkdirSync(er,{recursive:!0,mode:448})}static getConfigDir(){return er}static TOOL_STATES={login:!0,get_status:!0,get_cards:!0,add_card:!0,pay:!0,transaction_history:!0,update_spending_controls:!0,enroll_device:!1,verify_otp:!1,reset:!0,batch:!0,generate_x402_image:!1,browser_launch:!1,browser_navigate:!1,browser_snapshot:!1,browser_click:!1,browser_type:!1,browser_scroll:!1,generate_music_card:!1,generate_image_card:!0,query_onchain_prices_card:!0,generate_music_tempo_card:!0,check_music_status_tempo_card:!0,generate_image_fast_card:!0,pxlwall_card:!1,generate_video_tempo_card:!0};static loadToolStates(){return{...this.TOOL_STATES}}static getDisabledTools(){let e=new Set;for(let[t,n]of Object.entries(this.TOOL_STATES))n||e.add(t);return e}static isToolDisabled(e){return this.TOOL_STATES[e]===!1}};var ns="settings.json";function Rt(){return Pr.join(Y.getConfigDir(),ns)}var Ye={"auth.serverUrl":{type:"string",description:"Auth server base URL. Override for staging / self-hosted backends.",requiresRestart:!0,validate:r=>{if(typeof r!="string")throw new Error("auth.serverUrl must be a string");let e;try{e=new URL(r)}catch{throw new Error(`auth.serverUrl must be a valid URL (got: ${JSON.stringify(r)})`)}if(e.protocol!=="https:"&&e.protocol!=="http:")throw new Error(`auth.serverUrl must use http or https (got: ${e.protocol})`)}},"ui.suppressBrowser":{type:"boolean",description:"When true, the CLI/MCP server stops auto-opening result URLs in your browser."},"ui.suppressFeed":{type:"boolean",description:"When true, generated images/music are not auto-submitted to the public Made-with-Visa feed."},"tools.meta":{type:"boolean",description:"Show category meta-tools (generate_image, generate_music, ...). Restart required.",requiresRestart:!0},"tools.specific":{type:"boolean",description:"Show hardcoded per-merchant tools (generate_image_card, query_onchain_prices_card, ...). Restart required.",requiresRestart:!0},"tools.discover":{type:"boolean",description:"Show the dynamic-catalog tools (discover_tools, execute_tool). Restart required.",requiresRestart:!0}};function It(){let r=Rt();if(!ge.existsSync(r))return{};try{let e=ge.readFileSync(r,"utf-8"),t=JSON.parse(e);return!t||typeof t!="object"||Array.isArray(t)?{}:t}catch{return{}}}function Lr(r){Y.ensureConfigDir();let e=Rt(),t=`${e}.tmp`,n=JSON.stringify(r,null,2)+`
3
+ `;ge.writeFileSync(t,n,{mode:384}),ge.renameSync(t,e)}function tr(r){let e=It()[r];return typeof e=="string"?e:void 0}function Re(r){let e=It()[r];if(typeof e=="boolean")return e;if(e==="true")return!0;if(e==="false")return!1}var Se=class extends Error{constructor(e){let t=Object.keys(Ye).sort().join(", ");super(`Unknown setting "${e}". Settable keys: ${t}. For server-controlled values (biometric.*, spending.*) use the dedicated tools (biometric_on/off, update_spending_controls).`),this.name="UnknownSettingKeyError"}},Te=class extends Error{constructor(e){let t="";e.startsWith("biometric.")?t="biometric_on / biometric_off":e.startsWith("spending.")?t="update_spending_controls":e.startsWith("cards.")?t="add_card / remove_card / set_default_card":e.startsWith("account.")&&(t="login / reset"),super(`"${e}" is a server-controlled value and cannot be set via config set. `+(t?`Use ${t} instead.`:"No client-side override is supported.")),this.name="ServerOnlySettingError"}},$r=["biometric.","spending.","account.","cards.","biometric"];function Ur(r,e){if($r.some(i=>r.startsWith(i)))throw new Te(r);let t=Ye[r];if(!t)throw new Se(r);let n;if(t.type==="boolean")if(typeof e=="boolean")n=e;else if(typeof e=="string"){let i=e.toLowerCase();if(i==="true")n=!0;else if(i==="false")n=!1;else throw new Error(`${r} expects true or false (got: ${JSON.stringify(e)})`)}else throw new Error(`${r} expects a boolean (got: ${typeof e})`);else{if(typeof e!="string"||e.length===0)throw new Error(`${r} expects a non-empty string`);n=e}t.validate&&t.validate(n);let s=It();return s[r]=n,Lr(s),{key:r,value:n,requiresRestart:!!t.requiresRestart,path:Rt()}}function jr(r){if($r.some(s=>r.startsWith(s)))throw new Te(r);let e=Ye[r];if(!e)throw new Se(r);let t=It(),n=r in t;return n&&(delete t[r],Lr(t)),{key:r,removed:n,requiresRestart:n&&!!e.requiresRestart,path:Rt()}}var ss="https://auth.visacli.sh";function Je(){let r=process.env.VISA_AUTH_URL;if(r!==void 0&&r!=="")return r;let e=tr("auth.serverUrl");return e!==void 0?e:ss}function qr(){let r=process.env.VISA_SUPPRESS_BROWSER;return r!==void 0?r==="true":Re("ui.suppressBrowser")??!1}function Mr(){let r=process.env.VISA_SUPPRESS_FEED;return r!==void 0?r==="true":Re("ui.suppressFeed")??!1}function Xe(){let r=process.env.VISA_META_TOOLS;return r!==void 0?r!=="false":Re("tools.meta")??!0}function Qe(){let r=process.env.VISA_SPECIFIC_TOOLS;return r!==void 0?r!=="false":Re("tools.specific")??!0}function et(){let r=process.env.VISA_DISCOVER_TOOLS;return r!==void 0?r!=="false":Re("tools.discover")??!0}var rr="1.8.0",Et=class{constructor(e){this.getSessionToken=e;this.baseUrl=Je()}getSessionToken;baseUrl;lastSignals={};parseServerSignals(e){if(this.lastSignals={},!Ge()){let n=e.headers.get("X-Latest-Version"),s=e.headers.get("X-Update-Message");n&&St(n,rr)&&(this.lastSignals.updateAvailable={version:n,message:s||`Update available: v${n}. Run: npm install -g @visa/cli && visa-cli setup`})}let t=e.headers.get("X-Feedback-Prompt");if(t)try{this.lastSignals.feedbackPrompt=JSON.parse(t)}catch{}}getClientVersion(){return rr}async request(e,t,n,s,i){let a=await this.getSessionToken();if(!a)throw new Error("Not logged in. Sign up at https://visacli.sh or run: visa-cli setup");let o={Authorization:`Bearer ${a}`};i&&(e==="GET"?o["X-User-Context"]=i.replace(/[\r\n\0]/g," ").slice(0,1e3):n={...n||{},user_context:i}),n&&(o["Content-Type"]="application/json");let c;try{c=await Xt(`${this.baseUrl}${t}`,{method:e,headers:{...o,"X-Visa-CLI-Version":rr},body:n?JSON.stringify(n):void 0,timeoutMs:s})}catch(d){throw d.name==="AbortError"||d.message?.includes("aborted")?new Error("The request timed out. The server may be under heavy load. Please try again."):new Error("Cannot reach the Visa CLI server. Check your internet connection and try again.")}if(this.parseServerSignals(c),c.status===401)throw new Error("Your session has expired. Run: visa-cli setup");if(c.status===429){let d=c.headers.get("Retry-After")||"3";throw new Error(`Rate limited \u2014 wait ${d}s. Tip: use the batch tool to combine multiple requests into one.`)}if(c.status===503)throw new Error("Visa CLI is temporarily unavailable. Check https://visacli.sh for status.");let u;try{u=await c.json()}catch{throw c.status===500?new Error(`Server error on ${t}. Try again or check https://visacli.sh for status.`):new Error(`Unexpected response from ${t}. Try again.`)}if(!c.ok)throw c.status===500?new Error(`Server error on ${t}. Try again or check https://visacli.sh for status.`):new Error(u?.error||`Request failed (${c.status}). Try again.`);return u}async pay(e,t){return this.request("POST","/v1/pay",e,void 0,t)}async shortcut(e,t,n,s){return this.request("POST",`/v1/shortcuts/${encodeURIComponent(e)}`,t,n,s)}async batch(e,t,n){return this.request("POST","/v1/batch",e,t,n)}async catalogSearch(e,t){let n=new URLSearchParams;e&&n.set("q",e),t&&n.set("category",t);let s=n.toString();return this.request("GET",`/v1/catalog${s?`?${s}`:""}`)}async catalogTool(e){try{return await this.request("GET",`/v1/catalog/${encodeURIComponent(e)}`)}catch{return null}}async paymentPreview(e,t){return this.request("POST","/v1/payment-preview",e,void 0,t)}async getStatus(e){return this.request("GET","/v1/status",void 0,void 0,e)}async getTransactions(e){return this.request("GET","/v1/transactions",void 0,void 0,e)}async updateSpendingControls(e,t){return this.request("POST","/v1/spending-controls",e,void 0,t)}async removeCard(e,t,n){return this.request("DELETE",`/v1/cards/${encodeURIComponent(String(e))}`,t,void 0,n)}async setDefaultCard(e,t,n){return this.request("POST",`/v1/cards/${encodeURIComponent(String(e))}/default`,t,void 0,n)}async getAttestationChallenge(){return this.request("GET","/v1/attestation-challenge")}async registerAttestationKey(e){return this.request("POST","/v1/attestation-key",{publicKey:e})}async setBiometricPreference(e,t){return this.request("POST","/v1/biometric-preference",{...e,confirm:!0},void 0,t)}async logout(e,t){return this.request("POST","/v1/logout",e,void 0,t)}async feedback(e,t,n){return this.request("POST","/v1/feedback",{message:e,...t&&{transaction_id:t}},void 0,n)}async feedSubmit(e){return this.request("POST","/v1/feed",e)}async feedList(e){let t=new URLSearchParams;e?.tab&&t.set("tab",e.tab),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let n=t.toString();return this.request("GET",`/v1/feed${n?"?"+n:""}`)}async feedVote(e,t){return this.request("POST",`/v1/feed/${encodeURIComponent(e)}/vote`,{direction:t})}async feedApprove(e){return this.request("POST",`/v1/feed/${encodeURIComponent(e)}/approve`)}async feedDelete(e){return this.request("DELETE",`/v1/feed/${encodeURIComponent(e)}`)}async feedPending(){return this.request("GET","/v1/feed/pending")}async submitFeedback(e,t,n){return this.request("POST","/v1/feedback",{message:e,...t&&{transaction_id:t}},void 0,n)}async getFeedback(e,t){let n=new URLSearchParams;e&&n.set("limit",String(e));let s=n.toString();return this.request("GET",`/v1/feedback${s?"?"+s:""}`,void 0,void 0,t)}async submitRatedFeedback(e){return this.request("POST","/v1/feedback",e)}};var or=require("child_process"),Wr=require("util"),Kr=I(require("crypto")),L=I(require("fs")),zr=I(require("os")),Q=I(require("path"));var D=I(require("fs")),ir=I(require("path")),Dr=I(require("os")),sr=ir.join(Dr.homedir(),".visa-mcp"),dt=ir.join(sr,"mcp-server.log"),is=5*1024*1024,nr=null;function as(){D.existsSync(sr)||D.mkdirSync(sr,{recursive:!0,mode:448})}function os(){if(!nr){if(as(),D.existsSync(dt)&&D.statSync(dt).size>is){let e=dt+".1";D.existsSync(e)&&D.unlinkSync(e),D.renameSync(dt,e)}nr=D.createWriteStream(dt,{flags:"a"})}return nr}function At(r,...e){let t=new Date().toISOString(),n=e.map(i=>typeof i=="string"?i:JSON.stringify(i,null,2)).join(" "),s=`[${t}] [${r}] ${n}
4
4
  `;process.stderr.write(s),os().write(s)}var l={debug:(...r)=>At("DEBUG",...r),info:(...r)=>At("INFO",...r),warn:(...r)=>At("WARN",...r),error:(...r)=>At("ERROR",...r)};var tt=(0,Wr.promisify)(or.execFile),Nt=Q.join(zr.homedir(),".visa-mcp","bin"),Ie=Q.join(Nt,"Visa CLI"),cs=Q.join(__dirname,"..","native"),Vr="5",Hr=Q.join(Nt,"visa-keychain.version"),Fr=Q.join(Nt,"visa-keychain.sha256");function Br(r){let e=L.readFileSync(r);return Kr.createHash("sha256").update(e).digest("hex")}async function Zr(){try{if(L.readFileSync(Hr,"utf-8").trim()===Vr&&L.existsSync(Ie)){let n=L.readFileSync(Fr,"utf-8").trim();if(Br(Ie)!==n)l.warn("binary:hash-mismatch",{message:"Binary hash mismatch \u2014 possible tampering detected. Recompiling from source."}),L.unlinkSync(Ie);else return Ie}}catch{}let r=Q.join(cs,"visa-keychain.m");if(L.existsSync(r)||(r=Q.resolve(__dirname,"..","..","native","visa-keychain.m")),L.existsSync(r)||(r=Q.resolve(__dirname,"..","native","visa-keychain.m")),!L.existsSync(r))throw new Error("visa-keychain.m source not found. Reinstall Visa CLI.");L.mkdirSync(Nt,{recursive:!0,mode:448});try{await tt("clang",["-framework","Security","-framework","LocalAuthentication","-framework","Foundation","-framework","AppKit","-o",Ie,r],{timeout:3e4})}catch(t){throw t.code==="ENOENT"?new Error("Xcode Command Line Tools required. Install: xcode-select --install"):t}let e=Br(Ie);return L.writeFileSync(Fr,e,{mode:384}),L.writeFileSync(Hr,Vr,{mode:384}),Ie}async function Gr(r){let e=await Zr(),t;try{t=(await tt(e,r,{timeout:6e4})).stdout}catch(i){t=i.stdout||"";let a=t.trim();throw a.startsWith("ERROR:")?new Error(a.slice(6)):new Error(i.stderr?.trim()||i.message||"Unknown error")}let n=t.trim();if(n.startsWith("OK:"))return n.slice(3);if(n==="OK")return;let s=n.startsWith("ERROR:")?n.slice(6):"Unknown error";throw new Error(s)}var ar=null;function le(){return process.env.VISA_MOCK_TOUCHID==="true"?!0:process.platform!=="darwin"?!1:ar!==null?ar:(ar=!0,!0)}var Ct="visa-cli",Ot="attestation-key";async function us(r){try{await tt("security",["delete-generic-password","-s",Ct,"-a",Ot],{timeout:5e3})}catch{}await tt("security",["add-generic-password","-s",Ct,"-a",Ot,"-w",r],{timeout:5e3})}async function ls(){try{let{stdout:r}=await tt("security",["find-generic-password","-s",Ct,"-a",Ot,"-w"],{timeout:5e3});return r.trim()||null}catch{return null}}async function Yr(){let r=await Gr(["generate-key"]);if(!r)throw new Error("Key generation returned no output");let e=r.indexOf(":");if(e<0)throw new Error("Unexpected generate-key output format");let t=r.slice(0,e),n=r.slice(e+1);return await us(t),n}async function Jr(r,e){if(process.env.VISA_MOCK_TOUCHID==="true")return Promise.resolve("mock-ecdsa-signature-for-testing");let t=await ls();if(!t)throw new Error("Attestation key not found. Run setup to generate a new key.");let n=await Zr(),s=["sign",r];return e&&s.push(e),new Promise((i,a)=>{let o=(0,or.execFile)(n,s,{timeout:6e4},(c,u)=>{let d=(u||"").trim();if(c){d.startsWith("ERROR:")?a(new Error(d.slice(6))):a(new Error(c.stderr?.trim()||c.message||"Unknown error"));return}d.startsWith("OK:")?i(d.slice(3)):a(new Error(d.startsWith("ERROR:")?d.slice(6):"Unknown error"))});o.stdin.write(t),o.stdin.end()})}async function Xr(){try{await tt("security",["delete-generic-password","-s",Ct,"-a",Ot],{timeout:5e3})}catch{}try{await Gr(["delete-key"])}catch{}}var $t=require("child_process"),Qr=require("util"),_e=I(require("fs")),Ut=I(require("os")),pr=I(require("path")),ee=(0,Qr.promisify)($t.execFile),mr=pr.join(Ut.homedir(),".visa-mcp"),Pt=pr.join(mr,"session-token"),K="visa-cli",ye="session-token",Lt="rc-access",ds=5e3;async function ps(){try{let{stdout:r}=await ee("security",["find-generic-password","-s",K,"-a",ye,"-w"],{timeout:5e3});return r.trim()||null}catch{return null}}async function ms(r){try{try{await ee("security",["delete-generic-password","-s",K,"-a",ye],{timeout:5e3})}catch{}return await ee("security",["add-generic-password","-s",K,"-a",ye,"-w",r],{timeout:5e3}),!0}catch{return!1}}async function fs(){try{await ee("security",["delete-generic-password","-s",K,"-a",ye],{timeout:5e3})}catch{}}async function hs(){if(!fr())return null;try{let{stdout:r}=await ee("secret-tool",["lookup","service",K,"account",ye],{timeout:5e3});return r.trim()||null}catch{return null}}async function gs(r){if(!fr())return!1;try{let e=(0,$t.execFile)("secret-tool",["store","--label",`${K} ${ye}`,"service",K,"account",ye]);return e.stdin?(e.stdin.write(r),e.stdin.end(),await Promise.race([new Promise((t,n)=>{e.on("exit",s=>s===0?t():n(new Error(`secret-tool exited ${s}`))),e.on("error",n)}),new Promise((t,n)=>setTimeout(()=>{e.kill(),n(new Error("secret-tool timed out"))},ds))]),!0):!1}catch{return!1}}async function ys(){if(fr())try{await ee("secret-tool",["clear","service",K,"account",ye],{timeout:5e3})}catch{}}function fr(){return!!process.env.DBUS_SESSION_BUS_ADDRESS}async function _s(){try{let{stdout:r}=await ee("security",["find-generic-password","-s",K,"-a",Lt,"-w"],{timeout:5e3});return r.trim()||null}catch{return null}}async function vs(r){try{try{await ee("security",["delete-generic-password","-s",K,"-a",Lt],{timeout:5e3})}catch{}await ee("security",["add-generic-password","-s",K,"-a",Lt,"-w",r],{timeout:5e3})}catch{}}async function bs(){try{await ee("security",["delete-generic-password","-s",K,"-a",Lt],{timeout:5e3})}catch{}}function lr(){try{return _e.readFileSync(Pt,"utf-8").trim()||null}catch{return null}}function en(r){_e.mkdirSync(mr,{recursive:!0,mode:448}),_e.writeFileSync(Pt,r,{mode:384}),process.platform==="win32"&&ws(Pt)}function dr(){try{_e.unlinkSync(Pt)}catch{}}function ws(r){try{let e=Ut.userInfo().username;(0,$t.execFile)("icacls",[r,"/inheritance:r","/grant:r",`${e}:F`],{timeout:5e3},t=>{t&&console.error(`[visa-cli] icacls ACL restriction failed: ${t.message}`)})}catch(e){console.error(`[visa-cli] Failed to invoke icacls: ${e instanceof Error?e.message:String(e)}`)}}function ur(){switch(process.platform){case"darwin":return{get:ps,store:ms,delete:fs};case"linux":return{get:hs,store:gs,delete:ys};default:return{get:async()=>lr(),store:async r=>{try{return en(r),!0}catch{return!1}},delete:async()=>dr(),storesInSessionFile:!0}}}var U=class{static async getSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return Promise.resolve("mock-session-token-for-testing");let e=ur(),t=await e.get();if(t)return t;let n=lr();return n?(await e.store(n),n):null}static async saveSessionToken(e){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;let t=ur();if(await t.store(e)){if(await t.get()===e){t.storesInSessionFile||dr();return}await t.delete()}if(en(e),lr()!==e)throw new Error("Failed to persist session token. "+(process.platform==="darwin"?'Check Keychain Access permissions for "visa-cli".':`Ensure ${mr} is writable.`))}static async getRcAccessToken(){return process.env.VISA_MOCK_KEYCHAIN==="true"?"mock-rc-token-for-testing":_s()}static async saveRcAccessToken(e){process.env.VISA_MOCK_KEYCHAIN!=="true"&&await vs(e)}static async deleteSessionToken(){if(process.env.VISA_MOCK_KEYCHAIN==="true")return;await ur().delete(),dr()}static async clearAll(){await this.deleteSessionToken(),await bs()}};var jt={generate_image:{intro:"Generate an AI image.",tiers:{balanced:{toolId:"fal-flux-pro",priceCents:4,notes:"FLUX Pro v1.1, 1K, ~10s (DEFAULT \u2014 good quality/speed tradeoff)"},fast:{toolId:"fal-flux-schnell",priceCents:1,notes:"FLUX Schnell, 1K, ~3s (drafts, iteration, cheapest)"},pro:{toolId:"fal-flux-pro-ultra",priceCents:6,notes:"FLUX Pro Ultra, 2K, ~30s (hero images, detail)"},text_heavy:{toolId:"fal-ideogram-v2",priceCents:8,notes:"Ideogram V2 \u2014 best when the image contains rendered text/logos"},vector:{toolId:"fal-recraft-v3",priceCents:5,notes:"Recraft V3 \u2014 vector/flat/illustration styles"}},guidance:"If the user didn't specify a tier, pick 'balanced' unless the prompt clearly signals otherwise (text \u2192 text_heavy, logo/icon \u2192 vector, quick test \u2192 fast, hero/print \u2192 pro).",inputProperties:{prompt:{type:"string",description:"Text description of the image to generate."},aspect_ratio:{type:"string",description:'Aspect ratio, e.g. "16:9", "1:1", "9:16".',default:"16:9"}},required:["prompt"]},generate_video:{intro:"Generate an AI video from a text prompt.",tiers:{balanced:{toolId:"fal-minimax-video",priceCents:15,notes:"MiniMax \u2014 good quality/price balance (DEFAULT)"},fast:{toolId:"fal-wan-video",priceCents:10,notes:"Wan \u2014 cheapest, shorter clips"},pro:{toolId:"fal-kling-video",priceCents:20,notes:"Kling \u2014 highest quality, cinematic"}},guidance:"Show the tier menu with prices unless the user specified one. Videos take 60-180s to generate.",inputProperties:{prompt:{type:"string",description:"Text description of the video scene."},aspect_ratio:{type:"string",description:'Aspect ratio, e.g. "16:9" or "9:16".',default:"16:9"}},required:["prompt"]},generate_music:{intro:"Generate an original music track from a prompt.",tiers:{suno:{toolId:"suno-music",priceCents:10,notes:"Suno v4 \u2014 songs with vocals, lyrics, full arrangement"}},guidance:"Takes ~60-90s. Returns an audio URL the user can play.",inputProperties:{prompt:{type:"string",description:"Musical style / mood / lyrics hint."},instrumental:{type:"boolean",description:"True for instrumental (no vocals), false for vocal track.",default:!1}},required:["prompt"]},generate_audio:{intro:"Generate speech or sound effects.",tiers:{tts:{toolId:"fal-metavoice",priceCents:3,notes:"MetaVoice \u2014 high-quality TTS from text"},sfx:{toolId:"fal-stable-audio",priceCents:4,notes:"Stable Audio \u2014 sound effects and ambient from a prompt"}},guidance:'Pick "tts" for spoken words, "sfx" for music-beds/effects/ambient.',inputProperties:{prompt:{type:"string",description:"Text to speak (tts) or description of sound (sfx)."}},required:["prompt"]},generate_3d:{intro:"Generate a 3D model from a text description.",tiers:{trellis:{toolId:"fal-trellis-3d",priceCents:8,notes:"Trellis \u2014 fast text-to-3D, returns a GLB mesh URL"}},guidance:"Takes ~30-60s. Returns a downloadable 3D mesh URL.",inputProperties:{prompt:{type:"string",description:"Description of the 3D object."}},required:["prompt"]},upscale_image:{intro:"Upscale an image to higher resolution.",tiers:{aura:{toolId:"fal-aura-sr",priceCents:3,notes:"Aura SR \u2014 default; preserves detail without hallucination"}},guidance:"Pass the existing image URL. Returns an upscaled version.",inputProperties:{image_url:{type:"string",description:"URL of the image to upscale."}},required:["image_url"]},transcribe_audio:{intro:"Transcribe speech in an audio/video URL to text.",tiers:{whisper:{toolId:"fal-whisper",priceCents:2,notes:"OpenAI Whisper \u2014 fast, multilingual"}},guidance:"Pass the URL. Returns the transcript text.",inputProperties:{audio_url:{type:"string",description:"URL of the audio or video file to transcribe."}},required:["audio_url"]},run_llm:{intro:"Run a text prompt through an LLM (OpenRouter). Token-metered \u2014 prices below are per 1M input/output tokens. Typical 500-in/500-out prompts cost 1\u20139\xA2 depending on model.",tiers:{fast:{toolId:"or-gpt-4o-mini",priceCents:1,notes:"GPT-4o Mini \u2014 $0.15/M in \xB7 $0.60/M out. Fastest, cheapest, good general-purpose (DEFAULT)"},reasoning:{toolId:"or-claude-sonnet",priceCents:9,notes:"Claude 3.5 Sonnet \u2014 $3.00/M in \xB7 $15.00/M out. Strong reasoning, long-context. ~20x pricier than `fast`."},deep_reasoning:{toolId:"or-deepseek-r1",priceCents:2,notes:"DeepSeek R1 \u2014 $0.55/M in \xB7 $2.19/M out. Deep chain-of-thought reasoning, mid-range pricing."},search:{toolId:"or-perplexity-sonar",priceCents:1,notes:"Perplexity Sonar \u2014 $1.00/M in \xB7 $1.00/M out. Search-augmented, web-grounded with citations."},open_source:{toolId:"or-llama-70b",priceCents:1,notes:"Llama 3.3 70B \u2014 $0.30/M in \xB7 $0.40/M out. Open-source large model."},coding:{toolId:"or-deepseek-chat",priceCents:1,notes:"DeepSeek Chat V3 \u2014 $0.30/M in \xB7 $0.88/M out. Strong at code generation."}},guidance:"Pick based on the user's need: fast (most questions, cheapest), reasoning (complex analysis \u2014 WARN user it's ~$0.09/call), search (questions about current events), coding (code generation), deep_reasoning (hard math/logic problems).",inputProperties:{prompt:{type:"string",description:"The user query."},system_prompt:{type:"string",description:"Optional system prompt to set model behavior."},max_tokens:{type:"number",description:"Maximum output tokens.",default:1024,minimum:1,maximum:8192},temperature:{type:"number",description:"Sampling temperature \u2014 0 is deterministic, higher is more creative.",default:.7,minimum:0,maximum:2}},required:["prompt"]}};function tn(r){let e=jt[r];if(!e)throw new Error(`Unknown meta-tool: ${r}`);let t=[e.intro,"","Tiers:"];for(let[n,s]of Object.entries(e.tiers)){let i=`$${(s.priceCents/100).toFixed(2)}`;t.push(` - ${n.padEnd(15)} ${i.padStart(6)} ${s.notes}`)}return t.push("",e.guidance),t.join(`
5
- `)}function rn(r){let e=jt[r];if(!e)throw new Error(`Unknown meta-tool: ${r}`);let t=Object.keys(e.tiers);return{type:"object",properties:{tier:{type:"string",enum:t,default:t[0],description:`Quality/style tier. Default: ${t[0]}.`},...e.inputProperties},required:e.required??[]}}function qt(r,e){if(!Ee.includes(r))return r;let t=jt[r];if(!t)return r;let n=Object.keys(t.tiers),s=e||n[0],i=t.tiers[s];if(!i)throw new Error(`Unknown tier '${s}' for ${r}. Valid tiers: ${n.join(", ")}`);return i.toolId}async function nn(r,e,t){let n=qt(r,e.tier),{tier:s,...i}=e;return C.executeTool({tool_id:n,...i},t)}var Ee=Object.keys(jt);function sn(r=process.env,e=process.platform){return r.VISA_CLI_NO_BROWSER==="1"||r.VISA_CLI_NO_BROWSER==="true"?{headless:!0,reason:"VISA_CLI_NO_BROWSER is set"}:r.CI==="true"||r.CI==="1"?{headless:!0,reason:"CI environment detected"}:r.SSH_CONNECTION||r.SSH_TTY?{headless:!0,reason:"SSH session detected"}:e==="linux"&&!r.DISPLAY&&!r.WAYLAND_DISPLAY?{headless:!0,reason:"Linux with no $DISPLAY or $WAYLAND_DISPLAY"}:{headless:!1}}function an(r,e=process.platform){return e==="darwin"?{cmd:"open",args:[r]}:e==="win32"?{cmd:"cmd",args:["/c","start","",r]}:e==="linux"?{cmd:"xdg-open",args:[r]}:null}var ht=I(require("crypto")),pn=require("child_process"),W=I(require("fs")),gt=I(require("os")),yt=I(require("path"));var xs="# visa-cli-hud-v1";function Mt(r){return typeof r!="string"?!1:r.includes(xs)?!0:r.includes("visa-cli")&&r.includes("statusline")}async function on(r,e){try{return await e()}catch(t){if(t.message==="Invalid signature"&&le()){l.warn("attestation:key-mismatch",{action:"reregistering"});try{let n=await Yr();await r.registerAttestationKey(n),l.info("attestation:key-reregistered")}catch(n){throw l.error("attestation:reregister-failure",{error:n.message}),t}return await e()}throw t}}var cn="1.8.0-rc.3";function hr(r,e){return e?{kind:"env",var:r}:{kind:"default"}}function ks(r,e,t){let n=process.env[r];if(n!==void 0&&n!=="")return{value:n,source:{kind:"env",var:r}};let s=tr(e);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:t,source:{kind:"default"}}}function pt(r,e,t){let n=process.env[r];if(n!==void 0)return{value:t==="opt-in"?n==="true":n!=="false",source:{kind:"env",var:r}};let s=Re(e);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:t!=="opt-in",source:{kind:"default"}}}function F(r){return r==null?"\u2014":r?"yes":"no"}function Dt(r){return r==null?"\u2014":`$${r.toFixed(2)}`}async function un(r){let e=null,t=null;try{e=await r.api.getStatus()}catch(A){t=A?.message||"unknown error"}let n=[],s=ks("VISA_AUTH_URL","auth.serverUrl","https://auth.visacli.sh");n.push({key:"auth.serverUrl",value:s.value,formatted:s.value,source:s.source,hint:s.source.kind==="default"?"Persist with `visa-cli config set auth.serverUrl <url>` (or set VISA_AUTH_URL for one-off overrides).":void 0}),n.push({key:"account.enrolled",value:e?.enrolled??null,formatted:F(e?.enrolled),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),e?.githubUser&&n.push({key:"account.githubUser",value:e.githubUser,formatted:e.githubUser,source:{kind:"server"}});let i=e?e.attestationRequired!==!1:void 0;n.push({key:"biometric.required",value:i,formatted:F(i),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"},hint:i===!1?"Touch ID prompts are suppressed. Re-enable with `visa-cli biometric on`.":void 0}),n.push({key:"biometric.keyRegistered",value:e?.hasAttestationKey??null,formatted:F(e?.hasAttestationKey),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"biometric.deviceAvailable",value:le(),formatted:F(le()),source:{kind:"device"}});let a=e?.spendingControls,o=a?a.max_transaction_amount??a.maxTransactionAmount??null:null,c=a?a.daily_limit??a.dailyLimit??null:null;n.push({key:"spending.maxPerTxn",value:o,formatted:Dt(o),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailyLimit",value:c,formatted:Dt(c),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailySpent",value:e?.dailySpent??null,formatted:Dt(e?.dailySpent),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailyRemaining",value:e?.dailyRemaining??null,formatted:Dt(e?.dailyRemaining),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"cards.count",value:e?.cardCount??null,formatted:e?.cardCount!=null?String(e.cardCount):"\u2014",source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}});let u=e?.cards?.find(A=>A.isDefault)??e?.cards?.[0];u&&n.push({key:"cards.default",value:{brand:u.brand??null,last4:u.last4},formatted:`${u.brand||"card"} \u2022\u2022\u2022\u2022 ${u.last4}`,source:{kind:"server"}});let d=pt("VISA_SUPPRESS_BROWSER","ui.suppressBrowser","opt-in");n.push({key:"ui.suppressBrowser",value:d.value,formatted:F(d.value),source:d.source,hint:"Persist with `visa-cli config set ui.suppressBrowser true` to stop auto-opening result URLs."});let g=pt("VISA_SUPPRESS_FEED","ui.suppressFeed","opt-in");n.push({key:"ui.suppressFeed",value:g.value,formatted:F(g.value),source:g.source});let O=Ge(),y;process.env.VISA_CLI_NO_UPDATE_CHECK?y={kind:"env",var:"VISA_CLI_NO_UPDATE_CHECK"}:process.env.CI?y={kind:"env",var:"CI"}:process.env.NODE_ENV==="test"?y={kind:"env",var:"NODE_ENV"}:y={kind:"default"},n.push({key:"ui.updateCheck",value:!O,formatted:F(!O),source:y});let he=pt("VISA_META_TOOLS","tools.meta","opt-out");n.push({key:"tools.meta",value:he.value,formatted:F(he.value),source:he.source,hint:"Persist with `visa-cli config set tools.meta false`. Restart Claude Code for changes to take effect."});let w=pt("VISA_SPECIFIC_TOOLS","tools.specific","opt-out");n.push({key:"tools.specific",value:w.value,formatted:F(w.value),source:w.source});let R=pt("VISA_DISCOVER_TOOLS","tools.discover","opt-out");if(n.push({key:"tools.discover",value:R.value,formatted:F(R.value),source:R.source}),n.push({key:"client.version",value:cn,formatted:cn,source:{kind:"default"}}),r.includeDev){let A=process.env.VISA_MOCK_KEYCHAIN;n.push({key:"dev.mockKeychain",value:A==="true",formatted:F(A==="true"),source:hr("VISA_MOCK_KEYCHAIN",!!A)});let M=process.env.VISA_MOCK_TOUCHID;n.push({key:"dev.mockTouchid",value:M==="true",formatted:F(M==="true"),source:hr("VISA_MOCK_TOUCHID",!!M)});let oe=process.env.VISA_CLI_DEBUG;n.push({key:"dev.debug",value:!!oe,formatted:F(!!oe),source:hr("VISA_CLI_DEBUG",!!oe)})}return{entries:n,statusError:t}}function Vt(){return Je()}var k=new Et(()=>U.getSessionToken()),Ss="1.8.0-rc.3",Ts=["generate_image","generate_video","generate_music","generate_audio","generate_3d","upscale_image","transcribe_audio","run_llm"],ln=["","","You're ready to go! Try:","","Core:",'\u2022 "Show my account status" \u2192 get_status','\u2022 "List my enrolled cards" \u2192 get_cards','\u2022 "Show my recent transactions" \u2192 transaction_history','\u2022 "Set my daily limit to $50" \u2192 update_spending_controls','\u2022 "Pay https://example.com/checkout" \u2192 pay','\u2022 "Generate 3 variations in parallel" \u2192 batch',"","Fast shortcuts:",'\u2022 "Generate an image of a sunset over Tokyo" \u2192 generate_image_card (~$0.06)','\u2022 "Make a fast thumbnail: minimalist cat logo" \u2192 generate_image_fast_card (~$0.04)','\u2022 "Make a 4-second video of a penguin juggling" \u2192 generate_video_tempo_card (~$0.30)','\u2022 "Make a song about coding late at night" \u2192 generate_music_tempo_card (~$0.10)','\u2022 "Check the status of my music job" \u2192 check_music_status_tempo_card','\u2022 "What is ETH on Base trading at?" \u2192 query_onchain_prices_card (~$0.02)','\u2022 "Explore stablecoin inflows on Base" \u2192 allium_explorer_card','\u2022 "Open the latest Allium result set" \u2192 allium_explorer_results_card','\u2022 "Show pxlwall campaign insights" \u2192 pxlwall_card',"","Category tools:",...Ts.map(r=>`\u2022 "${r.replace(/_/g," ")}" \u2192 ${r}`),"","Tool catalog:",'\u2022 "Find an image upscaler" \u2192 discover_tools','\u2022 "Run fal-aura-sr on this URL" \u2192 execute_tool'].join(`
5
+ `)}function rn(r){let e=jt[r];if(!e)throw new Error(`Unknown meta-tool: ${r}`);let t=Object.keys(e.tiers);return{type:"object",properties:{tier:{type:"string",enum:t,default:t[0],description:`Quality/style tier. Default: ${t[0]}.`},...e.inputProperties},required:e.required??[]}}function qt(r,e){if(!Ee.includes(r))return r;let t=jt[r];if(!t)return r;let n=Object.keys(t.tiers),s=e||n[0],i=t.tiers[s];if(!i)throw new Error(`Unknown tier '${s}' for ${r}. Valid tiers: ${n.join(", ")}`);return i.toolId}async function nn(r,e,t){let n=qt(r,e.tier),{tier:s,...i}=e;return C.executeTool({tool_id:n,...i},t)}var Ee=Object.keys(jt);function sn(r=process.env,e=process.platform){return r.VISA_CLI_NO_BROWSER==="1"||r.VISA_CLI_NO_BROWSER==="true"?{headless:!0,reason:"VISA_CLI_NO_BROWSER is set"}:r.CI==="true"||r.CI==="1"?{headless:!0,reason:"CI environment detected"}:r.SSH_CONNECTION||r.SSH_TTY?{headless:!0,reason:"SSH session detected"}:e==="linux"&&!r.DISPLAY&&!r.WAYLAND_DISPLAY?{headless:!0,reason:"Linux with no $DISPLAY or $WAYLAND_DISPLAY"}:{headless:!1}}function an(r,e=process.platform){return e==="darwin"?{cmd:"open",args:[r]}:e==="win32"?{cmd:"cmd",args:["/c","start","",r]}:e==="linux"?{cmd:"xdg-open",args:[r]}:null}var ht=I(require("crypto")),pn=require("child_process"),W=I(require("fs")),gt=I(require("os")),yt=I(require("path"));var xs="# visa-cli-hud-v1";function Mt(r){return typeof r!="string"?!1:r.includes(xs)?!0:r.includes("visa-cli")&&r.includes("statusline")}async function on(r,e){try{return await e()}catch(t){if(t.message==="Invalid signature"&&le()){l.warn("attestation:key-mismatch",{action:"reregistering"});try{let n=await Yr();await r.registerAttestationKey(n),l.info("attestation:key-reregistered")}catch(n){throw l.error("attestation:reregister-failure",{error:n.message}),t}return await e()}throw t}}var cn="1.8.0";function hr(r,e){return e?{kind:"env",var:r}:{kind:"default"}}function ks(r,e,t){let n=process.env[r];if(n!==void 0&&n!=="")return{value:n,source:{kind:"env",var:r}};let s=tr(e);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:t,source:{kind:"default"}}}function pt(r,e,t){let n=process.env[r];if(n!==void 0)return{value:t==="opt-in"?n==="true":n!=="false",source:{kind:"env",var:r}};let s=Re(e);return s!==void 0?{value:s,source:{kind:"settings"}}:{value:t!=="opt-in",source:{kind:"default"}}}function F(r){return r==null?"\u2014":r?"yes":"no"}function Dt(r){return r==null?"\u2014":`$${r.toFixed(2)}`}async function un(r){let e=null,t=null;try{e=await r.api.getStatus()}catch(A){t=A?.message||"unknown error"}let n=[],s=ks("VISA_AUTH_URL","auth.serverUrl","https://auth.visacli.sh");n.push({key:"auth.serverUrl",value:s.value,formatted:s.value,source:s.source,hint:s.source.kind==="default"?"Persist with `visa-cli config set auth.serverUrl <url>` (or set VISA_AUTH_URL for one-off overrides).":void 0}),n.push({key:"account.enrolled",value:e?.enrolled??null,formatted:F(e?.enrolled),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),e?.githubUser&&n.push({key:"account.githubUser",value:e.githubUser,formatted:e.githubUser,source:{kind:"server"}});let i=e?e.attestationRequired!==!1:void 0;n.push({key:"biometric.required",value:i,formatted:F(i),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"},hint:i===!1?"Touch ID prompts are suppressed. Re-enable with `visa-cli biometric on`.":void 0}),n.push({key:"biometric.keyRegistered",value:e?.hasAttestationKey??null,formatted:F(e?.hasAttestationKey),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"biometric.deviceAvailable",value:le(),formatted:F(le()),source:{kind:"device"}});let a=e?.spendingControls,o=a?a.max_transaction_amount??a.maxTransactionAmount??null:null,c=a?a.daily_limit??a.dailyLimit??null:null;n.push({key:"spending.maxPerTxn",value:o,formatted:Dt(o),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailyLimit",value:c,formatted:Dt(c),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailySpent",value:e?.dailySpent??null,formatted:Dt(e?.dailySpent),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"spending.dailyRemaining",value:e?.dailyRemaining??null,formatted:Dt(e?.dailyRemaining),source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}}),n.push({key:"cards.count",value:e?.cardCount??null,formatted:e?.cardCount!=null?String(e.cardCount):"\u2014",source:e?{kind:"server"}:{kind:"unknown",reason:t||"offline"}});let u=e?.cards?.find(A=>A.isDefault)??e?.cards?.[0];u&&n.push({key:"cards.default",value:{brand:u.brand??null,last4:u.last4},formatted:`${u.brand||"card"} \u2022\u2022\u2022\u2022 ${u.last4}`,source:{kind:"server"}});let d=pt("VISA_SUPPRESS_BROWSER","ui.suppressBrowser","opt-in");n.push({key:"ui.suppressBrowser",value:d.value,formatted:F(d.value),source:d.source,hint:"Persist with `visa-cli config set ui.suppressBrowser true` to stop auto-opening result URLs."});let g=pt("VISA_SUPPRESS_FEED","ui.suppressFeed","opt-in");n.push({key:"ui.suppressFeed",value:g.value,formatted:F(g.value),source:g.source});let O=Ge(),y;process.env.VISA_CLI_NO_UPDATE_CHECK?y={kind:"env",var:"VISA_CLI_NO_UPDATE_CHECK"}:process.env.CI?y={kind:"env",var:"CI"}:process.env.NODE_ENV==="test"?y={kind:"env",var:"NODE_ENV"}:y={kind:"default"},n.push({key:"ui.updateCheck",value:!O,formatted:F(!O),source:y});let he=pt("VISA_META_TOOLS","tools.meta","opt-out");n.push({key:"tools.meta",value:he.value,formatted:F(he.value),source:he.source,hint:"Persist with `visa-cli config set tools.meta false`. Restart Claude Code for changes to take effect."});let w=pt("VISA_SPECIFIC_TOOLS","tools.specific","opt-out");n.push({key:"tools.specific",value:w.value,formatted:F(w.value),source:w.source});let R=pt("VISA_DISCOVER_TOOLS","tools.discover","opt-out");if(n.push({key:"tools.discover",value:R.value,formatted:F(R.value),source:R.source}),n.push({key:"client.version",value:cn,formatted:cn,source:{kind:"default"}}),r.includeDev){let A=process.env.VISA_MOCK_KEYCHAIN;n.push({key:"dev.mockKeychain",value:A==="true",formatted:F(A==="true"),source:hr("VISA_MOCK_KEYCHAIN",!!A)});let M=process.env.VISA_MOCK_TOUCHID;n.push({key:"dev.mockTouchid",value:M==="true",formatted:F(M==="true"),source:hr("VISA_MOCK_TOUCHID",!!M)});let oe=process.env.VISA_CLI_DEBUG;n.push({key:"dev.debug",value:!!oe,formatted:F(!!oe),source:hr("VISA_CLI_DEBUG",!!oe)})}return{entries:n,statusError:t}}function Vt(){return Je()}var k=new Et(()=>U.getSessionToken()),Ss="1.8.0",Ts=["generate_image","generate_video","generate_music","generate_audio","generate_3d","upscale_image","transcribe_audio","run_llm"],ln=["","","You're ready to go! Try:","","Core:",'\u2022 "Show my account status" \u2192 get_status','\u2022 "List my enrolled cards" \u2192 get_cards','\u2022 "Show my recent transactions" \u2192 transaction_history','\u2022 "Set my daily limit to $50" \u2192 update_spending_controls','\u2022 "Pay https://example.com/checkout" \u2192 pay','\u2022 "Generate 3 variations in parallel" \u2192 batch',"","Fast shortcuts:",'\u2022 "Generate an image of a sunset over Tokyo" \u2192 generate_image_card (~$0.06)','\u2022 "Make a fast thumbnail: minimalist cat logo" \u2192 generate_image_fast_card (~$0.04)','\u2022 "Make a 4-second video of a penguin juggling" \u2192 generate_video_tempo_card (~$0.30)','\u2022 "Make a song about coding late at night" \u2192 generate_music_tempo_card (~$0.10)','\u2022 "Check the status of my music job" \u2192 check_music_status_tempo_card','\u2022 "What is ETH on Base trading at?" \u2192 query_onchain_prices_card (~$0.02)','\u2022 "Explore stablecoin inflows on Base" \u2192 allium_explorer_card','\u2022 "Open the latest Allium result set" \u2192 allium_explorer_results_card','\u2022 "Show pxlwall campaign insights" \u2192 pxlwall_card',"","Category tools:",...Ts.map(r=>`\u2022 "${r.replace(/_/g," ")}" \u2192 ${r}`),"","Tool catalog:",'\u2022 "Find an image upscaler" \u2192 discover_tools','\u2022 "Run fal-aura-sr on this URL" \u2192 execute_tool'].join(`
6
6
  `);function B(r){if(!r||typeof r!="string"||qr())return;let e;try{e=new URL(r)}catch{return}if(e.protocol!=="https:"&&e.protocol!=="http:")return;let t=e.toString(),n=sn();if(n.headless){l.info(`Browser auto-open skipped (${n.reason}). URL: ${t}`);return}let s=an(t);if(!s){l.info(`No browser command for platform "${gt.platform()}". URL: ${t}`);return}(0,pn.execFile)(s.cmd,s.args,i=>{i&&l.warn(`Browser open failed: ${i.message}. URL: ${t}`)})}async function j(r){return on(k,r)}var mt=null,Rs=3e4;function mn(){mt=null}async function Is(r){let e=Date.now();if(mt&&mt.expiresAt>e)return mt.value;try{let n=(await k.getStatus(r)).attestationRequired!==!1;return mt={value:n,expiresAt:e+Rs},n}catch{return!0}}async function N(r,e,t,n,s){if(!le()){l.warn("attestation:unavailable",{context:r});return}if(!await Is(s)){l.info("attestation:skipped-by-server-policy",{context:r});return}l.info("attestation:attempt",{context:r,amount:e,merchant:t});try{let{nonce:a}=await k.getAttestationChallenge(),o=Buffer.from(JSON.stringify({nonce:a,amount:e,merchant:t,context:r})).toString("base64");l.info("touchid:prompt",{context:r,amount:e,merchant:t});let c=await Jr(o,n);return l.info("attestation:success",{context:r,amount:e,merchant:t}),{signature:c,nonce:a,amount:e,merchant:t}}catch(a){throw l.error("attestation:failure",{context:r,amount:e,merchant:t,error:a.message}),a}}async function J(r,e,t){let n=await k.paymentPreview({tool:r,url:e},t);if(!n||!n.merchantName||!n.amount||n.amount<=0)throw new Error("Could not determine payment amount and merchant. Try again.");if(!Number.isFinite(n.amount)||n.amount<0||n.amount>999999)throw new Error(`Invalid payment amount: ${n.amount}. Payment rejected for safety.`);return n}function te(r){if(r.pricingMode==="max-cap"){let e=typeof r.estimatedAmount=="number"&&r.estimatedAmount>0?` (estimated $${r.estimatedAmount.toFixed(2)})`:"";return`pay up to $${r.amount.toFixed(2)} to ${r.merchantName}${e}`}return`pay $${r.amount.toFixed(2)} to ${r.merchantName}`}function fn(){return yt.join(gt.homedir(),".visa-mcp","allium-results")}var Es=16*1024,As=50*1024*1024,Cs=10;function Os(r){return r.replace(/[^A-Za-z0-9_\-]/g,"_").slice(0,128)}function Ns(r,e){let t=fn();W.mkdirSync(t,{recursive:!0});let n=Os(r),s=yt.join(t,`${n}.csv`);W.writeFileSync(s,e);let i=Buffer.byteLength(e),a=e.split(`
7
7
  `),o=a[0]??"",c=a.slice(1).filter(g=>g.length>0),u=[o,...c.slice(0,Cs)].join(`
8
8
  `),d={file_path:s,row_count:c.length,size_bytes:i,columns:o,preview:u,truncated:!0};if(i>As){let g=(i/1048576).toFixed(1);l.warn("allium:large_csv_written",{sessionId:r,size_bytes:i,file_path:s}),d.warning=`Wrote ${g} MB to ${s}. Delete ~/.visa-mcp/allium-results/ files you no longer need \u2014 they are never auto-cleaned.`}return d}function Ps(){let r=fn();try{if(!W.existsSync(r))return{file_count:0,size_bytes:0,path:r};let e=W.readdirSync(r),t=0,n=0;for(let s of e)try{let i=W.statSync(yt.join(r,s));i.isFile()&&(t+=i.size,n++)}catch{}return{file_count:n,size_bytes:t,path:r}}catch(e){return l.warn("allium:disk_usage_error",{error:e.message}),{file_count:0,size_bytes:0,path:r}}}async function _t(r){if(!Mr())try{let e=await U.getSessionToken();if(!e)return;await fetch(`${Vt()}/v1/feed`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e}`},body:JSON.stringify({prompt:r.prompt,tool:r.tool,media_url:r.mediaUrl,media_type:r.mediaType,cost:r.cost,transaction_id:r.transactionId,auto:!0,...r.userContext&&{user_context:r.userContext}}),signal:AbortSignal.timeout(5e3)}),l.info("feed:submitted",{tool:r.tool,mediaType:r.mediaType})}catch{}}async function Ls(r,e){if(!r.url||!r.url.trim())throw new Error("A URL is required for payments. Provide the merchant payment endpoint.");let t=await J(void 0,r.url,e);l.info("payment:attempt",{tool:"pay",amount:t.amount,merchant:t.merchantName,url:r.url});try{return await j(async()=>{let n=await N(r.url||"pay",t.amount,t.merchantName,te(t)),s=await k.pay({url:r.url||"",merchantName:r.merchantName||"Unknown",description:r.description||"",method:r.method,body:r.body,attestation:n,idempotencyKey:ht.randomUUID()},e);return s.success?(l.info("payment:success",{tool:"pay",amount:t.amount,merchant:t.merchantName,rail:s.receipt?.rail}),s.receipt&&gi(s.receipt)):l.warn("payment:declined",{tool:"pay",amount:t.amount,merchant:t.merchantName,message:s.message}),s})}catch(n){throw l.error("payment:failure",{tool:"pay",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function $s(r,e){if(!r.prompt||!r.prompt.trim())throw new Error("A prompt is required. Provide a description of what you want to generate.");let t=await J("generate_image_card",void 0,e);l.info("payment:attempt",{tool:"generate_image_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("generate_image_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("generate_image_card",{...r,attestation:n},12e4,e);return l.info("payment:success",{tool:"generate_image_card",amount:t.amount,merchant:t.merchantName}),s.urls?.length?(s.urls.forEach(i=>B(i)),_t({prompt:r.prompt,tool:"generate_image_card",mediaUrl:s.urls[0],mediaType:"image",cost:s.amount??t.amount,transactionId:s.transactionId,userContext:e})):l.warn("generation:no-urls",{tool:"generate_image_card",resultKeys:Object.keys(s||{})}),s})}catch(n){throw l.error("payment:failure",{tool:"generate_image_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function Us(r,e){if(!r.prompt||!r.prompt.trim())throw new Error("A prompt is required. Provide a description of what you want to generate.");let t=await J("generate_image_fast_card",void 0,e);l.info("payment:attempt",{tool:"generate_image_fast_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("generate_image_fast_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("generate_image_fast_card",{...r,attestation:n},6e4,e);return l.info("payment:success",{tool:"generate_image_fast_card",amount:t.amount,merchant:t.merchantName}),s.urls?.length?(s.urls.forEach(i=>B(i)),_t({prompt:r.prompt,tool:"generate_image_fast_card",mediaUrl:s.urls[0],mediaType:"image",cost:s.amount??t.amount,transactionId:s.transactionId,userContext:e})):l.warn("generation:no-urls",{tool:"generate_image_fast_card",resultKeys:Object.keys(s||{})}),s})}catch(n){throw l.error("payment:failure",{tool:"generate_image_fast_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function js(r,e){if(!r.prompt||!r.prompt.trim())throw new Error("A prompt is required. Provide a description of what you want to generate.");let t=await J("generate_video_tempo_card",void 0,e);l.info("payment:attempt",{tool:"generate_video_tempo_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("generate_video_tempo_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("generate_video_tempo_card",{...r,attestation:n},12e4,e);return l.info("payment:success",{tool:"generate_video_tempo_card",amount:t.amount,merchant:t.merchantName}),s.urls?.length?(s.urls.forEach(i=>B(i)),_t({prompt:r.prompt,tool:"generate_video_tempo_card",mediaUrl:s.urls[0],mediaType:"image",cost:s.amount??t.amount,transactionId:s.transactionId,userContext:e})):l.warn("generation:no-urls",{tool:"generate_video_tempo_card",resultKeys:Object.keys(s||{})}),s})}catch(n){throw l.error("payment:failure",{tool:"generate_video_tempo_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function qs(r,e){if(!r.prompt||!r.prompt.trim())throw new Error("A prompt is required. Provide a description of what you want to generate.");let t=await J("generate_music_tempo_card",void 0,e);l.info("payment:attempt",{tool:"generate_music_tempo_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("generate_music_tempo_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("generate_music_tempo_card",{...r,attestation:n},36e4,e);return l.info("payment:success",{tool:"generate_music_tempo_card",amount:t.amount,merchant:t.merchantName}),s.urls?.length&&s.status!=="processing"?(s.urls.forEach(i=>B(i)),_t({prompt:r.prompt,tool:"generate_music_tempo_card",mediaUrl:s.urls[0],mediaType:"audio",cost:s.amount??t.amount,transactionId:s.transactionId,userContext:e})):s.urls?.length&&s.status==="processing"?(s._preliminary_urls=s.urls,delete s.urls,l.info("generation:processing",{tool:"generate_music_tempo_card",note:"URLs withheld until status is completed"})):l.warn("generation:no-urls",{tool:"generate_music_tempo_card",resultKeys:Object.keys(s||{})}),s})}catch(n){throw l.error("payment:failure",{tool:"generate_music_tempo_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function Ms(r,e){let t=await J("check_music_status_tempo_card",void 0,e);l.info("payment:attempt",{tool:"check_music_status_tempo_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("check_music_status_tempo_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("check_music_status_tempo_card",{...r,attestation:n},void 0,e);return l.info("payment:success",{tool:"check_music_status_tempo_card",amount:t.amount,merchant:t.merchantName}),s.urls?.length&&s.urls.forEach(i=>B(i)),s})}catch(n){throw l.error("payment:failure",{tool:"check_music_status_tempo_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function Ds(r,e){if(!r.chain||!r.chain.trim())throw new Error('A chain is required (e.g., "ethereum", "solana").');if(!r.token_address||!r.token_address.trim())throw new Error("A token address is required. Provide the contract address for the token.");let t=await J("query_onchain_prices_card",void 0,e);l.info("payment:attempt",{tool:"query_onchain_prices_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("query_onchain_prices_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("query_onchain_prices_card",{...r,attestation:n},void 0,e);if(l.info("payment:success",{tool:"query_onchain_prices_card",amount:t.amount,merchant:t.merchantName}),Array.isArray(s?.data))s.data=s.data.map(i=>{if("mint"in i&&!("address"in i)){let{mint:a,...o}=i;return{address:a,...o}}return i});else if(s&&"mint"in s&&!("address"in s)){let{mint:i,...a}=s;return{address:i,...a}}return s})}catch(n){throw l.error("payment:failure",{tool:"query_onchain_prices_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function Vs(r,e){if(!r.prompt||!r.prompt.trim())throw new Error("A prompt is required. Provide a natural language question about blockchain data.");let t=await J("allium_explorer_card",void 0,e);l.info("payment:attempt",{tool:"allium_explorer_card",amount:t.amount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("allium_explorer_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("allium_explorer_card",{...r,attestation:n},12e4,e);return l.info("payment:success",{tool:"allium_explorer_card",amount:t.amount,merchant:t.merchantName}),s})}catch(n){throw l.error("payment:failure",{tool:"allium_explorer_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}async function Hs(r,e){if(!r.session_id||!r.session_id.trim())throw new Error("A session_id is required. Use the session_id returned from allium_explorer_card.");let t=await J("allium_explorer_results_card",void 0,e);l.info("payment:attempt",{tool:"allium_explorer_results_card",amount:t.amount,pricingMode:t.pricingMode,estimatedAmount:t.estimatedAmount,merchant:t.merchantName});try{return await j(async()=>{let n=await N("allium_explorer_results_card",t.amount,t.merchantName,te(t)),s=await k.shortcut("allium_explorer_results_card",{...r,attestation:n},6e4,e);l.info("payment:success",{tool:"allium_explorer_results_card",amount:t.amount,actualCost:s?.actualCost,merchant:t.merchantName});let i=typeof s?.data?.results=="string"?s.data.results:void 0;if(i&&Buffer.byteLength(i)>Es){let a=Ns(r.session_id,i),{results:o,...c}=s.data;return{...s,data:{...c,...a}}}return s})}catch(n){throw l.error("payment:failure",{tool:"allium_explorer_results_card",amount:t.amount,merchant:t.merchantName,error:n.message}),n}}var ft="https://pxlwall.com";async function Fs(r){if([r.shape,r.text,r.pixels].filter(Boolean).length>1)throw new Error("Provide only one of: shape, text, or pixels. Cannot combine modes.");let t,n,s=r.position||"cheapest";if(typeof s=="string"&&s.startsWith("{"))try{s=JSON.parse(s)}catch{}if(r.shape)t=`${ft}/api/agent/draw-shape`,n={shape:r.shape,color:r.color||"#ffffff",owner:r.owner,position:s},r.shape==="circle"?n.radius=r.size||10:r.shape==="rectangle"?(n.width=r.width||20,n.height=r.height||10):n.size=r.size||10;else if(r.text)t=`${ft}/api/agent/draw-text`,n={text:r.text,color:r.color||"#ffffff",owner:r.owner,position:s};else if(r.pixels){if(r.pixels.length<100)throw new Error(`Minimum 100 pixels per purchase. You requested ${r.pixels.length}.`);for(let a of r.pixels)if(a.x<0||a.x>499||a.y<0||a.y>499)throw new Error(`Pixel (${a.x},${a.y}) is out of bounds. Grid is 500x500 (coordinates 0-499).`);t=`${ft}/api/create-purchase-spec`,n={pixels:r.pixels,color:r.color||"#ffffff",owner:r.owner},r.colors&&(n.colors=r.colors)}else throw new Error("Provide one of: shape, text, or pixels.");let i=await fetch(t,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(n),signal:AbortSignal.timeout(15e3)});if(!i.ok){let a=await i.text().catch(()=>"");throw new Error(`pxlwall spec creation failed (${i.status}): ${a}`)}return i.json()}async function Bs(r,e){let t=await Fs(r),n=t.pixels?.length??r.pixels?.length??0,s="pxlwall";l.info("payment:attempt",{tool:"pxlwall_card",amount:t.totalUSD,pixelCount:n,merchant:s});try{let i=await N("pxlwall_card",t.totalUSD,s,`pay $${t.totalUSD.toFixed(2)} to ${s} for ${n} pixels`),a=await k.shortcut("pxlwall_card",{specId:t.specId,attestation:i},6e4,e);return l.info("payment:success",{tool:"pxlwall_card",merchant:s}),B(ft),a.urls?.length&&a.urls.forEach(o=>B(o)),{...a,specId:t.specId,pixelCount:n,totalUSD:t.totalUSD,canvasUrl:ft}}catch(i){throw l.error("payment:failure",{tool:"pxlwall_card",merchant:s,error:i.message}),i}}var Ws=["generate_music_tempo_card"],Ks=36e4,zs=18e4,Zs=15e3,Gs=12e4,Ys=2e3;async function Js(r,e){let t;if(r.requests?.some(w=>w.tool||w.tool_id)&&r.requests)t=r.requests.map(w=>{let R=w.tool||w.tool_id||r.tool;if(!R)throw new Error("Each request must specify tool or tool_id, or set tool at the top level.");let A=qt(R,w.tier||r.tier),{tool:M,tool_id:oe,tier:ce,...ue}=w;return{resolvedTool:A,params:ue}});else if(r.tool){let w=qt(r.tool,r.tier);t=(r.requests||(r.count&&r.params?Array.from({length:r.count},()=>({...r.params})):[])).map(A=>({resolvedTool:w,params:A}))}else throw new Error("Batch requires a top-level tool or per-request tool/tool_id.");if(t.length===0)throw new Error("Batch requires at least one item.");let s=[...new Set(t.map(w=>w.resolvedTool))],i=s.length===1,a={};for(let w of s)a[w]=await J(w,void 0,e);let o=0;for(let w of t)o+=a[w.resolvedTool].amount;let c=[...new Set(Object.values(a).map(w=>w.merchantName))].join(", "),u=i?s[0]:"mixed";l.info("payment:attempt",{tool:"batch",batchTool:u,count:t.length,totalAmount:o,merchant:c,heterogeneous:!i});let d=i?`pay $${o.toFixed(2)} to ${c} (${t.length} items, $${a[s[0]].amount.toFixed(2)} each)`:`pay $${o.toFixed(2)} to ${c} (${t.length} items across ${s.length} tools)`,g=i?t.map(w=>w.params):t.map(w=>({tool_id:w.resolvedTool,...w.params})),O=t.some(w=>Ws.includes(w.resolvedTool)),y=t.some(w=>w.resolvedTool.startsWith("or-")||w.resolvedTool==="run_llm"||w.resolvedTool==="execute_tool"),he=O?Ks:y?zs+t.length*Zs:Gs+t.length*Ys;try{return await j(async()=>{let w=await N(`batch:${u}`,o,c,d),R=await k.batch({tool:i?s[0]:u,requests:g,attestation:w,idempotencyKey:ht.randomUUID()},he,e);return l.info("payment:success",{tool:"batch",batchTool:u,count:t.length,totalAmount:o,merchant:c}),R.results&&R.results.forEach(A=>{A.urls&&A.urls.forEach(M=>B(M))}),R})}catch(w){throw l.error("payment:failure",{tool:"batch",batchTool:u,count:t.length,totalAmount:o,merchant:c,error:w.message}),w}}function Xs(){try{let r=yt.join(gt.homedir(),".claude","settings.json");if(!W.existsSync(r))return{enabled:!1,setup:"visa-cli hud enable"};let e=JSON.parse(W.readFileSync(r,"utf-8")),t=typeof e.statusLine=="object"?e.statusLine.command:"";return Mt(t)?{enabled:!0}:e.statusLine?{enabled:!1,setup:"Another HUD is active. To switch: edit ~/.claude/settings.json \u2192 statusLine"}:{enabled:!1,setup:"visa-cli hud enable"}}catch{return{enabled:!1,setup:"visa-cli hud enable"}}}async function Qs(r){let e=await k.getStatus(r);typeof e?.dailyRemaining=="number"&&(e.dailyRemaining=Math.round(e.dailyRemaining*100)/100);let t=Ps();return t.file_count>0&&(e.alliumResultsOnDisk=t),e.hud=Xs(),e.version=Ss,e}async function ei(r){let t=(await k.getStatus(r)).cards||[];return t.length===0?{cards:[],message:"No cards enrolled. Use the add_card tool to add a payment card."}:t.some(s=>!Number.isInteger(s?.id)||s.id<=0)?{success:!1,cards:[],message:"Card ids are unavailable right now, so remove_card and set_default_card are temporarily disabled."}:{cards:t}}async function ti(r){let e=await k.getTransactions(r);return Array.isArray(e?.transactions)&&(e.transactions=e.transactions.filter(t=>!(t.tool_name==null||t.amount===0&&t.status==="failed"))),e}async function ri(r,e){return await k.feedback(r.message,r.transaction_id,e)}async function ni(r,e){if(!r.confirm)return{success:!1,message:"Please confirm by setting confirm: true to update spending controls."};l.info("spending_controls:update",{maxTransactionAmount:r.maxTransactionAmount,dailyLimit:r.dailyLimit});try{return await j(async()=>{let t=await N("spending-controls",0,"","update spending controls"),n=await k.updateSpendingControls({maxTransactionAmount:r.maxTransactionAmount,dailyLimit:r.dailyLimit,confirm:!0,attestation:t},e);return l.info("spending_controls:success",{maxTransactionAmount:r.maxTransactionAmount,dailyLimit:r.dailyLimit}),n})}catch(t){throw l.error("spending_controls:failure",{error:t.message}),t}}async function si(r){let e=await un({api:k,includeDev:!!r.includeDev});return{config:e.entries.map(t=>({key:t.key,value:t.value,source:t.source,hint:t.hint})),statusError:e.statusError}}async function ii(r){if(!r.key||typeof r.key!="string")return{success:!1,error:"key is required. Call config_list first to see available keys."};if(r.value===void 0)return{success:!1,error:"value is required. Use config_unset to remove a setting."};l.info("config:set",{key:r.key});try{let e=Ur(r.key,r.value);return l.info("config:set:success",{key:e.key,requiresRestart:e.requiresRestart}),{success:!0,key:e.key,value:e.value,requiresRestart:e.requiresRestart,path:e.path,message:e.requiresRestart?`Saved ${e.key}. Restart Claude Code for the change to take effect.`:`Saved ${e.key}.`}}catch(e){let t=e instanceof Se?"UNKNOWN_KEY":e instanceof Te?"SERVER_CONTROLLED":"INVALID_VALUE";return l.warn("config:set:rejected",{key:r.key,code:t,error:e.message}),{success:!1,error:e.message,code:t,settableKeys:Object.keys(Ye).sort()}}}async function ai(r){if(!r.key||typeof r.key!="string")return{success:!1,error:"key is required. Call config_list first to see which keys are currently set via settings.json."};l.info("config:unset",{key:r.key});try{let e=jr(r.key);return l.info("config:unset:success",{key:e.key,removed:e.removed}),{success:!0,key:e.key,removed:e.removed,requiresRestart:e.requiresRestart,path:e.path,message:e.removed?e.requiresRestart?`Removed ${e.key}. Restart Claude Code for the change to take effect.`:`Removed ${e.key}.`:`${e.key} was not set in settings.json \u2014 nothing to remove.`}}catch(e){let t=e instanceof Se?"UNKNOWN_KEY":e instanceof Te?"SERVER_CONTROLLED":"INVALID_VALUE";return l.warn("config:unset:rejected",{key:r.key,code:t,error:e.message}),{success:!1,error:e.message,code:t,settableKeys:Object.keys(Ye).sort()}}}async function oi(r){let e=await k.getStatus(r),t=e.attestationRequired!==!1;return{required:t,hasAttestationKey:!!e.hasAttestationKey,touchIdAvailable:le(),message:t?"Touch ID is REQUIRED for payments.":"Touch ID is NOT required for payments. Payments will proceed without biometric confirmation."}}async function ci(r){l.info("biometric:on");let e=await k.setBiometricPreference({required:!0},r);return e.success?(mn(),{success:!0,required:!0,message:"Touch ID is now REQUIRED for payments."}):{success:!1,error:e.error||"unknown error"}}async function ui(r,e){if(!r.confirm)return{success:!1,message:"Please confirm by setting confirm: true. Disabling Touch ID is a security downgrade \u2014 the user will be prompted for one final Touch ID confirmation before the change takes effect."};l.info("biometric:off");try{return await j(async()=>{let t=await k.getStatus(e),n;if(t.hasAttestationKey&&(n=await N("biometric-preference",0,"","disable Touch ID requirement"),!n))throw new Error("Touch ID confirmation required to disable \u2014 not available on this device.");let s=await k.setBiometricPreference({required:!1,attestation:n},e);if(!s.success)throw new Error(s.error||"unknown error");return mn(),{success:!0,required:!1,message:"Touch ID is no longer required for payments."}})}catch(t){throw l.error("biometric:off:failure",{error:t.message}),t}}var dn=3e4,li=3e5;async function hn(r,e){let t=ht.randomBytes(16).toString("hex"),n=`${r}${r.includes("?")?"&":"?"}state=${t}`;B(n);let s=Date.now()+li;for(;Date.now()<s;)try{let i=await fetch(`${Vt()}/v1/auth-status`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({state:t,timeout:dn,...e&&{user_context:e}}),signal:AbortSignal.timeout(dn+5e3)});if(!i.ok)continue;let a=await i.json();if(a.status==="pending")continue;if(a.status==="expired")return{success:!1,message:"Session expired. Please try again."};if(a.status==="error")return{success:!1,message:a.error||"Authentication failed. Please try again."};if(a.status==="complete"){if(a.sessionToken){await U.saveSessionToken(a.sessionToken);let c=a.user||"",u=a.last4||"****";return l.info("auth:login_complete",{user:c,last4:u}),{success:!0,message:`Signed in as ${c}. Card ending in ${u} added.${ln}`}}let o=a.last4||"****";return l.info("auth:card_added",{last4:o}),{success:!0,message:`Card ending in ${o} enrolled.${ln}`}}}catch{}return{success:!1,message:"Login timed out. Please try again."}}async function di(r,e){if(!r.confirm)return{success:!1,message:"Please confirm by setting confirm: true to remove this card."};let t=r.cardId;if(!Number.isInteger(t)||t<=0)return{success:!1,message:"cardId must be a positive integer. Call get_cards to list enrolled cards and their ids."};l.info("cards:remove_attempt",{cardId:t});let n=`remove-card:${t}`,s=`remove enrolled card #${t}`;try{return await j(async()=>{let i=await N(n,0,"",s),a=await k.removeCard(t,{attestation:i},e);return l.info("cards:remove_success",{cardId:t,promotedId:a?.promotedId??null}),a})}catch(i){throw l.error("cards:remove_failure",{cardId:t,error:i.message}),i}}async function pi(r,e){let t=r.cardId;if(!Number.isInteger(t)||t<=0)return{success:!1,message:"cardId must be a positive integer. Call get_cards to list enrolled cards and their ids."};l.info("cards:set_default_attempt",{cardId:t});let n=`set-default-card:${t}`,s=`set card #${t} as default`;try{return await j(async()=>{let i=await N(n,0,"",s),a=await k.setDefaultCard(t,{attestation:i},e);return l.info("cards:set_default_success",{cardId:t}),a})}catch(i){throw l.error("cards:set_default_failure",{cardId:t,error:i.message}),i}}async function mi(r){return l.info("auth:login_attempt"),hn(`${Vt()}/login`,r)}async function fi(r){return l.info("auth:add_card_attempt"),await U.getSessionToken()?hn(`${Vt()}/enroll`,r):{success:!1,message:"Not logged in. Sign up at https://visacli.sh or call the login tool first."}}async function hi(r,e){if(!r.confirm)return{success:!1,message:"Please confirm by setting confirm: true to reset"};l.info("reset:attempt");let t=await N("reset",0,"","reset device and remove all credentials");try{await k.logout({attestation:t},e)}catch{}if(await U.clearAll(),le())try{await Xr()}catch{}return l.info("reset:success"),{success:!0,message:"Device reset. All credentials, cards, and keys have been removed. Use the login tool to re-enroll."}}function gi(r){let e=["url","resultUrl","imageUrl","audioUrl","trackUrl"];for(let t of e){let n=r[t];n&&typeof n=="string"&&n.startsWith("http")&&B(n)}Array.isArray(r.urls)&&r.urls.forEach(t=>{t&&typeof t=="string"&&t.startsWith("http")&&B(t)})}async function yi(r){if(!r.query&&!r.category)throw new Error("Provide a query (what you want to do) or category (image, video, audio, 3d, llm) to search the tool catalog.");l.info("catalog:discover",{query:r.query,category:r.category});try{let t=(await k.catalogSearch(r.query,r.category)).tools||[];if(t.length===0)return{content:[{type:"text",text:`No tools found for "${r.query||r.category}". Try a different search term.`}]};let n=t.map((s,i)=>`${i+1}. **${s.name}** (${s.id})
@@ -15,7 +15,7 @@
15
15
  ${n}
16
16
 
17
17
  Use execute_tool with the tool id and required params to run any of these.`}],_tools:t}}catch(e){throw l.error("catalog:discover:error",{error:e.message}),new Error(`Failed to search tool catalog: ${e.message}`)}}async function _i(r,e){let{tool_id:t,params:n,...s}=r,i=n||s;if(!t)throw new Error("tool_id is required. Use discover_tools first to find available tools.");l.info("catalog:execute",{tool:t});let a=await J(t,void 0,e);l.info("payment:attempt",{tool:t,amount:a.amount,merchant:a.merchantName});try{return await j(async()=>{let o=await N(t,a.amount,a.merchantName,te(a)),c=await k.shortcut(t,{...i,attestation:o},12e4,e);if(l.info("payment:success",{tool:t,amount:a.amount,merchant:a.merchantName}),c.urls?.length){c.urls.forEach(d=>B(d));let u=c.mediaType||(c.urls[0]?.match(/\.(mp4|webm|mov)/)?"video":"image");_t({prompt:i.prompt||`${t} execution`,tool:t,mediaUrl:c.urls[0],mediaType:u,cost:c.amount??a.amount,transactionId:c.transactionId,userContext:e})}return c})}catch(o){throw l.error("payment:failure",{tool:t,amount:a.amount,merchant:a.merchantName,error:o.message}),o}}var C=class{static async getStatus(e){return Qs(e)}static async pay(e,t){return Ls(e,t)}static async getCards(e){return ei(e)}static async transactionHistory(e){return ti(e)}static async feedback(e,t){return ri(e,t)}static async updateSpendingControls(e,t){return ni(e,t)}static async configList(e){return si(e||{})}static async configSet(e){return ii(e||{})}static async configUnset(e){return ai(e||{})}static async biometricStatus(e){return oi(e)}static async biometricOn(e){return ci(e)}static async biometricOff(e,t){return ui(e,t)}static async reset(e,t){return hi(e,t)}static async login(e){return mi(e)}static async addCard(e){return fi(e)}static async removeCard(e,t){return di(e,t)}static async setDefaultCard(e,t){return pi(e,t)}static async batch(e,t){return Js(e,t)}static async discoverTools(e){return yi(e)}static async executeTool(e,t){return _i(e,t)}static async shortcut(e,t,n){switch(e){case"generate_image_card":return $s(t,n);case"generate_image_fast_card":return Us(t,n);case"generate_video_tempo_card":return js(t,n);case"generate_music_tempo_card":return qs(t,n);case"check_music_status_tempo_card":return Ms(t,n);case"query_onchain_prices_card":return Ds(t,n);case"allium_explorer_card":return Vs(t,n);case"allium_explorer_results_card":return Hs(t,n);case"pxlwall_card":return Bs(t,n);default:{l.info("payment:attempt",{tool:e});try{let s=await N(e,0,""),i=await k.shortcut(e,{...t,attestation:s},void 0,n);return l.info("payment:success",{tool:e}),i.urls?.length&&i.urls.forEach(a=>B(a)),i}catch(s){throw l.error("payment:failure",{tool:e,error:s.message}),s}}}}static async submitFeedback(e,t,n){l.info("feedback:submit",{length:e.length});try{let s=await k.submitFeedback(e,t,n);return l.info("feedback:submitted",{message:"Feedback received"}),s}catch(s){let i=s instanceof Error?s.message:"Unknown error";throw l.error("feedback:error",{error:i}),s}}static async getFeedback(e,t){l.info("feedback:list",{limit:e||20});try{let n=await k.getFeedback(e,t);return l.info("feedback:listed",{count:n?.feedback?.length||0}),n}catch(n){let s=n instanceof Error?n.message:"Unknown error";throw l.error("feedback:error",{error:s}),n}}};var gr=new Set(["generate_image_card","generate_image_fast_card","generate_video_tempo_card","generate_music_tempo_card","check_music_status_tempo_card","query_onchain_prices_card","allium_explorer_card","allium_explorer_results_card","pxlwall_card"]),yr=new Set(["discover_tools","execute_tool"]),vi=new Set(Ee);function gn(r){return gr.has(r)&&!Qe()?"VISA_SPECIFIC_TOOLS":yr.has(r)&&!et()?"VISA_DISCOVER_TOOLS":vi.has(r)&&!Xe()?"VISA_META_TOOLS":null}var _r=["pay","generate_image_card","generate_image_fast_card","generate_video_tempo_card","generate_music_tempo_card","query_onchain_prices_card","allium_explorer_card","allium_explorer_results_card"],bi={generate_image_card:"image generation",generate_image_fast_card:"fast image generation",generate_music_tempo_card:"music generation",generate_video_tempo_card:"video generation",query_onchain_prices_card:"onchain price queries",allium_explorer_card:"blockchain data exploration",allium_explorer_results_card:"blockchain data results",pay:"payments"};function wi(r){return bi[r]||r}var Ae=null;async function Ht(r){if(Ae!==null)return Ae;try{let{transactions:e}=await r.getTransactions();Ae={};for(let t of e)t.status==="completed"&&(Ae[t.tool_name]=(Ae[t.tool_name]||0)+1)}catch{l.warn("feedback-prompting:cache-error",{message:"Failed to fetch transaction history for feedback prompting"}),Ae={}}return Ae}function yn(r,e,t){return _r.includes(r)?e===0?{_feedback_prompt:{message:`This was your first time using ${wi(r)} \u2014 if you have any thoughts on the experience, I'd be happy to pass them along to the Visa CLI team.`,transaction_id:t}}:e%5===0?{_feedback_hint:{message:"Feedback? Just say how that went.",transaction_id:t}}:{}:{}}var vt=I(require("fs")),_n=I(require("path"));var xi=5,ki={shownCodes:[]},Ce=null;function vn(){return process.env.VISA_CLI_REFERRAL_NUDGE_FILE||_n.join(Y.getConfigDir(),"referral-nudges.json")}function Si(){if(Ce)return Ce;try{let r=vt.readFileSync(vn(),"utf8"),e=JSON.parse(r);return Ce={shownCodes:Array.isArray(e.shownCodes)?e.shownCodes.filter(t=>typeof t=="string"):[]},Ce}catch{return Ce={...ki},Ce}}function Ti(r){Ce=r;try{Y.ensureConfigDir(),vt.writeFileSync(vn(),JSON.stringify(r,null,2)+`
18
- `,{mode:384})}catch{}}function Ri(r){return r.trim().toLowerCase()}function bn(r,e){if(e<xi)return{};if(!r.referralCode||!r.referralLink)return{};let t=Ri(r.referralCode);if(!t)return{};let n=Si();return n.shownCodes.includes(t)?{}:(Ti({shownCodes:[...n.shownCodes,t]}),{_referral_prompt:{message:`Thanks for giving Visa CLI a try. Know anyone who might want to try it too? Here's your referral code: ${r.referralCode}`,referral_code:r.referralCode,referral_link:r.referralLink}})}var T={};Ir(T,{BRAND:()=>Xi,DIRTY:()=>Oe,EMPTY_PATH:()=>Ci,INVALID:()=>_,NEVER:()=>Ua,OK:()=>$,ParseStatus:()=>P,Schema:()=>x,ZodAny:()=>we,ZodArray:()=>fe,ZodBigInt:()=>Pe,ZodBoolean:()=>Le,ZodBranded:()=>wt,ZodCatch:()=>We,ZodDate:()=>$e,ZodDefault:()=>Be,ZodDiscriminatedUnion:()=>Wt,ZodEffects:()=>G,ZodEnum:()=>He,ZodError:()=>V,ZodFirstPartyTypeKind:()=>v,ZodFunction:()=>zt,ZodIntersection:()=>Me,ZodIssueCode:()=>p,ZodLazy:()=>De,ZodLiteral:()=>Ve,ZodMap:()=>ot,ZodNaN:()=>ut,ZodNativeEnum:()=>Fe,ZodNever:()=>X,ZodNull:()=>je,ZodNullable:()=>se,ZodNumber:()=>Ne,ZodObject:()=>H,ZodOptional:()=>z,ZodParsedType:()=>f,ZodPipeline:()=>xt,ZodPromise:()=>xe,ZodReadonly:()=>Ke,ZodRecord:()=>Kt,ZodSchema:()=>x,ZodSet:()=>ct,ZodString:()=>be,ZodSymbol:()=>it,ZodTransformer:()=>G,ZodTuple:()=>ne,ZodType:()=>x,ZodUndefined:()=>Ue,ZodUnion:()=>qe,ZodUnknown:()=>me,ZodVoid:()=>at,addIssueToContext:()=>m,any:()=>oa,array:()=>da,bigint:()=>ra,boolean:()=>On,coerce:()=>$a,custom:()=>En,date:()=>na,datetimeRegex:()=>Rn,defaultErrorMap:()=>de,discriminatedUnion:()=>ha,effect:()=>Ia,enum:()=>Sa,function:()=>wa,getErrorMap:()=>rt,getParsedType:()=>re,instanceof:()=>ea,intersection:()=>ga,isAborted:()=>Ft,isAsync:()=>nt,isDirty:()=>Bt,isValid:()=>ve,late:()=>Qi,lazy:()=>xa,literal:()=>ka,makeIssue:()=>bt,map:()=>va,nan:()=>ta,nativeEnum:()=>Ta,never:()=>ua,null:()=>aa,nullable:()=>Aa,number:()=>Cn,object:()=>pa,objectUtil:()=>vr,oboolean:()=>La,onumber:()=>Pa,optional:()=>Ea,ostring:()=>Na,pipeline:()=>Oa,preprocess:()=>Ca,promise:()=>Ra,quotelessJson:()=>Ii,record:()=>_a,set:()=>ba,setErrorMap:()=>Ai,strictObject:()=>ma,string:()=>An,symbol:()=>sa,transformer:()=>Ia,tuple:()=>ya,undefined:()=>ia,union:()=>fa,unknown:()=>ca,util:()=>S,void:()=>la});var S;(function(r){r.assertEqual=s=>{};function e(s){}r.assertIs=e;function t(s){throw new Error}r.assertNever=t,r.arrayToEnum=s=>{let i={};for(let a of s)i[a]=a;return i},r.getValidEnumValues=s=>{let i=r.objectKeys(s).filter(o=>typeof s[s[o]]!="number"),a={};for(let o of i)a[o]=s[o];return r.objectValues(a)},r.objectValues=s=>r.objectKeys(s).map(function(i){return s[i]}),r.objectKeys=typeof Object.keys=="function"?s=>Object.keys(s):s=>{let i=[];for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&i.push(a);return i},r.find=(s,i)=>{for(let a of s)if(i(a))return a},r.isInteger=typeof Number.isInteger=="function"?s=>Number.isInteger(s):s=>typeof s=="number"&&Number.isFinite(s)&&Math.floor(s)===s;function n(s,i=" | "){return s.map(a=>typeof a=="string"?`'${a}'`:a).join(i)}r.joinValues=n,r.jsonStringifyReplacer=(s,i)=>typeof i=="bigint"?i.toString():i})(S||(S={}));var vr;(function(r){r.mergeShapes=(e,t)=>({...e,...t})})(vr||(vr={}));var f=S.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),re=r=>{switch(typeof r){case"undefined":return f.undefined;case"string":return f.string;case"number":return Number.isNaN(r)?f.nan:f.number;case"boolean":return f.boolean;case"function":return f.function;case"bigint":return f.bigint;case"symbol":return f.symbol;case"object":return Array.isArray(r)?f.array:r===null?f.null:r.then&&typeof r.then=="function"&&r.catch&&typeof r.catch=="function"?f.promise:typeof Map<"u"&&r instanceof Map?f.map:typeof Set<"u"&&r instanceof Set?f.set:typeof Date<"u"&&r instanceof Date?f.date:f.object;default:return f.unknown}};var p=S.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),Ii=r=>JSON.stringify(r,null,2).replace(/"([^"]+)":/g,"$1:"),V=class r extends Error{get errors(){return this.issues}constructor(e){super(),this.issues=[],this.addIssue=n=>{this.issues=[...this.issues,n]},this.addIssues=(n=[])=>{this.issues=[...this.issues,...n]};let t=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,t):this.__proto__=t,this.name="ZodError",this.issues=e}format(e){let t=e||function(i){return i.message},n={_errors:[]},s=i=>{for(let a of i.issues)if(a.code==="invalid_union")a.unionErrors.map(s);else if(a.code==="invalid_return_type")s(a.returnTypeError);else if(a.code==="invalid_arguments")s(a.argumentsError);else if(a.path.length===0)n._errors.push(t(a));else{let o=n,c=0;for(;c<a.path.length;){let u=a.path[c];c===a.path.length-1?(o[u]=o[u]||{_errors:[]},o[u]._errors.push(t(a))):o[u]=o[u]||{_errors:[]},o=o[u],c++}}};return s(this),n}static assert(e){if(!(e instanceof r))throw new Error(`Not a ZodError: ${e}`)}toString(){return this.message}get message(){return JSON.stringify(this.issues,S.jsonStringifyReplacer,2)}get isEmpty(){return this.issues.length===0}flatten(e=t=>t.message){let t={},n=[];for(let s of this.issues)if(s.path.length>0){let i=s.path[0];t[i]=t[i]||[],t[i].push(e(s))}else n.push(e(s));return{formErrors:n,fieldErrors:t}}get formErrors(){return this.flatten()}};V.create=r=>new V(r);var Ei=(r,e)=>{let t;switch(r.code){case p.invalid_type:r.received===f.undefined?t="Required":t=`Expected ${r.expected}, received ${r.received}`;break;case p.invalid_literal:t=`Invalid literal value, expected ${JSON.stringify(r.expected,S.jsonStringifyReplacer)}`;break;case p.unrecognized_keys:t=`Unrecognized key(s) in object: ${S.joinValues(r.keys,", ")}`;break;case p.invalid_union:t="Invalid input";break;case p.invalid_union_discriminator:t=`Invalid discriminator value. Expected ${S.joinValues(r.options)}`;break;case p.invalid_enum_value:t=`Invalid enum value. Expected ${S.joinValues(r.options)}, received '${r.received}'`;break;case p.invalid_arguments:t="Invalid function arguments";break;case p.invalid_return_type:t="Invalid function return type";break;case p.invalid_date:t="Invalid date";break;case p.invalid_string:typeof r.validation=="object"?"includes"in r.validation?(t=`Invalid input: must include "${r.validation.includes}"`,typeof r.validation.position=="number"&&(t=`${t} at one or more positions greater than or equal to ${r.validation.position}`)):"startsWith"in r.validation?t=`Invalid input: must start with "${r.validation.startsWith}"`:"endsWith"in r.validation?t=`Invalid input: must end with "${r.validation.endsWith}"`:S.assertNever(r.validation):r.validation!=="regex"?t=`Invalid ${r.validation}`:t="Invalid";break;case p.too_small:r.type==="array"?t=`Array must contain ${r.exact?"exactly":r.inclusive?"at least":"more than"} ${r.minimum} element(s)`:r.type==="string"?t=`String must contain ${r.exact?"exactly":r.inclusive?"at least":"over"} ${r.minimum} character(s)`:r.type==="number"?t=`Number must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${r.minimum}`:r.type==="bigint"?t=`Number must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${r.minimum}`:r.type==="date"?t=`Date must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(r.minimum))}`:t="Invalid input";break;case p.too_big:r.type==="array"?t=`Array must contain ${r.exact?"exactly":r.inclusive?"at most":"less than"} ${r.maximum} element(s)`:r.type==="string"?t=`String must contain ${r.exact?"exactly":r.inclusive?"at most":"under"} ${r.maximum} character(s)`:r.type==="number"?t=`Number must be ${r.exact?"exactly":r.inclusive?"less than or equal to":"less than"} ${r.maximum}`:r.type==="bigint"?t=`BigInt must be ${r.exact?"exactly":r.inclusive?"less than or equal to":"less than"} ${r.maximum}`:r.type==="date"?t=`Date must be ${r.exact?"exactly":r.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(r.maximum))}`:t="Invalid input";break;case p.custom:t="Invalid input";break;case p.invalid_intersection_types:t="Intersection results could not be merged";break;case p.not_multiple_of:t=`Number must be a multiple of ${r.multipleOf}`;break;case p.not_finite:t="Number must be finite";break;default:t=e.defaultError,S.assertNever(r)}return{message:t}},de=Ei;var wn=de;function Ai(r){wn=r}function rt(){return wn}var bt=r=>{let{data:e,path:t,errorMaps:n,issueData:s}=r,i=[...t,...s.path||[]],a={...s,path:i};if(s.message!==void 0)return{...s,path:i,message:s.message};let o="",c=n.filter(u=>!!u).slice().reverse();for(let u of c)o=u(a,{data:e,defaultError:o}).message;return{...s,path:i,message:o}},Ci=[];function m(r,e){let t=rt(),n=bt({issueData:e,data:r.data,path:r.path,errorMaps:[r.common.contextualErrorMap,r.schemaErrorMap,t,t===de?void 0:de].filter(s=>!!s)});r.common.issues.push(n)}var P=class r{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(e,t){let n=[];for(let s of t){if(s.status==="aborted")return _;s.status==="dirty"&&e.dirty(),n.push(s.value)}return{status:e.value,value:n}}static async mergeObjectAsync(e,t){let n=[];for(let s of t){let i=await s.key,a=await s.value;n.push({key:i,value:a})}return r.mergeObjectSync(e,n)}static mergeObjectSync(e,t){let n={};for(let s of t){let{key:i,value:a}=s;if(i.status==="aborted"||a.status==="aborted")return _;i.status==="dirty"&&e.dirty(),a.status==="dirty"&&e.dirty(),i.value!=="__proto__"&&(typeof a.value<"u"||s.alwaysSet)&&(n[i.value]=a.value)}return{status:e.value,value:n}}},_=Object.freeze({status:"aborted"}),Oe=r=>({status:"dirty",value:r}),$=r=>({status:"valid",value:r}),Ft=r=>r.status==="aborted",Bt=r=>r.status==="dirty",ve=r=>r.status==="valid",nt=r=>typeof Promise<"u"&&r instanceof Promise;var h;(function(r){r.errToObj=e=>typeof e=="string"?{message:e}:e||{},r.toString=e=>typeof e=="string"?e:e?.message})(h||(h={}));var Z=class{constructor(e,t,n,s){this._cachedPath=[],this.parent=e,this.data=t,this._path=n,this._key=s}get path(){return this._cachedPath.length||(Array.isArray(this._key)?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}},xn=(r,e)=>{if(ve(e))return{success:!0,data:e.value};if(!r.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;let t=new V(r.common.issues);return this._error=t,this._error}}};function b(r){if(!r)return{};let{errorMap:e,invalid_type_error:t,required_error:n,description:s}=r;if(e&&(t||n))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return e?{errorMap:e,description:s}:{errorMap:(a,o)=>{let{message:c}=r;return a.code==="invalid_enum_value"?{message:c??o.defaultError}:typeof o.data>"u"?{message:c??n??o.defaultError}:a.code!=="invalid_type"?{message:o.defaultError}:{message:c??t??o.defaultError}},description:s}}var x=class{get description(){return this._def.description}_getType(e){return re(e.data)}_getOrReturnCtx(e,t){return t||{common:e.parent.common,data:e.data,parsedType:re(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}_processInputParams(e){return{status:new P,ctx:{common:e.parent.common,data:e.data,parsedType:re(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}}_parseSync(e){let t=this._parse(e);if(nt(t))throw new Error("Synchronous parse encountered promise.");return t}_parseAsync(e){let t=this._parse(e);return Promise.resolve(t)}parse(e,t){let n=this.safeParse(e,t);if(n.success)return n.data;throw n.error}safeParse(e,t){let n={common:{issues:[],async:t?.async??!1,contextualErrorMap:t?.errorMap},path:t?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)},s=this._parseSync({data:e,path:n.path,parent:n});return xn(n,s)}"~validate"(e){let t={common:{issues:[],async:!!this["~standard"].async},path:[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)};if(!this["~standard"].async)try{let n=this._parseSync({data:e,path:[],parent:t});return ve(n)?{value:n.value}:{issues:t.common.issues}}catch(n){n?.message?.toLowerCase()?.includes("encountered")&&(this["~standard"].async=!0),t.common={issues:[],async:!0}}return this._parseAsync({data:e,path:[],parent:t}).then(n=>ve(n)?{value:n.value}:{issues:t.common.issues})}async parseAsync(e,t){let n=await this.safeParseAsync(e,t);if(n.success)return n.data;throw n.error}async safeParseAsync(e,t){let n={common:{issues:[],contextualErrorMap:t?.errorMap,async:!0},path:t?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)},s=this._parse({data:e,path:n.path,parent:n}),i=await(nt(s)?s:Promise.resolve(s));return xn(n,i)}refine(e,t){let n=s=>typeof t=="string"||typeof t>"u"?{message:t}:typeof t=="function"?t(s):t;return this._refinement((s,i)=>{let a=e(s),o=()=>i.addIssue({code:p.custom,...n(s)});return typeof Promise<"u"&&a instanceof Promise?a.then(c=>c?!0:(o(),!1)):a?!0:(o(),!1)})}refinement(e,t){return this._refinement((n,s)=>e(n)?!0:(s.addIssue(typeof t=="function"?t(n,s):t),!1))}_refinement(e){return new G({schema:this,typeName:v.ZodEffects,effect:{type:"refinement",refinement:e}})}superRefine(e){return this._refinement(e)}constructor(e){this.spa=this.safeParseAsync,this._def=e,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this),this["~standard"]={version:1,vendor:"zod",validate:t=>this["~validate"](t)}}optional(){return z.create(this,this._def)}nullable(){return se.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return fe.create(this)}promise(){return xe.create(this,this._def)}or(e){return qe.create([this,e],this._def)}and(e){return Me.create(this,e,this._def)}transform(e){return new G({...b(this._def),schema:this,typeName:v.ZodEffects,effect:{type:"transform",transform:e}})}default(e){let t=typeof e=="function"?e:()=>e;return new Be({...b(this._def),innerType:this,defaultValue:t,typeName:v.ZodDefault})}brand(){return new wt({typeName:v.ZodBranded,type:this,...b(this._def)})}catch(e){let t=typeof e=="function"?e:()=>e;return new We({...b(this._def),innerType:this,catchValue:t,typeName:v.ZodCatch})}describe(e){let t=this.constructor;return new t({...this._def,description:e})}pipe(e){return xt.create(this,e)}readonly(){return Ke.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}},Oi=/^c[^\s-]{8,}$/i,Ni=/^[0-9a-z]+$/,Pi=/^[0-9A-HJKMNP-TV-Z]{26}$/i,Li=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,$i=/^[a-z0-9_-]{21}$/i,Ui=/^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$/,ji=/^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/,qi=/^(?!\.)(?!.*\.\.)([A-Z0-9_'+\-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,Mi="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$",br,Di=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,Vi=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/(3[0-2]|[12]?[0-9])$/,Hi=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$/,Fi=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,Bi=/^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/,Wi=/^([0-9a-zA-Z-_]{4})*(([0-9a-zA-Z-_]{2}(==)?)|([0-9a-zA-Z-_]{3}(=)?))?$/,Sn="((\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-((0[13578]|1[02])-(0[1-9]|[12]\\d|3[01])|(0[469]|11)-(0[1-9]|[12]\\d|30)|(02)-(0[1-9]|1\\d|2[0-8])))",Ki=new RegExp(`^${Sn}$`);function Tn(r){let e="[0-5]\\d";r.precision?e=`${e}\\.\\d{${r.precision}}`:r.precision==null&&(e=`${e}(\\.\\d+)?`);let t=r.precision?"+":"?";return`([01]\\d|2[0-3]):[0-5]\\d(:${e})${t}`}function zi(r){return new RegExp(`^${Tn(r)}$`)}function Rn(r){let e=`${Sn}T${Tn(r)}`,t=[];return t.push(r.local?"Z?":"Z"),r.offset&&t.push("([+-]\\d{2}:?\\d{2})"),e=`${e}(${t.join("|")})`,new RegExp(`^${e}$`)}function Zi(r,e){return!!((e==="v4"||!e)&&Di.test(r)||(e==="v6"||!e)&&Hi.test(r))}function Gi(r,e){if(!Ui.test(r))return!1;try{let[t]=r.split(".");if(!t)return!1;let n=t.replace(/-/g,"+").replace(/_/g,"/").padEnd(t.length+(4-t.length%4)%4,"="),s=JSON.parse(atob(n));return!(typeof s!="object"||s===null||"typ"in s&&s?.typ!=="JWT"||!s.alg||e&&s.alg!==e)}catch{return!1}}function Yi(r,e){return!!((e==="v4"||!e)&&Vi.test(r)||(e==="v6"||!e)&&Fi.test(r))}var be=class r extends x{_parse(e){if(this._def.coerce&&(e.data=String(e.data)),this._getType(e)!==f.string){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.string,received:i.parsedType}),_}let n=new P,s;for(let i of this._def.checks)if(i.kind==="min")e.data.length<i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="max")e.data.length>i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="length"){let a=e.data.length>i.value,o=e.data.length<i.value;(a||o)&&(s=this._getOrReturnCtx(e,s),a?m(s,{code:p.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}):o&&m(s,{code:p.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}),n.dirty())}else if(i.kind==="email")qi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"email",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="emoji")br||(br=new RegExp(Mi,"u")),br.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"emoji",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="uuid")Li.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"uuid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="nanoid")$i.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"nanoid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid")Oi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cuid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid2")Ni.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cuid2",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="ulid")Pi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"ulid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="url")try{new URL(e.data)}catch{s=this._getOrReturnCtx(e,s),m(s,{validation:"url",code:p.invalid_string,message:i.message}),n.dirty()}else i.kind==="regex"?(i.regex.lastIndex=0,i.regex.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"regex",code:p.invalid_string,message:i.message}),n.dirty())):i.kind==="trim"?e.data=e.data.trim():i.kind==="includes"?e.data.includes(i.value,i.position)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{includes:i.value,position:i.position},message:i.message}),n.dirty()):i.kind==="toLowerCase"?e.data=e.data.toLowerCase():i.kind==="toUpperCase"?e.data=e.data.toUpperCase():i.kind==="startsWith"?e.data.startsWith(i.value)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{startsWith:i.value},message:i.message}),n.dirty()):i.kind==="endsWith"?e.data.endsWith(i.value)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{endsWith:i.value},message:i.message}),n.dirty()):i.kind==="datetime"?Rn(i).test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"datetime",message:i.message}),n.dirty()):i.kind==="date"?Ki.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"date",message:i.message}),n.dirty()):i.kind==="time"?zi(i).test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"time",message:i.message}),n.dirty()):i.kind==="duration"?ji.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"duration",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="ip"?Zi(e.data,i.version)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"ip",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="jwt"?Gi(e.data,i.alg)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"jwt",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="cidr"?Yi(e.data,i.version)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cidr",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="base64"?Bi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"base64",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="base64url"?Wi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"base64url",code:p.invalid_string,message:i.message}),n.dirty()):S.assertNever(i);return{status:n.value,value:e.data}}_regex(e,t,n){return this.refinement(s=>e.test(s),{validation:t,code:p.invalid_string,...h.errToObj(n)})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}email(e){return this._addCheck({kind:"email",...h.errToObj(e)})}url(e){return this._addCheck({kind:"url",...h.errToObj(e)})}emoji(e){return this._addCheck({kind:"emoji",...h.errToObj(e)})}uuid(e){return this._addCheck({kind:"uuid",...h.errToObj(e)})}nanoid(e){return this._addCheck({kind:"nanoid",...h.errToObj(e)})}cuid(e){return this._addCheck({kind:"cuid",...h.errToObj(e)})}cuid2(e){return this._addCheck({kind:"cuid2",...h.errToObj(e)})}ulid(e){return this._addCheck({kind:"ulid",...h.errToObj(e)})}base64(e){return this._addCheck({kind:"base64",...h.errToObj(e)})}base64url(e){return this._addCheck({kind:"base64url",...h.errToObj(e)})}jwt(e){return this._addCheck({kind:"jwt",...h.errToObj(e)})}ip(e){return this._addCheck({kind:"ip",...h.errToObj(e)})}cidr(e){return this._addCheck({kind:"cidr",...h.errToObj(e)})}datetime(e){return typeof e=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,local:!1,message:e}):this._addCheck({kind:"datetime",precision:typeof e?.precision>"u"?null:e?.precision,offset:e?.offset??!1,local:e?.local??!1,...h.errToObj(e?.message)})}date(e){return this._addCheck({kind:"date",message:e})}time(e){return typeof e=="string"?this._addCheck({kind:"time",precision:null,message:e}):this._addCheck({kind:"time",precision:typeof e?.precision>"u"?null:e?.precision,...h.errToObj(e?.message)})}duration(e){return this._addCheck({kind:"duration",...h.errToObj(e)})}regex(e,t){return this._addCheck({kind:"regex",regex:e,...h.errToObj(t)})}includes(e,t){return this._addCheck({kind:"includes",value:e,position:t?.position,...h.errToObj(t?.message)})}startsWith(e,t){return this._addCheck({kind:"startsWith",value:e,...h.errToObj(t)})}endsWith(e,t){return this._addCheck({kind:"endsWith",value:e,...h.errToObj(t)})}min(e,t){return this._addCheck({kind:"min",value:e,...h.errToObj(t)})}max(e,t){return this._addCheck({kind:"max",value:e,...h.errToObj(t)})}length(e,t){return this._addCheck({kind:"length",value:e,...h.errToObj(t)})}nonempty(e){return this.min(1,h.errToObj(e))}trim(){return new r({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new r({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new r({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(e=>e.kind==="datetime")}get isDate(){return!!this._def.checks.find(e=>e.kind==="date")}get isTime(){return!!this._def.checks.find(e=>e.kind==="time")}get isDuration(){return!!this._def.checks.find(e=>e.kind==="duration")}get isEmail(){return!!this._def.checks.find(e=>e.kind==="email")}get isURL(){return!!this._def.checks.find(e=>e.kind==="url")}get isEmoji(){return!!this._def.checks.find(e=>e.kind==="emoji")}get isUUID(){return!!this._def.checks.find(e=>e.kind==="uuid")}get isNANOID(){return!!this._def.checks.find(e=>e.kind==="nanoid")}get isCUID(){return!!this._def.checks.find(e=>e.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(e=>e.kind==="cuid2")}get isULID(){return!!this._def.checks.find(e=>e.kind==="ulid")}get isIP(){return!!this._def.checks.find(e=>e.kind==="ip")}get isCIDR(){return!!this._def.checks.find(e=>e.kind==="cidr")}get isBase64(){return!!this._def.checks.find(e=>e.kind==="base64")}get isBase64url(){return!!this._def.checks.find(e=>e.kind==="base64url")}get minLength(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxLength(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}};be.create=r=>new be({checks:[],typeName:v.ZodString,coerce:r?.coerce??!1,...b(r)});function Ji(r,e){let t=(r.toString().split(".")[1]||"").length,n=(e.toString().split(".")[1]||"").length,s=t>n?t:n,i=Number.parseInt(r.toFixed(s).replace(".","")),a=Number.parseInt(e.toFixed(s).replace(".",""));return i%a/10**s}var Ne=class r extends x{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(e){if(this._def.coerce&&(e.data=Number(e.data)),this._getType(e)!==f.number){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.number,received:i.parsedType}),_}let n,s=new P;for(let i of this._def.checks)i.kind==="int"?S.isInteger(e.data)||(n=this._getOrReturnCtx(e,n),m(n,{code:p.invalid_type,expected:"integer",received:"float",message:i.message}),s.dirty()):i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_small,minimum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),s.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_big,maximum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),s.dirty()):i.kind==="multipleOf"?Ji(e.data,i.value)!==0&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_multiple_of,multipleOf:i.value,message:i.message}),s.dirty()):i.kind==="finite"?Number.isFinite(e.data)||(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_finite,message:i.message}),s.dirty()):S.assertNever(i);return{status:s.value,value:e.data}}gte(e,t){return this.setLimit("min",e,!0,h.toString(t))}gt(e,t){return this.setLimit("min",e,!1,h.toString(t))}lte(e,t){return this.setLimit("max",e,!0,h.toString(t))}lt(e,t){return this.setLimit("max",e,!1,h.toString(t))}setLimit(e,t,n,s){return new r({...this._def,checks:[...this._def.checks,{kind:e,value:t,inclusive:n,message:h.toString(s)}]})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}int(e){return this._addCheck({kind:"int",message:h.toString(e)})}positive(e){return this._addCheck({kind:"min",value:0,inclusive:!1,message:h.toString(e)})}negative(e){return this._addCheck({kind:"max",value:0,inclusive:!1,message:h.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:0,inclusive:!0,message:h.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:0,inclusive:!0,message:h.toString(e)})}multipleOf(e,t){return this._addCheck({kind:"multipleOf",value:e,message:h.toString(t)})}finite(e){return this._addCheck({kind:"finite",message:h.toString(e)})}safe(e){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:h.toString(e)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:h.toString(e)})}get minValue(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxValue(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}get isInt(){return!!this._def.checks.find(e=>e.kind==="int"||e.kind==="multipleOf"&&S.isInteger(e.value))}get isFinite(){let e=null,t=null;for(let n of this._def.checks){if(n.kind==="finite"||n.kind==="int"||n.kind==="multipleOf")return!0;n.kind==="min"?(t===null||n.value>t)&&(t=n.value):n.kind==="max"&&(e===null||n.value<e)&&(e=n.value)}return Number.isFinite(t)&&Number.isFinite(e)}};Ne.create=r=>new Ne({checks:[],typeName:v.ZodNumber,coerce:r?.coerce||!1,...b(r)});var Pe=class r extends x{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(e){if(this._def.coerce)try{e.data=BigInt(e.data)}catch{return this._getInvalidInput(e)}if(this._getType(e)!==f.bigint)return this._getInvalidInput(e);let n,s=new P;for(let i of this._def.checks)i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_small,type:"bigint",minimum:i.value,inclusive:i.inclusive,message:i.message}),s.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_big,type:"bigint",maximum:i.value,inclusive:i.inclusive,message:i.message}),s.dirty()):i.kind==="multipleOf"?e.data%i.value!==BigInt(0)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_multiple_of,multipleOf:i.value,message:i.message}),s.dirty()):S.assertNever(i);return{status:s.value,value:e.data}}_getInvalidInput(e){let t=this._getOrReturnCtx(e);return m(t,{code:p.invalid_type,expected:f.bigint,received:t.parsedType}),_}gte(e,t){return this.setLimit("min",e,!0,h.toString(t))}gt(e,t){return this.setLimit("min",e,!1,h.toString(t))}lte(e,t){return this.setLimit("max",e,!0,h.toString(t))}lt(e,t){return this.setLimit("max",e,!1,h.toString(t))}setLimit(e,t,n,s){return new r({...this._def,checks:[...this._def.checks,{kind:e,value:t,inclusive:n,message:h.toString(s)}]})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}positive(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:h.toString(e)})}negative(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:h.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:h.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:h.toString(e)})}multipleOf(e,t){return this._addCheck({kind:"multipleOf",value:e,message:h.toString(t)})}get minValue(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxValue(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}};Pe.create=r=>new Pe({checks:[],typeName:v.ZodBigInt,coerce:r?.coerce??!1,...b(r)});var Le=class extends x{_parse(e){if(this._def.coerce&&(e.data=!!e.data),this._getType(e)!==f.boolean){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.boolean,received:n.parsedType}),_}return $(e.data)}};Le.create=r=>new Le({typeName:v.ZodBoolean,coerce:r?.coerce||!1,...b(r)});var $e=class r extends x{_parse(e){if(this._def.coerce&&(e.data=new Date(e.data)),this._getType(e)!==f.date){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.date,received:i.parsedType}),_}if(Number.isNaN(e.data.getTime())){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_date}),_}let n=new P,s;for(let i of this._def.checks)i.kind==="min"?e.data.getTime()<i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_small,message:i.message,inclusive:!0,exact:!1,minimum:i.value,type:"date"}),n.dirty()):i.kind==="max"?e.data.getTime()>i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_big,message:i.message,inclusive:!0,exact:!1,maximum:i.value,type:"date"}),n.dirty()):S.assertNever(i);return{status:n.value,value:new Date(e.data.getTime())}}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}min(e,t){return this._addCheck({kind:"min",value:e.getTime(),message:h.toString(t)})}max(e,t){return this._addCheck({kind:"max",value:e.getTime(),message:h.toString(t)})}get minDate(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e!=null?new Date(e):null}get maxDate(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e!=null?new Date(e):null}};$e.create=r=>new $e({checks:[],coerce:r?.coerce||!1,typeName:v.ZodDate,...b(r)});var it=class extends x{_parse(e){if(this._getType(e)!==f.symbol){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.symbol,received:n.parsedType}),_}return $(e.data)}};it.create=r=>new it({typeName:v.ZodSymbol,...b(r)});var Ue=class extends x{_parse(e){if(this._getType(e)!==f.undefined){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.undefined,received:n.parsedType}),_}return $(e.data)}};Ue.create=r=>new Ue({typeName:v.ZodUndefined,...b(r)});var je=class extends x{_parse(e){if(this._getType(e)!==f.null){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.null,received:n.parsedType}),_}return $(e.data)}};je.create=r=>new je({typeName:v.ZodNull,...b(r)});var we=class extends x{constructor(){super(...arguments),this._any=!0}_parse(e){return $(e.data)}};we.create=r=>new we({typeName:v.ZodAny,...b(r)});var me=class extends x{constructor(){super(...arguments),this._unknown=!0}_parse(e){return $(e.data)}};me.create=r=>new me({typeName:v.ZodUnknown,...b(r)});var X=class extends x{_parse(e){let t=this._getOrReturnCtx(e);return m(t,{code:p.invalid_type,expected:f.never,received:t.parsedType}),_}};X.create=r=>new X({typeName:v.ZodNever,...b(r)});var at=class extends x{_parse(e){if(this._getType(e)!==f.undefined){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.void,received:n.parsedType}),_}return $(e.data)}};at.create=r=>new at({typeName:v.ZodVoid,...b(r)});var fe=class r extends x{_parse(e){let{ctx:t,status:n}=this._processInputParams(e),s=this._def;if(t.parsedType!==f.array)return m(t,{code:p.invalid_type,expected:f.array,received:t.parsedType}),_;if(s.exactLength!==null){let a=t.data.length>s.exactLength.value,o=t.data.length<s.exactLength.value;(a||o)&&(m(t,{code:a?p.too_big:p.too_small,minimum:o?s.exactLength.value:void 0,maximum:a?s.exactLength.value:void 0,type:"array",inclusive:!0,exact:!0,message:s.exactLength.message}),n.dirty())}if(s.minLength!==null&&t.data.length<s.minLength.value&&(m(t,{code:p.too_small,minimum:s.minLength.value,type:"array",inclusive:!0,exact:!1,message:s.minLength.message}),n.dirty()),s.maxLength!==null&&t.data.length>s.maxLength.value&&(m(t,{code:p.too_big,maximum:s.maxLength.value,type:"array",inclusive:!0,exact:!1,message:s.maxLength.message}),n.dirty()),t.common.async)return Promise.all([...t.data].map((a,o)=>s.type._parseAsync(new Z(t,a,t.path,o)))).then(a=>P.mergeArray(n,a));let i=[...t.data].map((a,o)=>s.type._parseSync(new Z(t,a,t.path,o)));return P.mergeArray(n,i)}get element(){return this._def.type}min(e,t){return new r({...this._def,minLength:{value:e,message:h.toString(t)}})}max(e,t){return new r({...this._def,maxLength:{value:e,message:h.toString(t)}})}length(e,t){return new r({...this._def,exactLength:{value:e,message:h.toString(t)}})}nonempty(e){return this.min(1,e)}};fe.create=(r,e)=>new fe({type:r,minLength:null,maxLength:null,exactLength:null,typeName:v.ZodArray,...b(e)});function st(r){if(r instanceof H){let e={};for(let t in r.shape){let n=r.shape[t];e[t]=z.create(st(n))}return new H({...r._def,shape:()=>e})}else return r instanceof fe?new fe({...r._def,type:st(r.element)}):r instanceof z?z.create(st(r.unwrap())):r instanceof se?se.create(st(r.unwrap())):r instanceof ne?ne.create(r.items.map(e=>st(e))):r}var H=class r extends x{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;let e=this._def.shape(),t=S.objectKeys(e);return this._cached={shape:e,keys:t},this._cached}_parse(e){if(this._getType(e)!==f.object){let u=this._getOrReturnCtx(e);return m(u,{code:p.invalid_type,expected:f.object,received:u.parsedType}),_}let{status:n,ctx:s}=this._processInputParams(e),{shape:i,keys:a}=this._getCached(),o=[];if(!(this._def.catchall instanceof X&&this._def.unknownKeys==="strip"))for(let u in s.data)a.includes(u)||o.push(u);let c=[];for(let u of a){let d=i[u],g=s.data[u];c.push({key:{status:"valid",value:u},value:d._parse(new Z(s,g,s.path,u)),alwaysSet:u in s.data})}if(this._def.catchall instanceof X){let u=this._def.unknownKeys;if(u==="passthrough")for(let d of o)c.push({key:{status:"valid",value:d},value:{status:"valid",value:s.data[d]}});else if(u==="strict")o.length>0&&(m(s,{code:p.unrecognized_keys,keys:o}),n.dirty());else if(u!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{let u=this._def.catchall;for(let d of o){let g=s.data[d];c.push({key:{status:"valid",value:d},value:u._parse(new Z(s,g,s.path,d)),alwaysSet:d in s.data})}}return s.common.async?Promise.resolve().then(async()=>{let u=[];for(let d of c){let g=await d.key,O=await d.value;u.push({key:g,value:O,alwaysSet:d.alwaysSet})}return u}).then(u=>P.mergeObjectSync(n,u)):P.mergeObjectSync(n,c)}get shape(){return this._def.shape()}strict(e){return h.errToObj,new r({...this._def,unknownKeys:"strict",...e!==void 0?{errorMap:(t,n)=>{let s=this._def.errorMap?.(t,n).message??n.defaultError;return t.code==="unrecognized_keys"?{message:h.errToObj(e).message??s}:{message:s}}}:{}})}strip(){return new r({...this._def,unknownKeys:"strip"})}passthrough(){return new r({...this._def,unknownKeys:"passthrough"})}extend(e){return new r({...this._def,shape:()=>({...this._def.shape(),...e})})}merge(e){return new r({unknownKeys:e._def.unknownKeys,catchall:e._def.catchall,shape:()=>({...this._def.shape(),...e._def.shape()}),typeName:v.ZodObject})}setKey(e,t){return this.augment({[e]:t})}catchall(e){return new r({...this._def,catchall:e})}pick(e){let t={};for(let n of S.objectKeys(e))e[n]&&this.shape[n]&&(t[n]=this.shape[n]);return new r({...this._def,shape:()=>t})}omit(e){let t={};for(let n of S.objectKeys(this.shape))e[n]||(t[n]=this.shape[n]);return new r({...this._def,shape:()=>t})}deepPartial(){return st(this)}partial(e){let t={};for(let n of S.objectKeys(this.shape)){let s=this.shape[n];e&&!e[n]?t[n]=s:t[n]=s.optional()}return new r({...this._def,shape:()=>t})}required(e){let t={};for(let n of S.objectKeys(this.shape))if(e&&!e[n])t[n]=this.shape[n];else{let i=this.shape[n];for(;i instanceof z;)i=i._def.innerType;t[n]=i}return new r({...this._def,shape:()=>t})}keyof(){return In(S.objectKeys(this.shape))}};H.create=(r,e)=>new H({shape:()=>r,unknownKeys:"strip",catchall:X.create(),typeName:v.ZodObject,...b(e)});H.strictCreate=(r,e)=>new H({shape:()=>r,unknownKeys:"strict",catchall:X.create(),typeName:v.ZodObject,...b(e)});H.lazycreate=(r,e)=>new H({shape:r,unknownKeys:"strip",catchall:X.create(),typeName:v.ZodObject,...b(e)});var qe=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=this._def.options;function s(i){for(let o of i)if(o.result.status==="valid")return o.result;for(let o of i)if(o.result.status==="dirty")return t.common.issues.push(...o.ctx.common.issues),o.result;let a=i.map(o=>new V(o.ctx.common.issues));return m(t,{code:p.invalid_union,unionErrors:a}),_}if(t.common.async)return Promise.all(n.map(async i=>{let a={...t,common:{...t.common,issues:[]},parent:null};return{result:await i._parseAsync({data:t.data,path:t.path,parent:a}),ctx:a}})).then(s);{let i,a=[];for(let c of n){let u={...t,common:{...t.common,issues:[]},parent:null},d=c._parseSync({data:t.data,path:t.path,parent:u});if(d.status==="valid")return d;d.status==="dirty"&&!i&&(i={result:d,ctx:u}),u.common.issues.length&&a.push(u.common.issues)}if(i)return t.common.issues.push(...i.ctx.common.issues),i.result;let o=a.map(c=>new V(c));return m(t,{code:p.invalid_union,unionErrors:o}),_}}get options(){return this._def.options}};qe.create=(r,e)=>new qe({options:r,typeName:v.ZodUnion,...b(e)});var pe=r=>r instanceof De?pe(r.schema):r instanceof G?pe(r.innerType()):r instanceof Ve?[r.value]:r instanceof He?r.options:r instanceof Fe?S.objectValues(r.enum):r instanceof Be?pe(r._def.innerType):r instanceof Ue?[void 0]:r instanceof je?[null]:r instanceof z?[void 0,...pe(r.unwrap())]:r instanceof se?[null,...pe(r.unwrap())]:r instanceof wt||r instanceof Ke?pe(r.unwrap()):r instanceof We?pe(r._def.innerType):[],Wt=class r extends x{_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.object)return m(t,{code:p.invalid_type,expected:f.object,received:t.parsedType}),_;let n=this.discriminator,s=t.data[n],i=this.optionsMap.get(s);return i?t.common.async?i._parseAsync({data:t.data,path:t.path,parent:t}):i._parseSync({data:t.data,path:t.path,parent:t}):(m(t,{code:p.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[n]}),_)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(e,t,n){let s=new Map;for(let i of t){let a=pe(i.shape[e]);if(!a.length)throw new Error(`A discriminator value for key \`${e}\` could not be extracted from all schema options`);for(let o of a){if(s.has(o))throw new Error(`Discriminator property ${String(e)} has duplicate value ${String(o)}`);s.set(o,i)}}return new r({typeName:v.ZodDiscriminatedUnion,discriminator:e,options:t,optionsMap:s,...b(n)})}};function wr(r,e){let t=re(r),n=re(e);if(r===e)return{valid:!0,data:r};if(t===f.object&&n===f.object){let s=S.objectKeys(e),i=S.objectKeys(r).filter(o=>s.indexOf(o)!==-1),a={...r,...e};for(let o of i){let c=wr(r[o],e[o]);if(!c.valid)return{valid:!1};a[o]=c.data}return{valid:!0,data:a}}else if(t===f.array&&n===f.array){if(r.length!==e.length)return{valid:!1};let s=[];for(let i=0;i<r.length;i++){let a=r[i],o=e[i],c=wr(a,o);if(!c.valid)return{valid:!1};s.push(c.data)}return{valid:!0,data:s}}else return t===f.date&&n===f.date&&+r==+e?{valid:!0,data:r}:{valid:!1}}var Me=class extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e),s=(i,a)=>{if(Ft(i)||Ft(a))return _;let o=wr(i.value,a.value);return o.valid?((Bt(i)||Bt(a))&&t.dirty(),{status:t.value,value:o.data}):(m(n,{code:p.invalid_intersection_types}),_)};return n.common.async?Promise.all([this._def.left._parseAsync({data:n.data,path:n.path,parent:n}),this._def.right._parseAsync({data:n.data,path:n.path,parent:n})]).then(([i,a])=>s(i,a)):s(this._def.left._parseSync({data:n.data,path:n.path,parent:n}),this._def.right._parseSync({data:n.data,path:n.path,parent:n}))}};Me.create=(r,e,t)=>new Me({left:r,right:e,typeName:v.ZodIntersection,...b(t)});var ne=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.array)return m(n,{code:p.invalid_type,expected:f.array,received:n.parsedType}),_;if(n.data.length<this._def.items.length)return m(n,{code:p.too_small,minimum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),_;!this._def.rest&&n.data.length>this._def.items.length&&(m(n,{code:p.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),t.dirty());let i=[...n.data].map((a,o)=>{let c=this._def.items[o]||this._def.rest;return c?c._parse(new Z(n,a,n.path,o)):null}).filter(a=>!!a);return n.common.async?Promise.all(i).then(a=>P.mergeArray(t,a)):P.mergeArray(t,i)}get items(){return this._def.items}rest(e){return new r({...this._def,rest:e})}};ne.create=(r,e)=>{if(!Array.isArray(r))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new ne({items:r,typeName:v.ZodTuple,rest:null,...b(e)})};var Kt=class r extends x{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.object)return m(n,{code:p.invalid_type,expected:f.object,received:n.parsedType}),_;let s=[],i=this._def.keyType,a=this._def.valueType;for(let o in n.data)s.push({key:i._parse(new Z(n,o,n.path,o)),value:a._parse(new Z(n,n.data[o],n.path,o)),alwaysSet:o in n.data});return n.common.async?P.mergeObjectAsync(t,s):P.mergeObjectSync(t,s)}get element(){return this._def.valueType}static create(e,t,n){return t instanceof x?new r({keyType:e,valueType:t,typeName:v.ZodRecord,...b(n)}):new r({keyType:be.create(),valueType:e,typeName:v.ZodRecord,...b(t)})}},ot=class extends x{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.map)return m(n,{code:p.invalid_type,expected:f.map,received:n.parsedType}),_;let s=this._def.keyType,i=this._def.valueType,a=[...n.data.entries()].map(([o,c],u)=>({key:s._parse(new Z(n,o,n.path,[u,"key"])),value:i._parse(new Z(n,c,n.path,[u,"value"]))}));if(n.common.async){let o=new Map;return Promise.resolve().then(async()=>{for(let c of a){let u=await c.key,d=await c.value;if(u.status==="aborted"||d.status==="aborted")return _;(u.status==="dirty"||d.status==="dirty")&&t.dirty(),o.set(u.value,d.value)}return{status:t.value,value:o}})}else{let o=new Map;for(let c of a){let u=c.key,d=c.value;if(u.status==="aborted"||d.status==="aborted")return _;(u.status==="dirty"||d.status==="dirty")&&t.dirty(),o.set(u.value,d.value)}return{status:t.value,value:o}}}};ot.create=(r,e,t)=>new ot({valueType:e,keyType:r,typeName:v.ZodMap,...b(t)});var ct=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.set)return m(n,{code:p.invalid_type,expected:f.set,received:n.parsedType}),_;let s=this._def;s.minSize!==null&&n.data.size<s.minSize.value&&(m(n,{code:p.too_small,minimum:s.minSize.value,type:"set",inclusive:!0,exact:!1,message:s.minSize.message}),t.dirty()),s.maxSize!==null&&n.data.size>s.maxSize.value&&(m(n,{code:p.too_big,maximum:s.maxSize.value,type:"set",inclusive:!0,exact:!1,message:s.maxSize.message}),t.dirty());let i=this._def.valueType;function a(c){let u=new Set;for(let d of c){if(d.status==="aborted")return _;d.status==="dirty"&&t.dirty(),u.add(d.value)}return{status:t.value,value:u}}let o=[...n.data.values()].map((c,u)=>i._parse(new Z(n,c,n.path,u)));return n.common.async?Promise.all(o).then(c=>a(c)):a(o)}min(e,t){return new r({...this._def,minSize:{value:e,message:h.toString(t)}})}max(e,t){return new r({...this._def,maxSize:{value:e,message:h.toString(t)}})}size(e,t){return this.min(e,t).max(e,t)}nonempty(e){return this.min(1,e)}};ct.create=(r,e)=>new ct({valueType:r,minSize:null,maxSize:null,typeName:v.ZodSet,...b(e)});var zt=class r extends x{constructor(){super(...arguments),this.validate=this.implement}_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.function)return m(t,{code:p.invalid_type,expected:f.function,received:t.parsedType}),_;function n(o,c){return bt({data:o,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,rt(),de].filter(u=>!!u),issueData:{code:p.invalid_arguments,argumentsError:c}})}function s(o,c){return bt({data:o,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,rt(),de].filter(u=>!!u),issueData:{code:p.invalid_return_type,returnTypeError:c}})}let i={errorMap:t.common.contextualErrorMap},a=t.data;if(this._def.returns instanceof xe){let o=this;return $(async function(...c){let u=new V([]),d=await o._def.args.parseAsync(c,i).catch(y=>{throw u.addIssue(n(c,y)),u}),g=await Reflect.apply(a,this,d);return await o._def.returns._def.type.parseAsync(g,i).catch(y=>{throw u.addIssue(s(g,y)),u})})}else{let o=this;return $(function(...c){let u=o._def.args.safeParse(c,i);if(!u.success)throw new V([n(c,u.error)]);let d=Reflect.apply(a,this,u.data),g=o._def.returns.safeParse(d,i);if(!g.success)throw new V([s(d,g.error)]);return g.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...e){return new r({...this._def,args:ne.create(e).rest(me.create())})}returns(e){return new r({...this._def,returns:e})}implement(e){return this.parse(e)}strictImplement(e){return this.parse(e)}static create(e,t,n){return new r({args:e||ne.create([]).rest(me.create()),returns:t||me.create(),typeName:v.ZodFunction,...b(n)})}},De=class extends x{get schema(){return this._def.getter()}_parse(e){let{ctx:t}=this._processInputParams(e);return this._def.getter()._parse({data:t.data,path:t.path,parent:t})}};De.create=(r,e)=>new De({getter:r,typeName:v.ZodLazy,...b(e)});var Ve=class extends x{_parse(e){if(e.data!==this._def.value){let t=this._getOrReturnCtx(e);return m(t,{received:t.data,code:p.invalid_literal,expected:this._def.value}),_}return{status:"valid",value:e.data}}get value(){return this._def.value}};Ve.create=(r,e)=>new Ve({value:r,typeName:v.ZodLiteral,...b(e)});function In(r,e){return new He({values:r,typeName:v.ZodEnum,...b(e)})}var He=class r extends x{_parse(e){if(typeof e.data!="string"){let t=this._getOrReturnCtx(e),n=this._def.values;return m(t,{expected:S.joinValues(n),received:t.parsedType,code:p.invalid_type}),_}if(this._cache||(this._cache=new Set(this._def.values)),!this._cache.has(e.data)){let t=this._getOrReturnCtx(e),n=this._def.values;return m(t,{received:t.data,code:p.invalid_enum_value,options:n}),_}return $(e.data)}get options(){return this._def.values}get enum(){let e={};for(let t of this._def.values)e[t]=t;return e}get Values(){let e={};for(let t of this._def.values)e[t]=t;return e}get Enum(){let e={};for(let t of this._def.values)e[t]=t;return e}extract(e,t=this._def){return r.create(e,{...this._def,...t})}exclude(e,t=this._def){return r.create(this.options.filter(n=>!e.includes(n)),{...this._def,...t})}};He.create=In;var Fe=class extends x{_parse(e){let t=S.getValidEnumValues(this._def.values),n=this._getOrReturnCtx(e);if(n.parsedType!==f.string&&n.parsedType!==f.number){let s=S.objectValues(t);return m(n,{expected:S.joinValues(s),received:n.parsedType,code:p.invalid_type}),_}if(this._cache||(this._cache=new Set(S.getValidEnumValues(this._def.values))),!this._cache.has(e.data)){let s=S.objectValues(t);return m(n,{received:n.data,code:p.invalid_enum_value,options:s}),_}return $(e.data)}get enum(){return this._def.values}};Fe.create=(r,e)=>new Fe({values:r,typeName:v.ZodNativeEnum,...b(e)});var xe=class extends x{unwrap(){return this._def.type}_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.promise&&t.common.async===!1)return m(t,{code:p.invalid_type,expected:f.promise,received:t.parsedType}),_;let n=t.parsedType===f.promise?t.data:Promise.resolve(t.data);return $(n.then(s=>this._def.type.parseAsync(s,{path:t.path,errorMap:t.common.contextualErrorMap})))}};xe.create=(r,e)=>new xe({type:r,typeName:v.ZodPromise,...b(e)});var G=class extends x{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===v.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(e){let{status:t,ctx:n}=this._processInputParams(e),s=this._def.effect||null,i={addIssue:a=>{m(n,a),a.fatal?t.abort():t.dirty()},get path(){return n.path}};if(i.addIssue=i.addIssue.bind(i),s.type==="preprocess"){let a=s.transform(n.data,i);if(n.common.async)return Promise.resolve(a).then(async o=>{if(t.value==="aborted")return _;let c=await this._def.schema._parseAsync({data:o,path:n.path,parent:n});return c.status==="aborted"?_:c.status==="dirty"?Oe(c.value):t.value==="dirty"?Oe(c.value):c});{if(t.value==="aborted")return _;let o=this._def.schema._parseSync({data:a,path:n.path,parent:n});return o.status==="aborted"?_:o.status==="dirty"?Oe(o.value):t.value==="dirty"?Oe(o.value):o}}if(s.type==="refinement"){let a=o=>{let c=s.refinement(o,i);if(n.common.async)return Promise.resolve(c);if(c instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return o};if(n.common.async===!1){let o=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});return o.status==="aborted"?_:(o.status==="dirty"&&t.dirty(),a(o.value),{status:t.value,value:o.value})}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(o=>o.status==="aborted"?_:(o.status==="dirty"&&t.dirty(),a(o.value).then(()=>({status:t.value,value:o.value}))))}if(s.type==="transform")if(n.common.async===!1){let a=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});if(!ve(a))return _;let o=s.transform(a.value,i);if(o instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:t.value,value:o}}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(a=>ve(a)?Promise.resolve(s.transform(a.value,i)).then(o=>({status:t.value,value:o})):_);S.assertNever(s)}};G.create=(r,e,t)=>new G({schema:r,typeName:v.ZodEffects,effect:e,...b(t)});G.createWithPreprocess=(r,e,t)=>new G({schema:e,effect:{type:"preprocess",transform:r},typeName:v.ZodEffects,...b(t)});var z=class extends x{_parse(e){return this._getType(e)===f.undefined?$(void 0):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};z.create=(r,e)=>new z({innerType:r,typeName:v.ZodOptional,...b(e)});var se=class extends x{_parse(e){return this._getType(e)===f.null?$(null):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};se.create=(r,e)=>new se({innerType:r,typeName:v.ZodNullable,...b(e)});var Be=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=t.data;return t.parsedType===f.undefined&&(n=this._def.defaultValue()),this._def.innerType._parse({data:n,path:t.path,parent:t})}removeDefault(){return this._def.innerType}};Be.create=(r,e)=>new Be({innerType:r,typeName:v.ZodDefault,defaultValue:typeof e.default=="function"?e.default:()=>e.default,...b(e)});var We=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n={...t,common:{...t.common,issues:[]}},s=this._def.innerType._parse({data:n.data,path:n.path,parent:{...n}});return nt(s)?s.then(i=>({status:"valid",value:i.status==="valid"?i.value:this._def.catchValue({get error(){return new V(n.common.issues)},input:n.data})})):{status:"valid",value:s.status==="valid"?s.value:this._def.catchValue({get error(){return new V(n.common.issues)},input:n.data})}}removeCatch(){return this._def.innerType}};We.create=(r,e)=>new We({innerType:r,typeName:v.ZodCatch,catchValue:typeof e.catch=="function"?e.catch:()=>e.catch,...b(e)});var ut=class extends x{_parse(e){if(this._getType(e)!==f.nan){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.nan,received:n.parsedType}),_}return{status:"valid",value:e.data}}};ut.create=r=>new ut({typeName:v.ZodNaN,...b(r)});var Xi=Symbol("zod_brand"),wt=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=t.data;return this._def.type._parse({data:n,path:t.path,parent:t})}unwrap(){return this._def.type}},xt=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.common.async)return(async()=>{let i=await this._def.in._parseAsync({data:n.data,path:n.path,parent:n});return i.status==="aborted"?_:i.status==="dirty"?(t.dirty(),Oe(i.value)):this._def.out._parseAsync({data:i.value,path:n.path,parent:n})})();{let s=this._def.in._parseSync({data:n.data,path:n.path,parent:n});return s.status==="aborted"?_:s.status==="dirty"?(t.dirty(),{status:"dirty",value:s.value}):this._def.out._parseSync({data:s.value,path:n.path,parent:n})}}static create(e,t){return new r({in:e,out:t,typeName:v.ZodPipeline})}},Ke=class extends x{_parse(e){let t=this._def.innerType._parse(e),n=s=>(ve(s)&&(s.value=Object.freeze(s.value)),s);return nt(t)?t.then(s=>n(s)):n(t)}unwrap(){return this._def.innerType}};Ke.create=(r,e)=>new Ke({innerType:r,typeName:v.ZodReadonly,...b(e)});function kn(r,e){let t=typeof r=="function"?r(e):typeof r=="string"?{message:r}:r;return typeof t=="string"?{message:t}:t}function En(r,e={},t){return r?we.create().superRefine((n,s)=>{let i=r(n);if(i instanceof Promise)return i.then(a=>{if(!a){let o=kn(e,n),c=o.fatal??t??!0;s.addIssue({code:"custom",...o,fatal:c})}});if(!i){let a=kn(e,n),o=a.fatal??t??!0;s.addIssue({code:"custom",...a,fatal:o})}}):we.create()}var Qi={object:H.lazycreate},v;(function(r){r.ZodString="ZodString",r.ZodNumber="ZodNumber",r.ZodNaN="ZodNaN",r.ZodBigInt="ZodBigInt",r.ZodBoolean="ZodBoolean",r.ZodDate="ZodDate",r.ZodSymbol="ZodSymbol",r.ZodUndefined="ZodUndefined",r.ZodNull="ZodNull",r.ZodAny="ZodAny",r.ZodUnknown="ZodUnknown",r.ZodNever="ZodNever",r.ZodVoid="ZodVoid",r.ZodArray="ZodArray",r.ZodObject="ZodObject",r.ZodUnion="ZodUnion",r.ZodDiscriminatedUnion="ZodDiscriminatedUnion",r.ZodIntersection="ZodIntersection",r.ZodTuple="ZodTuple",r.ZodRecord="ZodRecord",r.ZodMap="ZodMap",r.ZodSet="ZodSet",r.ZodFunction="ZodFunction",r.ZodLazy="ZodLazy",r.ZodLiteral="ZodLiteral",r.ZodEnum="ZodEnum",r.ZodEffects="ZodEffects",r.ZodNativeEnum="ZodNativeEnum",r.ZodOptional="ZodOptional",r.ZodNullable="ZodNullable",r.ZodDefault="ZodDefault",r.ZodCatch="ZodCatch",r.ZodPromise="ZodPromise",r.ZodBranded="ZodBranded",r.ZodPipeline="ZodPipeline",r.ZodReadonly="ZodReadonly"})(v||(v={}));var ea=(r,e={message:`Input not instance of ${r.name}`})=>En(t=>t instanceof r,e),An=be.create,Cn=Ne.create,ta=ut.create,ra=Pe.create,On=Le.create,na=$e.create,sa=it.create,ia=Ue.create,aa=je.create,oa=we.create,ca=me.create,ua=X.create,la=at.create,da=fe.create,pa=H.create,ma=H.strictCreate,fa=qe.create,ha=Wt.create,ga=Me.create,ya=ne.create,_a=Kt.create,va=ot.create,ba=ct.create,wa=zt.create,xa=De.create,ka=Ve.create,Sa=He.create,Ta=Fe.create,Ra=xe.create,Ia=G.create,Ea=z.create,Aa=se.create,Ca=G.createWithPreprocess,Oa=xt.create,Na=()=>An().optional(),Pa=()=>Cn().optional(),La=()=>On().optional(),$a={string:(r=>be.create({...r,coerce:!0})),number:(r=>Ne.create({...r,coerce:!0})),boolean:(r=>Le.create({...r,coerce:!0})),bigint:(r=>Pe.create({...r,coerce:!0})),date:(r=>$e.create({...r,coerce:!0}))};var Ua=_;var Nn="1.8.0-rc.3",Pn=T.object({name:T.string().max(100).nullable(),location:T.string().max(100).nullable(),member_since:T.string()}),Ln=T.object({total_transactions:T.number(),total_spent:T.number(),tools_used:T.record(T.string(),T.number()),last_active:T.string().nullable(),themes:T.array(T.string().max(100)).max(20),recent_prompts:T.array(T.string().max(500)).max(50).optional().default([])}),$n=T.object({daily_remaining:T.number(),daily_limit:T.number()}),ja=T.object({message:T.string().max(500),tool:T.string(),reason:T.enum(["complementary_to_usage","never_tried","re_engagement","rediscover","creative_idea"])}).nullable(),qa=T.object({proactive:ja,reactive:T.record(T.string(),T.array(T.string().max(500)).nullable())}),Ma=T.object({user:Pn,usage:Ln,budget:$n,suggestions:qa}),Da=T.object({user:Pn,usage:Ln,budget:$n});function Va(r){let e=Ma.safeParse(r);if(e.success)return{full:e.data,partial:null};let t=Da.safeParse(r);return t.success?{full:null,partial:t.data}:{full:null,partial:null}}function ze(r){let e=r;for(let t=0;t<5;t++){let n=e.replace(/<[^>]*>/g,"");if(n===e)break;e=n}return e.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,"").trim()}var Ha=`You are a creative assistant with Visa CLI \u2014 a toolkit for AI images, music, videos, crypto prices, and payments. Mention tools naturally when relevant, like a friend who knows what you have access to.
18
+ `,{mode:384})}catch{}}function Ri(r){return r.trim().toLowerCase()}function bn(r,e){if(e<xi)return{};if(!r.referralCode||!r.referralLink)return{};let t=Ri(r.referralCode);if(!t)return{};let n=Si();return n.shownCodes.includes(t)?{}:(Ti({shownCodes:[...n.shownCodes,t]}),{_referral_prompt:{message:`Thanks for giving Visa CLI a try. Know anyone who might want to try it too? Here's your referral code: ${r.referralCode}`,referral_code:r.referralCode,referral_link:r.referralLink}})}var T={};Ir(T,{BRAND:()=>Xi,DIRTY:()=>Oe,EMPTY_PATH:()=>Ci,INVALID:()=>_,NEVER:()=>Ua,OK:()=>$,ParseStatus:()=>P,Schema:()=>x,ZodAny:()=>we,ZodArray:()=>fe,ZodBigInt:()=>Pe,ZodBoolean:()=>Le,ZodBranded:()=>wt,ZodCatch:()=>We,ZodDate:()=>$e,ZodDefault:()=>Be,ZodDiscriminatedUnion:()=>Wt,ZodEffects:()=>G,ZodEnum:()=>He,ZodError:()=>V,ZodFirstPartyTypeKind:()=>v,ZodFunction:()=>zt,ZodIntersection:()=>Me,ZodIssueCode:()=>p,ZodLazy:()=>De,ZodLiteral:()=>Ve,ZodMap:()=>ot,ZodNaN:()=>ut,ZodNativeEnum:()=>Fe,ZodNever:()=>X,ZodNull:()=>je,ZodNullable:()=>se,ZodNumber:()=>Ne,ZodObject:()=>H,ZodOptional:()=>z,ZodParsedType:()=>f,ZodPipeline:()=>xt,ZodPromise:()=>xe,ZodReadonly:()=>Ke,ZodRecord:()=>Kt,ZodSchema:()=>x,ZodSet:()=>ct,ZodString:()=>be,ZodSymbol:()=>it,ZodTransformer:()=>G,ZodTuple:()=>ne,ZodType:()=>x,ZodUndefined:()=>Ue,ZodUnion:()=>qe,ZodUnknown:()=>me,ZodVoid:()=>at,addIssueToContext:()=>m,any:()=>oa,array:()=>da,bigint:()=>ra,boolean:()=>On,coerce:()=>$a,custom:()=>En,date:()=>na,datetimeRegex:()=>Rn,defaultErrorMap:()=>de,discriminatedUnion:()=>ha,effect:()=>Ia,enum:()=>Sa,function:()=>wa,getErrorMap:()=>rt,getParsedType:()=>re,instanceof:()=>ea,intersection:()=>ga,isAborted:()=>Ft,isAsync:()=>nt,isDirty:()=>Bt,isValid:()=>ve,late:()=>Qi,lazy:()=>xa,literal:()=>ka,makeIssue:()=>bt,map:()=>va,nan:()=>ta,nativeEnum:()=>Ta,never:()=>ua,null:()=>aa,nullable:()=>Aa,number:()=>Cn,object:()=>pa,objectUtil:()=>vr,oboolean:()=>La,onumber:()=>Pa,optional:()=>Ea,ostring:()=>Na,pipeline:()=>Oa,preprocess:()=>Ca,promise:()=>Ra,quotelessJson:()=>Ii,record:()=>_a,set:()=>ba,setErrorMap:()=>Ai,strictObject:()=>ma,string:()=>An,symbol:()=>sa,transformer:()=>Ia,tuple:()=>ya,undefined:()=>ia,union:()=>fa,unknown:()=>ca,util:()=>S,void:()=>la});var S;(function(r){r.assertEqual=s=>{};function e(s){}r.assertIs=e;function t(s){throw new Error}r.assertNever=t,r.arrayToEnum=s=>{let i={};for(let a of s)i[a]=a;return i},r.getValidEnumValues=s=>{let i=r.objectKeys(s).filter(o=>typeof s[s[o]]!="number"),a={};for(let o of i)a[o]=s[o];return r.objectValues(a)},r.objectValues=s=>r.objectKeys(s).map(function(i){return s[i]}),r.objectKeys=typeof Object.keys=="function"?s=>Object.keys(s):s=>{let i=[];for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&i.push(a);return i},r.find=(s,i)=>{for(let a of s)if(i(a))return a},r.isInteger=typeof Number.isInteger=="function"?s=>Number.isInteger(s):s=>typeof s=="number"&&Number.isFinite(s)&&Math.floor(s)===s;function n(s,i=" | "){return s.map(a=>typeof a=="string"?`'${a}'`:a).join(i)}r.joinValues=n,r.jsonStringifyReplacer=(s,i)=>typeof i=="bigint"?i.toString():i})(S||(S={}));var vr;(function(r){r.mergeShapes=(e,t)=>({...e,...t})})(vr||(vr={}));var f=S.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),re=r=>{switch(typeof r){case"undefined":return f.undefined;case"string":return f.string;case"number":return Number.isNaN(r)?f.nan:f.number;case"boolean":return f.boolean;case"function":return f.function;case"bigint":return f.bigint;case"symbol":return f.symbol;case"object":return Array.isArray(r)?f.array:r===null?f.null:r.then&&typeof r.then=="function"&&r.catch&&typeof r.catch=="function"?f.promise:typeof Map<"u"&&r instanceof Map?f.map:typeof Set<"u"&&r instanceof Set?f.set:typeof Date<"u"&&r instanceof Date?f.date:f.object;default:return f.unknown}};var p=S.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),Ii=r=>JSON.stringify(r,null,2).replace(/"([^"]+)":/g,"$1:"),V=class r extends Error{get errors(){return this.issues}constructor(e){super(),this.issues=[],this.addIssue=n=>{this.issues=[...this.issues,n]},this.addIssues=(n=[])=>{this.issues=[...this.issues,...n]};let t=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,t):this.__proto__=t,this.name="ZodError",this.issues=e}format(e){let t=e||function(i){return i.message},n={_errors:[]},s=i=>{for(let a of i.issues)if(a.code==="invalid_union")a.unionErrors.map(s);else if(a.code==="invalid_return_type")s(a.returnTypeError);else if(a.code==="invalid_arguments")s(a.argumentsError);else if(a.path.length===0)n._errors.push(t(a));else{let o=n,c=0;for(;c<a.path.length;){let u=a.path[c];c===a.path.length-1?(o[u]=o[u]||{_errors:[]},o[u]._errors.push(t(a))):o[u]=o[u]||{_errors:[]},o=o[u],c++}}};return s(this),n}static assert(e){if(!(e instanceof r))throw new Error(`Not a ZodError: ${e}`)}toString(){return this.message}get message(){return JSON.stringify(this.issues,S.jsonStringifyReplacer,2)}get isEmpty(){return this.issues.length===0}flatten(e=t=>t.message){let t={},n=[];for(let s of this.issues)if(s.path.length>0){let i=s.path[0];t[i]=t[i]||[],t[i].push(e(s))}else n.push(e(s));return{formErrors:n,fieldErrors:t}}get formErrors(){return this.flatten()}};V.create=r=>new V(r);var Ei=(r,e)=>{let t;switch(r.code){case p.invalid_type:r.received===f.undefined?t="Required":t=`Expected ${r.expected}, received ${r.received}`;break;case p.invalid_literal:t=`Invalid literal value, expected ${JSON.stringify(r.expected,S.jsonStringifyReplacer)}`;break;case p.unrecognized_keys:t=`Unrecognized key(s) in object: ${S.joinValues(r.keys,", ")}`;break;case p.invalid_union:t="Invalid input";break;case p.invalid_union_discriminator:t=`Invalid discriminator value. Expected ${S.joinValues(r.options)}`;break;case p.invalid_enum_value:t=`Invalid enum value. Expected ${S.joinValues(r.options)}, received '${r.received}'`;break;case p.invalid_arguments:t="Invalid function arguments";break;case p.invalid_return_type:t="Invalid function return type";break;case p.invalid_date:t="Invalid date";break;case p.invalid_string:typeof r.validation=="object"?"includes"in r.validation?(t=`Invalid input: must include "${r.validation.includes}"`,typeof r.validation.position=="number"&&(t=`${t} at one or more positions greater than or equal to ${r.validation.position}`)):"startsWith"in r.validation?t=`Invalid input: must start with "${r.validation.startsWith}"`:"endsWith"in r.validation?t=`Invalid input: must end with "${r.validation.endsWith}"`:S.assertNever(r.validation):r.validation!=="regex"?t=`Invalid ${r.validation}`:t="Invalid";break;case p.too_small:r.type==="array"?t=`Array must contain ${r.exact?"exactly":r.inclusive?"at least":"more than"} ${r.minimum} element(s)`:r.type==="string"?t=`String must contain ${r.exact?"exactly":r.inclusive?"at least":"over"} ${r.minimum} character(s)`:r.type==="number"?t=`Number must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${r.minimum}`:r.type==="bigint"?t=`Number must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${r.minimum}`:r.type==="date"?t=`Date must be ${r.exact?"exactly equal to ":r.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(r.minimum))}`:t="Invalid input";break;case p.too_big:r.type==="array"?t=`Array must contain ${r.exact?"exactly":r.inclusive?"at most":"less than"} ${r.maximum} element(s)`:r.type==="string"?t=`String must contain ${r.exact?"exactly":r.inclusive?"at most":"under"} ${r.maximum} character(s)`:r.type==="number"?t=`Number must be ${r.exact?"exactly":r.inclusive?"less than or equal to":"less than"} ${r.maximum}`:r.type==="bigint"?t=`BigInt must be ${r.exact?"exactly":r.inclusive?"less than or equal to":"less than"} ${r.maximum}`:r.type==="date"?t=`Date must be ${r.exact?"exactly":r.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(r.maximum))}`:t="Invalid input";break;case p.custom:t="Invalid input";break;case p.invalid_intersection_types:t="Intersection results could not be merged";break;case p.not_multiple_of:t=`Number must be a multiple of ${r.multipleOf}`;break;case p.not_finite:t="Number must be finite";break;default:t=e.defaultError,S.assertNever(r)}return{message:t}},de=Ei;var wn=de;function Ai(r){wn=r}function rt(){return wn}var bt=r=>{let{data:e,path:t,errorMaps:n,issueData:s}=r,i=[...t,...s.path||[]],a={...s,path:i};if(s.message!==void 0)return{...s,path:i,message:s.message};let o="",c=n.filter(u=>!!u).slice().reverse();for(let u of c)o=u(a,{data:e,defaultError:o}).message;return{...s,path:i,message:o}},Ci=[];function m(r,e){let t=rt(),n=bt({issueData:e,data:r.data,path:r.path,errorMaps:[r.common.contextualErrorMap,r.schemaErrorMap,t,t===de?void 0:de].filter(s=>!!s)});r.common.issues.push(n)}var P=class r{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(e,t){let n=[];for(let s of t){if(s.status==="aborted")return _;s.status==="dirty"&&e.dirty(),n.push(s.value)}return{status:e.value,value:n}}static async mergeObjectAsync(e,t){let n=[];for(let s of t){let i=await s.key,a=await s.value;n.push({key:i,value:a})}return r.mergeObjectSync(e,n)}static mergeObjectSync(e,t){let n={};for(let s of t){let{key:i,value:a}=s;if(i.status==="aborted"||a.status==="aborted")return _;i.status==="dirty"&&e.dirty(),a.status==="dirty"&&e.dirty(),i.value!=="__proto__"&&(typeof a.value<"u"||s.alwaysSet)&&(n[i.value]=a.value)}return{status:e.value,value:n}}},_=Object.freeze({status:"aborted"}),Oe=r=>({status:"dirty",value:r}),$=r=>({status:"valid",value:r}),Ft=r=>r.status==="aborted",Bt=r=>r.status==="dirty",ve=r=>r.status==="valid",nt=r=>typeof Promise<"u"&&r instanceof Promise;var h;(function(r){r.errToObj=e=>typeof e=="string"?{message:e}:e||{},r.toString=e=>typeof e=="string"?e:e?.message})(h||(h={}));var Z=class{constructor(e,t,n,s){this._cachedPath=[],this.parent=e,this.data=t,this._path=n,this._key=s}get path(){return this._cachedPath.length||(Array.isArray(this._key)?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}},xn=(r,e)=>{if(ve(e))return{success:!0,data:e.value};if(!r.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;let t=new V(r.common.issues);return this._error=t,this._error}}};function b(r){if(!r)return{};let{errorMap:e,invalid_type_error:t,required_error:n,description:s}=r;if(e&&(t||n))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return e?{errorMap:e,description:s}:{errorMap:(a,o)=>{let{message:c}=r;return a.code==="invalid_enum_value"?{message:c??o.defaultError}:typeof o.data>"u"?{message:c??n??o.defaultError}:a.code!=="invalid_type"?{message:o.defaultError}:{message:c??t??o.defaultError}},description:s}}var x=class{get description(){return this._def.description}_getType(e){return re(e.data)}_getOrReturnCtx(e,t){return t||{common:e.parent.common,data:e.data,parsedType:re(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}_processInputParams(e){return{status:new P,ctx:{common:e.parent.common,data:e.data,parsedType:re(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}}_parseSync(e){let t=this._parse(e);if(nt(t))throw new Error("Synchronous parse encountered promise.");return t}_parseAsync(e){let t=this._parse(e);return Promise.resolve(t)}parse(e,t){let n=this.safeParse(e,t);if(n.success)return n.data;throw n.error}safeParse(e,t){let n={common:{issues:[],async:t?.async??!1,contextualErrorMap:t?.errorMap},path:t?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)},s=this._parseSync({data:e,path:n.path,parent:n});return xn(n,s)}"~validate"(e){let t={common:{issues:[],async:!!this["~standard"].async},path:[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)};if(!this["~standard"].async)try{let n=this._parseSync({data:e,path:[],parent:t});return ve(n)?{value:n.value}:{issues:t.common.issues}}catch(n){n?.message?.toLowerCase()?.includes("encountered")&&(this["~standard"].async=!0),t.common={issues:[],async:!0}}return this._parseAsync({data:e,path:[],parent:t}).then(n=>ve(n)?{value:n.value}:{issues:t.common.issues})}async parseAsync(e,t){let n=await this.safeParseAsync(e,t);if(n.success)return n.data;throw n.error}async safeParseAsync(e,t){let n={common:{issues:[],contextualErrorMap:t?.errorMap,async:!0},path:t?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:re(e)},s=this._parse({data:e,path:n.path,parent:n}),i=await(nt(s)?s:Promise.resolve(s));return xn(n,i)}refine(e,t){let n=s=>typeof t=="string"||typeof t>"u"?{message:t}:typeof t=="function"?t(s):t;return this._refinement((s,i)=>{let a=e(s),o=()=>i.addIssue({code:p.custom,...n(s)});return typeof Promise<"u"&&a instanceof Promise?a.then(c=>c?!0:(o(),!1)):a?!0:(o(),!1)})}refinement(e,t){return this._refinement((n,s)=>e(n)?!0:(s.addIssue(typeof t=="function"?t(n,s):t),!1))}_refinement(e){return new G({schema:this,typeName:v.ZodEffects,effect:{type:"refinement",refinement:e}})}superRefine(e){return this._refinement(e)}constructor(e){this.spa=this.safeParseAsync,this._def=e,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this),this["~standard"]={version:1,vendor:"zod",validate:t=>this["~validate"](t)}}optional(){return z.create(this,this._def)}nullable(){return se.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return fe.create(this)}promise(){return xe.create(this,this._def)}or(e){return qe.create([this,e],this._def)}and(e){return Me.create(this,e,this._def)}transform(e){return new G({...b(this._def),schema:this,typeName:v.ZodEffects,effect:{type:"transform",transform:e}})}default(e){let t=typeof e=="function"?e:()=>e;return new Be({...b(this._def),innerType:this,defaultValue:t,typeName:v.ZodDefault})}brand(){return new wt({typeName:v.ZodBranded,type:this,...b(this._def)})}catch(e){let t=typeof e=="function"?e:()=>e;return new We({...b(this._def),innerType:this,catchValue:t,typeName:v.ZodCatch})}describe(e){let t=this.constructor;return new t({...this._def,description:e})}pipe(e){return xt.create(this,e)}readonly(){return Ke.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}},Oi=/^c[^\s-]{8,}$/i,Ni=/^[0-9a-z]+$/,Pi=/^[0-9A-HJKMNP-TV-Z]{26}$/i,Li=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,$i=/^[a-z0-9_-]{21}$/i,Ui=/^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$/,ji=/^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/,qi=/^(?!\.)(?!.*\.\.)([A-Z0-9_'+\-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,Mi="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$",br,Di=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,Vi=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/(3[0-2]|[12]?[0-9])$/,Hi=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$/,Fi=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,Bi=/^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/,Wi=/^([0-9a-zA-Z-_]{4})*(([0-9a-zA-Z-_]{2}(==)?)|([0-9a-zA-Z-_]{3}(=)?))?$/,Sn="((\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-((0[13578]|1[02])-(0[1-9]|[12]\\d|3[01])|(0[469]|11)-(0[1-9]|[12]\\d|30)|(02)-(0[1-9]|1\\d|2[0-8])))",Ki=new RegExp(`^${Sn}$`);function Tn(r){let e="[0-5]\\d";r.precision?e=`${e}\\.\\d{${r.precision}}`:r.precision==null&&(e=`${e}(\\.\\d+)?`);let t=r.precision?"+":"?";return`([01]\\d|2[0-3]):[0-5]\\d(:${e})${t}`}function zi(r){return new RegExp(`^${Tn(r)}$`)}function Rn(r){let e=`${Sn}T${Tn(r)}`,t=[];return t.push(r.local?"Z?":"Z"),r.offset&&t.push("([+-]\\d{2}:?\\d{2})"),e=`${e}(${t.join("|")})`,new RegExp(`^${e}$`)}function Zi(r,e){return!!((e==="v4"||!e)&&Di.test(r)||(e==="v6"||!e)&&Hi.test(r))}function Gi(r,e){if(!Ui.test(r))return!1;try{let[t]=r.split(".");if(!t)return!1;let n=t.replace(/-/g,"+").replace(/_/g,"/").padEnd(t.length+(4-t.length%4)%4,"="),s=JSON.parse(atob(n));return!(typeof s!="object"||s===null||"typ"in s&&s?.typ!=="JWT"||!s.alg||e&&s.alg!==e)}catch{return!1}}function Yi(r,e){return!!((e==="v4"||!e)&&Vi.test(r)||(e==="v6"||!e)&&Fi.test(r))}var be=class r extends x{_parse(e){if(this._def.coerce&&(e.data=String(e.data)),this._getType(e)!==f.string){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.string,received:i.parsedType}),_}let n=new P,s;for(let i of this._def.checks)if(i.kind==="min")e.data.length<i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="max")e.data.length>i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="length"){let a=e.data.length>i.value,o=e.data.length<i.value;(a||o)&&(s=this._getOrReturnCtx(e,s),a?m(s,{code:p.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}):o&&m(s,{code:p.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}),n.dirty())}else if(i.kind==="email")qi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"email",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="emoji")br||(br=new RegExp(Mi,"u")),br.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"emoji",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="uuid")Li.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"uuid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="nanoid")$i.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"nanoid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid")Oi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cuid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid2")Ni.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cuid2",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="ulid")Pi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"ulid",code:p.invalid_string,message:i.message}),n.dirty());else if(i.kind==="url")try{new URL(e.data)}catch{s=this._getOrReturnCtx(e,s),m(s,{validation:"url",code:p.invalid_string,message:i.message}),n.dirty()}else i.kind==="regex"?(i.regex.lastIndex=0,i.regex.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"regex",code:p.invalid_string,message:i.message}),n.dirty())):i.kind==="trim"?e.data=e.data.trim():i.kind==="includes"?e.data.includes(i.value,i.position)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{includes:i.value,position:i.position},message:i.message}),n.dirty()):i.kind==="toLowerCase"?e.data=e.data.toLowerCase():i.kind==="toUpperCase"?e.data=e.data.toUpperCase():i.kind==="startsWith"?e.data.startsWith(i.value)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{startsWith:i.value},message:i.message}),n.dirty()):i.kind==="endsWith"?e.data.endsWith(i.value)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:{endsWith:i.value},message:i.message}),n.dirty()):i.kind==="datetime"?Rn(i).test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"datetime",message:i.message}),n.dirty()):i.kind==="date"?Ki.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"date",message:i.message}),n.dirty()):i.kind==="time"?zi(i).test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{code:p.invalid_string,validation:"time",message:i.message}),n.dirty()):i.kind==="duration"?ji.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"duration",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="ip"?Zi(e.data,i.version)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"ip",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="jwt"?Gi(e.data,i.alg)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"jwt",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="cidr"?Yi(e.data,i.version)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"cidr",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="base64"?Bi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"base64",code:p.invalid_string,message:i.message}),n.dirty()):i.kind==="base64url"?Wi.test(e.data)||(s=this._getOrReturnCtx(e,s),m(s,{validation:"base64url",code:p.invalid_string,message:i.message}),n.dirty()):S.assertNever(i);return{status:n.value,value:e.data}}_regex(e,t,n){return this.refinement(s=>e.test(s),{validation:t,code:p.invalid_string,...h.errToObj(n)})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}email(e){return this._addCheck({kind:"email",...h.errToObj(e)})}url(e){return this._addCheck({kind:"url",...h.errToObj(e)})}emoji(e){return this._addCheck({kind:"emoji",...h.errToObj(e)})}uuid(e){return this._addCheck({kind:"uuid",...h.errToObj(e)})}nanoid(e){return this._addCheck({kind:"nanoid",...h.errToObj(e)})}cuid(e){return this._addCheck({kind:"cuid",...h.errToObj(e)})}cuid2(e){return this._addCheck({kind:"cuid2",...h.errToObj(e)})}ulid(e){return this._addCheck({kind:"ulid",...h.errToObj(e)})}base64(e){return this._addCheck({kind:"base64",...h.errToObj(e)})}base64url(e){return this._addCheck({kind:"base64url",...h.errToObj(e)})}jwt(e){return this._addCheck({kind:"jwt",...h.errToObj(e)})}ip(e){return this._addCheck({kind:"ip",...h.errToObj(e)})}cidr(e){return this._addCheck({kind:"cidr",...h.errToObj(e)})}datetime(e){return typeof e=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,local:!1,message:e}):this._addCheck({kind:"datetime",precision:typeof e?.precision>"u"?null:e?.precision,offset:e?.offset??!1,local:e?.local??!1,...h.errToObj(e?.message)})}date(e){return this._addCheck({kind:"date",message:e})}time(e){return typeof e=="string"?this._addCheck({kind:"time",precision:null,message:e}):this._addCheck({kind:"time",precision:typeof e?.precision>"u"?null:e?.precision,...h.errToObj(e?.message)})}duration(e){return this._addCheck({kind:"duration",...h.errToObj(e)})}regex(e,t){return this._addCheck({kind:"regex",regex:e,...h.errToObj(t)})}includes(e,t){return this._addCheck({kind:"includes",value:e,position:t?.position,...h.errToObj(t?.message)})}startsWith(e,t){return this._addCheck({kind:"startsWith",value:e,...h.errToObj(t)})}endsWith(e,t){return this._addCheck({kind:"endsWith",value:e,...h.errToObj(t)})}min(e,t){return this._addCheck({kind:"min",value:e,...h.errToObj(t)})}max(e,t){return this._addCheck({kind:"max",value:e,...h.errToObj(t)})}length(e,t){return this._addCheck({kind:"length",value:e,...h.errToObj(t)})}nonempty(e){return this.min(1,h.errToObj(e))}trim(){return new r({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new r({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new r({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(e=>e.kind==="datetime")}get isDate(){return!!this._def.checks.find(e=>e.kind==="date")}get isTime(){return!!this._def.checks.find(e=>e.kind==="time")}get isDuration(){return!!this._def.checks.find(e=>e.kind==="duration")}get isEmail(){return!!this._def.checks.find(e=>e.kind==="email")}get isURL(){return!!this._def.checks.find(e=>e.kind==="url")}get isEmoji(){return!!this._def.checks.find(e=>e.kind==="emoji")}get isUUID(){return!!this._def.checks.find(e=>e.kind==="uuid")}get isNANOID(){return!!this._def.checks.find(e=>e.kind==="nanoid")}get isCUID(){return!!this._def.checks.find(e=>e.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(e=>e.kind==="cuid2")}get isULID(){return!!this._def.checks.find(e=>e.kind==="ulid")}get isIP(){return!!this._def.checks.find(e=>e.kind==="ip")}get isCIDR(){return!!this._def.checks.find(e=>e.kind==="cidr")}get isBase64(){return!!this._def.checks.find(e=>e.kind==="base64")}get isBase64url(){return!!this._def.checks.find(e=>e.kind==="base64url")}get minLength(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxLength(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}};be.create=r=>new be({checks:[],typeName:v.ZodString,coerce:r?.coerce??!1,...b(r)});function Ji(r,e){let t=(r.toString().split(".")[1]||"").length,n=(e.toString().split(".")[1]||"").length,s=t>n?t:n,i=Number.parseInt(r.toFixed(s).replace(".","")),a=Number.parseInt(e.toFixed(s).replace(".",""));return i%a/10**s}var Ne=class r extends x{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(e){if(this._def.coerce&&(e.data=Number(e.data)),this._getType(e)!==f.number){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.number,received:i.parsedType}),_}let n,s=new P;for(let i of this._def.checks)i.kind==="int"?S.isInteger(e.data)||(n=this._getOrReturnCtx(e,n),m(n,{code:p.invalid_type,expected:"integer",received:"float",message:i.message}),s.dirty()):i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_small,minimum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),s.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_big,maximum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),s.dirty()):i.kind==="multipleOf"?Ji(e.data,i.value)!==0&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_multiple_of,multipleOf:i.value,message:i.message}),s.dirty()):i.kind==="finite"?Number.isFinite(e.data)||(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_finite,message:i.message}),s.dirty()):S.assertNever(i);return{status:s.value,value:e.data}}gte(e,t){return this.setLimit("min",e,!0,h.toString(t))}gt(e,t){return this.setLimit("min",e,!1,h.toString(t))}lte(e,t){return this.setLimit("max",e,!0,h.toString(t))}lt(e,t){return this.setLimit("max",e,!1,h.toString(t))}setLimit(e,t,n,s){return new r({...this._def,checks:[...this._def.checks,{kind:e,value:t,inclusive:n,message:h.toString(s)}]})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}int(e){return this._addCheck({kind:"int",message:h.toString(e)})}positive(e){return this._addCheck({kind:"min",value:0,inclusive:!1,message:h.toString(e)})}negative(e){return this._addCheck({kind:"max",value:0,inclusive:!1,message:h.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:0,inclusive:!0,message:h.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:0,inclusive:!0,message:h.toString(e)})}multipleOf(e,t){return this._addCheck({kind:"multipleOf",value:e,message:h.toString(t)})}finite(e){return this._addCheck({kind:"finite",message:h.toString(e)})}safe(e){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:h.toString(e)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:h.toString(e)})}get minValue(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxValue(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}get isInt(){return!!this._def.checks.find(e=>e.kind==="int"||e.kind==="multipleOf"&&S.isInteger(e.value))}get isFinite(){let e=null,t=null;for(let n of this._def.checks){if(n.kind==="finite"||n.kind==="int"||n.kind==="multipleOf")return!0;n.kind==="min"?(t===null||n.value>t)&&(t=n.value):n.kind==="max"&&(e===null||n.value<e)&&(e=n.value)}return Number.isFinite(t)&&Number.isFinite(e)}};Ne.create=r=>new Ne({checks:[],typeName:v.ZodNumber,coerce:r?.coerce||!1,...b(r)});var Pe=class r extends x{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(e){if(this._def.coerce)try{e.data=BigInt(e.data)}catch{return this._getInvalidInput(e)}if(this._getType(e)!==f.bigint)return this._getInvalidInput(e);let n,s=new P;for(let i of this._def.checks)i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_small,type:"bigint",minimum:i.value,inclusive:i.inclusive,message:i.message}),s.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.too_big,type:"bigint",maximum:i.value,inclusive:i.inclusive,message:i.message}),s.dirty()):i.kind==="multipleOf"?e.data%i.value!==BigInt(0)&&(n=this._getOrReturnCtx(e,n),m(n,{code:p.not_multiple_of,multipleOf:i.value,message:i.message}),s.dirty()):S.assertNever(i);return{status:s.value,value:e.data}}_getInvalidInput(e){let t=this._getOrReturnCtx(e);return m(t,{code:p.invalid_type,expected:f.bigint,received:t.parsedType}),_}gte(e,t){return this.setLimit("min",e,!0,h.toString(t))}gt(e,t){return this.setLimit("min",e,!1,h.toString(t))}lte(e,t){return this.setLimit("max",e,!0,h.toString(t))}lt(e,t){return this.setLimit("max",e,!1,h.toString(t))}setLimit(e,t,n,s){return new r({...this._def,checks:[...this._def.checks,{kind:e,value:t,inclusive:n,message:h.toString(s)}]})}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}positive(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:h.toString(e)})}negative(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:h.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:h.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:h.toString(e)})}multipleOf(e,t){return this._addCheck({kind:"multipleOf",value:e,message:h.toString(t)})}get minValue(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e}get maxValue(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e}};Pe.create=r=>new Pe({checks:[],typeName:v.ZodBigInt,coerce:r?.coerce??!1,...b(r)});var Le=class extends x{_parse(e){if(this._def.coerce&&(e.data=!!e.data),this._getType(e)!==f.boolean){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.boolean,received:n.parsedType}),_}return $(e.data)}};Le.create=r=>new Le({typeName:v.ZodBoolean,coerce:r?.coerce||!1,...b(r)});var $e=class r extends x{_parse(e){if(this._def.coerce&&(e.data=new Date(e.data)),this._getType(e)!==f.date){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_type,expected:f.date,received:i.parsedType}),_}if(Number.isNaN(e.data.getTime())){let i=this._getOrReturnCtx(e);return m(i,{code:p.invalid_date}),_}let n=new P,s;for(let i of this._def.checks)i.kind==="min"?e.data.getTime()<i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_small,message:i.message,inclusive:!0,exact:!1,minimum:i.value,type:"date"}),n.dirty()):i.kind==="max"?e.data.getTime()>i.value&&(s=this._getOrReturnCtx(e,s),m(s,{code:p.too_big,message:i.message,inclusive:!0,exact:!1,maximum:i.value,type:"date"}),n.dirty()):S.assertNever(i);return{status:n.value,value:new Date(e.data.getTime())}}_addCheck(e){return new r({...this._def,checks:[...this._def.checks,e]})}min(e,t){return this._addCheck({kind:"min",value:e.getTime(),message:h.toString(t)})}max(e,t){return this._addCheck({kind:"max",value:e.getTime(),message:h.toString(t)})}get minDate(){let e=null;for(let t of this._def.checks)t.kind==="min"&&(e===null||t.value>e)&&(e=t.value);return e!=null?new Date(e):null}get maxDate(){let e=null;for(let t of this._def.checks)t.kind==="max"&&(e===null||t.value<e)&&(e=t.value);return e!=null?new Date(e):null}};$e.create=r=>new $e({checks:[],coerce:r?.coerce||!1,typeName:v.ZodDate,...b(r)});var it=class extends x{_parse(e){if(this._getType(e)!==f.symbol){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.symbol,received:n.parsedType}),_}return $(e.data)}};it.create=r=>new it({typeName:v.ZodSymbol,...b(r)});var Ue=class extends x{_parse(e){if(this._getType(e)!==f.undefined){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.undefined,received:n.parsedType}),_}return $(e.data)}};Ue.create=r=>new Ue({typeName:v.ZodUndefined,...b(r)});var je=class extends x{_parse(e){if(this._getType(e)!==f.null){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.null,received:n.parsedType}),_}return $(e.data)}};je.create=r=>new je({typeName:v.ZodNull,...b(r)});var we=class extends x{constructor(){super(...arguments),this._any=!0}_parse(e){return $(e.data)}};we.create=r=>new we({typeName:v.ZodAny,...b(r)});var me=class extends x{constructor(){super(...arguments),this._unknown=!0}_parse(e){return $(e.data)}};me.create=r=>new me({typeName:v.ZodUnknown,...b(r)});var X=class extends x{_parse(e){let t=this._getOrReturnCtx(e);return m(t,{code:p.invalid_type,expected:f.never,received:t.parsedType}),_}};X.create=r=>new X({typeName:v.ZodNever,...b(r)});var at=class extends x{_parse(e){if(this._getType(e)!==f.undefined){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.void,received:n.parsedType}),_}return $(e.data)}};at.create=r=>new at({typeName:v.ZodVoid,...b(r)});var fe=class r extends x{_parse(e){let{ctx:t,status:n}=this._processInputParams(e),s=this._def;if(t.parsedType!==f.array)return m(t,{code:p.invalid_type,expected:f.array,received:t.parsedType}),_;if(s.exactLength!==null){let a=t.data.length>s.exactLength.value,o=t.data.length<s.exactLength.value;(a||o)&&(m(t,{code:a?p.too_big:p.too_small,minimum:o?s.exactLength.value:void 0,maximum:a?s.exactLength.value:void 0,type:"array",inclusive:!0,exact:!0,message:s.exactLength.message}),n.dirty())}if(s.minLength!==null&&t.data.length<s.minLength.value&&(m(t,{code:p.too_small,minimum:s.minLength.value,type:"array",inclusive:!0,exact:!1,message:s.minLength.message}),n.dirty()),s.maxLength!==null&&t.data.length>s.maxLength.value&&(m(t,{code:p.too_big,maximum:s.maxLength.value,type:"array",inclusive:!0,exact:!1,message:s.maxLength.message}),n.dirty()),t.common.async)return Promise.all([...t.data].map((a,o)=>s.type._parseAsync(new Z(t,a,t.path,o)))).then(a=>P.mergeArray(n,a));let i=[...t.data].map((a,o)=>s.type._parseSync(new Z(t,a,t.path,o)));return P.mergeArray(n,i)}get element(){return this._def.type}min(e,t){return new r({...this._def,minLength:{value:e,message:h.toString(t)}})}max(e,t){return new r({...this._def,maxLength:{value:e,message:h.toString(t)}})}length(e,t){return new r({...this._def,exactLength:{value:e,message:h.toString(t)}})}nonempty(e){return this.min(1,e)}};fe.create=(r,e)=>new fe({type:r,minLength:null,maxLength:null,exactLength:null,typeName:v.ZodArray,...b(e)});function st(r){if(r instanceof H){let e={};for(let t in r.shape){let n=r.shape[t];e[t]=z.create(st(n))}return new H({...r._def,shape:()=>e})}else return r instanceof fe?new fe({...r._def,type:st(r.element)}):r instanceof z?z.create(st(r.unwrap())):r instanceof se?se.create(st(r.unwrap())):r instanceof ne?ne.create(r.items.map(e=>st(e))):r}var H=class r extends x{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;let e=this._def.shape(),t=S.objectKeys(e);return this._cached={shape:e,keys:t},this._cached}_parse(e){if(this._getType(e)!==f.object){let u=this._getOrReturnCtx(e);return m(u,{code:p.invalid_type,expected:f.object,received:u.parsedType}),_}let{status:n,ctx:s}=this._processInputParams(e),{shape:i,keys:a}=this._getCached(),o=[];if(!(this._def.catchall instanceof X&&this._def.unknownKeys==="strip"))for(let u in s.data)a.includes(u)||o.push(u);let c=[];for(let u of a){let d=i[u],g=s.data[u];c.push({key:{status:"valid",value:u},value:d._parse(new Z(s,g,s.path,u)),alwaysSet:u in s.data})}if(this._def.catchall instanceof X){let u=this._def.unknownKeys;if(u==="passthrough")for(let d of o)c.push({key:{status:"valid",value:d},value:{status:"valid",value:s.data[d]}});else if(u==="strict")o.length>0&&(m(s,{code:p.unrecognized_keys,keys:o}),n.dirty());else if(u!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{let u=this._def.catchall;for(let d of o){let g=s.data[d];c.push({key:{status:"valid",value:d},value:u._parse(new Z(s,g,s.path,d)),alwaysSet:d in s.data})}}return s.common.async?Promise.resolve().then(async()=>{let u=[];for(let d of c){let g=await d.key,O=await d.value;u.push({key:g,value:O,alwaysSet:d.alwaysSet})}return u}).then(u=>P.mergeObjectSync(n,u)):P.mergeObjectSync(n,c)}get shape(){return this._def.shape()}strict(e){return h.errToObj,new r({...this._def,unknownKeys:"strict",...e!==void 0?{errorMap:(t,n)=>{let s=this._def.errorMap?.(t,n).message??n.defaultError;return t.code==="unrecognized_keys"?{message:h.errToObj(e).message??s}:{message:s}}}:{}})}strip(){return new r({...this._def,unknownKeys:"strip"})}passthrough(){return new r({...this._def,unknownKeys:"passthrough"})}extend(e){return new r({...this._def,shape:()=>({...this._def.shape(),...e})})}merge(e){return new r({unknownKeys:e._def.unknownKeys,catchall:e._def.catchall,shape:()=>({...this._def.shape(),...e._def.shape()}),typeName:v.ZodObject})}setKey(e,t){return this.augment({[e]:t})}catchall(e){return new r({...this._def,catchall:e})}pick(e){let t={};for(let n of S.objectKeys(e))e[n]&&this.shape[n]&&(t[n]=this.shape[n]);return new r({...this._def,shape:()=>t})}omit(e){let t={};for(let n of S.objectKeys(this.shape))e[n]||(t[n]=this.shape[n]);return new r({...this._def,shape:()=>t})}deepPartial(){return st(this)}partial(e){let t={};for(let n of S.objectKeys(this.shape)){let s=this.shape[n];e&&!e[n]?t[n]=s:t[n]=s.optional()}return new r({...this._def,shape:()=>t})}required(e){let t={};for(let n of S.objectKeys(this.shape))if(e&&!e[n])t[n]=this.shape[n];else{let i=this.shape[n];for(;i instanceof z;)i=i._def.innerType;t[n]=i}return new r({...this._def,shape:()=>t})}keyof(){return In(S.objectKeys(this.shape))}};H.create=(r,e)=>new H({shape:()=>r,unknownKeys:"strip",catchall:X.create(),typeName:v.ZodObject,...b(e)});H.strictCreate=(r,e)=>new H({shape:()=>r,unknownKeys:"strict",catchall:X.create(),typeName:v.ZodObject,...b(e)});H.lazycreate=(r,e)=>new H({shape:r,unknownKeys:"strip",catchall:X.create(),typeName:v.ZodObject,...b(e)});var qe=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=this._def.options;function s(i){for(let o of i)if(o.result.status==="valid")return o.result;for(let o of i)if(o.result.status==="dirty")return t.common.issues.push(...o.ctx.common.issues),o.result;let a=i.map(o=>new V(o.ctx.common.issues));return m(t,{code:p.invalid_union,unionErrors:a}),_}if(t.common.async)return Promise.all(n.map(async i=>{let a={...t,common:{...t.common,issues:[]},parent:null};return{result:await i._parseAsync({data:t.data,path:t.path,parent:a}),ctx:a}})).then(s);{let i,a=[];for(let c of n){let u={...t,common:{...t.common,issues:[]},parent:null},d=c._parseSync({data:t.data,path:t.path,parent:u});if(d.status==="valid")return d;d.status==="dirty"&&!i&&(i={result:d,ctx:u}),u.common.issues.length&&a.push(u.common.issues)}if(i)return t.common.issues.push(...i.ctx.common.issues),i.result;let o=a.map(c=>new V(c));return m(t,{code:p.invalid_union,unionErrors:o}),_}}get options(){return this._def.options}};qe.create=(r,e)=>new qe({options:r,typeName:v.ZodUnion,...b(e)});var pe=r=>r instanceof De?pe(r.schema):r instanceof G?pe(r.innerType()):r instanceof Ve?[r.value]:r instanceof He?r.options:r instanceof Fe?S.objectValues(r.enum):r instanceof Be?pe(r._def.innerType):r instanceof Ue?[void 0]:r instanceof je?[null]:r instanceof z?[void 0,...pe(r.unwrap())]:r instanceof se?[null,...pe(r.unwrap())]:r instanceof wt||r instanceof Ke?pe(r.unwrap()):r instanceof We?pe(r._def.innerType):[],Wt=class r extends x{_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.object)return m(t,{code:p.invalid_type,expected:f.object,received:t.parsedType}),_;let n=this.discriminator,s=t.data[n],i=this.optionsMap.get(s);return i?t.common.async?i._parseAsync({data:t.data,path:t.path,parent:t}):i._parseSync({data:t.data,path:t.path,parent:t}):(m(t,{code:p.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[n]}),_)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(e,t,n){let s=new Map;for(let i of t){let a=pe(i.shape[e]);if(!a.length)throw new Error(`A discriminator value for key \`${e}\` could not be extracted from all schema options`);for(let o of a){if(s.has(o))throw new Error(`Discriminator property ${String(e)} has duplicate value ${String(o)}`);s.set(o,i)}}return new r({typeName:v.ZodDiscriminatedUnion,discriminator:e,options:t,optionsMap:s,...b(n)})}};function wr(r,e){let t=re(r),n=re(e);if(r===e)return{valid:!0,data:r};if(t===f.object&&n===f.object){let s=S.objectKeys(e),i=S.objectKeys(r).filter(o=>s.indexOf(o)!==-1),a={...r,...e};for(let o of i){let c=wr(r[o],e[o]);if(!c.valid)return{valid:!1};a[o]=c.data}return{valid:!0,data:a}}else if(t===f.array&&n===f.array){if(r.length!==e.length)return{valid:!1};let s=[];for(let i=0;i<r.length;i++){let a=r[i],o=e[i],c=wr(a,o);if(!c.valid)return{valid:!1};s.push(c.data)}return{valid:!0,data:s}}else return t===f.date&&n===f.date&&+r==+e?{valid:!0,data:r}:{valid:!1}}var Me=class extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e),s=(i,a)=>{if(Ft(i)||Ft(a))return _;let o=wr(i.value,a.value);return o.valid?((Bt(i)||Bt(a))&&t.dirty(),{status:t.value,value:o.data}):(m(n,{code:p.invalid_intersection_types}),_)};return n.common.async?Promise.all([this._def.left._parseAsync({data:n.data,path:n.path,parent:n}),this._def.right._parseAsync({data:n.data,path:n.path,parent:n})]).then(([i,a])=>s(i,a)):s(this._def.left._parseSync({data:n.data,path:n.path,parent:n}),this._def.right._parseSync({data:n.data,path:n.path,parent:n}))}};Me.create=(r,e,t)=>new Me({left:r,right:e,typeName:v.ZodIntersection,...b(t)});var ne=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.array)return m(n,{code:p.invalid_type,expected:f.array,received:n.parsedType}),_;if(n.data.length<this._def.items.length)return m(n,{code:p.too_small,minimum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),_;!this._def.rest&&n.data.length>this._def.items.length&&(m(n,{code:p.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),t.dirty());let i=[...n.data].map((a,o)=>{let c=this._def.items[o]||this._def.rest;return c?c._parse(new Z(n,a,n.path,o)):null}).filter(a=>!!a);return n.common.async?Promise.all(i).then(a=>P.mergeArray(t,a)):P.mergeArray(t,i)}get items(){return this._def.items}rest(e){return new r({...this._def,rest:e})}};ne.create=(r,e)=>{if(!Array.isArray(r))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new ne({items:r,typeName:v.ZodTuple,rest:null,...b(e)})};var Kt=class r extends x{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.object)return m(n,{code:p.invalid_type,expected:f.object,received:n.parsedType}),_;let s=[],i=this._def.keyType,a=this._def.valueType;for(let o in n.data)s.push({key:i._parse(new Z(n,o,n.path,o)),value:a._parse(new Z(n,n.data[o],n.path,o)),alwaysSet:o in n.data});return n.common.async?P.mergeObjectAsync(t,s):P.mergeObjectSync(t,s)}get element(){return this._def.valueType}static create(e,t,n){return t instanceof x?new r({keyType:e,valueType:t,typeName:v.ZodRecord,...b(n)}):new r({keyType:be.create(),valueType:e,typeName:v.ZodRecord,...b(t)})}},ot=class extends x{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.map)return m(n,{code:p.invalid_type,expected:f.map,received:n.parsedType}),_;let s=this._def.keyType,i=this._def.valueType,a=[...n.data.entries()].map(([o,c],u)=>({key:s._parse(new Z(n,o,n.path,[u,"key"])),value:i._parse(new Z(n,c,n.path,[u,"value"]))}));if(n.common.async){let o=new Map;return Promise.resolve().then(async()=>{for(let c of a){let u=await c.key,d=await c.value;if(u.status==="aborted"||d.status==="aborted")return _;(u.status==="dirty"||d.status==="dirty")&&t.dirty(),o.set(u.value,d.value)}return{status:t.value,value:o}})}else{let o=new Map;for(let c of a){let u=c.key,d=c.value;if(u.status==="aborted"||d.status==="aborted")return _;(u.status==="dirty"||d.status==="dirty")&&t.dirty(),o.set(u.value,d.value)}return{status:t.value,value:o}}}};ot.create=(r,e,t)=>new ot({valueType:e,keyType:r,typeName:v.ZodMap,...b(t)});var ct=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.parsedType!==f.set)return m(n,{code:p.invalid_type,expected:f.set,received:n.parsedType}),_;let s=this._def;s.minSize!==null&&n.data.size<s.minSize.value&&(m(n,{code:p.too_small,minimum:s.minSize.value,type:"set",inclusive:!0,exact:!1,message:s.minSize.message}),t.dirty()),s.maxSize!==null&&n.data.size>s.maxSize.value&&(m(n,{code:p.too_big,maximum:s.maxSize.value,type:"set",inclusive:!0,exact:!1,message:s.maxSize.message}),t.dirty());let i=this._def.valueType;function a(c){let u=new Set;for(let d of c){if(d.status==="aborted")return _;d.status==="dirty"&&t.dirty(),u.add(d.value)}return{status:t.value,value:u}}let o=[...n.data.values()].map((c,u)=>i._parse(new Z(n,c,n.path,u)));return n.common.async?Promise.all(o).then(c=>a(c)):a(o)}min(e,t){return new r({...this._def,minSize:{value:e,message:h.toString(t)}})}max(e,t){return new r({...this._def,maxSize:{value:e,message:h.toString(t)}})}size(e,t){return this.min(e,t).max(e,t)}nonempty(e){return this.min(1,e)}};ct.create=(r,e)=>new ct({valueType:r,minSize:null,maxSize:null,typeName:v.ZodSet,...b(e)});var zt=class r extends x{constructor(){super(...arguments),this.validate=this.implement}_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.function)return m(t,{code:p.invalid_type,expected:f.function,received:t.parsedType}),_;function n(o,c){return bt({data:o,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,rt(),de].filter(u=>!!u),issueData:{code:p.invalid_arguments,argumentsError:c}})}function s(o,c){return bt({data:o,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,rt(),de].filter(u=>!!u),issueData:{code:p.invalid_return_type,returnTypeError:c}})}let i={errorMap:t.common.contextualErrorMap},a=t.data;if(this._def.returns instanceof xe){let o=this;return $(async function(...c){let u=new V([]),d=await o._def.args.parseAsync(c,i).catch(y=>{throw u.addIssue(n(c,y)),u}),g=await Reflect.apply(a,this,d);return await o._def.returns._def.type.parseAsync(g,i).catch(y=>{throw u.addIssue(s(g,y)),u})})}else{let o=this;return $(function(...c){let u=o._def.args.safeParse(c,i);if(!u.success)throw new V([n(c,u.error)]);let d=Reflect.apply(a,this,u.data),g=o._def.returns.safeParse(d,i);if(!g.success)throw new V([s(d,g.error)]);return g.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...e){return new r({...this._def,args:ne.create(e).rest(me.create())})}returns(e){return new r({...this._def,returns:e})}implement(e){return this.parse(e)}strictImplement(e){return this.parse(e)}static create(e,t,n){return new r({args:e||ne.create([]).rest(me.create()),returns:t||me.create(),typeName:v.ZodFunction,...b(n)})}},De=class extends x{get schema(){return this._def.getter()}_parse(e){let{ctx:t}=this._processInputParams(e);return this._def.getter()._parse({data:t.data,path:t.path,parent:t})}};De.create=(r,e)=>new De({getter:r,typeName:v.ZodLazy,...b(e)});var Ve=class extends x{_parse(e){if(e.data!==this._def.value){let t=this._getOrReturnCtx(e);return m(t,{received:t.data,code:p.invalid_literal,expected:this._def.value}),_}return{status:"valid",value:e.data}}get value(){return this._def.value}};Ve.create=(r,e)=>new Ve({value:r,typeName:v.ZodLiteral,...b(e)});function In(r,e){return new He({values:r,typeName:v.ZodEnum,...b(e)})}var He=class r extends x{_parse(e){if(typeof e.data!="string"){let t=this._getOrReturnCtx(e),n=this._def.values;return m(t,{expected:S.joinValues(n),received:t.parsedType,code:p.invalid_type}),_}if(this._cache||(this._cache=new Set(this._def.values)),!this._cache.has(e.data)){let t=this._getOrReturnCtx(e),n=this._def.values;return m(t,{received:t.data,code:p.invalid_enum_value,options:n}),_}return $(e.data)}get options(){return this._def.values}get enum(){let e={};for(let t of this._def.values)e[t]=t;return e}get Values(){let e={};for(let t of this._def.values)e[t]=t;return e}get Enum(){let e={};for(let t of this._def.values)e[t]=t;return e}extract(e,t=this._def){return r.create(e,{...this._def,...t})}exclude(e,t=this._def){return r.create(this.options.filter(n=>!e.includes(n)),{...this._def,...t})}};He.create=In;var Fe=class extends x{_parse(e){let t=S.getValidEnumValues(this._def.values),n=this._getOrReturnCtx(e);if(n.parsedType!==f.string&&n.parsedType!==f.number){let s=S.objectValues(t);return m(n,{expected:S.joinValues(s),received:n.parsedType,code:p.invalid_type}),_}if(this._cache||(this._cache=new Set(S.getValidEnumValues(this._def.values))),!this._cache.has(e.data)){let s=S.objectValues(t);return m(n,{received:n.data,code:p.invalid_enum_value,options:s}),_}return $(e.data)}get enum(){return this._def.values}};Fe.create=(r,e)=>new Fe({values:r,typeName:v.ZodNativeEnum,...b(e)});var xe=class extends x{unwrap(){return this._def.type}_parse(e){let{ctx:t}=this._processInputParams(e);if(t.parsedType!==f.promise&&t.common.async===!1)return m(t,{code:p.invalid_type,expected:f.promise,received:t.parsedType}),_;let n=t.parsedType===f.promise?t.data:Promise.resolve(t.data);return $(n.then(s=>this._def.type.parseAsync(s,{path:t.path,errorMap:t.common.contextualErrorMap})))}};xe.create=(r,e)=>new xe({type:r,typeName:v.ZodPromise,...b(e)});var G=class extends x{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===v.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(e){let{status:t,ctx:n}=this._processInputParams(e),s=this._def.effect||null,i={addIssue:a=>{m(n,a),a.fatal?t.abort():t.dirty()},get path(){return n.path}};if(i.addIssue=i.addIssue.bind(i),s.type==="preprocess"){let a=s.transform(n.data,i);if(n.common.async)return Promise.resolve(a).then(async o=>{if(t.value==="aborted")return _;let c=await this._def.schema._parseAsync({data:o,path:n.path,parent:n});return c.status==="aborted"?_:c.status==="dirty"?Oe(c.value):t.value==="dirty"?Oe(c.value):c});{if(t.value==="aborted")return _;let o=this._def.schema._parseSync({data:a,path:n.path,parent:n});return o.status==="aborted"?_:o.status==="dirty"?Oe(o.value):t.value==="dirty"?Oe(o.value):o}}if(s.type==="refinement"){let a=o=>{let c=s.refinement(o,i);if(n.common.async)return Promise.resolve(c);if(c instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return o};if(n.common.async===!1){let o=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});return o.status==="aborted"?_:(o.status==="dirty"&&t.dirty(),a(o.value),{status:t.value,value:o.value})}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(o=>o.status==="aborted"?_:(o.status==="dirty"&&t.dirty(),a(o.value).then(()=>({status:t.value,value:o.value}))))}if(s.type==="transform")if(n.common.async===!1){let a=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});if(!ve(a))return _;let o=s.transform(a.value,i);if(o instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:t.value,value:o}}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(a=>ve(a)?Promise.resolve(s.transform(a.value,i)).then(o=>({status:t.value,value:o})):_);S.assertNever(s)}};G.create=(r,e,t)=>new G({schema:r,typeName:v.ZodEffects,effect:e,...b(t)});G.createWithPreprocess=(r,e,t)=>new G({schema:e,effect:{type:"preprocess",transform:r},typeName:v.ZodEffects,...b(t)});var z=class extends x{_parse(e){return this._getType(e)===f.undefined?$(void 0):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};z.create=(r,e)=>new z({innerType:r,typeName:v.ZodOptional,...b(e)});var se=class extends x{_parse(e){return this._getType(e)===f.null?$(null):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};se.create=(r,e)=>new se({innerType:r,typeName:v.ZodNullable,...b(e)});var Be=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=t.data;return t.parsedType===f.undefined&&(n=this._def.defaultValue()),this._def.innerType._parse({data:n,path:t.path,parent:t})}removeDefault(){return this._def.innerType}};Be.create=(r,e)=>new Be({innerType:r,typeName:v.ZodDefault,defaultValue:typeof e.default=="function"?e.default:()=>e.default,...b(e)});var We=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n={...t,common:{...t.common,issues:[]}},s=this._def.innerType._parse({data:n.data,path:n.path,parent:{...n}});return nt(s)?s.then(i=>({status:"valid",value:i.status==="valid"?i.value:this._def.catchValue({get error(){return new V(n.common.issues)},input:n.data})})):{status:"valid",value:s.status==="valid"?s.value:this._def.catchValue({get error(){return new V(n.common.issues)},input:n.data})}}removeCatch(){return this._def.innerType}};We.create=(r,e)=>new We({innerType:r,typeName:v.ZodCatch,catchValue:typeof e.catch=="function"?e.catch:()=>e.catch,...b(e)});var ut=class extends x{_parse(e){if(this._getType(e)!==f.nan){let n=this._getOrReturnCtx(e);return m(n,{code:p.invalid_type,expected:f.nan,received:n.parsedType}),_}return{status:"valid",value:e.data}}};ut.create=r=>new ut({typeName:v.ZodNaN,...b(r)});var Xi=Symbol("zod_brand"),wt=class extends x{_parse(e){let{ctx:t}=this._processInputParams(e),n=t.data;return this._def.type._parse({data:n,path:t.path,parent:t})}unwrap(){return this._def.type}},xt=class r extends x{_parse(e){let{status:t,ctx:n}=this._processInputParams(e);if(n.common.async)return(async()=>{let i=await this._def.in._parseAsync({data:n.data,path:n.path,parent:n});return i.status==="aborted"?_:i.status==="dirty"?(t.dirty(),Oe(i.value)):this._def.out._parseAsync({data:i.value,path:n.path,parent:n})})();{let s=this._def.in._parseSync({data:n.data,path:n.path,parent:n});return s.status==="aborted"?_:s.status==="dirty"?(t.dirty(),{status:"dirty",value:s.value}):this._def.out._parseSync({data:s.value,path:n.path,parent:n})}}static create(e,t){return new r({in:e,out:t,typeName:v.ZodPipeline})}},Ke=class extends x{_parse(e){let t=this._def.innerType._parse(e),n=s=>(ve(s)&&(s.value=Object.freeze(s.value)),s);return nt(t)?t.then(s=>n(s)):n(t)}unwrap(){return this._def.innerType}};Ke.create=(r,e)=>new Ke({innerType:r,typeName:v.ZodReadonly,...b(e)});function kn(r,e){let t=typeof r=="function"?r(e):typeof r=="string"?{message:r}:r;return typeof t=="string"?{message:t}:t}function En(r,e={},t){return r?we.create().superRefine((n,s)=>{let i=r(n);if(i instanceof Promise)return i.then(a=>{if(!a){let o=kn(e,n),c=o.fatal??t??!0;s.addIssue({code:"custom",...o,fatal:c})}});if(!i){let a=kn(e,n),o=a.fatal??t??!0;s.addIssue({code:"custom",...a,fatal:o})}}):we.create()}var Qi={object:H.lazycreate},v;(function(r){r.ZodString="ZodString",r.ZodNumber="ZodNumber",r.ZodNaN="ZodNaN",r.ZodBigInt="ZodBigInt",r.ZodBoolean="ZodBoolean",r.ZodDate="ZodDate",r.ZodSymbol="ZodSymbol",r.ZodUndefined="ZodUndefined",r.ZodNull="ZodNull",r.ZodAny="ZodAny",r.ZodUnknown="ZodUnknown",r.ZodNever="ZodNever",r.ZodVoid="ZodVoid",r.ZodArray="ZodArray",r.ZodObject="ZodObject",r.ZodUnion="ZodUnion",r.ZodDiscriminatedUnion="ZodDiscriminatedUnion",r.ZodIntersection="ZodIntersection",r.ZodTuple="ZodTuple",r.ZodRecord="ZodRecord",r.ZodMap="ZodMap",r.ZodSet="ZodSet",r.ZodFunction="ZodFunction",r.ZodLazy="ZodLazy",r.ZodLiteral="ZodLiteral",r.ZodEnum="ZodEnum",r.ZodEffects="ZodEffects",r.ZodNativeEnum="ZodNativeEnum",r.ZodOptional="ZodOptional",r.ZodNullable="ZodNullable",r.ZodDefault="ZodDefault",r.ZodCatch="ZodCatch",r.ZodPromise="ZodPromise",r.ZodBranded="ZodBranded",r.ZodPipeline="ZodPipeline",r.ZodReadonly="ZodReadonly"})(v||(v={}));var ea=(r,e={message:`Input not instance of ${r.name}`})=>En(t=>t instanceof r,e),An=be.create,Cn=Ne.create,ta=ut.create,ra=Pe.create,On=Le.create,na=$e.create,sa=it.create,ia=Ue.create,aa=je.create,oa=we.create,ca=me.create,ua=X.create,la=at.create,da=fe.create,pa=H.create,ma=H.strictCreate,fa=qe.create,ha=Wt.create,ga=Me.create,ya=ne.create,_a=Kt.create,va=ot.create,ba=ct.create,wa=zt.create,xa=De.create,ka=Ve.create,Sa=He.create,Ta=Fe.create,Ra=xe.create,Ia=G.create,Ea=z.create,Aa=se.create,Ca=G.createWithPreprocess,Oa=xt.create,Na=()=>An().optional(),Pa=()=>Cn().optional(),La=()=>On().optional(),$a={string:(r=>be.create({...r,coerce:!0})),number:(r=>Ne.create({...r,coerce:!0})),boolean:(r=>Le.create({...r,coerce:!0})),bigint:(r=>Pe.create({...r,coerce:!0})),date:(r=>$e.create({...r,coerce:!0}))};var Ua=_;var Nn="1.8.0",Pn=T.object({name:T.string().max(100).nullable(),location:T.string().max(100).nullable(),member_since:T.string()}),Ln=T.object({total_transactions:T.number(),total_spent:T.number(),tools_used:T.record(T.string(),T.number()),last_active:T.string().nullable(),themes:T.array(T.string().max(100)).max(20),recent_prompts:T.array(T.string().max(500)).max(50).optional().default([])}),$n=T.object({daily_remaining:T.number(),daily_limit:T.number()}),ja=T.object({message:T.string().max(500),tool:T.string(),reason:T.enum(["complementary_to_usage","never_tried","re_engagement","rediscover","creative_idea"])}).nullable(),qa=T.object({proactive:ja,reactive:T.record(T.string(),T.array(T.string().max(500)).nullable())}),Ma=T.object({user:Pn,usage:Ln,budget:$n,suggestions:qa}),Da=T.object({user:Pn,usage:Ln,budget:$n});function Va(r){let e=Ma.safeParse(r);if(e.success)return{full:e.data,partial:null};let t=Da.safeParse(r);return t.success?{full:null,partial:t.data}:{full:null,partial:null}}function ze(r){let e=r;for(let t=0;t<5;t++){let n=e.replace(/<[^>]*>/g,"");if(n===e)break;e=n}return e.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,"").trim()}var Ha=`You are a creative assistant with Visa CLI \u2014 a toolkit for AI images, music, videos, crypto prices, and payments. Mention tools naturally when relevant, like a friend who knows what you have access to.
19
19
 
20
20
  Rules:
21
21
  - If the user asks a question that one of your tools can answer \u2014 including historical data, analytics, comparisons, or trends \u2014 offer to use the tool. Don't just answer from your training data when live data is available.
@@ -60,7 +60,7 @@ Your first response in this session MUST end with this line in bold italic:
60
60
  `+g.map(O=>`- "${O}"`).join(`
61
61
  `))}}return e.join(`
62
62
 
63
- `)}},kr=new Set(["generate_image_card","generate_image_fast_card","generate_video_tempo_card","generate_music_tempo_card","query_onchain_prices_card","allium_explorer_card"]),Sr=class{constructor(e){this.reactiveMap=e}reactiveMap;lastSuggestedTool=null;skipNext=!1;getReactiveSuggestion(e){if(!kr.has(e))return null;if(this.skipNext&&this.lastSuggestedTool===e)return this.skipNext=!1,null;let t=this.reactiveMap[e]??null;return t&&t.length>0?(this.lastSuggestedTool=e,this.skipNext=!0,t[Math.floor(Math.random()*t.length)]):null}injectSuggestion(e,t){if(!kr.has(e)||t._feedback_prompt||t._feedback_hint)return t;let n=this.getReactiveSuggestion(e);return n&&(t._suggestion=ze(n)),t}},za=3e3;async function Tr(r,e,t){let n={instructions:new kt(null,t).build(),manager:null};try{let s=await r();if(!s)return l.info("suggestions: no session token, using static instructions"),n;let{fetchWithTimeout:i}=await Promise.resolve().then(()=>(Qt(),Er)),a=await i(`${e}/v1/suggestions`,{method:"GET",headers:{Authorization:`Bearer ${s}`,"X-Visa-CLI-Version":Nn},timeoutMs:za});if(!a.ok)return l.warn(`suggestions: backend returned ${a.status}, using static instructions`),n;let o;if(!Ge()){let d=a.headers.get("X-Latest-Version"),g=a.headers.get("X-Update-Message");d&&St(d,Nn)&&(o=g||`Update available: v${d}. Run: npm install -g @visa/cli && visa-cli setup`)}let c=await a.json(),u=Va(c);if(u.full)return l.info(`suggestions: loaded for ${u.full.user.name??"unknown"} (proactive: ${u.full.suggestions.proactive?"yes":"none"})`),{instructions:new kt(u.full,t,o).build(),manager:new Sr(u.full.suggestions.reactive)};if(u.partial){l.warn("suggestions: suggestions block malformed, using partial payload");let d={...u.partial,suggestions:{proactive:null,reactive:{}}};return{instructions:new kt(d,t,o).build(),manager:null}}return l.warn("suggestions: response failed validation, using static instructions"),n}catch(s){return l.warn(`suggestions: fetch failed (${s.message}), using static instructions`),n}}var Zt=I(require("crypto")),Gt=I(require("tty")),Yt=I(require("fs"));var Ze="6820f6e91b762e645c9bf020c0d3673bb99d4a25a824880c0d548e10bb9bc7b1";function Ga(r){return/-rc\.|-beta\./.test(r)}function Rr(r){return Zt.createHash("sha256").update(r.trim()).digest("hex")}function jn(r){return Ze==="SKIP"?!0:Zt.timingSafeEqual(Buffer.from(Rr(r)),Buffer.from(Ze))}function Ya(r){return new Promise((e,t)=>{let n=Yt.openSync("/dev/tty","r+"),s=new Gt.ReadStream(n),i=new Gt.WriteStream(n),a=()=>{try{s.destroy()}catch{}try{i.destroy()}catch{}try{Yt.closeSync(n)}catch{}};i.write(r),s.setRawMode(!0),s.resume(),s.setEncoding("utf8");let o="";s.on("data",c=>{c==="\r"||c===`
63
+ `)}},kr=new Set(["generate_image_card","generate_image_fast_card","generate_video_tempo_card","generate_music_tempo_card","query_onchain_prices_card","allium_explorer_card"]),Sr=class{constructor(e){this.reactiveMap=e}reactiveMap;lastSuggestedTool=null;skipNext=!1;getReactiveSuggestion(e){if(!kr.has(e))return null;if(this.skipNext&&this.lastSuggestedTool===e)return this.skipNext=!1,null;let t=this.reactiveMap[e]??null;return t&&t.length>0?(this.lastSuggestedTool=e,this.skipNext=!0,t[Math.floor(Math.random()*t.length)]):null}injectSuggestion(e,t){if(!kr.has(e)||t._feedback_prompt||t._feedback_hint)return t;let n=this.getReactiveSuggestion(e);return n&&(t._suggestion=ze(n)),t}},za=3e3;async function Tr(r,e,t){let n={instructions:new kt(null,t).build(),manager:null};try{let s=await r();if(!s)return l.info("suggestions: no session token, using static instructions"),n;let{fetchWithTimeout:i}=await Promise.resolve().then(()=>(Qt(),Er)),a=await i(`${e}/v1/suggestions`,{method:"GET",headers:{Authorization:`Bearer ${s}`,"X-Visa-CLI-Version":Nn},timeoutMs:za});if(!a.ok)return l.warn(`suggestions: backend returned ${a.status}, using static instructions`),n;let o;if(!Ge()){let d=a.headers.get("X-Latest-Version"),g=a.headers.get("X-Update-Message");d&&St(d,Nn)&&(o=g||`Update available: v${d}. Run: npm install -g @visa/cli && visa-cli setup`)}let c=await a.json(),u=Va(c);if(u.full)return l.info(`suggestions: loaded for ${u.full.user.name??"unknown"} (proactive: ${u.full.suggestions.proactive?"yes":"none"})`),{instructions:new kt(u.full,t,o).build(),manager:new Sr(u.full.suggestions.reactive)};if(u.partial){l.warn("suggestions: suggestions block malformed, using partial payload");let d={...u.partial,suggestions:{proactive:null,reactive:{}}};return{instructions:new kt(d,t,o).build(),manager:null}}return l.warn("suggestions: response failed validation, using static instructions"),n}catch(s){return l.warn(`suggestions: fetch failed (${s.message}), using static instructions`),n}}var Zt=I(require("crypto")),Gt=I(require("tty")),Yt=I(require("fs"));var Ze="0000000000000000000000000000000000000000000000000000000000000000";function Ga(r){return/-rc\.|-beta\./.test(r)}function Rr(r){return Zt.createHash("sha256").update(r.trim()).digest("hex")}function jn(r){return Ze==="SKIP"?!0:Zt.timingSafeEqual(Buffer.from(Rr(r)),Buffer.from(Ze))}function Ya(r){return new Promise((e,t)=>{let n=Yt.openSync("/dev/tty","r+"),s=new Gt.ReadStream(n),i=new Gt.WriteStream(n),a=()=>{try{s.destroy()}catch{}try{i.destroy()}catch{}try{Yt.closeSync(n)}catch{}};i.write(r),s.setRawMode(!0),s.resume(),s.setEncoding("utf8");let o="";s.on("data",c=>{c==="\r"||c===`
64
64
  `?(i.write(`
65
65
  `),a(),e(o)):c===""?(i.write(`
66
66
  `),a(),t(new Error("Cancelled"))):c==="\x7F"||c==="\b"?o.length>0&&(o=o.slice(0,-1),i.write("\b \b")):(o+=c,i.write("\u2022"))})})}var Ja=`
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visa/cli",
3
- "version": "1.8.0-rc.3",
3
+ "version": "1.8.0",
4
4
  "description": "AI-powered payments for Claude Code",
5
5
  "bin": {
6
6
  "visa-cli": "./bin/visa-cli.js"