@frontstackdev/cli 0.0.0-canary-20251023180402 → 0.0.0-canary-20251025194100

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.
@@ -1,36 +1,36 @@
1
1
  #!/usr/bin/env node
2
- var qe=Object.defineProperty;var l=(r,e)=>qe(r,"name",{value:e,configurable:!0});var R,H,N,F,I,V,j;import Me from"events";import Ue from"child_process";import g from"path";import _,{readFileSync as We}from"fs";import Ge from"process";import d from"chalk";import he from"js-yaml";import{defu as Je}from"defu";import Be from"http";import Ke from"open";import $ from"handlebars";import ze from"openapi-typescript";import M from"prompts";import{fileURLToPath as Qe}from"url";var A={},D={},P={};let pe=(R=class extends Error{constructor(e,t,n){super(n),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name,this.code=t,this.exitCode=e,this.nestedError=void 0}},l(R,"CommanderError"),R),Ye=(H=class extends pe{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}},l(H,"InvalidArgumentError"),H);P.CommanderError=pe,P.InvalidArgumentError=Ye;const{InvalidArgumentError:Ze}=P;let Xe=(N=class{constructor(e,t){switch(this.description=t||"",this.variadic=!1,this.parseArg=void 0,this.defaultValue=void 0,this.defaultValueDescription=void 0,this.argChoices=void 0,e[0]){case"<":this.required=!0,this._name=e.slice(1,-1);break;case"[":this.required=!1,this._name=e.slice(1,-1);break;default:this.required=!0,this._name=e;break}this._name.length>3&&this._name.slice(-3)==="..."&&(this.variadic=!0,this._name=this._name.slice(0,-3))}name(){return this._name}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}argParser(e){return this.parseArg=e,this}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,n)=>{if(!this.argChoices.includes(t))throw new Ze(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,n):t},this}argRequired(){return this.required=!0,this}argOptional(){return this.required=!1,this}},l(N,"Argument"),N);function et(r){const e=r.name()+(r.variadic===!0?"...":"");return r.required?"<"+e+">":"["+e+"]"}l(et,"humanReadableArgName$2"),D.Argument=Xe,D.humanReadableArgName=et;var fe={},J={};const{humanReadableArgName:tt}=D;let nt=(F=class{constructor(){this.helpWidth=void 0,this.sortSubcommands=!1,this.sortOptions=!1,this.showGlobalOptions=!1}visibleCommands(e){const t=e.commands.filter(i=>!i._hidden),n=e._getHelpCommand();return n&&!n._hidden&&t.push(n),this.sortSubcommands&&t.sort((i,o)=>i.name().localeCompare(o.name())),t}compareOptions(e,t){const n=l(i=>i.short?i.short.replace(/^-/,""):i.long.replace(/^--/,""),"getSortKey");return n(e).localeCompare(n(t))}visibleOptions(e){const t=e.options.filter(i=>!i.hidden),n=e._getHelpOption();if(n&&!n.hidden){const i=n.short&&e._findOption(n.short),o=n.long&&e._findOption(n.long);!i&&!o?t.push(n):n.long&&!o?t.push(e.createOption(n.long,n.description)):n.short&&!i&&t.push(e.createOption(n.short,n.description))}return this.sortOptions&&t.sort(this.compareOptions),t}visibleGlobalOptions(e){if(!this.showGlobalOptions)return[];const t=[];for(let n=e.parent;n;n=n.parent){const i=n.options.filter(o=>!o.hidden);t.push(...i)}return this.sortOptions&&t.sort(this.compareOptions),t}visibleArguments(e){return e._argsDescription&&e.registeredArguments.forEach(t=>{t.description=t.description||e._argsDescription[t.name()]||""}),e.registeredArguments.find(t=>t.description)?e.registeredArguments:[]}subcommandTerm(e){const t=e.registeredArguments.map(n=>tt(n)).join(" ");return e._name+(e._aliases[0]?"|"+e._aliases[0]:"")+(e.options.length?" [options]":"")+(t?" "+t:"")}optionTerm(e){return e.flags}argumentTerm(e){return e.name()}longestSubcommandTermLength(e,t){return t.visibleCommands(e).reduce((n,i)=>Math.max(n,t.subcommandTerm(i).length),0)}longestOptionTermLength(e,t){return t.visibleOptions(e).reduce((n,i)=>Math.max(n,t.optionTerm(i).length),0)}longestGlobalOptionTermLength(e,t){return t.visibleGlobalOptions(e).reduce((n,i)=>Math.max(n,t.optionTerm(i).length),0)}longestArgumentTermLength(e,t){return t.visibleArguments(e).reduce((n,i)=>Math.max(n,t.argumentTerm(i).length),0)}commandUsage(e){let t=e._name;e._aliases[0]&&(t=t+"|"+e._aliases[0]);let n="";for(let i=e.parent;i;i=i.parent)n=i.name()+" "+n;return n+t+" "+e.usage()}commandDescription(e){return e.description()}subcommandDescription(e){return e.summary()||e.description()}optionDescription(e){const t=[];return e.argChoices&&t.push(`choices: ${e.argChoices.map(n=>JSON.stringify(n)).join(", ")}`),e.defaultValue!==void 0&&(e.required||e.optional||e.isBoolean()&&typeof e.defaultValue=="boolean")&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),e.presetArg!==void 0&&e.optional&&t.push(`preset: ${JSON.stringify(e.presetArg)}`),e.envVar!==void 0&&t.push(`env: ${e.envVar}`),t.length>0?`${e.description} (${t.join(", ")})`:e.description}argumentDescription(e){const t=[];if(e.argChoices&&t.push(`choices: ${e.argChoices.map(n=>JSON.stringify(n)).join(", ")}`),e.defaultValue!==void 0&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),t.length>0){const n=`(${t.join(", ")})`;return e.description?`${e.description} ${n}`:n}return e.description}formatHelp(e,t){const n=t.padWidth(e,t),i=t.helpWidth||80,o=2,a=2;function u(m,b){if(b){const x=`${m.padEnd(n+a)}${b}`;return t.wrap(x,i-o,n+a)}return m}l(u,"formatItem");function c(m){return m.join(`
3
- `).replace(/^/gm," ".repeat(o))}l(c,"formatList");let h=[`Usage: ${t.commandUsage(e)}`,""];const s=t.commandDescription(e);s.length>0&&(h=h.concat([t.wrap(s,i,0),""]));const p=t.visibleArguments(e).map(m=>u(t.argumentTerm(m),t.argumentDescription(m)));p.length>0&&(h=h.concat(["Arguments:",c(p),""]));const f=t.visibleOptions(e).map(m=>u(t.optionTerm(m),t.optionDescription(m)));if(f.length>0&&(h=h.concat(["Options:",c(f),""])),this.showGlobalOptions){const m=t.visibleGlobalOptions(e).map(b=>u(t.optionTerm(b),t.optionDescription(b)));m.length>0&&(h=h.concat(["Global Options:",c(m),""]))}const y=t.visibleCommands(e).map(m=>u(t.subcommandTerm(m),t.subcommandDescription(m)));return y.length>0&&(h=h.concat(["Commands:",c(y),""])),h.join(`
4
- `)}padWidth(e,t){return Math.max(t.longestOptionTermLength(e,t),t.longestGlobalOptionTermLength(e,t),t.longestSubcommandTermLength(e,t),t.longestArgumentTermLength(e,t))}wrap(e,t,n,i=40){const o=" \\f\\t\\v\xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF",a=new RegExp(`[\\n][${o}]+`);if(e.match(a))return e;const u=t-n;if(u<i)return e;const c=e.slice(0,n),h=e.slice(n).replace(`\r
2
+ var Ge=Object.defineProperty;var l=(o,e)=>Ge(o,"name",{value:e,configurable:!0});var R,H,N,I,F,V,T;import Je from"events";import Be from"child_process";import g,{join as Ke,dirname as ze}from"path";import _,{existsSync as fe,readFileSync as de,mkdirSync as Qe,writeFileSync as Ye}from"fs";import Ze from"process";import f from"chalk";import me from"js-yaml";import{defu as Xe}from"defu";import et from"http";import tt from"open";import $ from"handlebars";import nt from"openapi-typescript";import U from"prompts";import K from"semver";import{fileURLToPath as ot}from"url";var A={},D={},k={};let ge=(R=class extends Error{constructor(e,t,n){super(n),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name,this.code=t,this.exitCode=e,this.nestedError=void 0}},l(R,"CommanderError"),R),rt=(H=class extends ge{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}},l(H,"InvalidArgumentError"),H);k.CommanderError=ge,k.InvalidArgumentError=rt;const{InvalidArgumentError:it}=k;let st=(N=class{constructor(e,t){switch(this.description=t||"",this.variadic=!1,this.parseArg=void 0,this.defaultValue=void 0,this.defaultValueDescription=void 0,this.argChoices=void 0,e[0]){case"<":this.required=!0,this._name=e.slice(1,-1);break;case"[":this.required=!1,this._name=e.slice(1,-1);break;default:this.required=!0,this._name=e;break}this._name.length>3&&this._name.slice(-3)==="..."&&(this.variadic=!0,this._name=this._name.slice(0,-3))}name(){return this._name}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}argParser(e){return this.parseArg=e,this}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,n)=>{if(!this.argChoices.includes(t))throw new it(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,n):t},this}argRequired(){return this.required=!0,this}argOptional(){return this.required=!1,this}},l(N,"Argument"),N);function at(o){const e=o.name()+(o.variadic===!0?"...":"");return o.required?"<"+e+">":"["+e+"]"}l(at,"humanReadableArgName$2"),D.Argument=st,D.humanReadableArgName=at;var _e={},z={};const{humanReadableArgName:ct}=D;let lt=(I=class{constructor(){this.helpWidth=void 0,this.sortSubcommands=!1,this.sortOptions=!1,this.showGlobalOptions=!1}visibleCommands(e){const t=e.commands.filter(r=>!r._hidden),n=e._getHelpCommand();return n&&!n._hidden&&t.push(n),this.sortSubcommands&&t.sort((r,i)=>r.name().localeCompare(i.name())),t}compareOptions(e,t){const n=l(r=>r.short?r.short.replace(/^-/,""):r.long.replace(/^--/,""),"getSortKey");return n(e).localeCompare(n(t))}visibleOptions(e){const t=e.options.filter(r=>!r.hidden),n=e._getHelpOption();if(n&&!n.hidden){const r=n.short&&e._findOption(n.short),i=n.long&&e._findOption(n.long);!r&&!i?t.push(n):n.long&&!i?t.push(e.createOption(n.long,n.description)):n.short&&!r&&t.push(e.createOption(n.short,n.description))}return this.sortOptions&&t.sort(this.compareOptions),t}visibleGlobalOptions(e){if(!this.showGlobalOptions)return[];const t=[];for(let n=e.parent;n;n=n.parent){const r=n.options.filter(i=>!i.hidden);t.push(...r)}return this.sortOptions&&t.sort(this.compareOptions),t}visibleArguments(e){return e._argsDescription&&e.registeredArguments.forEach(t=>{t.description=t.description||e._argsDescription[t.name()]||""}),e.registeredArguments.find(t=>t.description)?e.registeredArguments:[]}subcommandTerm(e){const t=e.registeredArguments.map(n=>ct(n)).join(" ");return e._name+(e._aliases[0]?"|"+e._aliases[0]:"")+(e.options.length?" [options]":"")+(t?" "+t:"")}optionTerm(e){return e.flags}argumentTerm(e){return e.name()}longestSubcommandTermLength(e,t){return t.visibleCommands(e).reduce((n,r)=>Math.max(n,t.subcommandTerm(r).length),0)}longestOptionTermLength(e,t){return t.visibleOptions(e).reduce((n,r)=>Math.max(n,t.optionTerm(r).length),0)}longestGlobalOptionTermLength(e,t){return t.visibleGlobalOptions(e).reduce((n,r)=>Math.max(n,t.optionTerm(r).length),0)}longestArgumentTermLength(e,t){return t.visibleArguments(e).reduce((n,r)=>Math.max(n,t.argumentTerm(r).length),0)}commandUsage(e){let t=e._name;e._aliases[0]&&(t=t+"|"+e._aliases[0]);let n="";for(let r=e.parent;r;r=r.parent)n=r.name()+" "+n;return n+t+" "+e.usage()}commandDescription(e){return e.description()}subcommandDescription(e){return e.summary()||e.description()}optionDescription(e){const t=[];return e.argChoices&&t.push(`choices: ${e.argChoices.map(n=>JSON.stringify(n)).join(", ")}`),e.defaultValue!==void 0&&(e.required||e.optional||e.isBoolean()&&typeof e.defaultValue=="boolean")&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),e.presetArg!==void 0&&e.optional&&t.push(`preset: ${JSON.stringify(e.presetArg)}`),e.envVar!==void 0&&t.push(`env: ${e.envVar}`),t.length>0?`${e.description} (${t.join(", ")})`:e.description}argumentDescription(e){const t=[];if(e.argChoices&&t.push(`choices: ${e.argChoices.map(n=>JSON.stringify(n)).join(", ")}`),e.defaultValue!==void 0&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),t.length>0){const n=`(${t.join(", ")})`;return e.description?`${e.description} ${n}`:n}return e.description}formatHelp(e,t){const n=t.padWidth(e,t),r=t.helpWidth||80,i=2,a=2;function u(m,b){if(b){const x=`${m.padEnd(n+a)}${b}`;return t.wrap(x,r-i,n+a)}return m}l(u,"formatItem");function c(m){return m.join(`
3
+ `).replace(/^/gm," ".repeat(i))}l(c,"formatList");let h=[`Usage: ${t.commandUsage(e)}`,""];const s=t.commandDescription(e);s.length>0&&(h=h.concat([t.wrap(s,r,0),""]));const p=t.visibleArguments(e).map(m=>u(t.argumentTerm(m),t.argumentDescription(m)));p.length>0&&(h=h.concat(["Arguments:",c(p),""]));const d=t.visibleOptions(e).map(m=>u(t.optionTerm(m),t.optionDescription(m)));if(d.length>0&&(h=h.concat(["Options:",c(d),""])),this.showGlobalOptions){const m=t.visibleGlobalOptions(e).map(b=>u(t.optionTerm(b),t.optionDescription(b)));m.length>0&&(h=h.concat(["Global Options:",c(m),""]))}const y=t.visibleCommands(e).map(m=>u(t.subcommandTerm(m),t.subcommandDescription(m)));return y.length>0&&(h=h.concat(["Commands:",c(y),""])),h.join(`
4
+ `)}padWidth(e,t){return Math.max(t.longestOptionTermLength(e,t),t.longestGlobalOptionTermLength(e,t),t.longestSubcommandTermLength(e,t),t.longestArgumentTermLength(e,t))}wrap(e,t,n,r=40){const i=" \\f\\t\\v\xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF",a=new RegExp(`[\\n][${i}]+`);if(e.match(a))return e;const u=t-n;if(u<r)return e;const c=e.slice(0,n),h=e.slice(n).replace(`\r
5
5
  `,`
6
- `),s=" ".repeat(n),f="\\s\u200B",y=new RegExp(`
7
- |.{1,${u-1}}([${f}]|$)|[^${f}]+?([${f}]|$)`,"g"),m=h.match(y)||[];return c+m.map((b,x)=>b===`
6
+ `),s=" ".repeat(n),d="\\s\u200B",y=new RegExp(`
7
+ |.{1,${u-1}}([${d}]|$)|[^${d}]+?([${d}]|$)`,"g"),m=h.match(y)||[];return c+m.map((b,x)=>b===`
8
8
  `?"":(x>0?s:"")+b.trimEnd()).join(`
9
- `)}},l(F,"Help"),F);J.Help=nt;var U={};const{InvalidArgumentError:it}=P;let rt=(I=class{constructor(e,t){this.flags=e,this.description=t||"",this.required=e.includes("<"),this.optional=e.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test(e),this.mandatory=!1;const n=at(e);this.short=n.shortFlag,this.long=n.longFlag,this.negate=!1,this.long&&(this.negate=this.long.startsWith("--no-")),this.defaultValue=void 0,this.defaultValueDescription=void 0,this.presetArg=void 0,this.envVar=void 0,this.parseArg=void 0,this.hidden=!1,this.argChoices=void 0,this.conflictsWith=[],this.implied=void 0}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}preset(e){return this.presetArg=e,this}conflicts(e){return this.conflictsWith=this.conflictsWith.concat(e),this}implies(e){let t=e;return typeof e=="string"&&(t={[e]:!0}),this.implied=Object.assign(this.implied||{},t),this}env(e){return this.envVar=e,this}argParser(e){return this.parseArg=e,this}makeOptionMandatory(e=!0){return this.mandatory=!!e,this}hideHelp(e=!0){return this.hidden=!!e,this}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,n)=>{if(!this.argChoices.includes(t))throw new it(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,n):t},this}name(){return this.long?this.long.replace(/^--/,""):this.short.replace(/^-/,"")}attributeName(){return st(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},l(I,"Option"),I),ot=(V=class{constructor(e){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,e.forEach(t=>{t.negate?this.negativeOptions.set(t.attributeName(),t):this.positiveOptions.set(t.attributeName(),t)}),this.negativeOptions.forEach((t,n)=>{this.positiveOptions.has(n)&&this.dualOptions.add(n)})}valueFromOption(e,t){const n=t.attributeName();if(!this.dualOptions.has(n))return!0;const i=this.negativeOptions.get(n).presetArg,o=i!==void 0?i:!1;return t.negate===(o===e)}},l(V,"DualOptions"),V);function st(r){return r.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}l(st,"camelcase");function at(r){let e,t;const n=r.split(/[ |,]+/);return n.length>1&&!/^[[<]/.test(n[1])&&(e=n.shift()),t=n.shift(),!e&&/^-[^-]$/.test(t)&&(e=t,t=void 0),{shortFlag:e,longFlag:t}}l(at,"splitOptionFlags"),U.Option=rt,U.DualOptions=ot;var de={};const me=3;function ct(r,e){if(Math.abs(r.length-e.length)>me)return Math.max(r.length,e.length);const t=[];for(let n=0;n<=r.length;n++)t[n]=[n];for(let n=0;n<=e.length;n++)t[0][n]=n;for(let n=1;n<=e.length;n++)for(let i=1;i<=r.length;i++){let o=1;r[i-1]===e[n-1]?o=0:o=1,t[i][n]=Math.min(t[i-1][n]+1,t[i][n-1]+1,t[i-1][n-1]+o),i>1&&n>1&&r[i-1]===e[n-2]&&r[i-2]===e[n-1]&&(t[i][n]=Math.min(t[i][n],t[i-2][n-2]+1))}return t[r.length][e.length]}l(ct,"editDistance");function lt(r,e){if(!e||e.length===0)return"";e=Array.from(new Set(e));const t=r.startsWith("--");t&&(r=r.slice(2),e=e.map(a=>a.slice(2)));let n=[],i=me;const o=.4;return e.forEach(a=>{if(a.length<=1)return;const u=ct(r,a),c=Math.max(r.length,a.length);(c-u)/c>o&&(u<i?(i=u,n=[a]):u===i&&n.push(a))}),n.sort((a,u)=>a.localeCompare(u)),t&&(n=n.map(a=>`--${a}`)),n.length>1?`
9
+ `)}},l(I,"Help"),I);z.Help=lt;var W={};const{InvalidArgumentError:ut}=k;let ht=(F=class{constructor(e,t){this.flags=e,this.description=t||"",this.required=e.includes("<"),this.optional=e.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test(e),this.mandatory=!1;const n=dt(e);this.short=n.shortFlag,this.long=n.longFlag,this.negate=!1,this.long&&(this.negate=this.long.startsWith("--no-")),this.defaultValue=void 0,this.defaultValueDescription=void 0,this.presetArg=void 0,this.envVar=void 0,this.parseArg=void 0,this.hidden=!1,this.argChoices=void 0,this.conflictsWith=[],this.implied=void 0}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}preset(e){return this.presetArg=e,this}conflicts(e){return this.conflictsWith=this.conflictsWith.concat(e),this}implies(e){let t=e;return typeof e=="string"&&(t={[e]:!0}),this.implied=Object.assign(this.implied||{},t),this}env(e){return this.envVar=e,this}argParser(e){return this.parseArg=e,this}makeOptionMandatory(e=!0){return this.mandatory=!!e,this}hideHelp(e=!0){return this.hidden=!!e,this}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,n)=>{if(!this.argChoices.includes(t))throw new ut(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,n):t},this}name(){return this.long?this.long.replace(/^--/,""):this.short.replace(/^-/,"")}attributeName(){return ft(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},l(F,"Option"),F),pt=(V=class{constructor(e){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,e.forEach(t=>{t.negate?this.negativeOptions.set(t.attributeName(),t):this.positiveOptions.set(t.attributeName(),t)}),this.negativeOptions.forEach((t,n)=>{this.positiveOptions.has(n)&&this.dualOptions.add(n)})}valueFromOption(e,t){const n=t.attributeName();if(!this.dualOptions.has(n))return!0;const r=this.negativeOptions.get(n).presetArg,i=r!==void 0?r:!1;return t.negate===(i===e)}},l(V,"DualOptions"),V);function ft(o){return o.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}l(ft,"camelcase");function dt(o){let e,t;const n=o.split(/[ |,]+/);return n.length>1&&!/^[[<]/.test(n[1])&&(e=n.shift()),t=n.shift(),!e&&/^-[^-]$/.test(t)&&(e=t,t=void 0),{shortFlag:e,longFlag:t}}l(dt,"splitOptionFlags"),W.Option=ht,W.DualOptions=pt;var ye={};const Oe=3;function mt(o,e){if(Math.abs(o.length-e.length)>Oe)return Math.max(o.length,e.length);const t=[];for(let n=0;n<=o.length;n++)t[n]=[n];for(let n=0;n<=e.length;n++)t[0][n]=n;for(let n=1;n<=e.length;n++)for(let r=1;r<=o.length;r++){let i=1;o[r-1]===e[n-1]?i=0:i=1,t[r][n]=Math.min(t[r-1][n]+1,t[r][n-1]+1,t[r-1][n-1]+i),r>1&&n>1&&o[r-1]===e[n-2]&&o[r-2]===e[n-1]&&(t[r][n]=Math.min(t[r][n],t[r-2][n-2]+1))}return t[o.length][e.length]}l(mt,"editDistance");function gt(o,e){if(!e||e.length===0)return"";e=Array.from(new Set(e));const t=o.startsWith("--");t&&(o=o.slice(2),e=e.map(a=>a.slice(2)));let n=[],r=Oe;const i=.4;return e.forEach(a=>{if(a.length<=1)return;const u=mt(o,a),c=Math.max(o.length,a.length);(c-u)/c>i&&(u<r?(r=u,n=[a]):u===r&&n.push(a))}),n.sort((a,u)=>a.localeCompare(u)),t&&(n=n.map(a=>`--${a}`)),n.length>1?`
10
10
  (Did you mean one of ${n.join(", ")}?)`:n.length===1?`
11
- (Did you mean ${n[0]}?)`:""}l(lt,"suggestSimilar$1"),de.suggestSimilar=lt;const ut=Me.EventEmitter,B=Ue,v=g,K=_,O=Ge,{Argument:ht,humanReadableArgName:pt}=D,{CommanderError:z}=P,{Help:ft}=J,{Option:ge,DualOptions:dt}=U,{suggestSimilar:_e}=de;let mt=(j=class extends ut{constructor(e){super(),this.commands=[],this.options=[],this.parent=null,this._allowUnknownOption=!1,this._allowExcessArguments=!0,this.registeredArguments=[],this._args=this.registeredArguments,this.args=[],this.rawArgs=[],this.processedArgs=[],this._scriptPath=null,this._name=e||"",this._optionValues={},this._optionValueSources={},this._storeOptionsAsProperties=!1,this._actionHandler=null,this._executableHandler=!1,this._executableFile=null,this._executableDir=null,this._defaultCommandName=null,this._exitCallback=null,this._aliases=[],this._combineFlagAndOptionalValue=!0,this._description="",this._summary="",this._argsDescription=void 0,this._enablePositionalOptions=!1,this._passThroughOptions=!1,this._lifeCycleHooks={},this._showHelpAfterError=!1,this._showSuggestionAfterError=!0,this._outputConfiguration={writeOut:l(t=>O.stdout.write(t),"writeOut"),writeErr:l(t=>O.stderr.write(t),"writeErr"),getOutHelpWidth:l(()=>O.stdout.isTTY?O.stdout.columns:void 0,"getOutHelpWidth"),getErrHelpWidth:l(()=>O.stderr.isTTY?O.stderr.columns:void 0,"getErrHelpWidth"),outputError:l((t,n)=>n(t),"outputError")},this._hidden=!1,this._helpOption=void 0,this._addImplicitHelpCommand=void 0,this._helpCommand=void 0,this._helpConfiguration={}}copyInheritedSettings(e){return this._outputConfiguration=e._outputConfiguration,this._helpOption=e._helpOption,this._helpCommand=e._helpCommand,this._helpConfiguration=e._helpConfiguration,this._exitCallback=e._exitCallback,this._storeOptionsAsProperties=e._storeOptionsAsProperties,this._combineFlagAndOptionalValue=e._combineFlagAndOptionalValue,this._allowExcessArguments=e._allowExcessArguments,this._enablePositionalOptions=e._enablePositionalOptions,this._showHelpAfterError=e._showHelpAfterError,this._showSuggestionAfterError=e._showSuggestionAfterError,this}_getCommandAndAncestors(){const e=[];for(let t=this;t;t=t.parent)e.push(t);return e}command(e,t,n){let i=t,o=n;typeof i=="object"&&i!==null&&(o=i,i=null),o=o||{};const[,a,u]=e.match(/([^ ]+) *(.*)/),c=this.createCommand(a);return i&&(c.description(i),c._executableHandler=!0),o.isDefault&&(this._defaultCommandName=c._name),c._hidden=!!(o.noHelp||o.hidden),c._executableFile=o.executableFile||null,u&&c.arguments(u),this._registerCommand(c),c.parent=this,c.copyInheritedSettings(this),i?this:c}createCommand(e){return new j(e)}createHelp(){return Object.assign(new ft,this.configureHelp())}configureHelp(e){return e===void 0?this._helpConfiguration:(this._helpConfiguration=e,this)}configureOutput(e){return e===void 0?this._outputConfiguration:(Object.assign(this._outputConfiguration,e),this)}showHelpAfterError(e=!0){return typeof e!="string"&&(e=!!e),this._showHelpAfterError=e,this}showSuggestionAfterError(e=!0){return this._showSuggestionAfterError=!!e,this}addCommand(e,t){if(!e._name)throw new Error(`Command passed to .addCommand() must have a name
12
- - specify the name in Command constructor or using .name()`);return t=t||{},t.isDefault&&(this._defaultCommandName=e._name),(t.noHelp||t.hidden)&&(e._hidden=!0),this._registerCommand(e),e.parent=this,e._checkForBrokenPassThrough(),this}createArgument(e,t){return new ht(e,t)}argument(e,t,n,i){const o=this.createArgument(e,t);return typeof n=="function"?o.default(i).argParser(n):o.default(n),this.addArgument(o),this}arguments(e){return e.trim().split(/ +/).forEach(t=>{this.argument(t)}),this}addArgument(e){const t=this.registeredArguments.slice(-1)[0];if(t&&t.variadic)throw new Error(`only the last argument can be variadic '${t.name()}'`);if(e.required&&e.defaultValue!==void 0&&e.parseArg===void 0)throw new Error(`a default value for a required argument is never used: '${e.name()}'`);return this.registeredArguments.push(e),this}helpCommand(e,t){if(typeof e=="boolean")return this._addImplicitHelpCommand=e,this;e=e??"help [command]";const[,n,i]=e.match(/([^ ]+) *(.*)/),o=t??"display help for command",a=this.createCommand(n);return a.helpOption(!1),i&&a.arguments(i),o&&a.description(o),this._addImplicitHelpCommand=!0,this._helpCommand=a,this}addHelpCommand(e,t){return typeof e!="object"?(this.helpCommand(e,t),this):(this._addImplicitHelpCommand=!0,this._helpCommand=e,this)}_getHelpCommand(){return this._addImplicitHelpCommand??(this.commands.length&&!this._actionHandler&&!this._findCommand("help"))?(this._helpCommand===void 0&&this.helpCommand(void 0,void 0),this._helpCommand):null}hook(e,t){const n=["preSubcommand","preAction","postAction"];if(!n.includes(e))throw new Error(`Unexpected value for event passed to hook : '${e}'.
13
- Expecting one of '${n.join("', '")}'`);return this._lifeCycleHooks[e]?this._lifeCycleHooks[e].push(t):this._lifeCycleHooks[e]=[t],this}exitOverride(e){return e?this._exitCallback=e:this._exitCallback=t=>{if(t.code!=="commander.executeSubCommandAsync")throw t},this}_exit(e,t,n){this._exitCallback&&this._exitCallback(new z(e,t,n)),O.exit(e)}action(e){const t=l(n=>{const i=this.registeredArguments.length,o=n.slice(0,i);return this._storeOptionsAsProperties?o[i]=this:o[i]=this.opts(),o.push(this),e.apply(this,o)},"listener");return this._actionHandler=t,this}createOption(e,t){return new ge(e,t)}_callParseArg(e,t,n,i){try{return e.parseArg(t,n)}catch(o){if(o.code==="commander.invalidArgument"){const a=`${i} ${o.message}`;this.error(a,{exitCode:o.exitCode,code:o.code})}throw o}}_registerOption(e){const t=e.short&&this._findOption(e.short)||e.long&&this._findOption(e.long);if(t){const n=e.long&&this._findOption(e.long)?e.long:e.short;throw new Error(`Cannot add option '${e.flags}'${this._name&&` to command '${this._name}'`} due to conflicting flag '${n}'
14
- - already used by option '${t.flags}'`)}this.options.push(e)}_registerCommand(e){const t=l(i=>[i.name()].concat(i.aliases()),"knownBy"),n=t(e).find(i=>this._findCommand(i));if(n){const i=t(this._findCommand(n)).join("|"),o=t(e).join("|");throw new Error(`cannot add command '${o}' as already have command '${i}'`)}this.commands.push(e)}addOption(e){this._registerOption(e);const t=e.name(),n=e.attributeName();if(e.negate){const o=e.long.replace(/^--no-/,"--");this._findOption(o)||this.setOptionValueWithSource(n,e.defaultValue===void 0?!0:e.defaultValue,"default")}else e.defaultValue!==void 0&&this.setOptionValueWithSource(n,e.defaultValue,"default");const i=l((o,a,u)=>{o==null&&e.presetArg!==void 0&&(o=e.presetArg);const c=this.getOptionValue(n);o!==null&&e.parseArg?o=this._callParseArg(e,o,c,a):o!==null&&e.variadic&&(o=e._concatValue(o,c)),o==null&&(e.negate?o=!1:e.isBoolean()||e.optional?o=!0:o=""),this.setOptionValueWithSource(n,o,u)},"handleOptionValue");return this.on("option:"+t,o=>{const a=`error: option '${e.flags}' argument '${o}' is invalid.`;i(o,a,"cli")}),e.envVar&&this.on("optionEnv:"+t,o=>{const a=`error: option '${e.flags}' value '${o}' from env '${e.envVar}' is invalid.`;i(o,a,"env")}),this}_optionEx(e,t,n,i,o){if(typeof t=="object"&&t instanceof ge)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");const a=this.createOption(t,n);if(a.makeOptionMandatory(!!e.mandatory),typeof i=="function")a.default(o).argParser(i);else if(i instanceof RegExp){const u=i;i=l((c,h)=>{const s=u.exec(c);return s?s[0]:h},"fn"),a.default(o).argParser(i)}else a.default(i);return this.addOption(a)}option(e,t,n,i){return this._optionEx({},e,t,n,i)}requiredOption(e,t,n,i){return this._optionEx({mandatory:!0},e,t,n,i)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,n){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=n,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(n=>{n.getOptionValueSource(e)!==void 0&&(t=n.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");t=t||{},e===void 0&&(e=O.argv,O.versions&&O.versions.electron&&(t.from="electron")),this.rawArgs=e.slice();let n;switch(t.from){case void 0:case"node":this._scriptPath=e[1],n=e.slice(2);break;case"electron":O.defaultApp?(this._scriptPath=e[1],n=e.slice(2)):n=e.slice(1);break;case"user":n=e.slice(0);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",n}parse(e,t){const n=this._prepareUserArgs(e,t);return this._parseCommand([],n),this}async parseAsync(e,t){const n=this._prepareUserArgs(e,t);return await this._parseCommand([],n),this}_executeSubCommand(e,t){t=t.slice();let n=!1;const i=[".js",".ts",".tsx",".mjs",".cjs"];function o(s,p){const f=v.resolve(s,p);if(K.existsSync(f))return f;if(i.includes(v.extname(p)))return;const y=i.find(m=>K.existsSync(`${f}${m}`));if(y)return`${f}${y}`}l(o,"findFile"),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let a=e._executableFile||`${this._name}-${e._name}`,u=this._executableDir||"";if(this._scriptPath){let s;try{s=K.realpathSync(this._scriptPath)}catch{s=this._scriptPath}u=v.resolve(v.dirname(s),u)}if(u){let s=o(u,a);if(!s&&!e._executableFile&&this._scriptPath){const p=v.basename(this._scriptPath,v.extname(this._scriptPath));p!==this._name&&(s=o(u,`${p}-${e._name}`))}a=s||a}n=i.includes(v.extname(a));let c;O.platform!=="win32"?n?(t.unshift(a),t=ye(O.execArgv).concat(t),c=B.spawn(O.argv[0],t,{stdio:"inherit"})):c=B.spawn(a,t,{stdio:"inherit"}):(t.unshift(a),t=ye(O.execArgv).concat(t),c=B.spawn(O.execPath,t,{stdio:"inherit"})),c.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(p=>{O.on(p,()=>{c.killed===!1&&c.exitCode===null&&c.kill(p)})});const h=this._exitCallback;c.on("close",(s,p)=>{s=s??1,h?h(new z(s,"commander.executeSubCommandAsync","(close)")):O.exit(s)}),c.on("error",s=>{if(s.code==="ENOENT"){const p=u?`searched for local subcommand relative to directory '${u}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",f=`'${a}' does not exist
11
+ (Did you mean ${n[0]}?)`:""}l(gt,"suggestSimilar$1"),ye.suggestSimilar=gt;const _t=Je.EventEmitter,Q=Be,v=g,Y=_,O=Ze,{Argument:yt,humanReadableArgName:Ot}=D,{CommanderError:Z}=k,{Help:bt}=z,{Option:be,DualOptions:wt}=W,{suggestSimilar:we}=ye;let At=(T=class extends _t{constructor(e){super(),this.commands=[],this.options=[],this.parent=null,this._allowUnknownOption=!1,this._allowExcessArguments=!0,this.registeredArguments=[],this._args=this.registeredArguments,this.args=[],this.rawArgs=[],this.processedArgs=[],this._scriptPath=null,this._name=e||"",this._optionValues={},this._optionValueSources={},this._storeOptionsAsProperties=!1,this._actionHandler=null,this._executableHandler=!1,this._executableFile=null,this._executableDir=null,this._defaultCommandName=null,this._exitCallback=null,this._aliases=[],this._combineFlagAndOptionalValue=!0,this._description="",this._summary="",this._argsDescription=void 0,this._enablePositionalOptions=!1,this._passThroughOptions=!1,this._lifeCycleHooks={},this._showHelpAfterError=!1,this._showSuggestionAfterError=!0,this._outputConfiguration={writeOut:l(t=>O.stdout.write(t),"writeOut"),writeErr:l(t=>O.stderr.write(t),"writeErr"),getOutHelpWidth:l(()=>O.stdout.isTTY?O.stdout.columns:void 0,"getOutHelpWidth"),getErrHelpWidth:l(()=>O.stderr.isTTY?O.stderr.columns:void 0,"getErrHelpWidth"),outputError:l((t,n)=>n(t),"outputError")},this._hidden=!1,this._helpOption=void 0,this._addImplicitHelpCommand=void 0,this._helpCommand=void 0,this._helpConfiguration={}}copyInheritedSettings(e){return this._outputConfiguration=e._outputConfiguration,this._helpOption=e._helpOption,this._helpCommand=e._helpCommand,this._helpConfiguration=e._helpConfiguration,this._exitCallback=e._exitCallback,this._storeOptionsAsProperties=e._storeOptionsAsProperties,this._combineFlagAndOptionalValue=e._combineFlagAndOptionalValue,this._allowExcessArguments=e._allowExcessArguments,this._enablePositionalOptions=e._enablePositionalOptions,this._showHelpAfterError=e._showHelpAfterError,this._showSuggestionAfterError=e._showSuggestionAfterError,this}_getCommandAndAncestors(){const e=[];for(let t=this;t;t=t.parent)e.push(t);return e}command(e,t,n){let r=t,i=n;typeof r=="object"&&r!==null&&(i=r,r=null),i=i||{};const[,a,u]=e.match(/([^ ]+) *(.*)/),c=this.createCommand(a);return r&&(c.description(r),c._executableHandler=!0),i.isDefault&&(this._defaultCommandName=c._name),c._hidden=!!(i.noHelp||i.hidden),c._executableFile=i.executableFile||null,u&&c.arguments(u),this._registerCommand(c),c.parent=this,c.copyInheritedSettings(this),r?this:c}createCommand(e){return new T(e)}createHelp(){return Object.assign(new bt,this.configureHelp())}configureHelp(e){return e===void 0?this._helpConfiguration:(this._helpConfiguration=e,this)}configureOutput(e){return e===void 0?this._outputConfiguration:(Object.assign(this._outputConfiguration,e),this)}showHelpAfterError(e=!0){return typeof e!="string"&&(e=!!e),this._showHelpAfterError=e,this}showSuggestionAfterError(e=!0){return this._showSuggestionAfterError=!!e,this}addCommand(e,t){if(!e._name)throw new Error(`Command passed to .addCommand() must have a name
12
+ - specify the name in Command constructor or using .name()`);return t=t||{},t.isDefault&&(this._defaultCommandName=e._name),(t.noHelp||t.hidden)&&(e._hidden=!0),this._registerCommand(e),e.parent=this,e._checkForBrokenPassThrough(),this}createArgument(e,t){return new yt(e,t)}argument(e,t,n,r){const i=this.createArgument(e,t);return typeof n=="function"?i.default(r).argParser(n):i.default(n),this.addArgument(i),this}arguments(e){return e.trim().split(/ +/).forEach(t=>{this.argument(t)}),this}addArgument(e){const t=this.registeredArguments.slice(-1)[0];if(t&&t.variadic)throw new Error(`only the last argument can be variadic '${t.name()}'`);if(e.required&&e.defaultValue!==void 0&&e.parseArg===void 0)throw new Error(`a default value for a required argument is never used: '${e.name()}'`);return this.registeredArguments.push(e),this}helpCommand(e,t){if(typeof e=="boolean")return this._addImplicitHelpCommand=e,this;e=e??"help [command]";const[,n,r]=e.match(/([^ ]+) *(.*)/),i=t??"display help for command",a=this.createCommand(n);return a.helpOption(!1),r&&a.arguments(r),i&&a.description(i),this._addImplicitHelpCommand=!0,this._helpCommand=a,this}addHelpCommand(e,t){return typeof e!="object"?(this.helpCommand(e,t),this):(this._addImplicitHelpCommand=!0,this._helpCommand=e,this)}_getHelpCommand(){return this._addImplicitHelpCommand??(this.commands.length&&!this._actionHandler&&!this._findCommand("help"))?(this._helpCommand===void 0&&this.helpCommand(void 0,void 0),this._helpCommand):null}hook(e,t){const n=["preSubcommand","preAction","postAction"];if(!n.includes(e))throw new Error(`Unexpected value for event passed to hook : '${e}'.
13
+ Expecting one of '${n.join("', '")}'`);return this._lifeCycleHooks[e]?this._lifeCycleHooks[e].push(t):this._lifeCycleHooks[e]=[t],this}exitOverride(e){return e?this._exitCallback=e:this._exitCallback=t=>{if(t.code!=="commander.executeSubCommandAsync")throw t},this}_exit(e,t,n){this._exitCallback&&this._exitCallback(new Z(e,t,n)),O.exit(e)}action(e){const t=l(n=>{const r=this.registeredArguments.length,i=n.slice(0,r);return this._storeOptionsAsProperties?i[r]=this:i[r]=this.opts(),i.push(this),e.apply(this,i)},"listener");return this._actionHandler=t,this}createOption(e,t){return new be(e,t)}_callParseArg(e,t,n,r){try{return e.parseArg(t,n)}catch(i){if(i.code==="commander.invalidArgument"){const a=`${r} ${i.message}`;this.error(a,{exitCode:i.exitCode,code:i.code})}throw i}}_registerOption(e){const t=e.short&&this._findOption(e.short)||e.long&&this._findOption(e.long);if(t){const n=e.long&&this._findOption(e.long)?e.long:e.short;throw new Error(`Cannot add option '${e.flags}'${this._name&&` to command '${this._name}'`} due to conflicting flag '${n}'
14
+ - already used by option '${t.flags}'`)}this.options.push(e)}_registerCommand(e){const t=l(r=>[r.name()].concat(r.aliases()),"knownBy"),n=t(e).find(r=>this._findCommand(r));if(n){const r=t(this._findCommand(n)).join("|"),i=t(e).join("|");throw new Error(`cannot add command '${i}' as already have command '${r}'`)}this.commands.push(e)}addOption(e){this._registerOption(e);const t=e.name(),n=e.attributeName();if(e.negate){const i=e.long.replace(/^--no-/,"--");this._findOption(i)||this.setOptionValueWithSource(n,e.defaultValue===void 0?!0:e.defaultValue,"default")}else e.defaultValue!==void 0&&this.setOptionValueWithSource(n,e.defaultValue,"default");const r=l((i,a,u)=>{i==null&&e.presetArg!==void 0&&(i=e.presetArg);const c=this.getOptionValue(n);i!==null&&e.parseArg?i=this._callParseArg(e,i,c,a):i!==null&&e.variadic&&(i=e._concatValue(i,c)),i==null&&(e.negate?i=!1:e.isBoolean()||e.optional?i=!0:i=""),this.setOptionValueWithSource(n,i,u)},"handleOptionValue");return this.on("option:"+t,i=>{const a=`error: option '${e.flags}' argument '${i}' is invalid.`;r(i,a,"cli")}),e.envVar&&this.on("optionEnv:"+t,i=>{const a=`error: option '${e.flags}' value '${i}' from env '${e.envVar}' is invalid.`;r(i,a,"env")}),this}_optionEx(e,t,n,r,i){if(typeof t=="object"&&t instanceof be)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");const a=this.createOption(t,n);if(a.makeOptionMandatory(!!e.mandatory),typeof r=="function")a.default(i).argParser(r);else if(r instanceof RegExp){const u=r;r=l((c,h)=>{const s=u.exec(c);return s?s[0]:h},"fn"),a.default(i).argParser(r)}else a.default(r);return this.addOption(a)}option(e,t,n,r){return this._optionEx({},e,t,n,r)}requiredOption(e,t,n,r){return this._optionEx({mandatory:!0},e,t,n,r)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,n){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=n,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(n=>{n.getOptionValueSource(e)!==void 0&&(t=n.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");t=t||{},e===void 0&&(e=O.argv,O.versions&&O.versions.electron&&(t.from="electron")),this.rawArgs=e.slice();let n;switch(t.from){case void 0:case"node":this._scriptPath=e[1],n=e.slice(2);break;case"electron":O.defaultApp?(this._scriptPath=e[1],n=e.slice(2)):n=e.slice(1);break;case"user":n=e.slice(0);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",n}parse(e,t){const n=this._prepareUserArgs(e,t);return this._parseCommand([],n),this}async parseAsync(e,t){const n=this._prepareUserArgs(e,t);return await this._parseCommand([],n),this}_executeSubCommand(e,t){t=t.slice();let n=!1;const r=[".js",".ts",".tsx",".mjs",".cjs"];function i(s,p){const d=v.resolve(s,p);if(Y.existsSync(d))return d;if(r.includes(v.extname(p)))return;const y=r.find(m=>Y.existsSync(`${d}${m}`));if(y)return`${d}${y}`}l(i,"findFile"),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let a=e._executableFile||`${this._name}-${e._name}`,u=this._executableDir||"";if(this._scriptPath){let s;try{s=Y.realpathSync(this._scriptPath)}catch{s=this._scriptPath}u=v.resolve(v.dirname(s),u)}if(u){let s=i(u,a);if(!s&&!e._executableFile&&this._scriptPath){const p=v.basename(this._scriptPath,v.extname(this._scriptPath));p!==this._name&&(s=i(u,`${p}-${e._name}`))}a=s||a}n=r.includes(v.extname(a));let c;O.platform!=="win32"?n?(t.unshift(a),t=Ae(O.execArgv).concat(t),c=Q.spawn(O.argv[0],t,{stdio:"inherit"})):c=Q.spawn(a,t,{stdio:"inherit"}):(t.unshift(a),t=Ae(O.execArgv).concat(t),c=Q.spawn(O.execPath,t,{stdio:"inherit"})),c.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(p=>{O.on(p,()=>{c.killed===!1&&c.exitCode===null&&c.kill(p)})});const h=this._exitCallback;c.on("close",(s,p)=>{s=s??1,h?h(new Z(s,"commander.executeSubCommandAsync","(close)")):O.exit(s)}),c.on("error",s=>{if(s.code==="ENOENT"){const p=u?`searched for local subcommand relative to directory '${u}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",d=`'${a}' does not exist
15
15
  - if '${e._name}' is not meant to be an executable command, remove description parameter from '.command()' and use '.description()' instead
16
16
  - if the default executable name is not suitable, use the executableFile option to supply a custom name or path
17
- - ${p}`;throw new Error(f)}else if(s.code==="EACCES")throw new Error(`'${a}' not executable`);if(!h)O.exit(1);else{const p=new z(1,"commander.executeSubCommandAsync","(error)");p.nestedError=s,h(p)}}),this.runningCommand=c}_dispatchSubcommand(e,t,n){const i=this._findCommand(e);i||this.help({error:!0});let o;return o=this._chainOrCallSubCommandHook(o,i,"preSubcommand"),o=this._chainOrCall(o,()=>{if(i._executableHandler)this._executeSubCommand(i,t.concat(n));else return i._parseCommand(t,n)}),o}_dispatchHelpCommand(e){e||this.help();const t=this._findCommand(e);return t&&!t._executableHandler&&t.help(),this._dispatchSubcommand(e,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){this.registeredArguments.forEach((e,t)=>{e.required&&this.args[t]==null&&this.missingArgument(e.name())}),!(this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)&&this.args.length>this.registeredArguments.length&&this._excessArguments(this.args)}_processArguments(){const e=l((n,i,o)=>{let a=i;if(i!==null&&n.parseArg){const u=`error: command-argument value '${i}' is invalid for argument '${n.name()}'.`;a=this._callParseArg(n,i,o,u)}return a},"myParseArg");this._checkNumberOfArguments();const t=[];this.registeredArguments.forEach((n,i)=>{let o=n.defaultValue;n.variadic?i<this.args.length?(o=this.args.slice(i),n.parseArg&&(o=o.reduce((a,u)=>e(n,u,a),n.defaultValue))):o===void 0&&(o=[]):i<this.args.length&&(o=this.args[i],n.parseArg&&(o=e(n,o,n.defaultValue))),t[i]=o}),this.processedArgs=t}_chainOrCall(e,t){return e&&e.then&&typeof e.then=="function"?e.then(()=>t()):t()}_chainOrCallHooks(e,t){let n=e;const i=[];return this._getCommandAndAncestors().reverse().filter(o=>o._lifeCycleHooks[t]!==void 0).forEach(o=>{o._lifeCycleHooks[t].forEach(a=>{i.push({hookedCommand:o,callback:a})})}),t==="postAction"&&i.reverse(),i.forEach(o=>{n=this._chainOrCall(n,()=>o.callback(o.hookedCommand,this))}),n}_chainOrCallSubCommandHook(e,t,n){let i=e;return this._lifeCycleHooks[n]!==void 0&&this._lifeCycleHooks[n].forEach(o=>{i=this._chainOrCall(i,()=>o(this,t))}),i}_parseCommand(e,t){const n=this.parseOptions(t);if(this._parseOptionsEnv(),this._parseOptionsImplied(),e=e.concat(n.operands),t=n.unknown,this.args=e.concat(t),e&&this._findCommand(e[0]))return this._dispatchSubcommand(e[0],e.slice(1),t);if(this._getHelpCommand()&&e[0]===this._getHelpCommand().name())return this._dispatchHelpCommand(e[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(t),this._dispatchSubcommand(this._defaultCommandName,e,t);this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName&&this.help({error:!0}),this._outputHelpIfRequested(n.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();const i=l(()=>{n.unknown.length>0&&this.unknownOption(n.unknown[0])},"checkForUnknownOptions"),o=`command:${this.name()}`;if(this._actionHandler){i(),this._processArguments();let a;return a=this._chainOrCallHooks(a,"preAction"),a=this._chainOrCall(a,()=>this._actionHandler(this.processedArgs)),this.parent&&(a=this._chainOrCall(a,()=>{this.parent.emit(o,e,t)})),a=this._chainOrCallHooks(a,"postAction"),a}if(this.parent&&this.parent.listenerCount(o))i(),this._processArguments(),this.parent.emit(o,e,t);else if(e.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",e,t);this.listenerCount("command:*")?this.emit("command:*",e,t):this.commands.length?this.unknownCommand():(i(),this._processArguments())}else this.commands.length?(i(),this.help({error:!0})):(i(),this._processArguments())}_findCommand(e){if(e)return this.commands.find(t=>t._name===e||t._aliases.includes(e))}_findOption(e){return this.options.find(t=>t.is(e))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(e=>{e.options.forEach(t=>{t.mandatory&&e.getOptionValue(t.attributeName())===void 0&&e.missingMandatoryOptionValue(t)})})}_checkForConflictingLocalOptions(){const e=this.options.filter(n=>{const i=n.attributeName();return this.getOptionValue(i)===void 0?!1:this.getOptionValueSource(i)!=="default"});e.filter(n=>n.conflictsWith.length>0).forEach(n=>{const i=e.find(o=>n.conflictsWith.includes(o.attributeName()));i&&this._conflictingOption(n,i)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(e=>{e._checkForConflictingLocalOptions()})}parseOptions(e){const t=[],n=[];let i=t;const o=e.slice();function a(c){return c.length>1&&c[0]==="-"}l(a,"maybeOption");let u=null;for(;o.length;){const c=o.shift();if(c==="--"){i===n&&i.push(c),i.push(...o);break}if(u&&!a(c)){this.emit(`option:${u.name()}`,c);continue}if(u=null,a(c)){const h=this._findOption(c);if(h){if(h.required){const s=o.shift();s===void 0&&this.optionMissingArgument(h),this.emit(`option:${h.name()}`,s)}else if(h.optional){let s=null;o.length>0&&!a(o[0])&&(s=o.shift()),this.emit(`option:${h.name()}`,s)}else this.emit(`option:${h.name()}`);u=h.variadic?h:null;continue}}if(c.length>2&&c[0]==="-"&&c[1]!=="-"){const h=this._findOption(`-${c[1]}`);if(h){h.required||h.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${h.name()}`,c.slice(2)):(this.emit(`option:${h.name()}`),o.unshift(`-${c.slice(2)}`));continue}}if(/^--[^=]+=/.test(c)){const h=c.indexOf("="),s=this._findOption(c.slice(0,h));if(s&&(s.required||s.optional)){this.emit(`option:${s.name()}`,c.slice(h+1));continue}}if(a(c)&&(i=n),(this._enablePositionalOptions||this._passThroughOptions)&&t.length===0&&n.length===0){if(this._findCommand(c)){t.push(c),o.length>0&&n.push(...o);break}else if(this._getHelpCommand()&&c===this._getHelpCommand().name()){t.push(c),o.length>0&&t.push(...o);break}else if(this._defaultCommandName){n.push(c),o.length>0&&n.push(...o);break}}if(this._passThroughOptions){i.push(c),o.length>0&&i.push(...o);break}i.push(c)}return{operands:t,unknown:n}}opts(){if(this._storeOptionsAsProperties){const e={},t=this.options.length;for(let n=0;n<t;n++){const i=this.options[n].attributeName();e[i]=i===this._versionOptionName?this._version:this[i]}return e}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce((e,t)=>Object.assign(e,t.opts()),{})}error(e,t){this._outputConfiguration.outputError(`${e}
17
+ - ${p}`;throw new Error(d)}else if(s.code==="EACCES")throw new Error(`'${a}' not executable`);if(!h)O.exit(1);else{const p=new Z(1,"commander.executeSubCommandAsync","(error)");p.nestedError=s,h(p)}}),this.runningCommand=c}_dispatchSubcommand(e,t,n){const r=this._findCommand(e);r||this.help({error:!0});let i;return i=this._chainOrCallSubCommandHook(i,r,"preSubcommand"),i=this._chainOrCall(i,()=>{if(r._executableHandler)this._executeSubCommand(r,t.concat(n));else return r._parseCommand(t,n)}),i}_dispatchHelpCommand(e){e||this.help();const t=this._findCommand(e);return t&&!t._executableHandler&&t.help(),this._dispatchSubcommand(e,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){this.registeredArguments.forEach((e,t)=>{e.required&&this.args[t]==null&&this.missingArgument(e.name())}),!(this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)&&this.args.length>this.registeredArguments.length&&this._excessArguments(this.args)}_processArguments(){const e=l((n,r,i)=>{let a=r;if(r!==null&&n.parseArg){const u=`error: command-argument value '${r}' is invalid for argument '${n.name()}'.`;a=this._callParseArg(n,r,i,u)}return a},"myParseArg");this._checkNumberOfArguments();const t=[];this.registeredArguments.forEach((n,r)=>{let i=n.defaultValue;n.variadic?r<this.args.length?(i=this.args.slice(r),n.parseArg&&(i=i.reduce((a,u)=>e(n,u,a),n.defaultValue))):i===void 0&&(i=[]):r<this.args.length&&(i=this.args[r],n.parseArg&&(i=e(n,i,n.defaultValue))),t[r]=i}),this.processedArgs=t}_chainOrCall(e,t){return e&&e.then&&typeof e.then=="function"?e.then(()=>t()):t()}_chainOrCallHooks(e,t){let n=e;const r=[];return this._getCommandAndAncestors().reverse().filter(i=>i._lifeCycleHooks[t]!==void 0).forEach(i=>{i._lifeCycleHooks[t].forEach(a=>{r.push({hookedCommand:i,callback:a})})}),t==="postAction"&&r.reverse(),r.forEach(i=>{n=this._chainOrCall(n,()=>i.callback(i.hookedCommand,this))}),n}_chainOrCallSubCommandHook(e,t,n){let r=e;return this._lifeCycleHooks[n]!==void 0&&this._lifeCycleHooks[n].forEach(i=>{r=this._chainOrCall(r,()=>i(this,t))}),r}_parseCommand(e,t){const n=this.parseOptions(t);if(this._parseOptionsEnv(),this._parseOptionsImplied(),e=e.concat(n.operands),t=n.unknown,this.args=e.concat(t),e&&this._findCommand(e[0]))return this._dispatchSubcommand(e[0],e.slice(1),t);if(this._getHelpCommand()&&e[0]===this._getHelpCommand().name())return this._dispatchHelpCommand(e[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(t),this._dispatchSubcommand(this._defaultCommandName,e,t);this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName&&this.help({error:!0}),this._outputHelpIfRequested(n.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();const r=l(()=>{n.unknown.length>0&&this.unknownOption(n.unknown[0])},"checkForUnknownOptions"),i=`command:${this.name()}`;if(this._actionHandler){r(),this._processArguments();let a;return a=this._chainOrCallHooks(a,"preAction"),a=this._chainOrCall(a,()=>this._actionHandler(this.processedArgs)),this.parent&&(a=this._chainOrCall(a,()=>{this.parent.emit(i,e,t)})),a=this._chainOrCallHooks(a,"postAction"),a}if(this.parent&&this.parent.listenerCount(i))r(),this._processArguments(),this.parent.emit(i,e,t);else if(e.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",e,t);this.listenerCount("command:*")?this.emit("command:*",e,t):this.commands.length?this.unknownCommand():(r(),this._processArguments())}else this.commands.length?(r(),this.help({error:!0})):(r(),this._processArguments())}_findCommand(e){if(e)return this.commands.find(t=>t._name===e||t._aliases.includes(e))}_findOption(e){return this.options.find(t=>t.is(e))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(e=>{e.options.forEach(t=>{t.mandatory&&e.getOptionValue(t.attributeName())===void 0&&e.missingMandatoryOptionValue(t)})})}_checkForConflictingLocalOptions(){const e=this.options.filter(n=>{const r=n.attributeName();return this.getOptionValue(r)===void 0?!1:this.getOptionValueSource(r)!=="default"});e.filter(n=>n.conflictsWith.length>0).forEach(n=>{const r=e.find(i=>n.conflictsWith.includes(i.attributeName()));r&&this._conflictingOption(n,r)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(e=>{e._checkForConflictingLocalOptions()})}parseOptions(e){const t=[],n=[];let r=t;const i=e.slice();function a(c){return c.length>1&&c[0]==="-"}l(a,"maybeOption");let u=null;for(;i.length;){const c=i.shift();if(c==="--"){r===n&&r.push(c),r.push(...i);break}if(u&&!a(c)){this.emit(`option:${u.name()}`,c);continue}if(u=null,a(c)){const h=this._findOption(c);if(h){if(h.required){const s=i.shift();s===void 0&&this.optionMissingArgument(h),this.emit(`option:${h.name()}`,s)}else if(h.optional){let s=null;i.length>0&&!a(i[0])&&(s=i.shift()),this.emit(`option:${h.name()}`,s)}else this.emit(`option:${h.name()}`);u=h.variadic?h:null;continue}}if(c.length>2&&c[0]==="-"&&c[1]!=="-"){const h=this._findOption(`-${c[1]}`);if(h){h.required||h.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${h.name()}`,c.slice(2)):(this.emit(`option:${h.name()}`),i.unshift(`-${c.slice(2)}`));continue}}if(/^--[^=]+=/.test(c)){const h=c.indexOf("="),s=this._findOption(c.slice(0,h));if(s&&(s.required||s.optional)){this.emit(`option:${s.name()}`,c.slice(h+1));continue}}if(a(c)&&(r=n),(this._enablePositionalOptions||this._passThroughOptions)&&t.length===0&&n.length===0){if(this._findCommand(c)){t.push(c),i.length>0&&n.push(...i);break}else if(this._getHelpCommand()&&c===this._getHelpCommand().name()){t.push(c),i.length>0&&t.push(...i);break}else if(this._defaultCommandName){n.push(c),i.length>0&&n.push(...i);break}}if(this._passThroughOptions){r.push(c),i.length>0&&r.push(...i);break}r.push(c)}return{operands:t,unknown:n}}opts(){if(this._storeOptionsAsProperties){const e={},t=this.options.length;for(let n=0;n<t;n++){const r=this.options[n].attributeName();e[r]=r===this._versionOptionName?this._version:this[r]}return e}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce((e,t)=>Object.assign(e,t.opts()),{})}error(e,t){this._outputConfiguration.outputError(`${e}
18
18
  `,this._outputConfiguration.writeErr),typeof this._showHelpAfterError=="string"?this._outputConfiguration.writeErr(`${this._showHelpAfterError}
19
19
  `):this._showHelpAfterError&&(this._outputConfiguration.writeErr(`
20
- `),this.outputHelp({error:!0}));const n=t||{},i=n.exitCode||1,o=n.code||"commander.error";this._exit(i,o,e)}_parseOptionsEnv(){this.options.forEach(e=>{if(e.envVar&&e.envVar in O.env){const t=e.attributeName();(this.getOptionValue(t)===void 0||["default","config","env"].includes(this.getOptionValueSource(t)))&&(e.required||e.optional?this.emit(`optionEnv:${e.name()}`,O.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){const e=new dt(this.options),t=l(n=>this.getOptionValue(n)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(n)),"hasCustomOptionValue");this.options.filter(n=>n.implied!==void 0&&t(n.attributeName())&&e.valueFromOption(this.getOptionValue(n.attributeName()),n)).forEach(n=>{Object.keys(n.implied).filter(i=>!t(i)).forEach(i=>{this.setOptionValueWithSource(i,n.implied[i],"implied")})})}missingArgument(e){const t=`error: missing required argument '${e}'`;this.error(t,{code:"commander.missingArgument"})}optionMissingArgument(e){const t=`error: option '${e.flags}' argument missing`;this.error(t,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue(e){const t=`error: required option '${e.flags}' not specified`;this.error(t,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption(e,t){const n=l(a=>{const u=a.attributeName(),c=this.getOptionValue(u),h=this.options.find(p=>p.negate&&u===p.attributeName()),s=this.options.find(p=>!p.negate&&u===p.attributeName());return h&&(h.presetArg===void 0&&c===!1||h.presetArg!==void 0&&c===h.presetArg)?h:s||a},"findBestOptionFromValue"),i=l(a=>{const u=n(a),c=u.attributeName();return this.getOptionValueSource(c)==="env"?`environment variable '${u.envVar}'`:`option '${u.flags}'`},"getErrorMessage"),o=`error: ${i(e)} cannot be used with ${i(t)}`;this.error(o,{code:"commander.conflictingOption"})}unknownOption(e){if(this._allowUnknownOption)return;let t="";if(e.startsWith("--")&&this._showSuggestionAfterError){let i=[],o=this;do{const a=o.createHelp().visibleOptions(o).filter(u=>u.long).map(u=>u.long);i=i.concat(a),o=o.parent}while(o&&!o._enablePositionalOptions);t=_e(e,i)}const n=`error: unknown option '${e}'${t}`;this.error(n,{code:"commander.unknownOption"})}_excessArguments(e){if(this._allowExcessArguments)return;const t=this.registeredArguments.length,n=t===1?"":"s",o=`error: too many arguments${this.parent?` for '${this.name()}'`:""}. Expected ${t} argument${n} but got ${e.length}.`;this.error(o,{code:"commander.excessArguments"})}unknownCommand(){const e=this.args[0];let t="";if(this._showSuggestionAfterError){const i=[];this.createHelp().visibleCommands(this).forEach(o=>{i.push(o.name()),o.alias()&&i.push(o.alias())}),t=_e(e,i)}const n=`error: unknown command '${e}'${t}`;this.error(n,{code:"commander.unknownCommand"})}version(e,t,n){if(e===void 0)return this._version;this._version=e,t=t||"-V, --version",n=n||"output the version number";const i=this.createOption(t,n);return this._versionOptionName=i.attributeName(),this._registerOption(i),this.on("option:"+i.name(),()=>{this._outputConfiguration.writeOut(`${e}
21
- `),this._exit(0,"commander.version",e)}),this}description(e,t){return e===void 0&&t===void 0?this._description:(this._description=e,t&&(this._argsDescription=t),this)}summary(e){return e===void 0?this._summary:(this._summary=e,this)}alias(e){if(e===void 0)return this._aliases[0];let t=this;if(this.commands.length!==0&&this.commands[this.commands.length-1]._executableHandler&&(t=this.commands[this.commands.length-1]),e===t._name)throw new Error("Command alias can't be the same as its name");const n=this.parent?._findCommand(e);if(n){const i=[n.name()].concat(n.aliases()).join("|");throw new Error(`cannot add alias '${e}' to command '${this.name()}' as already have command '${i}'`)}return t._aliases.push(e),this}aliases(e){return e===void 0?this._aliases:(e.forEach(t=>this.alias(t)),this)}usage(e){if(e===void 0){if(this._usage)return this._usage;const t=this.registeredArguments.map(n=>pt(n));return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?t:[]).join(" ")}return this._usage=e,this}name(e){return e===void 0?this._name:(this._name=e,this)}nameFromFilename(e){return this._name=v.basename(e,v.extname(e)),this}executableDir(e){return e===void 0?this._executableDir:(this._executableDir=e,this)}helpInformation(e){const t=this.createHelp();return t.helpWidth===void 0&&(t.helpWidth=e&&e.error?this._outputConfiguration.getErrHelpWidth():this._outputConfiguration.getOutHelpWidth()),t.formatHelp(this,t)}_getHelpContext(e){e=e||{};const t={error:!!e.error};let n;return t.error?n=l(i=>this._outputConfiguration.writeErr(i),"write"):n=l(i=>this._outputConfiguration.writeOut(i),"write"),t.write=e.write||n,t.command=this,t}outputHelp(e){let t;typeof e=="function"&&(t=e,e=void 0);const n=this._getHelpContext(e);this._getCommandAndAncestors().reverse().forEach(o=>o.emit("beforeAllHelp",n)),this.emit("beforeHelp",n);let i=this.helpInformation(n);if(t&&(i=t(i),typeof i!="string"&&!Buffer.isBuffer(i)))throw new Error("outputHelp callback must return a string or a Buffer");n.write(i),this._getHelpOption()?.long&&this.emit(this._getHelpOption().long),this.emit("afterHelp",n),this._getCommandAndAncestors().forEach(o=>o.emit("afterAllHelp",n))}helpOption(e,t){return typeof e=="boolean"?(e?this._helpOption=this._helpOption??void 0:this._helpOption=null,this):(e=e??"-h, --help",t=t??"display help for command",this._helpOption=this.createOption(e,t),this)}_getHelpOption(){return this._helpOption===void 0&&this.helpOption(void 0,void 0),this._helpOption}addHelpOption(e){return this._helpOption=e,this}help(e){this.outputHelp(e);let t=O.exitCode||0;t===0&&e&&typeof e!="function"&&e.error&&(t=1),this._exit(t,"commander.help","(outputHelp)")}addHelpText(e,t){const n=["beforeAll","before","after","afterAll"];if(!n.includes(e))throw new Error(`Unexpected value for position to addHelpText.
22
- Expecting one of '${n.join("', '")}'`);const i=`${e}Help`;return this.on(i,o=>{let a;typeof t=="function"?a=t({error:o.error,command:o.command}):a=t,a&&o.write(`${a}
23
- `)}),this}_outputHelpIfRequested(e){const t=this._getHelpOption();t&&e.find(i=>t.is(i))&&(this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)"))}},l(j,"Command"),j);function ye(r){return r.map(e=>{if(!e.startsWith("--inspect"))return e;let t,n="127.0.0.1",i="9229",o;return(o=e.match(/^(--inspect(-brk)?)$/))!==null?t=o[1]:(o=e.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null?(t=o[1],/^\d+$/.test(o[3])?i=o[3]:n=o[3]):(o=e.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null&&(t=o[1],n=o[3],i=o[4]),t&&i!=="0"?`${t}=${n}:${parseInt(i)+1}`:e})}l(ye,"incrementNodeInspectorPort"),fe.Command=mt;const{Argument:Oe}=D,{Command:Q}=fe,{CommanderError:gt,InvalidArgumentError:be}=P,{Help:_t}=J,{Option:we}=U;A.program=new Q,A.createCommand=r=>new Q(r),A.createOption=(r,e)=>new we(r,e),A.createArgument=(r,e)=>new Oe(r,e),A.Command=Q,A.Option=we,A.Argument=Oe,A.Help=_t,A.CommanderError=gt,A.InvalidArgumentError=be,A.InvalidOptionArgumentError=be;const{program:Kn,createCommand:zn,createArgument:Qn,createOption:Yn,CommanderError:Zn,InvalidArgumentError:Xn,InvalidOptionArgumentError:ei,Command:yt,Argument:ti,Option:ni,Help:ii}=A,Ot=/"(?:_|\\u0{2}5[Ff]){2}(?:p|\\u0{2}70)(?:r|\\u0{2}72)(?:o|\\u0{2}6[Ff])(?:t|\\u0{2}74)(?:o|\\u0{2}6[Ff])(?:_|\\u0{2}5[Ff]){2}"\s*:/,bt=/"(?:c|\\u0063)(?:o|\\u006[Ff])(?:n|\\u006[Ee])(?:s|\\u0073)(?:t|\\u0074)(?:r|\\u0072)(?:u|\\u0075)(?:c|\\u0063)(?:t|\\u0074)(?:o|\\u006[Ff])(?:r|\\u0072)"\s*:/,wt=/^\s*["[{]|^\s*-?\d{1,16}(\.\d{1,17})?([Ee][+-]?\d+)?\s*$/;function At(r,e){if(r==="__proto__"||r==="constructor"&&e&&typeof e=="object"&&"prototype"in e){Ct(r);return}return e}l(At,"jsonParseTransform");function Ct(r){console.warn(`[destr] Dropping "${r}" key to prevent prototype pollution.`)}l(Ct,"warnKeyDropped");function Et(r,e={}){if(typeof r!="string")return r;const t=r.trim();if(r[0]==='"'&&r.endsWith('"')&&!r.includes("\\"))return t.slice(1,-1);if(t.length<=9){const n=t.toLowerCase();if(n==="true")return!0;if(n==="false")return!1;if(n==="undefined")return;if(n==="null")return null;if(n==="nan")return Number.NaN;if(n==="infinity")return Number.POSITIVE_INFINITY;if(n==="-infinity")return Number.NEGATIVE_INFINITY}if(!wt.test(r)){if(e.strict)throw new SyntaxError("[destr] Invalid JSON");return r}try{if(Ot.test(r)||bt.test(r)){if(e.strict)throw new Error("[destr] Possible prototype pollution");return JSON.parse(r,At)}return JSON.parse(r)}catch(n){if(e.strict)throw n;return r}}l(Et,"destr");const $t=/#/g,vt=/&/g,St=/\//g,Tt=/=/g,Y=/\+/g,jt=/%5e/gi,xt=/%60/gi,Pt=/%7c/gi,kt=/%20/gi;function Rt(r){return encodeURI(""+r).replace(Pt,"|")}l(Rt,"encode");function Z(r){return Rt(typeof r=="string"?r:JSON.stringify(r)).replace(Y,"%2B").replace(kt,"+").replace($t,"%23").replace(vt,"%26").replace(xt,"`").replace(jt,"^").replace(St,"%2F")}l(Z,"encodeQueryValue");function X(r){return Z(r).replace(Tt,"%3D")}l(X,"encodeQueryKey");function Ae(r=""){try{return decodeURIComponent(""+r)}catch{return""+r}}l(Ae,"decode");function Ht(r){return Ae(r.replace(Y," "))}l(Ht,"decodeQueryKey");function Nt(r){return Ae(r.replace(Y," "))}l(Nt,"decodeQueryValue");function Ft(r=""){const e={};r[0]==="?"&&(r=r.slice(1));for(const t of r.split("&")){const n=t.match(/([^=]+)=?(.*)/)||[];if(n.length<2)continue;const i=Ht(n[1]);if(i==="__proto__"||i==="constructor")continue;const o=Nt(n[2]||"");e[i]===void 0?e[i]=o:Array.isArray(e[i])?e[i].push(o):e[i]=[e[i],o]}return e}l(Ft,"parseQuery");function It(r,e){return(typeof e=="number"||typeof e=="boolean")&&(e=String(e)),e?Array.isArray(e)?e.map(t=>`${X(r)}=${Z(t)}`).join("&"):`${X(r)}=${Z(e)}`:X(r)}l(It,"encodeQueryItem");function Vt(r){return Object.keys(r).filter(e=>r[e]!==void 0).map(e=>It(e,r[e])).filter(Boolean).join("&")}l(Vt,"stringifyQuery");const Dt=/^[\s\w\0+.-]{2,}:([/\\]{1,2})/,Lt=/^[\s\w\0+.-]{2,}:([/\\]{2})?/,qt=/^([/\\]\s*){2,}[^/\\]/,Mt=/^\.?\//;function Ce(r,e={}){return typeof e=="boolean"&&(e={acceptRelative:e}),e.strict?Dt.test(r):Lt.test(r)||(e.acceptRelative?qt.test(r):!1)}l(Ce,"hasProtocol");function Ut(r="",e){return r.endsWith("/")}l(Ut,"hasTrailingSlash");function Wt(r="",e){return(Ut(r)?r.slice(0,-1):r)||"/"}l(Wt,"withoutTrailingSlash");function Gt(r="",e){return r.endsWith("/")?r:r+"/"}l(Gt,"withTrailingSlash");function Jt(r,e){if(Kt(e)||Ce(r))return r;const t=Wt(e);return r.startsWith(t)?r:Qt(t,r)}l(Jt,"withBase");function Bt(r,e){const t=Yt(r),n={...Ft(t.search),...e};return t.search=Vt(n),Zt(t)}l(Bt,"withQuery");function Kt(r){return!r||r==="/"}l(Kt,"isEmptyURL");function zt(r){return r&&r!=="/"}l(zt,"isNonEmptyURL");function Qt(r,...e){let t=r||"";for(const n of e.filter(i=>zt(i)))if(t){const i=n.replace(Mt,"");t=Gt(t)+i}else t=n;return t}l(Qt,"joinURL");const Ee=Symbol.for("ufo:protocolRelative");function Yt(r="",e){const t=r.match(/^[\s\0]*(blob:|data:|javascript:|vbscript:)(.*)/i);if(t){const[,p,f=""]=t;return{protocol:p.toLowerCase(),pathname:f,href:p+f,auth:"",host:"",search:"",hash:""}}if(!Ce(r,{acceptRelative:!0}))return $e(r);const[,n="",i,o=""]=r.replace(/\\/g,"/").match(/^[\s\0]*([\w+.-]{2,}:)?\/\/([^/@]+@)?(.*)/)||[];let[,a="",u=""]=o.match(/([^#/?]*)(.*)?/)||[];n==="file:"&&(u=u.replace(/\/(?=[A-Za-z]:)/,""));const{pathname:c,search:h,hash:s}=$e(u);return{protocol:n.toLowerCase(),auth:i?i.slice(0,Math.max(0,i.length-1)):"",host:a,pathname:c,search:h,hash:s,[Ee]:!n}}l(Yt,"parseURL");function $e(r=""){const[e="",t="",n=""]=(r.match(/([^#?]*)(\?[^#]*)?(#.*)?/)||[]).splice(1);return{pathname:e,search:t,hash:n}}l($e,"parsePath");function Zt(r){const e=r.pathname||"",t=r.search?(r.search.startsWith("?")?"":"?")+r.search:"",n=r.hash||"",i=r.auth?r.auth+"@":"",o=r.host||"";return(r.protocol||r[Ee]?(r.protocol||"")+"//":"")+i+o+e+t+n}l(Zt,"stringifyParsedURL");const oe=class oe extends Error{constructor(e,t){super(e,t),this.name="FetchError",t?.cause&&!this.cause&&(this.cause=t.cause)}};l(oe,"FetchError");let ee=oe;function Xt(r){const e=r.error?.message||r.error?.toString()||"",t=r.request?.method||r.options?.method||"GET",n=r.request?.url||String(r.request)||"/",i=`[${t}] ${JSON.stringify(n)}`,o=r.response?`${r.response.status} ${r.response.statusText}`:"<no response>",a=`${i}: ${o}${e?` ${e}`:""}`,u=new ee(a,r.error?{cause:r.error}:void 0);for(const c of["request","options","response"])Object.defineProperty(u,c,{get(){return r[c]}});for(const[c,h]of[["data","_data"],["status","status"],["statusCode","status"],["statusText","statusText"],["statusMessage","statusText"]])Object.defineProperty(u,c,{get(){return r.response&&r.response[h]}});return u}l(Xt,"createFetchError");const en=new Set(Object.freeze(["PATCH","POST","PUT","DELETE"]));function ve(r="GET"){return en.has(r.toUpperCase())}l(ve,"isPayloadMethod");function tn(r){if(r===void 0)return!1;const e=typeof r;return e==="string"||e==="number"||e==="boolean"||e===null?!0:e!=="object"?!1:Array.isArray(r)?!0:r.buffer?!1:r.constructor&&r.constructor.name==="Object"||typeof r.toJSON=="function"}l(tn,"isJSONSerializable");const nn=new Set(["image/svg","application/xml","application/xhtml","application/html"]),rn=/^application\/(?:[\w!#$%&*.^`~-]*\+)?json(;.+)?$/i;function on(r=""){if(!r)return"json";const e=r.split(";").shift()||"";return rn.test(e)?"json":nn.has(e)||e.startsWith("text/")?"text":"blob"}l(on,"detectResponseType");function sn(r,e,t=globalThis.Headers){const n={...e,...r};if(e?.params&&r?.params&&(n.params={...e?.params,...r?.params}),e?.query&&r?.query&&(n.query={...e?.query,...r?.query}),e?.headers&&r?.headers){n.headers=new t(e?.headers||{});for(const[i,o]of new t(r?.headers||{}))n.headers.set(i,o)}return n}l(sn,"mergeFetchOptions");const an=new Set([408,409,425,429,500,502,503,504]),cn=new Set([101,204,205,304]);function Se(r={}){const{fetch:e=globalThis.fetch,Headers:t=globalThis.Headers,AbortController:n=globalThis.AbortController}=r;async function i(u){const c=u.error&&u.error.name==="AbortError"&&!u.options.timeout||!1;if(u.options.retry!==!1&&!c){let s;typeof u.options.retry=="number"?s=u.options.retry:s=ve(u.options.method)?0:1;const p=u.response&&u.response.status||500;if(s>0&&(Array.isArray(u.options.retryStatusCodes)?u.options.retryStatusCodes.includes(p):an.has(p))){const f=u.options.retryDelay||0;return f>0&&await new Promise(y=>setTimeout(y,f)),o(u.request,{...u.options,retry:s-1})}}const h=Xt(u);throw Error.captureStackTrace&&Error.captureStackTrace(h,o),h}l(i,"onError");const o=l(async function(c,h={}){const s={request:c,options:sn(h,r.defaults,t),response:void 0,error:void 0};s.options.method=s.options.method?.toUpperCase(),s.options.onRequest&&await s.options.onRequest(s),typeof s.request=="string"&&(s.options.baseURL&&(s.request=Jt(s.request,s.options.baseURL)),(s.options.query||s.options.params)&&(s.request=Bt(s.request,{...s.options.params,...s.options.query}))),s.options.body&&ve(s.options.method)&&(tn(s.options.body)?(s.options.body=typeof s.options.body=="string"?s.options.body:JSON.stringify(s.options.body),s.options.headers=new t(s.options.headers||{}),s.options.headers.has("content-type")||s.options.headers.set("content-type","application/json"),s.options.headers.has("accept")||s.options.headers.set("accept","application/json")):("pipeTo"in s.options.body&&typeof s.options.body.pipeTo=="function"||typeof s.options.body.pipe=="function")&&("duplex"in s.options||(s.options.duplex="half")));let p;if(!s.options.signal&&s.options.timeout){const y=new n;p=setTimeout(()=>y.abort(),s.options.timeout),s.options.signal=y.signal}try{s.response=await e(s.request,s.options)}catch(y){return s.error=y,s.options.onRequestError&&await s.options.onRequestError(s),await i(s)}finally{p&&clearTimeout(p)}if(s.response.body&&!cn.has(s.response.status)&&s.options.method!=="HEAD"){const y=(s.options.parseResponse?"json":s.options.responseType)||on(s.response.headers.get("content-type")||"");switch(y){case"json":{const m=await s.response.text(),b=s.options.parseResponse||Et;s.response._data=b(m);break}case"stream":{s.response._data=s.response.body;break}default:s.response._data=await s.response[y]()}}return s.options.onResponse&&await s.options.onResponse(s),!s.options.ignoreResponseError&&s.response.status>=400&&s.response.status<600?(s.options.onResponseError&&await s.options.onResponseError(s),await i(s)):s.response},"$fetchRaw2"),a=l(async function(c,h){return(await o(c,h))._data},"$fetch2");return a.raw=o,a.native=(...u)=>e(...u),a.create=(u={})=>Se({...r,defaults:{...r.defaults,...u}}),a}l(Se,"createFetch");const te=function(){if(typeof globalThis<"u")return globalThis;if(typeof self<"u")return self;if(typeof window<"u")return window;if(typeof global<"u")return global;throw new Error("unable to locate global object")}(),ln=te.fetch||(()=>Promise.reject(new Error("[ofetch] global.fetch is not supported!"))),un=te.Headers,hn=te.AbortController,W=Se({fetch:ln,Headers:un,AbortController:hn}),pn={apiRoot:process.env.FRONTSTACK_CLI_API_ROOT||(process.env.FRONTSTACK_CLI_DEV_MODE=="1"?"https://backend.frontstack.test/":"https://backend.frontstack.dev/")},L=pn.apiRoot,fn=`${L}login`,dn=`${L}api/fetch-api/spec.yaml`,Te=3008,je=`http://localhost:${Te}`,xe=`${fn}?redirectUrl=${je}/callback`,mn=".frontstack-local/",S=g.join(process.cwd(),mn),ne="api_session.jwt",Pe="project.json",k=l(()=>{const r=l(()=>{console.info("Not auth.login implemented yet")},"login"),e=l(async()=>{try{return a(),0}catch(p){console.log(p)}},"logout"),t=l(async(p=!1)=>{try{return process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await W(`${L}profile`,{method:"GET",headers:{"Content-Type":"application/json",Authorization:`Bearer ${i()}`}})}catch(f){return p&&console.log(f),1}},"getProfile"),n=l(async p=>{try{if(p==null)throw new Error(`You have no project selected
24
- Run ${d.hex("#7c3bed")("frontstack project")} to select a frontstack project`);return process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await W(dn,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${i()}`,"FS-Project":p},parseResponse:l(y=>{try{return he.load(y)}catch{throw new Error("Invalid API specification. The API specification must be a valid YAML file.")}},"parseResponse")})}catch(f){throw"data"in f&&"message"in f.data?new Error(`Server error: ${f.data.message}`):f}},"getFetchApiSpec"),i=l(()=>{const p=g.join(S,ne);return _.existsSync(p)?_.readFileSync(p,"utf8"):null},"getToken"),o=l(p=>(_.existsSync(S)||_.mkdirSync(S),_.writeFileSync(g.join(S,ne),p),0),"writeToken"),a=l(()=>{const p=g.join(S,ne);_.existsSync(p)&&_.unlinkSync(p)},"deleteToken"),u=l(async()=>(process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await W(`${L}api/project`,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${i()}`},parseResponse:l(p=>JSON.parse(p),"parseResponse")})),"getProjects"),c=l(()=>{const p=g.join(S,Pe);if(!_.existsSync(p))return null;try{return JSON.parse(_.readFileSync(p,"utf8")).projectId}catch{console.error("[Error] Corrupt project file - please run 'frontstack project'")}},"getProjectId");return{login:r,logout:e,getProfile:t,getFetchApiSpec:n,getToken:i,writeToken:o,deleteToken:a,getProjects:u,getProject:l(async(p=void 0)=>{try{return p===void 0&&(p=c()),p===void 0?void 0:(process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await W(`${L}api/project/${p}`,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${i()}`},parseResponse:l(f=>JSON.parse(f),"parseResponse")}))}catch(f){return{error:f.message}}},"getProject"),getProjectId:c,writeProject:l(p=>(_.existsSync(S)||_.mkdirSync(S),_.writeFileSync(g.join(S,Pe),JSON.stringify({projectId:p})),0),"writeProject")}},"auth"),ke=l(()=>{const r=l(t=>{const n=g.join(t,"metadata.json");if(_.existsSync(n)){const i=_.readFileSync(n,"utf8");return JSON.parse(i)}return null},"getMetadata");return{getMetadata:r,projectGuard:l(t=>{r(t)||(console.log(`${d.hex("#FFA500")("[WARNING]")} No \`.frontstack/metadata.json\` found, run ${d.hex("#7c3bed")("frontstack generate")} to create a metadata file.`),console.log(`${d.hex("#FFA500")("[WARNING]")} Metadata files have been introduced to keep track of your generated code across multiple projects and organizations.`),console.log(`${d.hex("#FFA500")("[WARNING]")} If you only have a single project, you can ignore this message.`))},"projectGuard")}},"useMetadata"),{writeToken:gn}=k(),_n=l(async(r,e,t=!1)=>new Promise(n=>{const i=new Set,o=Be.createServer((a,u)=>{const c=je;if(a.url===void 0)return;const s=new URL(a.url,c).searchParams.get("token");s&&(u.writeHead(200,{"Content-Type":"text/html"}),u.end('<html><head><script>// window.close()<\/script></head><body style="font-family: sans-serif;"><div style="height: 100%; width: 100%; display: flex; justify-content: center; align-items: center;"><div style="text-align: center"><h1 style="color: #7c3bed;">Login Successful</h1><p>You can <a href="#" onClick="window.close()">close</a> this browser window and return to the terminal.<p style="font-size: .8rem; color: #666; text-align: left; margin-top: 20px;">&copy; 2024 frontstack</p></div></div></html>'),u.on("finish",async()=>{for(const f of i)f.destroy();gn(s)!==0?(console.error("Login failed."),o.close(),n(!1)):(console.log(`${d.hex("#008000")("[SUCCESS]")} Login successful`),o.close(),n(!0)),t&&process.exit(0)}))}).listen(r,()=>{console.log(`Please continue login in your browser at ${d.hex("#7c3bed")(e)}`)});o.on("connection",a=>{i.add(a),a.on("close",()=>i.delete(a))}),setTimeout(()=>{o.close(),n(!1)},6e4)}),"login$1"),yn={processExit:!0,skipProjectGuard:!1},Re=l(async r=>{const e=Je(r,yn);await Ke(xe),await _n(Te,xe,!1);let t=".frontstack";if(e.skipProjectGuard){const{projectGuard:n}=ke();n(t)}e?.processExit&&process.exit(0)},"login"),On=k(),bn=l(async r=>{await On.logout()!==0&&(console.error("Logout failed."),process.exit(1)),console.log("Logout successful."),process.exit(0)},"logout"),{getFetchApiSpec:wn}=k();$.registerHelper("eq",function(r,e){return r===e}),$.registerHelper("uc",function(r){return r.toUpperCase()}),$.registerHelper("and",function(r,e){return r&&e}),$.registerHelper("contains",function(r,e){return r===void 0?!1:r.includes(e)}),$.registerHelper("endsWith",function(r,e){return r===void 0?!1:r.endsWith(e)}),$.registerHelper("blockNameFromOperationId",function(r){return r.replace("get","").replace("Block","")});const ie=l(r=>r.$ref?`components['schemas']['${r.$ref.split("/").pop()}']`:r.type==="array"?`Array<${ie(r.items)}>`:r.type==="object"?`{ ${Object.keys(r.properties).map(t=>`${t}: ${ie(r.properties[t])}`).join("; ")} }`:r.type,"getSchemaType");$.registerHelper("getSchemaType",r=>ie(r)),$.registerHelper("stringInArray",function(r,e,t){return e==null||e.length===0?!1:t.fn?e.indexOf(r)>-1?t.fn(this):t.inverse(this):e.indexOf(r)>-1}),$.registerHelper("log",function(r){console.log(r)});var An=l(async r=>{const e=g.dirname(new URL(import.meta.url).pathname),t=g.join(e,"src/commands/generate/templates"),n=g.join(t,"types.js.hbs"),i=_.readFileSync(n,"utf8"),o=$.compile(i),a=g.join(t,"client.js.hbs"),u=_.readFileSync(a,"utf8"),c=$.compile(u),h=g.join(t,"query.js.hbs"),s=_.readFileSync(h,"utf8");let p;if(p=await wn(r),p.error)throw new Error(`Issue fetching API specification. Check more information below.
25
- `+p.error);let f="";try{f=await ze(p)}catch(b){throw new Error(`Invalid API Specification: ${b.message}`)}const y=o({paths:p.paths,components:p.components}),m=c({components:p.components,paths:p.paths,servers:p.servers});return{_schemaTypes:f,_types:y,_client:m,_query:s,_specFile:p}},"generate");const{getProjects:Cn,writeProject:He}=k(),Ne=l(async r=>{let e=r.project??void 0,t=[];try{t=await Cn()}catch{console.log(`You are not logged in. Please run ${d.hex("#7c3bed")("frontstack login")} to login`);return}if(t.length<1){console.log("No projects found. Please create a new project in your Admin dashboard");return}if(e!==void 0){const o=t.find(a=>a.id===e);if(o){console.log(`Project ${d.hex("#7c3bed")(o.name)} selected`),He(o.id);return}else{console.log(`Project with ID "${e}" not found. Please select a valid project ID`);return}}const n={type:"select",name:"projectId",message:"Pick a project (Use arrow keys and Enter)",choices:t.map(o=>({title:(o.id===e?"(\u2714) ":"")+`${o.name}`,value:o.id}))};async function i(){const o=await M(n),a=t.find(u=>u.id===o.projectId);if(a===void 0){console.log(`Project with ID "${o.projectId}" not found. Please select a valid project ID`);return}console.log(`Project ${d.hex("#7c3bed")(a.name)} selected`),He(o.projectId)}l(i,"getProject"),await i()},"project"),En=l(async r=>{const e=r.verbose||!1,t=r.persistOas||!1,{getProject:n,getProfile:i,getProjects:o,writeProject:a}=k(),u=await i(e);if(!u||u===1){console.info("User not logged in"),await Re({processExit:!1,skipProjectGuard:!0});const w=await i();(!w||w===1)&&(console.info(`${d.hex("#b90404")("[ERROR]")} Login failed`),process.exit(1))}let c=r.output||".frontstack",h=await n();(!h||"error"in h)&&(console.info("No project selected"),console.info("Running project selection..."),await Ne({}));const{getMetadata:s}=ke(),p=s(c);if(h=await n(),!h||"error"in h){console.info(`${d.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${d.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`);return}if(p&&p.project.id!==h.id){const C=(await o()).find(G=>G.id===p.project.id),E=[];C&&E.push({title:`Switch to project ${d.hex("#7c3bed")(p.project.name)} and generate client`,value:"switch"}),E.push({title:`Overwrite client with project ${d.hex("#7c3bed")(h.name)}`,value:"overwrite"}),E.push({title:"Cancel",value:"cancel"}),console.log(`${d.hex("#FFA500")("[WARNING]")} Client mismatch detected`),console.log(`${d.hex("#FFA500")("[WARNING]")} The client in ${d.hex("#7c3bed")(c)} was generated for project ${d.hex("#7c3bed")(p.project.name)}.`),console.log(`${d.hex("#FFA500")("[WARNING]")} The selected project is ${d.hex("#7c3bed")(h.name)}.
26
- `);const De={type:"select",name:"action",message:"How would you like to proceed?",choices:E},{action:q}=await M(De);if(q==="cancel"){console.info("Generation cancelled.");return}if(q==="switch"&&C&&(a(C.id),h=C,console.info(`Switched to project ${d.hex("#7c3bed")(h.name)}.`)),q==="overwrite"){const G={type:"text",name:"confirmation",message:'This is a destructive action and will overwrite the existing client. Type "confirm" to proceed.'},{confirmation:Le}=await M(G);if(Le!=="confirm"){console.info("Generation cancelled.");return}console.info(`Proceeding to generate client for project ${d.hex("#7c3bed")(h.name)}.`)}if(!q){console.info("Generation cancelled.");return}}let f=h;if(!h||"error"in h){console.info(`${d.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${d.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`);return}if(r.env&&h.environments.length>0){let w;if(r.env!=="develop"){if(w=h.environments.find(C=>C.environment===r.env),!w){console.info(`${d.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${d.hex("#b90404")("[ERROR]")} Environment ${r.env} not found`);return}f=w}}if(!r.env&&h.environments.length>0){const w={type:"select",name:"projectId",message:"Pick an environment (use arrow keys and enter)",choices:[{title:`${h.name} (${h.environment})`,value:h.id},...h.environments.map(E=>({title:(E.id===f?.id?"(\u2714) ":"")+`${E.name} (${E.environment})`,value:E.id}))]},C=await M(w);f=h.environments.find(E=>E.id===C.projectId)??h}let y,m,b,x,se;try{e&&console.log("Generating Javascript client"),{_schemaTypes:y,_types:m,_client:b,_query:x,_specFile:se}=await An(f.id)}catch(w){console.info(`${d.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${d.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`),e?console.info(`${d.hex("#b90404")("[ERROR]")} ${w.message}`):(console.info("Are you..."),console.info(` * logged in using the ${d.hex("#7c3bed")("frontstack login")} command?`),console.info(" * connected to the internet?"),console.info(`Alternatively, run ${d.hex("#7c3bed")("frontstack generate -v")} for additional output.`));return}process.stdout.write("Generating Javascript client"),c.startsWith("/")||(c=g.join(process.cwd(),c)),c.endsWith("/")||(c+="/");const ae=g.join(c,"fetch-api.d.ts"),ce=g.join(c,"generated-types.d.ts"),le=g.join(c,"generated-client.ts"),Ie=g.join(c,"query-types.ts"),ue=g.join(c,"metadata.json"),Ve={project:{id:f.id,name:f.name}};if(e&&(console.log(`
27
- Schema types path: ${d.dim(ae)}`),console.log(`Types path: ${d.dim(ce)}`),console.log(`Client path: ${d.dim(le)}`),console.log(`Target directory: ${d.dim(c)}`),console.log(`Metadata path: ${d.dim(ue)}`)),_.mkdirSync(c,{recursive:!0}),t){const w=he.dump(se,{indent:2}),C=g.join(c,"fetch-api.spec.yaml");console.log(`
28
- Persisting OpenAPI Specification file in ${C}`),_.writeFileSync(g.join(C),w)}_.writeFileSync(g.join(ae),y),_.writeFileSync(g.join(ce),m),_.writeFileSync(g.join(le),b),_.writeFileSync(g.join(Ie),x),_.writeFileSync(g.join(ue),JSON.stringify(Ve,null,2)),e?console.log(`Javascript client generated for ${d.hex("#7c3bed")(`${f.name} (${f.environment})`)}`):(process.stdout.clearLine(0),process.stdout.cursorTo(0),process.stdout.write(d.green(`Javascript client generated for ${d.hex("#7c3bed")(`${f.name} (${f.environment})`)}
20
+ `),this.outputHelp({error:!0}));const n=t||{},r=n.exitCode||1,i=n.code||"commander.error";this._exit(r,i,e)}_parseOptionsEnv(){this.options.forEach(e=>{if(e.envVar&&e.envVar in O.env){const t=e.attributeName();(this.getOptionValue(t)===void 0||["default","config","env"].includes(this.getOptionValueSource(t)))&&(e.required||e.optional?this.emit(`optionEnv:${e.name()}`,O.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){const e=new wt(this.options),t=l(n=>this.getOptionValue(n)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(n)),"hasCustomOptionValue");this.options.filter(n=>n.implied!==void 0&&t(n.attributeName())&&e.valueFromOption(this.getOptionValue(n.attributeName()),n)).forEach(n=>{Object.keys(n.implied).filter(r=>!t(r)).forEach(r=>{this.setOptionValueWithSource(r,n.implied[r],"implied")})})}missingArgument(e){const t=`error: missing required argument '${e}'`;this.error(t,{code:"commander.missingArgument"})}optionMissingArgument(e){const t=`error: option '${e.flags}' argument missing`;this.error(t,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue(e){const t=`error: required option '${e.flags}' not specified`;this.error(t,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption(e,t){const n=l(a=>{const u=a.attributeName(),c=this.getOptionValue(u),h=this.options.find(p=>p.negate&&u===p.attributeName()),s=this.options.find(p=>!p.negate&&u===p.attributeName());return h&&(h.presetArg===void 0&&c===!1||h.presetArg!==void 0&&c===h.presetArg)?h:s||a},"findBestOptionFromValue"),r=l(a=>{const u=n(a),c=u.attributeName();return this.getOptionValueSource(c)==="env"?`environment variable '${u.envVar}'`:`option '${u.flags}'`},"getErrorMessage"),i=`error: ${r(e)} cannot be used with ${r(t)}`;this.error(i,{code:"commander.conflictingOption"})}unknownOption(e){if(this._allowUnknownOption)return;let t="";if(e.startsWith("--")&&this._showSuggestionAfterError){let r=[],i=this;do{const a=i.createHelp().visibleOptions(i).filter(u=>u.long).map(u=>u.long);r=r.concat(a),i=i.parent}while(i&&!i._enablePositionalOptions);t=we(e,r)}const n=`error: unknown option '${e}'${t}`;this.error(n,{code:"commander.unknownOption"})}_excessArguments(e){if(this._allowExcessArguments)return;const t=this.registeredArguments.length,n=t===1?"":"s",i=`error: too many arguments${this.parent?` for '${this.name()}'`:""}. Expected ${t} argument${n} but got ${e.length}.`;this.error(i,{code:"commander.excessArguments"})}unknownCommand(){const e=this.args[0];let t="";if(this._showSuggestionAfterError){const r=[];this.createHelp().visibleCommands(this).forEach(i=>{r.push(i.name()),i.alias()&&r.push(i.alias())}),t=we(e,r)}const n=`error: unknown command '${e}'${t}`;this.error(n,{code:"commander.unknownCommand"})}version(e,t,n){if(e===void 0)return this._version;this._version=e,t=t||"-V, --version",n=n||"output the version number";const r=this.createOption(t,n);return this._versionOptionName=r.attributeName(),this._registerOption(r),this.on("option:"+r.name(),()=>{this._outputConfiguration.writeOut(`${e}
21
+ `),this._exit(0,"commander.version",e)}),this}description(e,t){return e===void 0&&t===void 0?this._description:(this._description=e,t&&(this._argsDescription=t),this)}summary(e){return e===void 0?this._summary:(this._summary=e,this)}alias(e){if(e===void 0)return this._aliases[0];let t=this;if(this.commands.length!==0&&this.commands[this.commands.length-1]._executableHandler&&(t=this.commands[this.commands.length-1]),e===t._name)throw new Error("Command alias can't be the same as its name");const n=this.parent?._findCommand(e);if(n){const r=[n.name()].concat(n.aliases()).join("|");throw new Error(`cannot add alias '${e}' to command '${this.name()}' as already have command '${r}'`)}return t._aliases.push(e),this}aliases(e){return e===void 0?this._aliases:(e.forEach(t=>this.alias(t)),this)}usage(e){if(e===void 0){if(this._usage)return this._usage;const t=this.registeredArguments.map(n=>Ot(n));return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?t:[]).join(" ")}return this._usage=e,this}name(e){return e===void 0?this._name:(this._name=e,this)}nameFromFilename(e){return this._name=v.basename(e,v.extname(e)),this}executableDir(e){return e===void 0?this._executableDir:(this._executableDir=e,this)}helpInformation(e){const t=this.createHelp();return t.helpWidth===void 0&&(t.helpWidth=e&&e.error?this._outputConfiguration.getErrHelpWidth():this._outputConfiguration.getOutHelpWidth()),t.formatHelp(this,t)}_getHelpContext(e){e=e||{};const t={error:!!e.error};let n;return t.error?n=l(r=>this._outputConfiguration.writeErr(r),"write"):n=l(r=>this._outputConfiguration.writeOut(r),"write"),t.write=e.write||n,t.command=this,t}outputHelp(e){let t;typeof e=="function"&&(t=e,e=void 0);const n=this._getHelpContext(e);this._getCommandAndAncestors().reverse().forEach(i=>i.emit("beforeAllHelp",n)),this.emit("beforeHelp",n);let r=this.helpInformation(n);if(t&&(r=t(r),typeof r!="string"&&!Buffer.isBuffer(r)))throw new Error("outputHelp callback must return a string or a Buffer");n.write(r),this._getHelpOption()?.long&&this.emit(this._getHelpOption().long),this.emit("afterHelp",n),this._getCommandAndAncestors().forEach(i=>i.emit("afterAllHelp",n))}helpOption(e,t){return typeof e=="boolean"?(e?this._helpOption=this._helpOption??void 0:this._helpOption=null,this):(e=e??"-h, --help",t=t??"display help for command",this._helpOption=this.createOption(e,t),this)}_getHelpOption(){return this._helpOption===void 0&&this.helpOption(void 0,void 0),this._helpOption}addHelpOption(e){return this._helpOption=e,this}help(e){this.outputHelp(e);let t=O.exitCode||0;t===0&&e&&typeof e!="function"&&e.error&&(t=1),this._exit(t,"commander.help","(outputHelp)")}addHelpText(e,t){const n=["beforeAll","before","after","afterAll"];if(!n.includes(e))throw new Error(`Unexpected value for position to addHelpText.
22
+ Expecting one of '${n.join("', '")}'`);const r=`${e}Help`;return this.on(r,i=>{let a;typeof t=="function"?a=t({error:i.error,command:i.command}):a=t,a&&i.write(`${a}
23
+ `)}),this}_outputHelpIfRequested(e){const t=this._getHelpOption();t&&e.find(r=>t.is(r))&&(this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)"))}},l(T,"Command"),T);function Ae(o){return o.map(e=>{if(!e.startsWith("--inspect"))return e;let t,n="127.0.0.1",r="9229",i;return(i=e.match(/^(--inspect(-brk)?)$/))!==null?t=i[1]:(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null?(t=i[1],/^\d+$/.test(i[3])?r=i[3]:n=i[3]):(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null&&(t=i[1],n=i[3],r=i[4]),t&&r!=="0"?`${t}=${n}:${parseInt(r)+1}`:e})}l(Ae,"incrementNodeInspectorPort"),_e.Command=At;const{Argument:Ce}=D,{Command:X}=_e,{CommanderError:Ct,InvalidArgumentError:Ee}=k,{Help:Et}=z,{Option:$e}=W;A.program=new X,A.createCommand=o=>new X(o),A.createOption=(o,e)=>new $e(o,e),A.createArgument=(o,e)=>new Ce(o,e),A.Command=X,A.Option=$e,A.Argument=Ce,A.Help=Et,A.CommanderError=Ct,A.InvalidArgumentError=Ee,A.InvalidOptionArgumentError=Ee;const{program:lo,createCommand:uo,createArgument:ho,createOption:po,CommanderError:fo,InvalidArgumentError:mo,InvalidOptionArgumentError:go,Command:$t,Argument:_o,Option:yo,Help:Oo}=A,vt=/"(?:_|\\u0{2}5[Ff]){2}(?:p|\\u0{2}70)(?:r|\\u0{2}72)(?:o|\\u0{2}6[Ff])(?:t|\\u0{2}74)(?:o|\\u0{2}6[Ff])(?:_|\\u0{2}5[Ff]){2}"\s*:/,St=/"(?:c|\\u0063)(?:o|\\u006[Ff])(?:n|\\u006[Ee])(?:s|\\u0073)(?:t|\\u0074)(?:r|\\u0072)(?:u|\\u0075)(?:c|\\u0063)(?:t|\\u0074)(?:o|\\u006[Ff])(?:r|\\u0072)"\s*:/,jt=/^\s*["[{]|^\s*-?\d{1,16}(\.\d{1,17})?([Ee][+-]?\d+)?\s*$/;function Tt(o,e){if(o==="__proto__"||o==="constructor"&&e&&typeof e=="object"&&"prototype"in e){xt(o);return}return e}l(Tt,"jsonParseTransform");function xt(o){console.warn(`[destr] Dropping "${o}" key to prevent prototype pollution.`)}l(xt,"warnKeyDropped");function kt(o,e={}){if(typeof o!="string")return o;const t=o.trim();if(o[0]==='"'&&o.endsWith('"')&&!o.includes("\\"))return t.slice(1,-1);if(t.length<=9){const n=t.toLowerCase();if(n==="true")return!0;if(n==="false")return!1;if(n==="undefined")return;if(n==="null")return null;if(n==="nan")return Number.NaN;if(n==="infinity")return Number.POSITIVE_INFINITY;if(n==="-infinity")return Number.NEGATIVE_INFINITY}if(!jt.test(o)){if(e.strict)throw new SyntaxError("[destr] Invalid JSON");return o}try{if(vt.test(o)||St.test(o)){if(e.strict)throw new Error("[destr] Possible prototype pollution");return JSON.parse(o,Tt)}return JSON.parse(o)}catch(n){if(e.strict)throw n;return o}}l(kt,"destr");const Pt=/#/g,Rt=/&/g,Ht=/\//g,Nt=/=/g,ee=/\+/g,It=/%5e/gi,Ft=/%60/gi,Vt=/%7c/gi,Dt=/%20/gi;function Lt(o){return encodeURI(""+o).replace(Vt,"|")}l(Lt,"encode");function te(o){return Lt(typeof o=="string"?o:JSON.stringify(o)).replace(ee,"%2B").replace(Dt,"+").replace(Pt,"%23").replace(Rt,"%26").replace(Ft,"`").replace(It,"^").replace(Ht,"%2F")}l(te,"encodeQueryValue");function ne(o){return te(o).replace(Nt,"%3D")}l(ne,"encodeQueryKey");function ve(o=""){try{return decodeURIComponent(""+o)}catch{return""+o}}l(ve,"decode");function qt(o){return ve(o.replace(ee," "))}l(qt,"decodeQueryKey");function Mt(o){return ve(o.replace(ee," "))}l(Mt,"decodeQueryValue");function Ut(o=""){const e={};o[0]==="?"&&(o=o.slice(1));for(const t of o.split("&")){const n=t.match(/([^=]+)=?(.*)/)||[];if(n.length<2)continue;const r=qt(n[1]);if(r==="__proto__"||r==="constructor")continue;const i=Mt(n[2]||"");e[r]===void 0?e[r]=i:Array.isArray(e[r])?e[r].push(i):e[r]=[e[r],i]}return e}l(Ut,"parseQuery");function Wt(o,e){return(typeof e=="number"||typeof e=="boolean")&&(e=String(e)),e?Array.isArray(e)?e.map(t=>`${ne(o)}=${te(t)}`).join("&"):`${ne(o)}=${te(e)}`:ne(o)}l(Wt,"encodeQueryItem");function Gt(o){return Object.keys(o).filter(e=>o[e]!==void 0).map(e=>Wt(e,o[e])).filter(Boolean).join("&")}l(Gt,"stringifyQuery");const Jt=/^[\s\w\0+.-]{2,}:([/\\]{1,2})/,Bt=/^[\s\w\0+.-]{2,}:([/\\]{2})?/,Kt=/^([/\\]\s*){2,}[^/\\]/,zt=/^\.?\//;function Se(o,e={}){return typeof e=="boolean"&&(e={acceptRelative:e}),e.strict?Jt.test(o):Bt.test(o)||(e.acceptRelative?Kt.test(o):!1)}l(Se,"hasProtocol");function Qt(o="",e){return o.endsWith("/")}l(Qt,"hasTrailingSlash");function Yt(o="",e){return(Qt(o)?o.slice(0,-1):o)||"/"}l(Yt,"withoutTrailingSlash");function Zt(o="",e){return o.endsWith("/")?o:o+"/"}l(Zt,"withTrailingSlash");function Xt(o,e){if(tn(e)||Se(o))return o;const t=Yt(e);return o.startsWith(t)?o:on(t,o)}l(Xt,"withBase");function en(o,e){const t=rn(o),n={...Ut(t.search),...e};return t.search=Gt(n),sn(t)}l(en,"withQuery");function tn(o){return!o||o==="/"}l(tn,"isEmptyURL");function nn(o){return o&&o!=="/"}l(nn,"isNonEmptyURL");function on(o,...e){let t=o||"";for(const n of e.filter(r=>nn(r)))if(t){const r=n.replace(zt,"");t=Zt(t)+r}else t=n;return t}l(on,"joinURL");const je=Symbol.for("ufo:protocolRelative");function rn(o="",e){const t=o.match(/^[\s\0]*(blob:|data:|javascript:|vbscript:)(.*)/i);if(t){const[,p,d=""]=t;return{protocol:p.toLowerCase(),pathname:d,href:p+d,auth:"",host:"",search:"",hash:""}}if(!Se(o,{acceptRelative:!0}))return Te(o);const[,n="",r,i=""]=o.replace(/\\/g,"/").match(/^[\s\0]*([\w+.-]{2,}:)?\/\/([^/@]+@)?(.*)/)||[];let[,a="",u=""]=i.match(/([^#/?]*)(.*)?/)||[];n==="file:"&&(u=u.replace(/\/(?=[A-Za-z]:)/,""));const{pathname:c,search:h,hash:s}=Te(u);return{protocol:n.toLowerCase(),auth:r?r.slice(0,Math.max(0,r.length-1)):"",host:a,pathname:c,search:h,hash:s,[je]:!n}}l(rn,"parseURL");function Te(o=""){const[e="",t="",n=""]=(o.match(/([^#?]*)(\?[^#]*)?(#.*)?/)||[]).splice(1);return{pathname:e,search:t,hash:n}}l(Te,"parsePath");function sn(o){const e=o.pathname||"",t=o.search?(o.search.startsWith("?")?"":"?")+o.search:"",n=o.hash||"",r=o.auth?o.auth+"@":"",i=o.host||"";return(o.protocol||o[je]?(o.protocol||"")+"//":"")+r+i+e+t+n}l(sn,"stringifyParsedURL");const ae=class ae extends Error{constructor(e,t){super(e,t),this.name="FetchError",t?.cause&&!this.cause&&(this.cause=t.cause)}};l(ae,"FetchError");let oe=ae;function an(o){const e=o.error?.message||o.error?.toString()||"",t=o.request?.method||o.options?.method||"GET",n=o.request?.url||String(o.request)||"/",r=`[${t}] ${JSON.stringify(n)}`,i=o.response?`${o.response.status} ${o.response.statusText}`:"<no response>",a=`${r}: ${i}${e?` ${e}`:""}`,u=new oe(a,o.error?{cause:o.error}:void 0);for(const c of["request","options","response"])Object.defineProperty(u,c,{get(){return o[c]}});for(const[c,h]of[["data","_data"],["status","status"],["statusCode","status"],["statusText","statusText"],["statusMessage","statusText"]])Object.defineProperty(u,c,{get(){return o.response&&o.response[h]}});return u}l(an,"createFetchError");const cn=new Set(Object.freeze(["PATCH","POST","PUT","DELETE"]));function xe(o="GET"){return cn.has(o.toUpperCase())}l(xe,"isPayloadMethod");function ln(o){if(o===void 0)return!1;const e=typeof o;return e==="string"||e==="number"||e==="boolean"||e===null?!0:e!=="object"?!1:Array.isArray(o)?!0:o.buffer?!1:o.constructor&&o.constructor.name==="Object"||typeof o.toJSON=="function"}l(ln,"isJSONSerializable");const un=new Set(["image/svg","application/xml","application/xhtml","application/html"]),hn=/^application\/(?:[\w!#$%&*.^`~-]*\+)?json(;.+)?$/i;function pn(o=""){if(!o)return"json";const e=o.split(";").shift()||"";return hn.test(e)?"json":un.has(e)||e.startsWith("text/")?"text":"blob"}l(pn,"detectResponseType");function fn(o,e,t=globalThis.Headers){const n={...e,...o};if(e?.params&&o?.params&&(n.params={...e?.params,...o?.params}),e?.query&&o?.query&&(n.query={...e?.query,...o?.query}),e?.headers&&o?.headers){n.headers=new t(e?.headers||{});for(const[r,i]of new t(o?.headers||{}))n.headers.set(r,i)}return n}l(fn,"mergeFetchOptions");const dn=new Set([408,409,425,429,500,502,503,504]),mn=new Set([101,204,205,304]);function ke(o={}){const{fetch:e=globalThis.fetch,Headers:t=globalThis.Headers,AbortController:n=globalThis.AbortController}=o;async function r(u){const c=u.error&&u.error.name==="AbortError"&&!u.options.timeout||!1;if(u.options.retry!==!1&&!c){let s;typeof u.options.retry=="number"?s=u.options.retry:s=xe(u.options.method)?0:1;const p=u.response&&u.response.status||500;if(s>0&&(Array.isArray(u.options.retryStatusCodes)?u.options.retryStatusCodes.includes(p):dn.has(p))){const d=u.options.retryDelay||0;return d>0&&await new Promise(y=>setTimeout(y,d)),i(u.request,{...u.options,retry:s-1})}}const h=an(u);throw Error.captureStackTrace&&Error.captureStackTrace(h,i),h}l(r,"onError");const i=l(async function(c,h={}){const s={request:c,options:fn(h,o.defaults,t),response:void 0,error:void 0};s.options.method=s.options.method?.toUpperCase(),s.options.onRequest&&await s.options.onRequest(s),typeof s.request=="string"&&(s.options.baseURL&&(s.request=Xt(s.request,s.options.baseURL)),(s.options.query||s.options.params)&&(s.request=en(s.request,{...s.options.params,...s.options.query}))),s.options.body&&xe(s.options.method)&&(ln(s.options.body)?(s.options.body=typeof s.options.body=="string"?s.options.body:JSON.stringify(s.options.body),s.options.headers=new t(s.options.headers||{}),s.options.headers.has("content-type")||s.options.headers.set("content-type","application/json"),s.options.headers.has("accept")||s.options.headers.set("accept","application/json")):("pipeTo"in s.options.body&&typeof s.options.body.pipeTo=="function"||typeof s.options.body.pipe=="function")&&("duplex"in s.options||(s.options.duplex="half")));let p;if(!s.options.signal&&s.options.timeout){const y=new n;p=setTimeout(()=>y.abort(),s.options.timeout),s.options.signal=y.signal}try{s.response=await e(s.request,s.options)}catch(y){return s.error=y,s.options.onRequestError&&await s.options.onRequestError(s),await r(s)}finally{p&&clearTimeout(p)}if(s.response.body&&!mn.has(s.response.status)&&s.options.method!=="HEAD"){const y=(s.options.parseResponse?"json":s.options.responseType)||pn(s.response.headers.get("content-type")||"");switch(y){case"json":{const m=await s.response.text(),b=s.options.parseResponse||kt;s.response._data=b(m);break}case"stream":{s.response._data=s.response.body;break}default:s.response._data=await s.response[y]()}}return s.options.onResponse&&await s.options.onResponse(s),!s.options.ignoreResponseError&&s.response.status>=400&&s.response.status<600?(s.options.onResponseError&&await s.options.onResponseError(s),await r(s)):s.response},"$fetchRaw2"),a=l(async function(c,h){return(await i(c,h))._data},"$fetch2");return a.raw=i,a.native=(...u)=>e(...u),a.create=(u={})=>ke({...o,defaults:{...o.defaults,...u}}),a}l(ke,"createFetch");const re=function(){if(typeof globalThis<"u")return globalThis;if(typeof self<"u")return self;if(typeof window<"u")return window;if(typeof global<"u")return global;throw new Error("unable to locate global object")}(),gn=re.fetch||(()=>Promise.reject(new Error("[ofetch] global.fetch is not supported!"))),_n=re.Headers,yn=re.AbortController,L=ke({fetch:gn,Headers:_n,AbortController:yn}),On={apiRoot:process.env.FRONTSTACK_CLI_API_ROOT||(process.env.FRONTSTACK_CLI_DEV_MODE=="1"?"https://backend.frontstack.test/":"https://backend.frontstack.dev/")},q=On.apiRoot,bn=`${q}login`,wn=`${q}api/fetch-api/spec.yaml`,Pe=3008,Re=`http://localhost:${Pe}`,He=`${bn}?redirectUrl=${Re}/callback`,An=".frontstack-local/",S=g.join(process.cwd(),An),ie="api_session.jwt",Ne="project.json",P=l(()=>{const o=l(()=>{console.info("Not auth.login implemented yet")},"login"),e=l(async()=>{try{return a(),0}catch(p){console.log(p)}},"logout"),t=l(async(p=!1)=>{try{return process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await L(`${q}profile`,{method:"GET",headers:{"Content-Type":"application/json",Authorization:`Bearer ${r()}`}})}catch(d){return p&&console.log(d),1}},"getProfile"),n=l(async p=>{try{if(p==null)throw new Error(`You have no project selected
24
+ Run ${f.hex("#7c3bed")("frontstack project")} to select a frontstack project`);return process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await L(wn,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${r()}`,"FS-Project":p},parseResponse:l(y=>{try{return me.load(y)}catch{throw new Error("Invalid API specification. The API specification must be a valid YAML file.")}},"parseResponse")})}catch(d){throw"data"in d&&"message"in d.data?new Error(`Server error: ${d.data.message}`):d}},"getFetchApiSpec"),r=l(()=>{const p=g.join(S,ie);return _.existsSync(p)?_.readFileSync(p,"utf8"):null},"getToken"),i=l(p=>(_.existsSync(S)||_.mkdirSync(S),_.writeFileSync(g.join(S,ie),p),0),"writeToken"),a=l(()=>{const p=g.join(S,ie);_.existsSync(p)&&_.unlinkSync(p)},"deleteToken"),u=l(async()=>(process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await L(`${q}api/project`,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${r()}`},parseResponse:l(p=>JSON.parse(p),"parseResponse")})),"getProjects"),c=l(()=>{const p=g.join(S,Ne);if(!_.existsSync(p))return null;try{return JSON.parse(_.readFileSync(p,"utf8")).projectId}catch{console.error("[Error] Corrupt project file - please run 'frontstack project'")}},"getProjectId");return{login:o,logout:e,getProfile:t,getFetchApiSpec:n,getToken:r,writeToken:i,deleteToken:a,getProjects:u,getProject:l(async(p=void 0)=>{try{return p===void 0&&(p=c()),p===void 0?void 0:(process.env.NODE_TLS_REJECT_UNAUTHORIZED=process.env.FRONTSTACK_CLI_DEV_MODE?"0":"1",await L(`${q}api/project/${p}`,{method:"GET",headers:{"Content-Type":"application/yaml",Authorization:`Bearer ${r()}`},parseResponse:l(d=>JSON.parse(d),"parseResponse")}))}catch(d){return{error:d.message}}},"getProject"),getProjectId:c,writeProject:l(p=>(_.existsSync(S)||_.mkdirSync(S),_.writeFileSync(g.join(S,Ne),JSON.stringify({projectId:p})),0),"writeProject")}},"auth"),Ie=l(()=>{const o=l(t=>{const n=g.join(t,"metadata.json");if(_.existsSync(n)){const r=_.readFileSync(n,"utf8");return JSON.parse(r)}return null},"getMetadata");return{getMetadata:o,projectGuard:l(t=>{o(t)||(console.log(`${f.hex("#FFA500")("[WARNING]")} No \`${t}/metadata.json\` found, run ${f.hex("#7c3bed")("frontstack generate")} to create a metadata file.`),console.log(`${f.hex("#FFA500")("[WARNING]")} Metadata files have been introduced to keep track of your generated code across multiple projects and organizations.`),console.log(`${f.hex("#FFA500")("[WARNING]")} If you only have a single project, you can ignore this message.`))},"projectGuard")}},"useMetadata"),{writeToken:Cn}=P(),En=l(async(o,e,t=!1)=>new Promise(n=>{const r=new Set,i=et.createServer((a,u)=>{const c=Re;if(a.url===void 0)return;const s=new URL(a.url,c).searchParams.get("token");s&&(u.writeHead(200,{"Content-Type":"text/html"}),u.end('<html><head><script>// window.close()<\/script></head><body style="font-family: sans-serif;"><div style="height: 100%; width: 100%; display: flex; justify-content: center; align-items: center;"><div style="text-align: center"><h1 style="color: #7c3bed;">Login Successful</h1><p>You can <a href="#" onClick="window.close()">close</a> this browser window and return to the terminal.<p style="font-size: .8rem; color: #666; text-align: left; margin-top: 20px;">&copy; 2024 frontstack</p></div></div></html>'),u.on("finish",async()=>{for(const d of r)d.destroy();Cn(s)!==0?(console.error("Login failed."),i.close(),n(!1)):(console.log(`${f.hex("#008000")("[SUCCESS]")} Login successful`),i.close(),n(!0)),t&&process.exit(0)}))}).listen(o,()=>{console.log(`Please continue login in your browser at ${f.hex("#7c3bed")(e)}`)});i.on("connection",a=>{r.add(a),a.on("close",()=>r.delete(a))}),setTimeout(()=>{i.close(),n(!1)},6e4)}),"login$1"),$n={processExit:!0,skipProjectGuard:!1},Fe=l(async o=>{const e=Xe(o,$n);await tt(He),await En(Pe,He,!1);let t=".frontstack";if(e.skipProjectGuard){const{projectGuard:n}=Ie();n(t)}e?.processExit&&process.exit(0)},"login"),vn=P(),Sn=l(async o=>{await vn.logout()!==0&&(console.error("Logout failed."),process.exit(1)),console.log("Logout successful."),process.exit(0)},"logout"),{getFetchApiSpec:jn}=P();$.registerHelper("eq",function(o,e){return o===e}),$.registerHelper("uc",function(o){return o.toUpperCase()}),$.registerHelper("and",function(o,e){return o&&e}),$.registerHelper("contains",function(o,e){return o===void 0?!1:o.includes(e)}),$.registerHelper("endsWith",function(o,e){return o===void 0?!1:o.endsWith(e)}),$.registerHelper("blockNameFromOperationId",function(o){return o.replace("get","").replace("Block","")});const se=l(o=>o.$ref?`components['schemas']['${o.$ref.split("/").pop()}']`:o.type==="array"?`Array<${se(o.items)}>`:o.type==="object"?`{ ${Object.keys(o.properties).map(t=>`${t}: ${se(o.properties[t])}`).join("; ")} }`:o.type,"getSchemaType");$.registerHelper("getSchemaType",o=>se(o)),$.registerHelper("stringInArray",function(o,e,t){return e==null||e.length===0?!1:t.fn?e.indexOf(o)>-1?t.fn(this):t.inverse(this):e.indexOf(o)>-1}),$.registerHelper("log",function(o){console.log(o)});var Tn=l(async o=>{const e=g.dirname(new URL(import.meta.url).pathname),t=g.join(e,"src/commands/generate/templates"),n=g.join(t,"types.js.hbs"),r=_.readFileSync(n,"utf8"),i=$.compile(r),a=g.join(t,"client.js.hbs"),u=_.readFileSync(a,"utf8"),c=$.compile(u),h=g.join(t,"query.js.hbs"),s=_.readFileSync(h,"utf8");let p;if(p=await jn(o),p.error)throw new Error(`Issue fetching API specification. Check more information below.
25
+ `+p.error);let d="";try{d=await nt(p)}catch(b){throw new Error(`Invalid API Specification: ${b.message}`)}const y=i({paths:p.paths,components:p.components}),m=c({components:p.components,paths:p.paths,servers:p.servers});return{_schemaTypes:d,_types:y,_client:m,_query:s,_specFile:p}},"generate");const{getProjects:xn,writeProject:Ve}=P(),De=l(async o=>{let e=o.project??void 0,t=[];try{t=await xn()}catch{console.log(`You are not logged in. Please run ${f.hex("#7c3bed")("frontstack login")} to login`);return}if(t.length<1){console.log("No projects found. Please create a new project in your Admin dashboard");return}if(e!==void 0){const i=t.find(a=>a.id===e);if(i){console.log(`Project ${f.hex("#7c3bed")(i.name)} selected`),Ve(i.id);return}else{console.log(`Project with ID "${e}" not found. Please select a valid project ID`);return}}const n={type:"select",name:"projectId",message:"Pick a project (Use arrow keys and Enter)",choices:t.map(i=>({title:(i.id===e?"(\u2714) ":"")+`${i.name}`,value:i.id}))};async function r(){const i=await U(n),a=t.find(u=>u.id===i.projectId);if(a===void 0){console.log(`Project with ID "${i.projectId}" not found. Please select a valid project ID`);return}console.log(`Project ${f.hex("#7c3bed")(a.name)} selected`),Ve(i.projectId)}l(r,"getProject"),await r()},"project"),kn=l(async o=>{const e=o.verbose||!1,t=o.persistOas||!1,{getProject:n,getProfile:r,getProjects:i,writeProject:a}=P(),u=await r(e);if(!u||u===1){console.info("User not logged in"),await Fe({processExit:!1,skipProjectGuard:!0});const w=await r();(!w||w===1)&&(console.info(`${f.hex("#b90404")("[ERROR]")} Login failed`),process.exit(1))}let c=o.output||".frontstack",h=await n();(!h||"error"in h)&&(console.info("No project selected"),console.info("Running project selection..."),await De({}));const{getMetadata:s}=Ie(),p=s(c);if(h=await n(),!h||"error"in h){console.info(`${f.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${f.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`);return}if(p&&p.project.id!==h.id){const C=(await i()).find(B=>B.id===p.project.id),E=[];C&&E.push({title:`Switch to project ${f.hex("#7c3bed")(p.project.name)} and generate client`,value:"switch"}),E.push({title:`Overwrite client with project ${f.hex("#7c3bed")(h.name)}`,value:"overwrite"}),E.push({title:"Cancel",value:"cancel"}),console.log(`${f.hex("#FFA500")("[WARNING]")} Client mismatch detected`),console.log(`${f.hex("#FFA500")("[WARNING]")} The client in ${f.hex("#7c3bed")(c)} was generated for project ${f.hex("#7c3bed")(p.project.name)}.`),console.log(`${f.hex("#FFA500")("[WARNING]")} The selected project is ${f.hex("#7c3bed")(h.name)}.
26
+ `);const Ue={type:"select",name:"action",message:"How would you like to proceed?",choices:E},{action:M}=await U(Ue);if(M==="cancel"){console.info("Generation cancelled.");return}if(M==="switch"&&C&&(a(C.id),h=C,console.info(`Switched to project ${f.hex("#7c3bed")(h.name)}.`)),M==="overwrite"){const B={type:"text",name:"confirmation",message:'This is a destructive action and will overwrite the existing client. Type "confirm" to proceed.'},{confirmation:We}=await U(B);if(We!=="confirm"){console.info("Generation cancelled.");return}console.info(`Proceeding to generate client for project ${f.hex("#7c3bed")(h.name)}.`)}if(!M){console.info("Generation cancelled.");return}}let d=h;if(!h||"error"in h){console.info(`${f.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${f.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`);return}if(o.env&&h.environments.length>0){let w;if(o.env!=="develop"){if(w=h.environments.find(C=>C.environment===o.env),!w){console.info(`${f.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${f.hex("#b90404")("[ERROR]")} Environment ${o.env} not found`);return}d=w}}if(!o.env&&h.environments.length>0){const w={type:"select",name:"projectId",message:"Pick an environment (use arrow keys and enter)",choices:[{title:`${h.name} (${h.environment})`,value:h.id},...h.environments.map(E=>({title:(E.id===d?.id?"(\u2714) ":"")+`${E.name} (${E.environment})`,value:E.id}))]},C=await U(w);d=h.environments.find(E=>E.id===C.projectId)??h}let y,m,b,x,ce;try{e&&console.log("Generating Javascript client"),{_schemaTypes:y,_types:m,_client:b,_query:x,_specFile:ce}=await Tn(d.id)}catch(w){console.info(`${f.hex("#b90404")("[ERROR]")} frontstack generate`),console.info(`${f.hex("#b90404")("[ERROR]")} Failed to generate Javascript client`),e?console.info(`${f.hex("#b90404")("[ERROR]")} ${w.message}`):(console.info("Are you..."),console.info(` * logged in using the ${f.hex("#7c3bed")("frontstack login")} command?`),console.info(" * connected to the internet?"),console.info(`Alternatively, run ${f.hex("#7c3bed")("frontstack generate -v")} for additional output.`));return}process.stdout.write("Generating Javascript client"),c.startsWith("/")||(c=g.join(process.cwd(),c)),c.endsWith("/")||(c+="/");const le=g.join(c,"fetch-api.d.ts"),ue=g.join(c,"generated-types.d.ts"),he=g.join(c,"generated-client.ts"),qe=g.join(c,"query-types.ts"),pe=g.join(c,"metadata.json"),Me={project:{id:d.id,name:d.name}};if(e&&(console.log(`
27
+ Schema types path: ${f.dim(le)}`),console.log(`Types path: ${f.dim(ue)}`),console.log(`Client path: ${f.dim(he)}`),console.log(`Target directory: ${f.dim(c)}`),console.log(`Metadata path: ${f.dim(pe)}`)),_.mkdirSync(c,{recursive:!0}),t){const w=me.dump(ce,{indent:2}),C=g.join(c,"fetch-api.spec.yaml");console.log(`
28
+ Persisting OpenAPI Specification file in ${C}`),_.writeFileSync(g.join(C),w)}_.writeFileSync(g.join(le),y),_.writeFileSync(g.join(ue),m),_.writeFileSync(g.join(he),b),_.writeFileSync(g.join(qe),x),_.writeFileSync(g.join(pe),JSON.stringify(Me,null,2)),e?console.log(`Javascript client generated for ${f.hex("#7c3bed")(`${d.name} (${d.environment})`)}`):(process.stdout.clearLine(0),process.stdout.cursorTo(0),process.stdout.write(f.green(`Javascript client generated for ${f.hex("#7c3bed")(`${d.name} (${d.environment})`)}
29
29
  `))),console.log(`
30
30
  Use the following import in your project:
31
- `),console.log(" "+d.hex("#7c3bed")("import client from '.frontstack/generated-client';")),console.log(`
31
+ `),console.log(" "+f.hex("#7c3bed")("import client from '.frontstack/generated-client';")),console.log(`
32
32
  and use the client like this:
33
- `),console.log(" "+d.hex("#7c3bed")("const productDetail = await client.block('DetailPage', { key: 'my-product-id' });")),console.log(`
34
- If you make changes to your schema, run ${d.hex("#7c3bed")("frontstack generate")} again to update the client.`),process.exit(0)},"generateCommand"),{getToken:$n,getProfile:vn,getProject:Sn}=k(),Tn=l(async()=>{if($n()===null){console.log("Status: Not logged in."),console.log("Run "+d.hex("#7c3bed")("frontstack login")+" to login.");return}try{const e=await vn();if(e===void 0||e===1){console.log("Status: Not logged in."),console.log("Run "+d.hex("#7c3bed")("frontstack login")+" to login.");return}console.log("Logged in as "+d.hex("#7c3bed")(e.email)),console.log(`Organization: ${e.organization.name}`);const t=await Sn();if(t===void 0||"error"in t){console.log("Status: No project selected."),console.log("Run "+d.hex("#7c3bed")("frontstack project")+" to select a frontstack project");return}console.log(`Current Project: ${t.name??"[No active project selected]"}`)}catch(e){console.log(e)}},"info"),jn=Qe(import.meta.url),xn=g.dirname(jn),Fe=We(g.join(xn,"version"),"utf8");let re="0.0.1-dev";Fe&&(re=Fe.trim());const T=new yt;T.name("frontstack").alias("fst").description(`${d.bgHex("#7c3bed").bold("frontstack CLI")}
33
+ `),console.log(" "+f.hex("#7c3bed")("const productDetail = await client.block('DetailPage', { key: 'my-product-id' });")),console.log(`
34
+ If you make changes to your schema, run ${f.hex("#7c3bed")("frontstack generate")} again to update the client.`),process.exit(0)},"generateCommand"),{getToken:Pn,getProfile:Rn,getProject:Hn}=P(),Nn=l(async()=>{if(Pn()===null){console.log("Status: Not logged in."),console.log("Run "+f.hex("#7c3bed")("frontstack login")+" to login.");return}try{const e=await Rn();if(e===void 0||e===1){console.log("Status: Not logged in."),console.log("Run "+f.hex("#7c3bed")("frontstack login")+" to login.");return}console.log("Logged in as "+f.hex("#7c3bed")(e.email)),console.log(`Organization: ${e.organization.name}`);const t=await Hn();if(t===void 0||"error"in t){console.log("Status: No project selected."),console.log("Run "+f.hex("#7c3bed")("frontstack project")+" to select a frontstack project");return}console.log(`Current Project: ${t.name??"[No active project selected]"}`)}catch(e){console.log(e)}},"info"),G=Ke(".frontstack","version-check-cache.json"),In=24*60*60*1e3,Fn="https://registry.npmjs.org/@frontstackdev/cli/latest";function Vn(o,e){const t=K.clean(o),n=K.clean(e);return!t||!n?!1:K.gt(n,t)}l(Vn,"isOutdated");function Dn(){try{if(!fe(G))return null;const o=de(G,"utf8"),e=JSON.parse(o);return Date.now()-e.lastChecked<In?e:null}catch{return null}}l(Dn,"readCache");function Ln(o){try{const e=ze(G);fe(e)||Qe(e,{recursive:!0});const t={latestVersion:o,lastChecked:Date.now()};Ye(G,JSON.stringify(t,null,2))}catch{}}l(Ln,"writeCache");async function qn(){try{return(await L(Fn,{timeout:3e3})).version}catch{return null}}l(qn,"fetchLatestVersion");async function Mn(o){if(!o.includes("dev"))try{let e=Dn(),t;e?t=e.latestVersion:(t=await qn(),t&&Ln(t)),t&&Vn(o,t)&&(console.log(),console.log(f.bgHex("#7c3bed").bold("Update available!")),console.log(`Current version: ${f.red(o)}`),console.log(`Latest version: ${f.green(t)}`),console.log())}catch{}}l(Mn,"checkVersion");const Un=ot(import.meta.url),Wn=g.dirname(Un),Le=de(g.join(Wn,"version"),"utf8");let J="0.0.1-dev";Le&&(J=Le.trim());const j=new $t;j.name("frontstack").alias("fst").description(`${f.bgHex("#7c3bed").bold("frontstack CLI")}
35
35
  Manage frontstack projects from the command line.
36
- ${d.dim(`Version: ${re}`)}`).version(re),T.command("login").description("Login to frontstack account").action(()=>{Re()}),T.command("logout").description("Logout from frontstack account").action(async r=>{await bn()}),T.command("generate").description("Generate a JavaScript client for the current project").option("-o, --output <path>","Output path",".frontstack").option("-v, --verbose","Enable verbose logging").option("-e --env <alias>",'Pass an environment alias like "develop" or "preview"').option("-s --persist-oas","Persist OpenAPI specification file").action(async r=>{await En(r)}),T.command("info").description("Display information about the current organization, project, and user").action(async()=>{await Tn()}),T.command("project").description("Select current working project which will be used for schema and client updates").option("-p --project <project-id>","Set current project ID").action(async r=>{await Ne(r)});const Pn=l(()=>{try{T.parse(process.argv)}catch(r){console.log(r)}},"run");var kn=Pn();export{kn as default};
36
+ ${f.dim(`Version: ${J}`)}`).version(J),j.command("login").description("Login to frontstack account").action(()=>{Fe()}),j.command("logout").description("Logout from frontstack account").action(async o=>{await Sn()}),j.command("generate").description("Generate a JavaScript client for the current project").option("-o, --output <path>","Output path",".frontstack").option("-v, --verbose","Enable verbose logging").option("-e --env <alias>",'Pass an environment alias like "develop" or "preview"').option("-s --persist-oas","Persist OpenAPI specification file").action(async o=>{await kn(o)}),j.command("info").description("Display information about the current organization, project, and user").action(async()=>{await Nn()}),j.command("project").description("Select current working project which will be used for schema and client updates").option("-p --project <project-id>","Set current project ID").action(async o=>{await De(o)});const Gn=l(async()=>{try{await Mn(J),j.parse(process.argv)}catch(o){console.log(o)}},"run");var Jn=Gn();export{Jn as default};
@@ -11,6 +11,23 @@ import type { Query } from './query-types'
11
11
 
12
12
  type Method = 'GET' | 'POST' | 'PATCH' | 'DELETE'
13
13
 
14
+ /**
15
+ * Global configuration options for the frontstack client
16
+ */
17
+ export interface ClientConfig {
18
+ /**
19
+ * @description Proxy URL
20
+ *
21
+ * Optionally, provide a proxy URL path that will be concatenated with the original API path.
22
+ * For example, if proxyUrl is '/api' and the original request is to '/block',
23
+ * the request will be sent to '/api/block'.
24
+ * The original target URL is passed in the 'fs-target-url' header for the proxy to forward to.
25
+ * This is useful to prevent CORS issues when making requests from a browser.
26
+ * Can be overridden per-request via RequestOptions.
27
+ */
28
+ proxyUrl?: string
29
+ }
30
+
14
31
  /**
15
32
  * Interface describing the frontstack client API
16
33
  */
@@ -81,22 +98,26 @@ export interface FrontstackClient {
81
98
  * Fetch a context by its token
82
99
  * @param token The token of the context
83
100
  * @example 'ae0d4981-c363-4d5a-a49e-1f053d49f2f7'
101
+ * @param config Further configuration options
84
102
  *
85
103
  * @returns The context and token
86
104
  */
87
105
  context: (
88
- token: ContextToken
106
+ token: ContextToken,
107
+ config?: RequestOptions
89
108
  ) => Promise<Context>;
90
109
 
91
110
  /**
92
111
  * Fetch a list of contexts
93
112
  * @param token The token of the context to fetch
94
113
  * @example 'ae0d4981-c363-4d5a-a49e-1f053d49f2f7'
114
+ * @param config Further configuration options
95
115
  *
96
116
  * @returns The list of contexts and the token
97
117
  */
98
118
  contextList: (
99
- token?: ContextToken
119
+ token?: ContextToken,
120
+ config?: RequestOptions
100
121
  ) => Promise<[ContextOption[], ContextToken]>;
101
122
 
102
123
  /**
@@ -105,6 +126,7 @@ export interface FrontstackClient {
105
126
  * @example { region: 'uk', locale: 'en-GB' }
106
127
  * @param token The token of the context to update
107
128
  * @example 'ae0d4981-c363-4d5a-a49e-1f053d49f2f7'
129
+ * @param config Further configuration options
108
130
  *
109
131
  * @returns The updated context
110
132
  */
@@ -113,7 +135,8 @@ export interface FrontstackClient {
113
135
  region: string
114
136
  locale: string
115
137
  },
116
- token: ContextToken
138
+ token: ContextToken,
139
+ config?: RequestOptions
117
140
  ) => Promise<Context>;
118
141
  }
119
142
 
@@ -125,7 +148,7 @@ const endpoints: Endpoints = {
125
148
  {{/each}}
126
149
  }
127
150
 
128
- const invoke = async (path: string, method: Method, payload: any, headers: any) => {
151
+ const invoke = async (path: string, method: Method, payload: any, headers: any, proxyUrl?: string) => {
129
152
  const _headers: any = {
130
153
  'Content-Type': 'application/json',
131
154
  'Accept': 'application/json',
@@ -146,6 +169,21 @@ const invoke = async (path: string, method: Method, payload: any, headers: any)
146
169
  body: payload
147
170
  }
148
171
 
172
+ // If proxy URL is provided, concatenate it with the original path
173
+ if (proxyUrl) {
174
+ // Parse the original full URL to extract just the pathname
175
+ const url = new URL(path)
176
+ const originalPath = url.pathname
177
+
178
+ // Store the original full URL in header for the proxy to use
179
+ headers['fs-target-url'] = path
180
+
181
+ // Concatenate proxy URL with the original path
182
+ // Remove trailing slash from proxyUrl and leading slash is already in originalPath
183
+ const normalizedProxyUrl = proxyUrl.endsWith('/') ? proxyUrl.slice(0, -1) : proxyUrl
184
+ path = normalizedProxyUrl + originalPath
185
+ }
186
+
149
187
  return await ofetch.raw(path, options)
150
188
  }
151
189
 
@@ -157,124 +195,159 @@ const servers = [
157
195
  ]
158
196
 
159
197
  /**
160
- * frontstack Client
198
+ * Create a frontstack client with optional global configuration
199
+ *
200
+ * @param config Global configuration options for the client
201
+ * @example
202
+ * const client = createClient({ proxyUrl: '/api/frontstack' })
203
+ *
204
+ * @returns A configured frontstack client instance
161
205
  */
162
- const client: FrontstackClient = {
163
- /**
164
- * Fetch a block with a key
165
- */
166
- block: async (name, key, config) => {
167
- if(!(name in endpoints)) {
168
- throw new Error(`Block ${name} not found`)
169
- }
170
- let endpoint: string = `${servers[0].url}${endpoints[name]}`;
206
+ const createClient = (config?: ClientConfig): FrontstackClient => {
207
+ const globalConfig = config || {}
208
+
209
+ return {
210
+ /**
211
+ * Fetch a block with a key
212
+ */
213
+ block: async (name, key, config) => {
214
+ if(!(name in endpoints)) {
215
+ throw new Error(`Block ${name} not found`)
216
+ }
217
+ let endpoint: string = `${servers[0].url}${endpoints[name]}`;
218
+
219
+ // Replace '{key}' in the endpoint
220
+ endpoint = endpoint.replace('{key}', key);
221
+
222
+ // No additional parameters needed for blocks
223
+ let payload = { param: {} };
224
+
225
+ let headers: Record<string, string> = {}
226
+
227
+ if(config?.requestUrl !== undefined) {
228
+ headers['fs-request-url'] = config.requestUrl
229
+ }
230
+ if (config?.contextKey !== undefined) {
231
+ headers["fs-context"] = config.contextKey;
232
+ }
233
+
234
+ // Use per-request proxyUrl if provided, otherwise use global config
235
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
236
+
237
+ return (await invoke(endpoint, 'POST', payload, headers, proxyUrl))._data
238
+ },
171
239
 
172
- // Replace '{key}' in the endpoint
173
- endpoint = endpoint.replace('{key}', key);
240
+ /**
241
+ * Fetch a listing with parameters and optional query options
242
+ */
243
+ listing: async (name, parameters, config) => {
244
+ if(!(name in endpoints)) {
245
+ throw new Error(`Listing ${name} not found`)
246
+ }
174
247
 
175
- // No additional parameters needed for blocks
176
- let payload = { param: {} };
248
+ let endpoint: string = `${servers[0].url}${endpoints[name]}`;
177
249
 
178
- let headers: Record<string, string> = {}
250
+ // Merge listing parameters with query
251
+ let payload = config && 'query' in config ? { param: {...parameters}, ...config.query } : { param: {...parameters} }
179
252
 
180
- if(config?.requestUrl !== undefined) {
181
- headers['fs-request-url'] = config.requestUrl
182
- }
183
- if (config?.contextKey !== undefined) {
184
- headers["fs-context"] = config.contextKey;
185
- }
253
+ let headers: Record<string, string> = {}
186
254
 
187
- return (await invoke(endpoint, 'POST', payload, headers))._data
188
- },
255
+ if(config?.requestUrl !== undefined) {
256
+ headers['fs-request-url'] = config.requestUrl
257
+ }
258
+ if (config?.contextKey !== undefined) {
259
+ headers["fs-context"] = config.contextKey;
260
+ }
189
261
 
190
- /**
191
- * Fetch a listing with parameters and optional query options
192
- */
193
- listing: async (name, parameters, config) => {
194
- if(!(name in endpoints)) {
195
- throw new Error(`Listing ${name} not found`)
196
- }
262
+ // Use per-request proxyUrl if provided, otherwise use global config
263
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
197
264
 
198
- let endpoint: string = `${servers[0].url}${endpoints[name]}`;
265
+ return (await invoke(endpoint, 'POST', payload, headers, proxyUrl))._data
266
+ },
199
267
 
200
- // Merge listing parameters with query
201
- let payload = config && 'query' in config ? { param: {...parameters}, ...config.query } : { param: {...parameters} }
268
+ /**
269
+ * Fetch a page by its slug
270
+ */
271
+ page: async (slug, config) => {
272
+ let endpoint: string = `${servers[0].url}/page/${slug}`;
202
273
 
203
- let headers: Record<string, string> = {}
274
+ let headers: Record<string, string> = {}
204
275
 
205
- if(config?.requestUrl !== undefined) {
206
- headers['fs-request-url'] = config.requestUrl
207
- }
208
- if (config?.contextKey !== undefined) {
209
- headers["fs-context"] = config.contextKey;
210
- }
276
+ if(config?.requestUrl !== undefined) {
277
+ headers['fs-request-url'] = config.requestUrl
278
+ }
279
+ if (config?.contextKey !== undefined) {
280
+ headers["fs-context"] = config.contextKey;
281
+ }
211
282
 
212
- return (await invoke(endpoint, 'POST', payload, headers))._data
213
- },
283
+ // Use per-request proxyUrl if provided, otherwise use global config
284
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
214
285
 
215
- /**
216
- * Fetch a page by its slug
217
- */
218
- page: async (slug, config) => {
219
- let endpoint: string = `${servers[0].url}/page/${slug}`;
286
+ return (await invoke(endpoint, 'GET', null, headers, proxyUrl))._data
287
+ },
220
288
 
221
- let headers: Record<string, string> = {}
289
+ /**
290
+ * Fetch a context by its token
291
+ */
292
+ context: async (token, config) => {
293
+ let endpoint: string = `${servers[0].url}/context/token`;
222
294
 
223
- if(config?.requestUrl !== undefined) {
224
- headers['fs-request-url'] = config.requestUrl
225
- }
226
- if (config?.contextKey !== undefined) {
227
- headers["fs-context"] = config.contextKey;
228
- }
295
+ let headers: Record<string, string> = {
296
+ 'fs-context': token
297
+ }
229
298
 
230
- return (await invoke(endpoint, 'GET', null, headers))._data
231
- },
299
+ // Use per-request proxyUrl if provided, otherwise use global config
300
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
232
301
 
233
- /**
234
- * Fetch a context by its token
235
- */
236
- context: async (token) => {
237
- let endpoint: string = `${servers[0].url}/context/token`;
302
+ return (await invoke(endpoint, 'GET', null, headers, proxyUrl))._data
303
+ },
238
304
 
239
- let headers: Record<string, string> = {
240
- 'fs-context': token
241
- }
305
+ /**
306
+ * Fetch a list of contexts
307
+ */
308
+ contextList: async (token, config) => {
309
+ let endpoint: string = `${servers[0].url}/context`;
242
310
 
243
- return (await invoke(endpoint, 'GET', null, headers))._data
244
- },
311
+ const requestHeaders: Record<string, string> = {}
245
312
 
246
- /**
247
- * Fetch a list of contexts
248
- */
249
- contextList: async (token) => {
250
- let endpoint: string = `${servers[0].url}/context`;
313
+ if (token) {
314
+ requestHeaders["fs-context"] = token;
315
+ }
251
316
 
252
- const requestHeaders: Record<string, string> = {}
317
+ // Use per-request proxyUrl if provided, otherwise use global config
318
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
253
319
 
254
- if (token) {
255
- requestHeaders["fs-context"] = token;
256
- }
320
+ const {
321
+ _data,
322
+ headers: responseHeaders
323
+ } = await invoke(endpoint, 'GET', null, requestHeaders, proxyUrl)
257
324
 
258
- const {
259
- _data,
260
- headers: responseHeaders
261
- } = await invoke(endpoint, 'GET', null, requestHeaders)
325
+ return [_data, responseHeaders.get('fs-context')!]
326
+ },
262
327
 
263
- return [_data, responseHeaders.get('fs-context')!]
264
- },
328
+ /**
329
+ * Update a context
330
+ */
331
+ contextUpdate: async (context, token, config) => {
332
+ let endpoint: string = `${servers[0].url}/context`;
265
333
 
266
- /**
267
- * Update a context
268
- */
269
- contextUpdate: async (context, token) => {
270
- let endpoint: string = `${servers[0].url}/context`;
334
+ let headers: Record<string, string> = {
335
+ 'fs-context': token
336
+ }
271
337
 
272
- let headers: Record<string, string> = {
273
- 'fs-context': token
274
- }
338
+ // Use per-request proxyUrl if provided, otherwise use global config
339
+ const proxyUrl = config?.proxyUrl ?? globalConfig.proxyUrl
275
340
 
276
- return (await invoke(endpoint, 'PATCH', context, headers))._data
341
+ return (await invoke(endpoint, 'PATCH', context, headers, proxyUrl))._data
342
+ }
277
343
  }
278
344
  }
279
345
 
346
+ /**
347
+ * Default client instance (without global configuration)
348
+ * For global configuration (e.g. proxy URL), use createClient() instead
349
+ */
350
+ const client = createClient()
351
+
280
352
  export default client
353
+ export { createClient, client }
@@ -19,6 +19,17 @@ type RequestOptions = {
19
19
  * Providing a context key will override the default context key for the request
20
20
  */
21
21
  contextKey?: string
22
+
23
+ /**
24
+ * @description Proxy URL
25
+ *
26
+ * Optionally, provide a proxy URL path that will be concatenated with the original API path.
27
+ * For example, if proxyUrl is '/api' and the original request is to '/block',
28
+ * the request will be sent to '/api/block'.
29
+ * The original target URL is passed in the 'fs-target-url' header for the proxy to forward to.
30
+ * This is useful to prevent CORS issues when making requests from a browser.
31
+ */
32
+ proxyUrl?: string
22
33
  }
23
34
 
24
35
  /* List of all types used to fetch block parameters */
package/dist/version CHANGED
@@ -1 +1 @@
1
- 0.0.0-canary-20251023180402
1
+ 0.0.0-canary-20251025194100
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@frontstackdev/cli",
3
- "version": "0.0.0-canary-20251023180402",
3
+ "version": "0.0.0-canary-20251025194100",
4
4
  "description": "frontstack CLI for managing projects",
5
5
  "type": "module",
6
6
  "module": "dist/frontstack.mjs",
@@ -28,6 +28,7 @@
28
28
  "@types/node": "^22.5.0"
29
29
  },
30
30
  "devDependencies": {
31
+ "@types/semver": "^7.7.1",
31
32
  "commander": "^12.0.0",
32
33
  "msw": "^2.2.14",
33
34
  "ofetch": "^1.3.4",
@@ -46,6 +47,7 @@
46
47
  "js-yaml": "^4.1.0",
47
48
  "open": "^10.1.0",
48
49
  "openapi-typescript": "^6.7.5",
49
- "prompts": "^2.4.2"
50
+ "prompts": "^2.4.2",
51
+ "semver": "^7.7.3"
50
52
  }
51
53
  }