veloce-ts 0.2.6 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +501 -240
- package/README.md +141 -1
- package/dist/cjs/src/cli/index.js +125 -74
- package/dist/cjs/src/cli/index.js.map +4 -4
- package/dist/cjs/src/index.js +66 -25
- package/dist/cjs/src/index.js.map +112 -10
- package/dist/cjs/src/middleware/index.js +28 -2
- package/dist/cjs/src/middleware/index.js.map +79 -4
- package/dist/cjs/src/plugins/index.js +49 -23
- package/dist/cjs/src/plugins/index.js.map +74 -4
- package/dist/cjs/src/testing/index.js +30 -4
- package/dist/cjs/src/testing/index.js.map +80 -7
- package/dist/cjs/src/websocket/index.js +3 -3
- package/dist/cjs/src/websocket/index.js.map +1 -1
- package/dist/esm/src/cli/index.js +561 -22
- package/dist/esm/src/cli/index.js.map +8 -4
- package/dist/esm/src/docs/index.js +6 -6
- package/dist/esm/src/docs/index.js.map +10 -3
- package/dist/esm/src/errors/index.js +3 -2
- package/dist/esm/src/errors/index.js.map +7 -3
- package/dist/esm/src/graphql/index.js +82 -2
- package/dist/esm/src/graphql/index.js.map +18 -3
- package/dist/esm/src/index.js +165 -3
- package/dist/esm/src/index.js.map +202 -6
- package/dist/esm/src/middleware/index.js +28 -2
- package/dist/esm/src/middleware/index.js.map +81 -3
- package/dist/esm/src/plugins/index.js +113 -3
- package/dist/esm/src/plugins/index.js.map +131 -4
- package/dist/esm/src/testing/index.js +42 -2
- package/dist/esm/src/testing/index.js.map +97 -7
- package/dist/esm/src/types/index.js +2 -2
- package/dist/esm/src/types/index.js.map +10 -3
- package/dist/esm/src/validation/index.js +2 -2
- package/dist/esm/src/validation/index.js.map +13 -3
- package/dist/esm/src/websocket/index.js +15 -2
- package/dist/esm/src/websocket/index.js.map +9 -4
- package/dist/types/adapters/base.d.ts +10 -2
- package/dist/types/adapters/base.d.ts.map +1 -1
- package/dist/types/adapters/hono.d.ts +2 -2
- package/dist/types/adapters/hono.d.ts.map +1 -1
- package/dist/types/auth/permissions.d.ts +10 -10
- package/dist/types/auth/session.d.ts +2 -2
- package/dist/types/cache/index.d.ts +9 -0
- package/dist/types/cache/index.d.ts.map +1 -0
- package/dist/types/cache/manager.d.ts +75 -0
- package/dist/types/cache/manager.d.ts.map +1 -0
- package/dist/types/cache/memory-store.d.ts +55 -0
- package/dist/types/cache/memory-store.d.ts.map +1 -0
- package/dist/types/cache/redis-store.d.ts +55 -0
- package/dist/types/cache/redis-store.d.ts.map +1 -0
- package/dist/types/cache/types.d.ts +92 -0
- package/dist/types/cache/types.d.ts.map +1 -0
- package/dist/types/cli/commands/new.d.ts.map +1 -1
- package/dist/types/context/request-context.d.ts +66 -0
- package/dist/types/context/request-context.d.ts.map +1 -0
- package/dist/types/core/application.d.ts +11 -0
- package/dist/types/core/application.d.ts.map +1 -1
- package/dist/types/core/router-compiler.d.ts +1 -1
- package/dist/types/core/router-compiler.d.ts.map +1 -1
- package/dist/types/decorators/cache.d.ts +56 -0
- package/dist/types/decorators/cache.d.ts.map +1 -0
- package/dist/types/decorators/params.d.ts +24 -0
- package/dist/types/decorators/params.d.ts.map +1 -1
- package/dist/types/dependencies/container.d.ts +1 -1
- package/dist/types/dependencies/container.d.ts.map +1 -1
- package/dist/types/index.d.ts +7 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/logging/index.d.ts +10 -0
- package/dist/types/logging/index.d.ts.map +1 -0
- package/dist/types/logging/logger.d.ts +25 -0
- package/dist/types/logging/logger.d.ts.map +1 -0
- package/dist/types/logging/middleware.d.ts +15 -0
- package/dist/types/logging/middleware.d.ts.map +1 -0
- package/dist/types/logging/types.d.ts +22 -0
- package/dist/types/logging/types.d.ts.map +1 -0
- package/dist/types/middleware/cache.d.ts +54 -0
- package/dist/types/middleware/cache.d.ts.map +1 -0
- package/dist/types/middleware/index.d.ts +3 -0
- package/dist/types/middleware/index.d.ts.map +1 -1
- package/dist/types/middleware/request-context.d.ts +55 -0
- package/dist/types/middleware/request-context.d.ts.map +1 -0
- package/dist/types/orm/base-repository.d.ts +77 -0
- package/dist/types/orm/base-repository.d.ts.map +1 -0
- package/dist/types/orm/decorators.d.ts +35 -0
- package/dist/types/orm/decorators.d.ts.map +1 -0
- package/dist/types/orm/drizzle/index.d.ts +6 -0
- package/dist/types/orm/drizzle/index.d.ts.map +1 -0
- package/dist/types/orm/drizzle/plugin.d.ts +165 -0
- package/dist/types/orm/drizzle/plugin.d.ts.map +1 -0
- package/dist/types/orm/drizzle/repository.d.ts +61 -0
- package/dist/types/orm/drizzle/repository.d.ts.map +1 -0
- package/dist/types/orm/drizzle/schema-converter.d.ts +53 -0
- package/dist/types/orm/drizzle/schema-converter.d.ts.map +1 -0
- package/dist/types/orm/drizzle/transaction-manager.d.ts +58 -0
- package/dist/types/orm/drizzle/transaction-manager.d.ts.map +1 -0
- package/dist/types/orm/drizzle/types.d.ts +121 -0
- package/dist/types/orm/drizzle/types.d.ts.map +1 -0
- package/dist/types/orm/index.d.ts +16 -0
- package/dist/types/orm/index.d.ts.map +1 -0
- package/dist/types/orm/pagination.d.ts +147 -0
- package/dist/types/orm/pagination.d.ts.map +1 -0
- package/dist/types/orm/prisma/index.d.ts +6 -0
- package/dist/types/orm/prisma/index.d.ts.map +1 -0
- package/dist/types/orm/prisma/plugin.d.ts +68 -0
- package/dist/types/orm/prisma/plugin.d.ts.map +1 -0
- package/dist/types/orm/prisma/repository.d.ts +70 -0
- package/dist/types/orm/prisma/repository.d.ts.map +1 -0
- package/dist/types/orm/prisma/schema-generator.d.ts +45 -0
- package/dist/types/orm/prisma/schema-generator.d.ts.map +1 -0
- package/dist/types/orm/prisma/transaction-manager.d.ts +32 -0
- package/dist/types/orm/prisma/transaction-manager.d.ts.map +1 -0
- package/dist/types/orm/prisma/types.d.ts +67 -0
- package/dist/types/orm/prisma/types.d.ts.map +1 -0
- package/dist/types/orm/query-builder.d.ts +129 -0
- package/dist/types/orm/query-builder.d.ts.map +1 -0
- package/dist/types/orm/repository-factory.d.ts +130 -0
- package/dist/types/orm/repository-factory.d.ts.map +1 -0
- package/dist/types/orm/transaction-events.d.ts +122 -0
- package/dist/types/orm/transaction-events.d.ts.map +1 -0
- package/dist/types/orm/transaction-interceptor.d.ts +30 -0
- package/dist/types/orm/transaction-interceptor.d.ts.map +1 -0
- package/dist/types/orm/transaction-manager.d.ts +64 -0
- package/dist/types/orm/transaction-manager.d.ts.map +1 -0
- package/dist/types/orm/transaction-plugin.d.ts +117 -0
- package/dist/types/orm/transaction-plugin.d.ts.map +1 -0
- package/dist/types/orm/transaction-propagation.d.ts +49 -0
- package/dist/types/orm/transaction-propagation.d.ts.map +1 -0
- package/dist/types/orm/typeorm/decorators.d.ts +40 -0
- package/dist/types/orm/typeorm/decorators.d.ts.map +1 -0
- package/dist/types/orm/typeorm/index.d.ts +6 -0
- package/dist/types/orm/typeorm/index.d.ts.map +1 -0
- package/dist/types/orm/typeorm/plugin.d.ts +100 -0
- package/dist/types/orm/typeorm/plugin.d.ts.map +1 -0
- package/dist/types/orm/typeorm/repository.d.ts +58 -0
- package/dist/types/orm/typeorm/repository.d.ts.map +1 -0
- package/dist/types/orm/typeorm/transaction-manager.d.ts +48 -0
- package/dist/types/orm/typeorm/transaction-manager.d.ts.map +1 -0
- package/dist/types/orm/typeorm/types.d.ts +139 -0
- package/dist/types/orm/typeorm/types.d.ts.map +1 -0
- package/dist/types/plugins/health.d.ts +75 -0
- package/dist/types/plugins/health.d.ts.map +1 -0
- package/dist/types/plugins/index.d.ts +2 -0
- package/dist/types/plugins/index.d.ts.map +1 -1
- package/dist/types/types/index.d.ts +15 -2
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/types/websocket/index.d.ts +1 -1
- package/dist/types/websocket/index.d.ts.map +1 -1
- package/package.json +22 -2
- package/dist/esm/chunk-2100y16g.js +0 -5
- package/dist/esm/chunk-2100y16g.js.map +0 -10
- package/dist/esm/chunk-5q75d71c.js +0 -4
- package/dist/esm/chunk-5q75d71c.js.map +0 -16
- package/dist/esm/chunk-8dpc6an2.js +0 -7
- package/dist/esm/chunk-8dpc6an2.js.map +0 -10
- package/dist/esm/chunk-9v7atckx.js +0 -5
- package/dist/esm/chunk-9v7atckx.js.map +0 -10
- package/dist/esm/chunk-bvstdn0t.js +0 -60
- package/dist/esm/chunk-bvstdn0t.js.map +0 -10
- package/dist/esm/chunk-ctwpr5gr.js +0 -430
- package/dist/esm/chunk-ctwpr5gr.js.map +0 -10
- package/dist/esm/chunk-dtw2tbsd.js +0 -5
- package/dist/esm/chunk-dtw2tbsd.js.map +0 -12
- package/dist/esm/chunk-ef0vfd27.js +0 -72
- package/dist/esm/chunk-ef0vfd27.js.map +0 -13
- package/dist/esm/chunk-k66rn4fj.js +0 -18
- package/dist/esm/chunk-k66rn4fj.js.map +0 -10
- package/dist/esm/chunk-mky5qqg0.js +0 -5
- package/dist/esm/chunk-mky5qqg0.js.map +0 -10
- package/dist/esm/chunk-mznkhz9c.js +0 -5
- package/dist/esm/chunk-mznkhz9c.js.map +0 -12
- package/dist/esm/chunk-s5z0wb7e.js +0 -5
- package/dist/esm/chunk-s5z0wb7e.js.map +0 -10
- package/dist/esm/chunk-vh4sxcpe.js +0 -6
- package/dist/esm/chunk-vh4sxcpe.js.map +0 -10
- package/dist/esm/chunk-xa333k40.js +0 -7
- package/dist/esm/chunk-xa333k40.js.map +0 -10
- package/dist/esm/chunk-y262e56g.js +0 -5
- package/dist/esm/chunk-y262e56g.js.map +0 -9
- package/dist/esm/chunk-yq3gf9ts.js +0 -5
- package/dist/esm/chunk-yq3gf9ts.js.map +0 -10
|
@@ -1,30 +1,569 @@
|
|
|
1
1
|
#!/usr/bin/env bun
|
|
2
2
|
// @bun
|
|
3
|
-
|
|
4
|
-
`)}displayWidth(
|
|
5
|
-
`+" ".repeat(z+
|
|
6
|
-
${Y}`)}boxWrap(
|
|
7
|
-
`)}}function
|
|
3
|
+
var V$=Object.create;var{getPrototypeOf:D$,defineProperty:V,getOwnPropertyNames:h,getOwnPropertyDescriptor:N$}=Object,g=Object.prototype.hasOwnProperty;var y$=($,z,q)=>{q=$!=null?V$(D$($)):{};let B=z||!$||!$.__esModule?V(q,"default",{value:$,enumerable:!0}):q;for(let X of h($))if(!g.call(B,X))V(B,X,{get:()=>$[X],enumerable:!0});return B},u=new WeakMap,az=($)=>{var z=u.get($),q;if(z)return z;if(z=V({},"__esModule",{value:!0}),$&&typeof $==="object"||typeof $==="function")h($).map((B)=>!g.call(z,B)&&V(z,B,{get:()=>$[B],enumerable:!(q=N$($,B))||q.enumerable}));return u.set($,z),z},E=($,z)=>()=>(z||$((z={exports:{}}).exports,z),z.exports);var y=($,z)=>{for(var q in z)V($,q,{get:z[q],enumerable:!0,configurable:!0,set:(B)=>z[q]=()=>B})};var F=($,z)=>()=>($&&(z=$($=0)),z);var D=import.meta.require;var N=E((F$)=>{class P extends Error{constructor($,z,q){super(q);Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name,this.code=z,this.exitCode=$,this.nestedError=void 0}}class l extends P{constructor($){super(1,"commander.invalidArgument",$);Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}}F$.CommanderError=P;F$.InvalidArgumentError=l});var A=E((k$)=>{var{InvalidArgumentError:P$}=N();class c{constructor($,z){switch(this.description=z||"",this.variadic=!1,this.parseArg=void 0,this.defaultValue=void 0,this.defaultValueDescription=void 0,this.argChoices=void 0,$[0]){case"<":this.required=!0,this._name=$.slice(1,-1);break;case"[":this.required=!1,this._name=$.slice(1,-1);break;default:this.required=!0,this._name=$;break}if(this._name.endsWith("..."))this.variadic=!0,this._name=this._name.slice(0,-3)}name(){return this._name}_collectValue($,z){if(z===this.defaultValue||!Array.isArray(z))return[$];return z.push($),z}default($,z){return this.defaultValue=$,this.defaultValueDescription=z,this}argParser($){return this.parseArg=$,this}choices($){return this.argChoices=$.slice(),this.parseArg=(z,q)=>{if(!this.argChoices.includes(z))throw new P$(`Allowed choices are ${this.argChoices.join(", ")}.`);if(this.variadic)return this._collectValue(z,q);return z},this}argRequired(){return this.required=!0,this}argOptional(){return this.required=!1,this}}function w$($){let z=$.name()+($.variadic===!0?"...":"");return $.required?"<"+z+">":"["+z+"]"}k$.Argument=c;k$.humanReadableArgName=w$});var w=E((C$)=>{var{humanReadableArgName:x$}=A();class d{constructor(){this.helpWidth=void 0,this.minWidthToWrap=40,this.sortSubcommands=!1,this.sortOptions=!1,this.showGlobalOptions=!1}prepareContext($){this.helpWidth=this.helpWidth??$.helpWidth??80}visibleCommands($){let z=$.commands.filter((B)=>!B._hidden),q=$._getHelpCommand();if(q&&!q._hidden)z.push(q);if(this.sortSubcommands)z.sort((B,X)=>{return B.name().localeCompare(X.name())});return z}compareOptions($,z){let q=(B)=>{return B.short?B.short.replace(/^-/,""):B.long.replace(/^--/,"")};return q($).localeCompare(q(z))}visibleOptions($){let z=$.options.filter((B)=>!B.hidden),q=$._getHelpOption();if(q&&!q.hidden){let B=q.short&&$._findOption(q.short),X=q.long&&$._findOption(q.long);if(!B&&!X)z.push(q);else if(q.long&&!X)z.push($.createOption(q.long,q.description));else if(q.short&&!B)z.push($.createOption(q.short,q.description))}if(this.sortOptions)z.sort(this.compareOptions);return z}visibleGlobalOptions($){if(!this.showGlobalOptions)return[];let z=[];for(let q=$.parent;q;q=q.parent){let B=q.options.filter((X)=>!X.hidden);z.push(...B)}if(this.sortOptions)z.sort(this.compareOptions);return z}visibleArguments($){if($._argsDescription)$.registeredArguments.forEach((z)=>{z.description=z.description||$._argsDescription[z.name()]||""});if($.registeredArguments.find((z)=>z.description))return $.registeredArguments;return[]}subcommandTerm($){let z=$.registeredArguments.map((q)=>x$(q)).join(" ");return $._name+($._aliases[0]?"|"+$._aliases[0]:"")+($.options.length?" [options]":"")+(z?" "+z:"")}optionTerm($){return $.flags}argumentTerm($){return $.name()}longestSubcommandTermLength($,z){return z.visibleCommands($).reduce((q,B)=>{return Math.max(q,this.displayWidth(z.styleSubcommandTerm(z.subcommandTerm(B))))},0)}longestOptionTermLength($,z){return z.visibleOptions($).reduce((q,B)=>{return Math.max(q,this.displayWidth(z.styleOptionTerm(z.optionTerm(B))))},0)}longestGlobalOptionTermLength($,z){return z.visibleGlobalOptions($).reduce((q,B)=>{return Math.max(q,this.displayWidth(z.styleOptionTerm(z.optionTerm(B))))},0)}longestArgumentTermLength($,z){return z.visibleArguments($).reduce((q,B)=>{return Math.max(q,this.displayWidth(z.styleArgumentTerm(z.argumentTerm(B))))},0)}commandUsage($){let z=$._name;if($._aliases[0])z=z+"|"+$._aliases[0];let q="";for(let B=$.parent;B;B=B.parent)q=B.name()+" "+q;return q+z+" "+$.usage()}commandDescription($){return $.description()}subcommandDescription($){return $.summary()||$.description()}optionDescription($){let z=[];if($.argChoices)z.push(`choices: ${$.argChoices.map((q)=>JSON.stringify(q)).join(", ")}`);if($.defaultValue!==void 0){if($.required||$.optional||$.isBoolean()&&typeof $.defaultValue==="boolean")z.push(`default: ${$.defaultValueDescription||JSON.stringify($.defaultValue)}`)}if($.presetArg!==void 0&&$.optional)z.push(`preset: ${JSON.stringify($.presetArg)}`);if($.envVar!==void 0)z.push(`env: ${$.envVar}`);if(z.length>0){let q=`(${z.join(", ")})`;if($.description)return`${$.description} ${q}`;return q}return $.description}argumentDescription($){let z=[];if($.argChoices)z.push(`choices: ${$.argChoices.map((q)=>JSON.stringify(q)).join(", ")}`);if($.defaultValue!==void 0)z.push(`default: ${$.defaultValueDescription||JSON.stringify($.defaultValue)}`);if(z.length>0){let q=`(${z.join(", ")})`;if($.description)return`${$.description} ${q}`;return q}return $.description}formatItemList($,z,q){if(z.length===0)return[];return[q.styleTitle($),...z,""]}groupItems($,z,q){let B=new Map;return $.forEach((X)=>{let Y=q(X);if(!B.has(Y))B.set(Y,[])}),z.forEach((X)=>{let Y=q(X);if(!B.has(Y))B.set(Y,[]);B.get(Y).push(X)}),B}formatHelp($,z){let q=z.padWidth($,z),B=z.helpWidth??80;function X(J,U){return z.formatItem(J,q,U,z)}let Y=[`${z.styleTitle("Usage:")} ${z.styleUsage(z.commandUsage($))}`,""],Z=z.commandDescription($);if(Z.length>0)Y=Y.concat([z.boxWrap(z.styleCommandDescription(Z),B),""]);let Q=z.visibleArguments($).map((J)=>{return X(z.styleArgumentTerm(z.argumentTerm(J)),z.styleArgumentDescription(z.argumentDescription(J)))});if(Y=Y.concat(this.formatItemList("Arguments:",Q,z)),this.groupItems($.options,z.visibleOptions($),(J)=>J.helpGroupHeading??"Options:").forEach((J,U)=>{let L=J.map((W)=>{return X(z.styleOptionTerm(z.optionTerm(W)),z.styleOptionDescription(z.optionDescription(W)))});Y=Y.concat(this.formatItemList(U,L,z))}),z.showGlobalOptions){let J=z.visibleGlobalOptions($).map((U)=>{return X(z.styleOptionTerm(z.optionTerm(U)),z.styleOptionDescription(z.optionDescription(U)))});Y=Y.concat(this.formatItemList("Global Options:",J,z))}return this.groupItems($.commands,z.visibleCommands($),(J)=>J.helpGroup()||"Commands:").forEach((J,U)=>{let L=J.map((W)=>{return X(z.styleSubcommandTerm(z.subcommandTerm(W)),z.styleSubcommandDescription(z.subcommandDescription(W)))});Y=Y.concat(this.formatItemList(U,L,z))}),Y.join(`
|
|
4
|
+
`)}displayWidth($){return m($).length}styleTitle($){return $}styleUsage($){return $.split(" ").map((z)=>{if(z==="[options]")return this.styleOptionText(z);if(z==="[command]")return this.styleSubcommandText(z);if(z[0]==="["||z[0]==="<")return this.styleArgumentText(z);return this.styleCommandText(z)}).join(" ")}styleCommandDescription($){return this.styleDescriptionText($)}styleOptionDescription($){return this.styleDescriptionText($)}styleSubcommandDescription($){return this.styleDescriptionText($)}styleArgumentDescription($){return this.styleDescriptionText($)}styleDescriptionText($){return $}styleOptionTerm($){return this.styleOptionText($)}styleSubcommandTerm($){return $.split(" ").map((z)=>{if(z==="[options]")return this.styleOptionText(z);if(z[0]==="["||z[0]==="<")return this.styleArgumentText(z);return this.styleSubcommandText(z)}).join(" ")}styleArgumentTerm($){return this.styleArgumentText($)}styleOptionText($){return $}styleArgumentText($){return $}styleSubcommandText($){return $}styleCommandText($){return $}padWidth($,z){return Math.max(z.longestOptionTermLength($,z),z.longestGlobalOptionTermLength($,z),z.longestSubcommandTermLength($,z),z.longestArgumentTermLength($,z))}preformatted($){return/\n[^\S\r\n]/.test($)}formatItem($,z,q,B){let Y=" ".repeat(2);if(!q)return Y+$;let Z=$.padEnd(z+$.length-B.displayWidth($)),Q=2,_=(this.helpWidth??80)-z-Q-2,J;if(_<this.minWidthToWrap||B.preformatted(q))J=q;else J=B.boxWrap(q,_).replace(/\n/g,`
|
|
5
|
+
`+" ".repeat(z+Q));return Y+Z+" ".repeat(Q)+J.replace(/\n/g,`
|
|
6
|
+
${Y}`)}boxWrap($,z){if(z<this.minWidthToWrap)return $;let q=$.split(/\r\n|\n/),B=/[\s]*[^\s]+/g,X=[];return q.forEach((Y)=>{let Z=Y.match(B);if(Z===null){X.push("");return}let Q=[Z.shift()],R=this.displayWidth(Q[0]);Z.forEach((_)=>{let J=this.displayWidth(_);if(R+J<=z){Q.push(_),R+=J;return}X.push(Q.join(""));let U=_.trimStart();Q=[U],R=this.displayWidth(U)}),X.push(Q.join(""))}),X.join(`
|
|
7
|
+
`)}}function m($){let z=/\x1b\[\d*(;\d*)*m/g;return $.replace(z,"")}C$.Help=d;C$.stripColor=m});var k=E((g$)=>{var{InvalidArgumentError:u$}=N();class i{constructor($,z){this.flags=$,this.description=z||"",this.required=$.includes("<"),this.optional=$.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test($),this.mandatory=!1;let q=h$($);if(this.short=q.shortFlag,this.long=q.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,this.helpGroupHeading=void 0}default($,z){return this.defaultValue=$,this.defaultValueDescription=z,this}preset($){return this.presetArg=$,this}conflicts($){return this.conflictsWith=this.conflictsWith.concat($),this}implies($){let z=$;if(typeof $==="string")z={[$]:!0};return this.implied=Object.assign(this.implied||{},z),this}env($){return this.envVar=$,this}argParser($){return this.parseArg=$,this}makeOptionMandatory($=!0){return this.mandatory=!!$,this}hideHelp($=!0){return this.hidden=!!$,this}_collectValue($,z){if(z===this.defaultValue||!Array.isArray(z))return[$];return z.push($),z}choices($){return this.argChoices=$.slice(),this.parseArg=(z,q)=>{if(!this.argChoices.includes(z))throw new u$(`Allowed choices are ${this.argChoices.join(", ")}.`);if(this.variadic)return this._collectValue(z,q);return z},this}name(){if(this.long)return this.long.replace(/^--/,"");return this.short.replace(/^-/,"")}attributeName(){if(this.negate)return s(this.name().replace(/^no-/,""));return s(this.name())}helpGroup($){return this.helpGroupHeading=$,this}is($){return this.short===$||this.long===$}isBoolean(){return!this.required&&!this.optional&&!this.negate}}class p{constructor($){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,$.forEach((z)=>{if(z.negate)this.negativeOptions.set(z.attributeName(),z);else this.positiveOptions.set(z.attributeName(),z)}),this.negativeOptions.forEach((z,q)=>{if(this.positiveOptions.has(q))this.dualOptions.add(q)})}valueFromOption($,z){let q=z.attributeName();if(!this.dualOptions.has(q))return!0;let B=this.negativeOptions.get(q).presetArg,X=B!==void 0?B:!1;return z.negate===(X===$)}}function s($){return $.split("-").reduce((z,q)=>{return z+q[0].toUpperCase()+q.slice(1)})}function h$($){let z,q,B=/^-[^-]$/,X=/^--[^-]/,Y=$.split(/[ |,]+/).concat("guard");if(B.test(Y[0]))z=Y.shift();if(X.test(Y[0]))q=Y.shift();if(!z&&B.test(Y[0]))z=Y.shift();if(!z&&X.test(Y[0]))z=q,q=Y.shift();if(Y[0].startsWith("-")){let Z=Y[0],Q=`option creation failed due to '${Z}' in option flags '${$}'`;if(/^-[^-][^-]/.test(Z))throw Error(`${Q}
|
|
8
8
|
- a short flag is a single dash and a single character
|
|
9
9
|
- either use a single dash and a single character (for a short flag)
|
|
10
|
-
- or use a double dash for a long option (and can have two, like '--ws, --workspace')`);if(
|
|
11
|
-
- too many short flags`);if(X.test(Z))throw Error(`${
|
|
12
|
-
- too many long flags`);throw Error(`${
|
|
13
|
-
- unrecognised flag format`)}if(z===void 0&&
|
|
14
|
-
(Did you mean one of ${
|
|
15
|
-
(Did you mean ${
|
|
16
|
-
- specify the name in Command constructor or using .name()`);if(z=z||{},z.isDefault)this._defaultCommandName
|
|
17
|
-
Expecting one of '${
|
|
18
|
-
- already used by option '${z.flags}'`)}this._initOptionGroup(
|
|
19
|
-
- either make a new Command for each call to parse, or stop storing options as properties`);this._name=this._savedState._name,this._scriptPath=null,this.rawArgs=[],this._optionValues={...this._savedState._optionValues},this._optionValueSources={...this._savedState._optionValueSources},this.args=[],this.processedArgs=[]}_checkForMissingExecutable(
|
|
20
|
-
- if '${
|
|
10
|
+
- or use a double dash for a long option (and can have two, like '--ws, --workspace')`);if(B.test(Z))throw Error(`${Q}
|
|
11
|
+
- too many short flags`);if(X.test(Z))throw Error(`${Q}
|
|
12
|
+
- too many long flags`);throw Error(`${Q}
|
|
13
|
+
- unrecognised flag format`)}if(z===void 0&&q===void 0)throw Error(`option creation failed due to no flags found in '${$}'.`);return{shortFlag:z,longFlag:q}}g$.Option=i;g$.DualOptions=p});var r=E((s$)=>{function d$($,z){if(Math.abs($.length-z.length)>3)return Math.max($.length,z.length);let q=[];for(let B=0;B<=$.length;B++)q[B]=[B];for(let B=0;B<=z.length;B++)q[0][B]=B;for(let B=1;B<=z.length;B++)for(let X=1;X<=$.length;X++){let Y=1;if($[X-1]===z[B-1])Y=0;else Y=1;if(q[X][B]=Math.min(q[X-1][B]+1,q[X][B-1]+1,q[X-1][B-1]+Y),X>1&&B>1&&$[X-1]===z[B-2]&&$[X-2]===z[B-1])q[X][B]=Math.min(q[X][B],q[X-2][B-2]+1)}return q[$.length][z.length]}function m$($,z){if(!z||z.length===0)return"";z=Array.from(new Set(z));let q=$.startsWith("--");if(q)$=$.slice(2),z=z.map((Z)=>Z.slice(2));let B=[],X=3,Y=0.4;if(z.forEach((Z)=>{if(Z.length<=1)return;let Q=d$($,Z),R=Math.max($.length,Z.length);if((R-Q)/R>Y){if(Q<X)X=Q,B=[Z];else if(Q===X)B.push(Z)}}),B.sort((Z,Q)=>Z.localeCompare(Q)),q)B=B.map((Z)=>`--${Z}`);if(B.length>1)return`
|
|
14
|
+
(Did you mean one of ${B.join(", ")}?)`;if(B.length===1)return`
|
|
15
|
+
(Did you mean ${B[0]}?)`;return""}s$.suggestSimilar=m$});var o=E((e$)=>{var p$=D("events").EventEmitter,f=D("child_process"),G=D("path"),j=D("fs"),T=D("process"),{Argument:r$,humanReadableArgName:n$}=A(),{CommanderError:O}=N(),{Help:t$,stripColor:a$}=w(),{Option:n,DualOptions:o$}=k(),{suggestSimilar:t}=r();class C extends p${constructor($){super();this.commands=[],this.options=[],this.parent=null,this._allowUnknownOption=!1,this._allowExcessArguments=!1,this.registeredArguments=[],this._args=this.registeredArguments,this.args=[],this.rawArgs=[],this.processedArgs=[],this._scriptPath=null,this._name=$||"",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._savedState=null,this._outputConfiguration={writeOut:(z)=>T.stdout.write(z),writeErr:(z)=>T.stderr.write(z),outputError:(z,q)=>q(z),getOutHelpWidth:()=>T.stdout.isTTY?T.stdout.columns:void 0,getErrHelpWidth:()=>T.stderr.isTTY?T.stderr.columns:void 0,getOutHasColors:()=>x()??(T.stdout.isTTY&&T.stdout.hasColors?.()),getErrHasColors:()=>x()??(T.stderr.isTTY&&T.stderr.hasColors?.()),stripColor:(z)=>a$(z)},this._hidden=!1,this._helpOption=void 0,this._addImplicitHelpCommand=void 0,this._helpCommand=void 0,this._helpConfiguration={},this._helpGroupHeading=void 0,this._defaultCommandGroup=void 0,this._defaultOptionGroup=void 0}copyInheritedSettings($){return this._outputConfiguration=$._outputConfiguration,this._helpOption=$._helpOption,this._helpCommand=$._helpCommand,this._helpConfiguration=$._helpConfiguration,this._exitCallback=$._exitCallback,this._storeOptionsAsProperties=$._storeOptionsAsProperties,this._combineFlagAndOptionalValue=$._combineFlagAndOptionalValue,this._allowExcessArguments=$._allowExcessArguments,this._enablePositionalOptions=$._enablePositionalOptions,this._showHelpAfterError=$._showHelpAfterError,this._showSuggestionAfterError=$._showSuggestionAfterError,this}_getCommandAndAncestors(){let $=[];for(let z=this;z;z=z.parent)$.push(z);return $}command($,z,q){let B=z,X=q;if(typeof B==="object"&&B!==null)X=B,B=null;X=X||{};let[,Y,Z]=$.match(/([^ ]+) *(.*)/),Q=this.createCommand(Y);if(B)Q.description(B),Q._executableHandler=!0;if(X.isDefault)this._defaultCommandName=Q._name;if(Q._hidden=!!(X.noHelp||X.hidden),Q._executableFile=X.executableFile||null,Z)Q.arguments(Z);if(this._registerCommand(Q),Q.parent=this,Q.copyInheritedSettings(this),B)return this;return Q}createCommand($){return new C($)}createHelp(){return Object.assign(new t$,this.configureHelp())}configureHelp($){if($===void 0)return this._helpConfiguration;return this._helpConfiguration=$,this}configureOutput($){if($===void 0)return this._outputConfiguration;return this._outputConfiguration={...this._outputConfiguration,...$},this}showHelpAfterError($=!0){if(typeof $!=="string")$=!!$;return this._showHelpAfterError=$,this}showSuggestionAfterError($=!0){return this._showSuggestionAfterError=!!$,this}addCommand($,z){if(!$._name)throw Error(`Command passed to .addCommand() must have a name
|
|
16
|
+
- specify the name in Command constructor or using .name()`);if(z=z||{},z.isDefault)this._defaultCommandName=$._name;if(z.noHelp||z.hidden)$._hidden=!0;return this._registerCommand($),$.parent=this,$._checkForBrokenPassThrough(),this}createArgument($,z){return new r$($,z)}argument($,z,q,B){let X=this.createArgument($,z);if(typeof q==="function")X.default(B).argParser(q);else X.default(q);return this.addArgument(X),this}arguments($){return $.trim().split(/ +/).forEach((z)=>{this.argument(z)}),this}addArgument($){let z=this.registeredArguments.slice(-1)[0];if(z?.variadic)throw Error(`only the last argument can be variadic '${z.name()}'`);if($.required&&$.defaultValue!==void 0&&$.parseArg===void 0)throw Error(`a default value for a required argument is never used: '${$.name()}'`);return this.registeredArguments.push($),this}helpCommand($,z){if(typeof $==="boolean"){if(this._addImplicitHelpCommand=$,$&&this._defaultCommandGroup)this._initCommandGroup(this._getHelpCommand());return this}let q=$??"help [command]",[,B,X]=q.match(/([^ ]+) *(.*)/),Y=z??"display help for command",Z=this.createCommand(B);if(Z.helpOption(!1),X)Z.arguments(X);if(Y)Z.description(Y);if(this._addImplicitHelpCommand=!0,this._helpCommand=Z,$||z)this._initCommandGroup(Z);return this}addHelpCommand($,z){if(typeof $!=="object")return this.helpCommand($,z),this;return this._addImplicitHelpCommand=!0,this._helpCommand=$,this._initCommandGroup($),this}_getHelpCommand(){if(this._addImplicitHelpCommand??(this.commands.length&&!this._actionHandler&&!this._findCommand("help"))){if(this._helpCommand===void 0)this.helpCommand(void 0,void 0);return this._helpCommand}return null}hook($,z){let q=["preSubcommand","preAction","postAction"];if(!q.includes($))throw Error(`Unexpected value for event passed to hook : '${$}'.
|
|
17
|
+
Expecting one of '${q.join("', '")}'`);if(this._lifeCycleHooks[$])this._lifeCycleHooks[$].push(z);else this._lifeCycleHooks[$]=[z];return this}exitOverride($){if($)this._exitCallback=$;else this._exitCallback=(z)=>{if(z.code!=="commander.executeSubCommandAsync")throw z};return this}_exit($,z,q){if(this._exitCallback)this._exitCallback(new O($,z,q));T.exit($)}action($){let z=(q)=>{let B=this.registeredArguments.length,X=q.slice(0,B);if(this._storeOptionsAsProperties)X[B]=this;else X[B]=this.opts();return X.push(this),$.apply(this,X)};return this._actionHandler=z,this}createOption($,z){return new n($,z)}_callParseArg($,z,q,B){try{return $.parseArg(z,q)}catch(X){if(X.code==="commander.invalidArgument"){let Y=`${B} ${X.message}`;this.error(Y,{exitCode:X.exitCode,code:X.code})}throw X}}_registerOption($){let z=$.short&&this._findOption($.short)||$.long&&this._findOption($.long);if(z){let q=$.long&&this._findOption($.long)?$.long:$.short;throw Error(`Cannot add option '${$.flags}'${this._name&&` to command '${this._name}'`} due to conflicting flag '${q}'
|
|
18
|
+
- already used by option '${z.flags}'`)}this._initOptionGroup($),this.options.push($)}_registerCommand($){let z=(B)=>{return[B.name()].concat(B.aliases())},q=z($).find((B)=>this._findCommand(B));if(q){let B=z(this._findCommand(q)).join("|"),X=z($).join("|");throw Error(`cannot add command '${X}' as already have command '${B}'`)}this._initCommandGroup($),this.commands.push($)}addOption($){this._registerOption($);let z=$.name(),q=$.attributeName();if($.negate){let X=$.long.replace(/^--no-/,"--");if(!this._findOption(X))this.setOptionValueWithSource(q,$.defaultValue===void 0?!0:$.defaultValue,"default")}else if($.defaultValue!==void 0)this.setOptionValueWithSource(q,$.defaultValue,"default");let B=(X,Y,Z)=>{if(X==null&&$.presetArg!==void 0)X=$.presetArg;let Q=this.getOptionValue(q);if(X!==null&&$.parseArg)X=this._callParseArg($,X,Q,Y);else if(X!==null&&$.variadic)X=$._collectValue(X,Q);if(X==null)if($.negate)X=!1;else if($.isBoolean()||$.optional)X=!0;else X="";this.setOptionValueWithSource(q,X,Z)};if(this.on("option:"+z,(X)=>{let Y=`error: option '${$.flags}' argument '${X}' is invalid.`;B(X,Y,"cli")}),$.envVar)this.on("optionEnv:"+z,(X)=>{let Y=`error: option '${$.flags}' value '${X}' from env '${$.envVar}' is invalid.`;B(X,Y,"env")});return this}_optionEx($,z,q,B,X){if(typeof z==="object"&&z instanceof n)throw Error("To add an Option object use addOption() instead of option() or requiredOption()");let Y=this.createOption(z,q);if(Y.makeOptionMandatory(!!$.mandatory),typeof B==="function")Y.default(X).argParser(B);else if(B instanceof RegExp){let Z=B;B=(Q,R)=>{let _=Z.exec(Q);return _?_[0]:R},Y.default(X).argParser(B)}else Y.default(B);return this.addOption(Y)}option($,z,q,B){return this._optionEx({},$,z,q,B)}requiredOption($,z,q,B){return this._optionEx({mandatory:!0},$,z,q,B)}combineFlagAndOptionalValue($=!0){return this._combineFlagAndOptionalValue=!!$,this}allowUnknownOption($=!0){return this._allowUnknownOption=!!$,this}allowExcessArguments($=!0){return this._allowExcessArguments=!!$,this}enablePositionalOptions($=!0){return this._enablePositionalOptions=!!$,this}passThroughOptions($=!0){return this._passThroughOptions=!!$,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties($=!0){if(this.options.length)throw Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!$,this}getOptionValue($){if(this._storeOptionsAsProperties)return this[$];return this._optionValues[$]}setOptionValue($,z){return this.setOptionValueWithSource($,z,void 0)}setOptionValueWithSource($,z,q){if(this._storeOptionsAsProperties)this[$]=z;else this._optionValues[$]=z;return this._optionValueSources[$]=q,this}getOptionValueSource($){return this._optionValueSources[$]}getOptionValueSourceWithGlobals($){let z;return this._getCommandAndAncestors().forEach((q)=>{if(q.getOptionValueSource($)!==void 0)z=q.getOptionValueSource($)}),z}_prepareUserArgs($,z){if($!==void 0&&!Array.isArray($))throw Error("first parameter to parse must be array or undefined");if(z=z||{},$===void 0&&z.from===void 0){if(T.versions?.electron)z.from="electron";let B=T.execArgv??[];if(B.includes("-e")||B.includes("--eval")||B.includes("-p")||B.includes("--print"))z.from="eval"}if($===void 0)$=T.argv;this.rawArgs=$.slice();let q;switch(z.from){case void 0:case"node":this._scriptPath=$[1],q=$.slice(2);break;case"electron":if(T.defaultApp)this._scriptPath=$[1],q=$.slice(2);else q=$.slice(1);break;case"user":q=$.slice(0);break;case"eval":q=$.slice(1);break;default:throw Error(`unexpected parse option { from: '${z.from}' }`)}if(!this._name&&this._scriptPath)this.nameFromFilename(this._scriptPath);return this._name=this._name||"program",q}parse($,z){this._prepareForParse();let q=this._prepareUserArgs($,z);return this._parseCommand([],q),this}async parseAsync($,z){this._prepareForParse();let q=this._prepareUserArgs($,z);return await this._parseCommand([],q),this}_prepareForParse(){if(this._savedState===null)this.saveStateBeforeParse();else this.restoreStateBeforeParse()}saveStateBeforeParse(){this._savedState={_name:this._name,_optionValues:{...this._optionValues},_optionValueSources:{...this._optionValueSources}}}restoreStateBeforeParse(){if(this._storeOptionsAsProperties)throw Error(`Can not call parse again when storeOptionsAsProperties is true.
|
|
19
|
+
- either make a new Command for each call to parse, or stop storing options as properties`);this._name=this._savedState._name,this._scriptPath=null,this.rawArgs=[],this._optionValues={...this._savedState._optionValues},this._optionValueSources={...this._savedState._optionValueSources},this.args=[],this.processedArgs=[]}_checkForMissingExecutable($,z,q){if(j.existsSync($))return;let B=z?`searched for local subcommand relative to directory '${z}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",X=`'${$}' does not exist
|
|
20
|
+
- if '${q}' is not meant to be an executable command, remove description parameter from '.command()' and use '.description()' instead
|
|
21
21
|
- if the default executable name is not suitable, use the executableFile option to supply a custom name or path
|
|
22
|
-
- ${
|
|
22
|
+
- ${B}`;throw Error(X)}_executeSubCommand($,z){z=z.slice();let q=!1,B=[".js",".ts",".tsx",".mjs",".cjs"];function X(_,J){let U=G.resolve(_,J);if(j.existsSync(U))return U;if(B.includes(G.extname(J)))return;let L=B.find((W)=>j.existsSync(`${U}${W}`));if(L)return`${U}${L}`;return}this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let Y=$._executableFile||`${this._name}-${$._name}`,Z=this._executableDir||"";if(this._scriptPath){let _;try{_=j.realpathSync(this._scriptPath)}catch{_=this._scriptPath}Z=G.resolve(G.dirname(_),Z)}if(Z){let _=X(Z,Y);if(!_&&!$._executableFile&&this._scriptPath){let J=G.basename(this._scriptPath,G.extname(this._scriptPath));if(J!==this._name)_=X(Z,`${J}-${$._name}`)}Y=_||Y}q=B.includes(G.extname(Y));let Q;if(T.platform!=="win32")if(q)z.unshift(Y),z=a(T.execArgv).concat(z),Q=f.spawn(T.argv[0],z,{stdio:"inherit"});else Q=f.spawn(Y,z,{stdio:"inherit"});else this._checkForMissingExecutable(Y,Z,$._name),z.unshift(Y),z=a(T.execArgv).concat(z),Q=f.spawn(T.execPath,z,{stdio:"inherit"});if(!Q.killed)["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach((J)=>{T.on(J,()=>{if(Q.killed===!1&&Q.exitCode===null)Q.kill(J)})});let R=this._exitCallback;Q.on("close",(_)=>{if(_=_??1,!R)T.exit(_);else R(new O(_,"commander.executeSubCommandAsync","(close)"))}),Q.on("error",(_)=>{if(_.code==="ENOENT")this._checkForMissingExecutable(Y,Z,$._name);else if(_.code==="EACCES")throw Error(`'${Y}' not executable`);if(!R)T.exit(1);else{let J=new O(1,"commander.executeSubCommandAsync","(error)");J.nestedError=_,R(J)}}),this.runningCommand=Q}_dispatchSubcommand($,z,q){let B=this._findCommand($);if(!B)this.help({error:!0});B._prepareForParse();let X;return X=this._chainOrCallSubCommandHook(X,B,"preSubcommand"),X=this._chainOrCall(X,()=>{if(B._executableHandler)this._executeSubCommand(B,z.concat(q));else return B._parseCommand(z,q)}),X}_dispatchHelpCommand($){if(!$)this.help();let z=this._findCommand($);if(z&&!z._executableHandler)z.help();return this._dispatchSubcommand($,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){if(this.registeredArguments.forEach(($,z)=>{if($.required&&this.args[z]==null)this.missingArgument($.name())}),this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)return;if(this.args.length>this.registeredArguments.length)this._excessArguments(this.args)}_processArguments(){let $=(q,B,X)=>{let Y=B;if(B!==null&&q.parseArg){let Z=`error: command-argument value '${B}' is invalid for argument '${q.name()}'.`;Y=this._callParseArg(q,B,X,Z)}return Y};this._checkNumberOfArguments();let z=[];this.registeredArguments.forEach((q,B)=>{let X=q.defaultValue;if(q.variadic){if(B<this.args.length){if(X=this.args.slice(B),q.parseArg)X=X.reduce((Y,Z)=>{return $(q,Z,Y)},q.defaultValue)}else if(X===void 0)X=[]}else if(B<this.args.length){if(X=this.args[B],q.parseArg)X=$(q,X,q.defaultValue)}z[B]=X}),this.processedArgs=z}_chainOrCall($,z){if($?.then&&typeof $.then==="function")return $.then(()=>z());return z()}_chainOrCallHooks($,z){let q=$,B=[];if(this._getCommandAndAncestors().reverse().filter((X)=>X._lifeCycleHooks[z]!==void 0).forEach((X)=>{X._lifeCycleHooks[z].forEach((Y)=>{B.push({hookedCommand:X,callback:Y})})}),z==="postAction")B.reverse();return B.forEach((X)=>{q=this._chainOrCall(q,()=>{return X.callback(X.hookedCommand,this)})}),q}_chainOrCallSubCommandHook($,z,q){let B=$;if(this._lifeCycleHooks[q]!==void 0)this._lifeCycleHooks[q].forEach((X)=>{B=this._chainOrCall(B,()=>{return X(this,z)})});return B}_parseCommand($,z){let q=this.parseOptions(z);if(this._parseOptionsEnv(),this._parseOptionsImplied(),$=$.concat(q.operands),z=q.unknown,this.args=$.concat(z),$&&this._findCommand($[0]))return this._dispatchSubcommand($[0],$.slice(1),z);if(this._getHelpCommand()&&$[0]===this._getHelpCommand().name())return this._dispatchHelpCommand($[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(z),this._dispatchSubcommand(this._defaultCommandName,$,z);if(this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName)this.help({error:!0});this._outputHelpIfRequested(q.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let B=()=>{if(q.unknown.length>0)this.unknownOption(q.unknown[0])},X=`command:${this.name()}`;if(this._actionHandler){B(),this._processArguments();let Y;if(Y=this._chainOrCallHooks(Y,"preAction"),Y=this._chainOrCall(Y,()=>this._actionHandler(this.processedArgs)),this.parent)Y=this._chainOrCall(Y,()=>{this.parent.emit(X,$,z)});return Y=this._chainOrCallHooks(Y,"postAction"),Y}if(this.parent?.listenerCount(X))B(),this._processArguments(),this.parent.emit(X,$,z);else if($.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",$,z);if(this.listenerCount("command:*"))this.emit("command:*",$,z);else if(this.commands.length)this.unknownCommand();else B(),this._processArguments()}else if(this.commands.length)B(),this.help({error:!0});else B(),this._processArguments()}_findCommand($){if(!$)return;return this.commands.find((z)=>z._name===$||z._aliases.includes($))}_findOption($){return this.options.find((z)=>z.is($))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(($)=>{$.options.forEach((z)=>{if(z.mandatory&&$.getOptionValue(z.attributeName())===void 0)$.missingMandatoryOptionValue(z)})})}_checkForConflictingLocalOptions(){let $=this.options.filter((q)=>{let B=q.attributeName();if(this.getOptionValue(B)===void 0)return!1;return this.getOptionValueSource(B)!=="default"});$.filter((q)=>q.conflictsWith.length>0).forEach((q)=>{let B=$.find((X)=>q.conflictsWith.includes(X.attributeName()));if(B)this._conflictingOption(q,B)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(($)=>{$._checkForConflictingLocalOptions()})}parseOptions($){let z=[],q=[],B=z;function X(_){return _.length>1&&_[0]==="-"}let Y=(_)=>{if(!/^-\d*\.?\d+(e[+-]?\d+)?$/.test(_))return!1;return!this._getCommandAndAncestors().some((J)=>J.options.map((U)=>U.short).some((U)=>/^-\d$/.test(U)))},Z=null,Q=null,R=0;while(R<$.length||Q){let _=Q??$[R++];if(Q=null,_==="--"){if(B===q)B.push(_);B.push(...$.slice(R));break}if(Z&&(!X(_)||Y(_))){this.emit(`option:${Z.name()}`,_);continue}if(Z=null,X(_)){let J=this._findOption(_);if(J){if(J.required){let U=$[R++];if(U===void 0)this.optionMissingArgument(J);this.emit(`option:${J.name()}`,U)}else if(J.optional){let U=null;if(R<$.length&&(!X($[R])||Y($[R])))U=$[R++];this.emit(`option:${J.name()}`,U)}else this.emit(`option:${J.name()}`);Z=J.variadic?J:null;continue}}if(_.length>2&&_[0]==="-"&&_[1]!=="-"){let J=this._findOption(`-${_[1]}`);if(J){if(J.required||J.optional&&this._combineFlagAndOptionalValue)this.emit(`option:${J.name()}`,_.slice(2));else this.emit(`option:${J.name()}`),Q=`-${_.slice(2)}`;continue}}if(/^--[^=]+=/.test(_)){let J=_.indexOf("="),U=this._findOption(_.slice(0,J));if(U&&(U.required||U.optional)){this.emit(`option:${U.name()}`,_.slice(J+1));continue}}if(B===z&&X(_)&&!(this.commands.length===0&&Y(_)))B=q;if((this._enablePositionalOptions||this._passThroughOptions)&&z.length===0&&q.length===0){if(this._findCommand(_)){z.push(_),q.push(...$.slice(R));break}else if(this._getHelpCommand()&&_===this._getHelpCommand().name()){z.push(_,...$.slice(R));break}else if(this._defaultCommandName){q.push(_,...$.slice(R));break}}if(this._passThroughOptions){B.push(_,...$.slice(R));break}B.push(_)}return{operands:z,unknown:q}}opts(){if(this._storeOptionsAsProperties){let $={},z=this.options.length;for(let q=0;q<z;q++){let B=this.options[q].attributeName();$[B]=B===this._versionOptionName?this._version:this[B]}return $}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce(($,z)=>Object.assign($,z.opts()),{})}error($,z){if(this._outputConfiguration.outputError(`${$}
|
|
23
23
|
`,this._outputConfiguration.writeErr),typeof this._showHelpAfterError==="string")this._outputConfiguration.writeErr(`${this._showHelpAfterError}
|
|
24
24
|
`);else if(this._showHelpAfterError)this._outputConfiguration.writeErr(`
|
|
25
|
-
`),this.outputHelp({error:!0});let
|
|
26
|
-
`),this._exit(0,"commander.version"
|
|
27
|
-
Expecting one of '${
|
|
28
|
-
`)}),this}_outputHelpIfRequested(
|
|
25
|
+
`),this.outputHelp({error:!0});let q=z||{},B=q.exitCode||1,X=q.code||"commander.error";this._exit(B,X,$)}_parseOptionsEnv(){this.options.forEach(($)=>{if($.envVar&&$.envVar in T.env){let z=$.attributeName();if(this.getOptionValue(z)===void 0||["default","config","env"].includes(this.getOptionValueSource(z)))if($.required||$.optional)this.emit(`optionEnv:${$.name()}`,T.env[$.envVar]);else this.emit(`optionEnv:${$.name()}`)}})}_parseOptionsImplied(){let $=new o$(this.options),z=(q)=>{return this.getOptionValue(q)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(q))};this.options.filter((q)=>q.implied!==void 0&&z(q.attributeName())&&$.valueFromOption(this.getOptionValue(q.attributeName()),q)).forEach((q)=>{Object.keys(q.implied).filter((B)=>!z(B)).forEach((B)=>{this.setOptionValueWithSource(B,q.implied[B],"implied")})})}missingArgument($){let z=`error: missing required argument '${$}'`;this.error(z,{code:"commander.missingArgument"})}optionMissingArgument($){let z=`error: option '${$.flags}' argument missing`;this.error(z,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue($){let z=`error: required option '${$.flags}' not specified`;this.error(z,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption($,z){let q=(Y)=>{let Z=Y.attributeName(),Q=this.getOptionValue(Z),R=this.options.find((J)=>J.negate&&Z===J.attributeName()),_=this.options.find((J)=>!J.negate&&Z===J.attributeName());if(R&&(R.presetArg===void 0&&Q===!1||R.presetArg!==void 0&&Q===R.presetArg))return R;return _||Y},B=(Y)=>{let Z=q(Y),Q=Z.attributeName();if(this.getOptionValueSource(Q)==="env")return`environment variable '${Z.envVar}'`;return`option '${Z.flags}'`},X=`error: ${B($)} cannot be used with ${B(z)}`;this.error(X,{code:"commander.conflictingOption"})}unknownOption($){if(this._allowUnknownOption)return;let z="";if($.startsWith("--")&&this._showSuggestionAfterError){let B=[],X=this;do{let Y=X.createHelp().visibleOptions(X).filter((Z)=>Z.long).map((Z)=>Z.long);B=B.concat(Y),X=X.parent}while(X&&!X._enablePositionalOptions);z=t($,B)}let q=`error: unknown option '${$}'${z}`;this.error(q,{code:"commander.unknownOption"})}_excessArguments($){if(this._allowExcessArguments)return;let z=this.registeredArguments.length,q=z===1?"":"s",X=`error: too many arguments${this.parent?` for '${this.name()}'`:""}. Expected ${z} argument${q} but got ${$.length}.`;this.error(X,{code:"commander.excessArguments"})}unknownCommand(){let $=this.args[0],z="";if(this._showSuggestionAfterError){let B=[];this.createHelp().visibleCommands(this).forEach((X)=>{if(B.push(X.name()),X.alias())B.push(X.alias())}),z=t($,B)}let q=`error: unknown command '${$}'${z}`;this.error(q,{code:"commander.unknownCommand"})}version($,z,q){if($===void 0)return this._version;this._version=$,z=z||"-V, --version",q=q||"output the version number";let B=this.createOption(z,q);return this._versionOptionName=B.attributeName(),this._registerOption(B),this.on("option:"+B.name(),()=>{this._outputConfiguration.writeOut(`${$}
|
|
26
|
+
`),this._exit(0,"commander.version",$)}),this}description($,z){if($===void 0&&z===void 0)return this._description;if(this._description=$,z)this._argsDescription=z;return this}summary($){if($===void 0)return this._summary;return this._summary=$,this}alias($){if($===void 0)return this._aliases[0];let z=this;if(this.commands.length!==0&&this.commands[this.commands.length-1]._executableHandler)z=this.commands[this.commands.length-1];if($===z._name)throw Error("Command alias can't be the same as its name");let q=this.parent?._findCommand($);if(q){let B=[q.name()].concat(q.aliases()).join("|");throw Error(`cannot add alias '${$}' to command '${this.name()}' as already have command '${B}'`)}return z._aliases.push($),this}aliases($){if($===void 0)return this._aliases;return $.forEach((z)=>this.alias(z)),this}usage($){if($===void 0){if(this._usage)return this._usage;let z=this.registeredArguments.map((q)=>{return n$(q)});return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?z:[]).join(" ")}return this._usage=$,this}name($){if($===void 0)return this._name;return this._name=$,this}helpGroup($){if($===void 0)return this._helpGroupHeading??"";return this._helpGroupHeading=$,this}commandsGroup($){if($===void 0)return this._defaultCommandGroup??"";return this._defaultCommandGroup=$,this}optionsGroup($){if($===void 0)return this._defaultOptionGroup??"";return this._defaultOptionGroup=$,this}_initOptionGroup($){if(this._defaultOptionGroup&&!$.helpGroupHeading)$.helpGroup(this._defaultOptionGroup)}_initCommandGroup($){if(this._defaultCommandGroup&&!$.helpGroup())$.helpGroup(this._defaultCommandGroup)}nameFromFilename($){return this._name=G.basename($,G.extname($)),this}executableDir($){if($===void 0)return this._executableDir;return this._executableDir=$,this}helpInformation($){let z=this.createHelp(),q=this._getOutputContext($);z.prepareContext({error:q.error,helpWidth:q.helpWidth,outputHasColors:q.hasColors});let B=z.formatHelp(this,z);if(q.hasColors)return B;return this._outputConfiguration.stripColor(B)}_getOutputContext($){$=$||{};let z=!!$.error,q,B,X;if(z)q=(Z)=>this._outputConfiguration.writeErr(Z),B=this._outputConfiguration.getErrHasColors(),X=this._outputConfiguration.getErrHelpWidth();else q=(Z)=>this._outputConfiguration.writeOut(Z),B=this._outputConfiguration.getOutHasColors(),X=this._outputConfiguration.getOutHelpWidth();return{error:z,write:(Z)=>{if(!B)Z=this._outputConfiguration.stripColor(Z);return q(Z)},hasColors:B,helpWidth:X}}outputHelp($){let z;if(typeof $==="function")z=$,$=void 0;let q=this._getOutputContext($),B={error:q.error,write:q.write,command:this};this._getCommandAndAncestors().reverse().forEach((Y)=>Y.emit("beforeAllHelp",B)),this.emit("beforeHelp",B);let X=this.helpInformation({error:q.error});if(z){if(X=z(X),typeof X!=="string"&&!Buffer.isBuffer(X))throw Error("outputHelp callback must return a string or a Buffer")}if(q.write(X),this._getHelpOption()?.long)this.emit(this._getHelpOption().long);this.emit("afterHelp",B),this._getCommandAndAncestors().forEach((Y)=>Y.emit("afterAllHelp",B))}helpOption($,z){if(typeof $==="boolean"){if($){if(this._helpOption===null)this._helpOption=void 0;if(this._defaultOptionGroup)this._initOptionGroup(this._getHelpOption())}else this._helpOption=null;return this}if(this._helpOption=this.createOption($??"-h, --help",z??"display help for command"),$||z)this._initOptionGroup(this._helpOption);return this}_getHelpOption(){if(this._helpOption===void 0)this.helpOption(void 0,void 0);return this._helpOption}addHelpOption($){return this._helpOption=$,this._initOptionGroup($),this}help($){this.outputHelp($);let z=Number(T.exitCode??0);if(z===0&&$&&typeof $!=="function"&&$.error)z=1;this._exit(z,"commander.help","(outputHelp)")}addHelpText($,z){let q=["beforeAll","before","after","afterAll"];if(!q.includes($))throw Error(`Unexpected value for position to addHelpText.
|
|
27
|
+
Expecting one of '${q.join("', '")}'`);let B=`${$}Help`;return this.on(B,(X)=>{let Y;if(typeof z==="function")Y=z({error:X.error,command:X.command});else Y=z;if(Y)X.write(`${Y}
|
|
28
|
+
`)}),this}_outputHelpIfRequested($){let z=this._getHelpOption();if(z&&$.find((B)=>z.is(B)))this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)")}}function a($){return $.map((z)=>{if(!z.startsWith("--inspect"))return z;let q,B="127.0.0.1",X="9229",Y;if((Y=z.match(/^(--inspect(-brk)?)$/))!==null)q=Y[1];else if((Y=z.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null)if(q=Y[1],/^\d+$/.test(Y[3]))X=Y[3];else B=Y[3];else if((Y=z.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null)q=Y[1],B=Y[3],X=Y[4];if(q&&X!=="0")return`${q}=${B}:${parseInt(X)+1}`;return z})}function x(){if(T.env.NO_COLOR||T.env.FORCE_COLOR==="0"||T.env.FORCE_COLOR==="false")return!1;if(T.env.FORCE_COLOR||T.env.CLICOLOR_FORCE!==void 0)return!0;return}e$.Command=C;e$.useColor=x});var q$=E((Xz)=>{var{Argument:e}=A(),{Command:b}=o(),{CommanderError:qz,InvalidArgumentError:$$}=N(),{Help:Bz}=w(),{Option:z$}=k();Xz.program=new b;Xz.createCommand=($)=>new b($);Xz.createOption=($,z)=>new z$($,z);Xz.createArgument=($,z)=>new e($,z);Xz.Command=b;Xz.Option=z$;Xz.Argument=e;Xz.Help=Bz;Xz.CommanderError=qz;Xz.InvalidArgumentError=$$;Xz.InvalidOptionArgumentError=$$});var Z$={};y(Z$,{registerNewCommand:()=>Ez});import{mkdir as K,writeFile as M}from"fs/promises";import{readFileSync as Gz,existsSync as Y$}from"fs";import{join as H}from"path";async function Wz($){await M(H($,"public","docs.html"),`<!DOCTYPE html>
|
|
29
|
+
<html lang="en">
|
|
30
|
+
<head>
|
|
31
|
+
<meta charset="utf-8" />
|
|
32
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
33
|
+
<title>API Documentation</title>
|
|
34
|
+
<link rel="stylesheet" href="https://unpkg.com/swagger-ui-dist@latest/swagger-ui.css" />
|
|
35
|
+
<style>
|
|
36
|
+
body { margin: 0; padding: 0; }
|
|
37
|
+
</style>
|
|
38
|
+
</head>
|
|
39
|
+
<body>
|
|
40
|
+
<div id="swagger-ui"></div>
|
|
41
|
+
<script src="https://unpkg.com/swagger-ui-dist@latest/swagger-ui-bundle.js" crossorigin></script>
|
|
42
|
+
<script src="https://unpkg.com/swagger-ui-dist@latest/swagger-ui-standalone-preset.js" crossorigin></script>
|
|
43
|
+
<script>
|
|
44
|
+
window.onload = () => {
|
|
45
|
+
window.ui = SwaggerUIBundle({
|
|
46
|
+
url: 'http://localhost:3000/openapi.json',
|
|
47
|
+
dom_id: '#swagger-ui',
|
|
48
|
+
deepLinking: true,
|
|
49
|
+
presets: [
|
|
50
|
+
SwaggerUIBundle.presets.apis,
|
|
51
|
+
SwaggerUIStandalonePreset
|
|
52
|
+
],
|
|
53
|
+
layout: "StandaloneLayout"
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
</script>
|
|
57
|
+
</body>
|
|
58
|
+
</html>`)}function Ez($){$.command("new").description("Create a new VeloceTS project").argument("<name>","Project name").option("-t, --template <template>","Project template (rest, graphql, websocket, fullstack)","rest").action(async(z,q)=>{await Iz(z,q)})}async function Iz($,z){let q=H(process.cwd(),$);if(!$||$.trim()==="")console.error("\u274C Error: Project name cannot be empty"),process.exit(1);if(Y$(q))console.error(`\u274C Error: Directory "${$}" already exists`),process.exit(1);console.log(`\uD83D\uDE80 Creating new VeloceTS project: ${$}`),console.log(`\uD83D\uDCCB Template: ${z.template}`);try{switch(console.log("\uD83D\uDCC1 Creating project directories..."),await K(q,{recursive:!0}),await K(H(q,"src"),{recursive:!0}),await K(H(q,"src","controllers"),{recursive:!0}),console.log("\uD83D\uDCC4 Generating configuration files..."),await Sz(q,$),await Vz(q),await Dz(q),await Nz(q,$,z.template),console.log("\uD83D\uDD27 Generating template files..."),z.template){case"rest":await yz(q);break;case"graphql":await Fz(q);break;case"websocket":await Az(q);break;case"fullstack":await jz(q);break;default:throw Error(`Unknown template: ${z.template}`)}console.log("\uD83D\uDCDA Setting up documentation..."),await K(H(q,"public"),{recursive:!0}),await Wz(q),console.log(`
|
|
59
|
+
\u2705 Project created successfully!`),console.log(`
|
|
60
|
+
\uD83D\uDCCB Next steps:`),console.log(` cd ${$}`),console.log(" bun install"),console.log(" bun run dev"),console.log(`
|
|
61
|
+
\uD83C\uDF10 Your API will be available at:`),console.log(" http://localhost:3000"),console.log(" http://localhost:3000/docs (API Documentation)")}catch(B){console.error("\u274C Error creating project:",B);try{if(Y$(q))console.log("\uD83E\uDDF9 Cleaning up partial project..."),console.warn(`\u26A0\uFE0F Please manually remove the directory: ${q}`)}catch(X){console.warn("\u26A0\uFE0F Could not clean up partial project:",X)}process.exit(1)}}async function Sz($,z){console.log("\uD83D\uDCE6 Fetching latest VeloceTS version from npm...");let q=await Kz();console.log(`\u2705 Using VeloceTS version: ${q}`);let B={name:z,version:"0.1.0",description:"A Veloce-TS application",type:"module",main:"./dist/index.js",scripts:{dev:"bun --watch src/index.ts",build:"bun build src/index.ts --outdir dist --target bun",start:"bun run dist/index.js","generate:openapi":"bun run node_modules/veloce-ts/bin/veloce.ts generate openapi","generate:client":"bun run node_modules/veloce-ts/bin/veloce.ts generate client"},dependencies:{"veloce-ts":`^${q}`,hono:"^4.0.0","reflect-metadata":"^0.2.0",zod:"^3.22.0"},devDependencies:{"@types/bun":"latest",typescript:"^5.3.0"},engines:{node:">=18.0.0",bun:">=1.0.0"}};await M(H($,"package.json"),JSON.stringify(B,null,2))}async function Vz($){let z={compilerOptions:{target:"ES2022",module:"ESNext",lib:["ES2022"],moduleResolution:"bundler",experimentalDecorators:!0,emitDecoratorMetadata:!0,strict:!0,esModuleInterop:!0,skipLibCheck:!0,forceConsistentCasingInFileNames:!0,resolveJsonModule:!0,outDir:"./dist",rootDir:"./src"},include:["src/**/*"],exclude:["node_modules","dist"]};await M(H($,"tsconfig.json"),JSON.stringify(z,null,2))}async function Dz($){await M(H($,".gitignore"),`node_modules/
|
|
62
|
+
dist/
|
|
63
|
+
*.log
|
|
64
|
+
.env
|
|
65
|
+
.DS_Store
|
|
66
|
+
`)}async function Nz($,z,q){let B=`# ${z}
|
|
29
67
|
|
|
30
|
-
|
|
68
|
+
A modern TypeScript API built with [Veloce-TS](https://github.com/AlfredoMejia3001/veloce-ts) using the **${q}** template.
|
|
69
|
+
|
|
70
|
+
## Getting Started
|
|
71
|
+
|
|
72
|
+
### Install Dependencies
|
|
73
|
+
|
|
74
|
+
\`\`\`bash
|
|
75
|
+
bun install
|
|
76
|
+
\`\`\`
|
|
77
|
+
|
|
78
|
+
### Development
|
|
79
|
+
|
|
80
|
+
Run the development server with hot reload:
|
|
81
|
+
|
|
82
|
+
\`\`\`bash
|
|
83
|
+
bun run dev
|
|
84
|
+
\`\`\`
|
|
85
|
+
|
|
86
|
+
Your API will be available at http://localhost:3000
|
|
87
|
+
|
|
88
|
+
### Production
|
|
89
|
+
|
|
90
|
+
Build and start the production server:
|
|
91
|
+
|
|
92
|
+
\`\`\`bash
|
|
93
|
+
bun run build
|
|
94
|
+
bun run start
|
|
95
|
+
\`\`\`
|
|
96
|
+
|
|
97
|
+
## Documentation
|
|
98
|
+
|
|
99
|
+
- **API Documentation**: Visit http://localhost:3000/docs.html for interactive Swagger UI
|
|
100
|
+
- **Veloce-TS Docs**: Check out the [official documentation](https://docs.veloce-ts.com)
|
|
101
|
+
|
|
102
|
+
## Project Structure
|
|
103
|
+
|
|
104
|
+
\`\`\`
|
|
105
|
+
${z}/
|
|
106
|
+
\u251C\u2500\u2500 src/
|
|
107
|
+
\u2502 \u2514\u2500\u2500 index.ts # Application entry point
|
|
108
|
+
\u251C\u2500\u2500 package.json
|
|
109
|
+
\u251C\u2500\u2500 tsconfig.json
|
|
110
|
+
\u2514\u2500\u2500 README.md
|
|
111
|
+
\`\`\`
|
|
112
|
+
|
|
113
|
+
## Learn More
|
|
114
|
+
|
|
115
|
+
- [Veloce-TS GitHub](https://github.com/AlfredoMejia3001/veloce-ts)
|
|
116
|
+
- [TypeScript Documentation](https://www.typescriptlang.org/docs/)
|
|
117
|
+
- [Bun Documentation](https://bun.sh/docs)
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
Built with Veloce-TS
|
|
122
|
+
`;await M(H($,"README.md"),B)}async function yz($){await M(H($,"src","index.ts"),`import 'reflect-metadata';
|
|
123
|
+
import { Veloce, OpenAPIPlugin } from 'veloce-ts';
|
|
124
|
+
import { UserController } from './controllers/user.controller';
|
|
125
|
+
|
|
126
|
+
const app = new Veloce({
|
|
127
|
+
title: 'My REST API',
|
|
128
|
+
version: '1.0.0',
|
|
129
|
+
description: 'A REST API built with VeloceTS',
|
|
130
|
+
docs: true,
|
|
131
|
+
cors: {
|
|
132
|
+
origin: '*',
|
|
133
|
+
credentials: true,
|
|
134
|
+
},
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
// Enable OpenAPI documentation
|
|
138
|
+
app.usePlugin(new OpenAPIPlugin({
|
|
139
|
+
path: '/openapi.json',
|
|
140
|
+
docsPath: '/docs',
|
|
141
|
+
}));
|
|
142
|
+
|
|
143
|
+
// Register controllers
|
|
144
|
+
app.include(UserController);
|
|
145
|
+
|
|
146
|
+
// Add a simple docs route
|
|
147
|
+
app.get('/docs', {
|
|
148
|
+
handler: async (c) => {
|
|
149
|
+
const html = \`<!DOCTYPE html>
|
|
150
|
+
<html lang="en">
|
|
151
|
+
<head>
|
|
152
|
+
<meta charset="UTF-8">
|
|
153
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
154
|
+
<title>API Documentation</title>
|
|
155
|
+
<link rel="stylesheet" href="https://unpkg.com/swagger-ui-dist@5.9.0/swagger-ui.css" />
|
|
156
|
+
</head>
|
|
157
|
+
<body>
|
|
158
|
+
<div id="swagger-ui"></div>
|
|
159
|
+
<script src="https://unpkg.com/swagger-ui-dist@5.9.0/swagger-ui-bundle.js"></script>
|
|
160
|
+
<script src="https://unpkg.com/swagger-ui-dist@5.9.0/swagger-ui-standalone-preset.js"></script>
|
|
161
|
+
<script>
|
|
162
|
+
window.onload = function() {
|
|
163
|
+
window.ui = SwaggerUIBundle({
|
|
164
|
+
url: '/openapi.json',
|
|
165
|
+
dom_id: '#swagger-ui',
|
|
166
|
+
deepLinking: true,
|
|
167
|
+
presets: [SwaggerUIBundle.presets.apis, SwaggerUIStandalonePreset],
|
|
168
|
+
layout: "StandaloneLayout"
|
|
169
|
+
});
|
|
170
|
+
};
|
|
171
|
+
</script>
|
|
172
|
+
</body>
|
|
173
|
+
</html>\`;
|
|
174
|
+
|
|
175
|
+
return new Response(html, {
|
|
176
|
+
headers: { 'Content-Type': 'text/html; charset=utf-8' }
|
|
177
|
+
});
|
|
178
|
+
},
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
// Start server
|
|
182
|
+
async function startServer() {
|
|
183
|
+
try {
|
|
184
|
+
console.log('\uD83D\uDD04 Compiling application...');
|
|
185
|
+
await app.compile();
|
|
186
|
+
console.log('\u2705 Application compiled successfully');
|
|
187
|
+
|
|
188
|
+
app.listen(3000, () => {
|
|
189
|
+
console.log('\uD83D\uDE80 Server running on http://localhost:3000');
|
|
190
|
+
console.log('\uD83D\uDCDA API Docs available at http://localhost:3000/docs');
|
|
191
|
+
console.log('\uD83D\uDCC4 OpenAPI Spec at http://localhost:3000/openapi.json');
|
|
192
|
+
});
|
|
193
|
+
} catch (error) {
|
|
194
|
+
console.error('\u274C Error starting server:', error);
|
|
195
|
+
process.exit(1);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
startServer();
|
|
200
|
+
`);let q=`import { Controller, Get, Post, Body, Param } from 'veloce-ts';
|
|
201
|
+
import { z } from 'zod';
|
|
202
|
+
|
|
203
|
+
const UserSchema = z.object({
|
|
204
|
+
name: z.string(),
|
|
205
|
+
email: z.string().email(),
|
|
206
|
+
age: z.number().min(0).optional(),
|
|
207
|
+
});
|
|
208
|
+
|
|
209
|
+
type User = z.infer<typeof UserSchema>;
|
|
210
|
+
|
|
211
|
+
@Controller('/users')
|
|
212
|
+
export class UserController {
|
|
213
|
+
private users: User[] = [];
|
|
214
|
+
|
|
215
|
+
@Get('/')
|
|
216
|
+
async getUsers() {
|
|
217
|
+
return { users: this.users };
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
@Get('/:id')
|
|
221
|
+
async getUser(@Param('id') id: string) {
|
|
222
|
+
const user = this.users[parseInt(id)];
|
|
223
|
+
if (!user) {
|
|
224
|
+
throw new Error('User not found');
|
|
225
|
+
}
|
|
226
|
+
return user;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
@Post('/')
|
|
230
|
+
async createUser(@Body(UserSchema) user: User) {
|
|
231
|
+
this.users.push(user);
|
|
232
|
+
return { message: 'User created', user };
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
`;await M(H($,"src","controllers","user.controller.ts"),q)}async function Fz($){await K(H($,"src","resolvers"),{recursive:!0});let z=`import 'reflect-metadata';
|
|
236
|
+
import { Veloce } from 'veloce-ts';
|
|
237
|
+
import { GraphQLPlugin } from 'veloce-ts/plugins';
|
|
238
|
+
import { UserResolver } from './resolvers/user.resolver';
|
|
239
|
+
|
|
240
|
+
const app = new Veloce({
|
|
241
|
+
title: 'My GraphQL API',
|
|
242
|
+
version: '1.0.0',
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
// Enable GraphQL
|
|
246
|
+
app.usePlugin(new GraphQLPlugin({
|
|
247
|
+
resolvers: [UserResolver],
|
|
248
|
+
}));
|
|
249
|
+
|
|
250
|
+
// Compile routes
|
|
251
|
+
await app.compile();
|
|
252
|
+
|
|
253
|
+
app.listen(3000, () => {
|
|
254
|
+
console.log('Server running on http://localhost:3000');
|
|
255
|
+
console.log('GraphQL Playground at http://localhost:3000/graphql');
|
|
256
|
+
});
|
|
257
|
+
`;await M(H($,"src","index.ts"),z);let q=`import { Resolver, Query, Mutation, Arg } from 'veloce-ts/graphql';
|
|
258
|
+
import { z } from 'zod';
|
|
259
|
+
|
|
260
|
+
const UserSchema = z.object({
|
|
261
|
+
id: z.string(),
|
|
262
|
+
name: z.string(),
|
|
263
|
+
email: z.string().email(),
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
type User = z.infer<typeof UserSchema>;
|
|
267
|
+
|
|
268
|
+
@Resolver()
|
|
269
|
+
export class UserResolver {
|
|
270
|
+
private users: User[] = [];
|
|
271
|
+
|
|
272
|
+
@Query()
|
|
273
|
+
async users(): Promise<User[]> {
|
|
274
|
+
return this.users;
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
@Query()
|
|
278
|
+
async user(@Arg('id', z.string()) id: string): Promise<User | null> {
|
|
279
|
+
return this.users.find(u => u.id === id) || null;
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
@Mutation()
|
|
283
|
+
async createUser(
|
|
284
|
+
@Arg('name', z.string()) name: string,
|
|
285
|
+
@Arg('email', z.string().email()) email: string
|
|
286
|
+
): Promise<User> {
|
|
287
|
+
const user = { id: Date.now().toString(), name, email };
|
|
288
|
+
this.users.push(user);
|
|
289
|
+
return user;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
`;await M(H($,"src","resolvers","user.resolver.ts"),q)}async function Az($){await K(H($,"src","websockets"),{recursive:!0});let z=`import 'reflect-metadata';
|
|
293
|
+
import { Veloce } from 'veloce-ts';
|
|
294
|
+
import { WebSocketPlugin } from 'veloce-ts/plugins';
|
|
295
|
+
import { ChatWebSocket } from './websockets/chat.websocket';
|
|
296
|
+
|
|
297
|
+
const app = new Veloce({
|
|
298
|
+
title: 'My WebSocket API',
|
|
299
|
+
version: '1.0.0',
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
// Enable WebSocket
|
|
303
|
+
app.usePlugin(new WebSocketPlugin({
|
|
304
|
+
handlers: [ChatWebSocket],
|
|
305
|
+
}));
|
|
306
|
+
|
|
307
|
+
// Compile routes
|
|
308
|
+
await app.compile();
|
|
309
|
+
|
|
310
|
+
app.listen(3000, () => {
|
|
311
|
+
console.log('Server running on http://localhost:3000');
|
|
312
|
+
console.log('WebSocket endpoint at ws://localhost:3000/ws/chat');
|
|
313
|
+
});
|
|
314
|
+
`;await M(H($,"src","index.ts"),z);let q=`import { WebSocket, OnConnect, OnMessage, OnDisconnect } from 'veloce-ts/websocket';
|
|
315
|
+
import { z } from 'zod';
|
|
316
|
+
import type { WebSocketConnection } from 'veloce-ts/websocket';
|
|
317
|
+
|
|
318
|
+
const MessageSchema = z.object({
|
|
319
|
+
type: z.enum(['message', 'join', 'leave']),
|
|
320
|
+
content: z.string(),
|
|
321
|
+
username: z.string(),
|
|
322
|
+
});
|
|
323
|
+
|
|
324
|
+
@WebSocket('/ws/chat')
|
|
325
|
+
export class ChatWebSocket {
|
|
326
|
+
@OnConnect()
|
|
327
|
+
handleConnect(connection: WebSocketConnection) {
|
|
328
|
+
console.log('Client connected:', connection.id);
|
|
329
|
+
connection.send({ type: 'system', content: 'Welcome to the chat!' });
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
@OnMessage(MessageSchema)
|
|
333
|
+
async handleMessage(connection: WebSocketConnection, message: z.infer<typeof MessageSchema>) {
|
|
334
|
+
console.log('Received message:', message);
|
|
335
|
+
|
|
336
|
+
// Broadcast to all clients
|
|
337
|
+
connection.broadcast({
|
|
338
|
+
type: 'message',
|
|
339
|
+
username: message.username,
|
|
340
|
+
content: message.content,
|
|
341
|
+
timestamp: new Date().toISOString(),
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
@OnDisconnect()
|
|
346
|
+
handleDisconnect(connection: WebSocketConnection) {
|
|
347
|
+
console.log('Client disconnected:', connection.id);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
`;await M(H($,"src","websockets","chat.websocket.ts"),q)}async function jz($){await K(H($,"src","controllers"),{recursive:!0}),await K(H($,"src","resolvers"),{recursive:!0}),await K(H($,"src","websockets"),{recursive:!0});let z=`import 'reflect-metadata';
|
|
351
|
+
import { Veloce, OpenAPIPlugin } from 'veloce-ts';
|
|
352
|
+
import { UserController } from './controllers/user.controller';
|
|
353
|
+
|
|
354
|
+
const app = new Veloce({
|
|
355
|
+
title: 'My Fullstack API',
|
|
356
|
+
version: '1.0.0',
|
|
357
|
+
description: 'A fullstack API with REST, GraphQL, and WebSocket support',
|
|
358
|
+
docs: true,
|
|
359
|
+
cors: {
|
|
360
|
+
origin: '*',
|
|
361
|
+
credentials: true,
|
|
362
|
+
},
|
|
363
|
+
});
|
|
364
|
+
|
|
365
|
+
// Enable OpenAPI documentation
|
|
366
|
+
app.usePlugin(new OpenAPIPlugin({
|
|
367
|
+
path: '/openapi.json',
|
|
368
|
+
docsPath: '/docs',
|
|
369
|
+
}));
|
|
370
|
+
|
|
371
|
+
// REST API
|
|
372
|
+
app.include(UserController);
|
|
373
|
+
|
|
374
|
+
// TODO: Add GraphQL and WebSocket support when plugins are available
|
|
375
|
+
// app.usePlugin(new GraphQLPlugin({ resolvers: [UserResolver] }));
|
|
376
|
+
// app.usePlugin(new WebSocketPlugin({ handlers: [ChatWebSocket] }));
|
|
377
|
+
|
|
378
|
+
// Start server
|
|
379
|
+
async function startServer() {
|
|
380
|
+
try {
|
|
381
|
+
console.log('\uD83D\uDD04 Compiling application...');
|
|
382
|
+
await app.compile();
|
|
383
|
+
console.log('\u2705 Application compiled successfully');
|
|
384
|
+
|
|
385
|
+
app.listen(3000, () => {
|
|
386
|
+
console.log('\uD83D\uDE80 Server running on http://localhost:3000');
|
|
387
|
+
console.log('\uD83D\uDCDA REST API docs at http://localhost:3000/docs');
|
|
388
|
+
console.log('\uD83D\uDCC4 OpenAPI Spec at http://localhost:3000/openapi.json');
|
|
389
|
+
// console.log('\uD83D\uDD2E GraphQL Playground at http://localhost:3000/graphql');
|
|
390
|
+
// console.log('\uD83D\uDD0C WebSocket endpoint at ws://localhost:3000/ws/chat');
|
|
391
|
+
});
|
|
392
|
+
} catch (error) {
|
|
393
|
+
console.error('\u274C Error starting server:', error);
|
|
394
|
+
process.exit(1);
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
startServer();
|
|
399
|
+
`;await M(H($,"src","index.ts"),z);let q=`import { Controller, Get, Post, Body, Param } from 'veloce-ts';
|
|
400
|
+
import { z } from 'zod';
|
|
401
|
+
|
|
402
|
+
const UserSchema = z.object({
|
|
403
|
+
name: z.string(),
|
|
404
|
+
email: z.string().email(),
|
|
405
|
+
age: z.number().min(0).optional(),
|
|
406
|
+
});
|
|
407
|
+
|
|
408
|
+
type User = z.infer<typeof UserSchema>;
|
|
409
|
+
|
|
410
|
+
@Controller('/users')
|
|
411
|
+
export class UserController {
|
|
412
|
+
private users: User[] = [];
|
|
413
|
+
|
|
414
|
+
@Get('/')
|
|
415
|
+
async getUsers() {
|
|
416
|
+
return { users: this.users };
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
@Get('/:id')
|
|
420
|
+
async getUser(@Param('id') id: string) {
|
|
421
|
+
const user = this.users[parseInt(id)];
|
|
422
|
+
if (!user) {
|
|
423
|
+
throw new Error('User not found');
|
|
424
|
+
}
|
|
425
|
+
return user;
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
@Post('/')
|
|
429
|
+
async createUser(@Body(UserSchema) user: User) {
|
|
430
|
+
this.users.push(user);
|
|
431
|
+
return { message: 'User created', user };
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
`;await M(H($,"src","controllers","user.controller.ts"),q);let B=`import { Resolver, Query, Mutation, Arg } from 'veloce-ts/graphql';
|
|
435
|
+
import { z } from 'zod';
|
|
436
|
+
|
|
437
|
+
const UserSchema = z.object({
|
|
438
|
+
id: z.string(),
|
|
439
|
+
name: z.string(),
|
|
440
|
+
email: z.string().email(),
|
|
441
|
+
});
|
|
442
|
+
|
|
443
|
+
type User = z.infer<typeof UserSchema>;
|
|
444
|
+
|
|
445
|
+
@Resolver()
|
|
446
|
+
export class UserResolver {
|
|
447
|
+
private users: User[] = [];
|
|
448
|
+
|
|
449
|
+
@Query()
|
|
450
|
+
async users(): Promise<User[]> {
|
|
451
|
+
return this.users;
|
|
452
|
+
}
|
|
453
|
+
|
|
454
|
+
@Query()
|
|
455
|
+
async user(@Arg('id', z.string()) id: string): Promise<User | null> {
|
|
456
|
+
return this.users.find(u => u.id === id) || null;
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
@Mutation()
|
|
460
|
+
async createUser(
|
|
461
|
+
@Arg('name', z.string()) name: string,
|
|
462
|
+
@Arg('email', z.string().email()) email: string
|
|
463
|
+
): Promise<User> {
|
|
464
|
+
const user = { id: Date.now().toString(), name, email };
|
|
465
|
+
this.users.push(user);
|
|
466
|
+
return user;
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
`;await M(H($,"src","resolvers","user.resolver.ts"),B);let X=`import { WebSocket, OnConnect, OnMessage, OnDisconnect } from 'veloce-ts/websocket';
|
|
470
|
+
import { z } from 'zod';
|
|
471
|
+
import type { WebSocketConnection } from 'veloce-ts/websocket';
|
|
472
|
+
|
|
473
|
+
const MessageSchema = z.object({
|
|
474
|
+
type: z.enum(['message', 'join', 'leave']),
|
|
475
|
+
content: z.string(),
|
|
476
|
+
username: z.string(),
|
|
477
|
+
});
|
|
478
|
+
|
|
479
|
+
@WebSocket('/ws/chat')
|
|
480
|
+
export class ChatWebSocket {
|
|
481
|
+
@OnConnect()
|
|
482
|
+
handleConnect(connection: WebSocketConnection) {
|
|
483
|
+
console.log('Client connected:', connection.id);
|
|
484
|
+
connection.send({ type: 'system', content: 'Welcome to the chat!' });
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
@OnMessage(MessageSchema)
|
|
488
|
+
async handleMessage(connection: WebSocketConnection, message: z.infer<typeof MessageSchema>) {
|
|
489
|
+
console.log('Received message:', message);
|
|
490
|
+
|
|
491
|
+
// Broadcast to all clients
|
|
492
|
+
connection.broadcast({
|
|
493
|
+
type: 'message',
|
|
494
|
+
username: message.username,
|
|
495
|
+
content: message.content,
|
|
496
|
+
timestamp: new Date().toISOString(),
|
|
497
|
+
});
|
|
498
|
+
}
|
|
499
|
+
|
|
500
|
+
@OnDisconnect()
|
|
501
|
+
handleDisconnect(connection: WebSocketConnection) {
|
|
502
|
+
console.log('Client disconnected:', connection.id);
|
|
503
|
+
}
|
|
504
|
+
}
|
|
505
|
+
`;await M(H($,"src","websockets","chat.websocket.ts"),X)}var Kz=async()=>{try{let $=await fetch("https://registry.npmjs.org/veloce-ts");if($.ok){let q=(await $.json())["dist-tags"]?.latest;if(q&&typeof q==="string")return q}}catch($){console.warn("Could not fetch latest version from npm, using fallback")}try{let $=H(process.cwd(),"package.json");return JSON.parse(Gz($,"utf-8")).version||"0.3.0"}catch{return"0.3.0"}};var Q$=()=>{};var _$={};y(_$,{registerDevCommand:()=>fz});import{spawn as Pz}from"child_process";import{existsSync as wz}from"fs";import{join as kz}from"path";function fz($){$.command("dev").description("Start development server with hot reload").option("-p, --port <port>","Port to run the server on","3000").option("-w, --watch <path>","Additional paths to watch","src").action(async(z)=>{await Oz(z)})}async function Oz($){let z=kz(process.cwd(),"src","index.ts");if(!wz(z))console.error("Error: src/index.ts not found"),console.error("Make sure you are in a VeloceTS project directory"),process.exit(1);console.log("Starting development server..."),console.log(`Watching: ${$.watch||"src"}`),console.log(`Port: ${$.port||3000}`),console.log(`
|
|
506
|
+
Press Ctrl+C to stop
|
|
507
|
+
`);let q=["--watch","--hot",z],B={...process.env,NODE_ENV:"development",PORT:$.port?.toString()||"3000"},X=Pz("bun",q,{stdio:"inherit",env:B,shell:!0}),Y=()=>{console.log(`
|
|
508
|
+
Shutting down development server...`),X.kill("SIGTERM"),process.exit(0)};process.on("SIGINT",Y),process.on("SIGTERM",Y),X.on("error",(Z)=>{console.error("Failed to start development server:",Z),process.exit(1)}),X.on("exit",(Z)=>{if(Z!==0&&Z!==null)console.error(`Development server exited with code ${Z}`),process.exit(Z)})}var J$=()=>{};var H$={};y(H$,{registerBuildCommand:()=>Cz});import{existsSync as R$}from"fs";import{join as U$}from"path";import{rm as xz,mkdir as T$}from"fs/promises";function Cz($){$.command("build").description("Build project for production").option("-m, --minify","Minify output",!1).option("-s, --sourcemap","Generate sourcemaps",!0).option("-o, --outdir <dir>","Output directory","dist").option("-f, --format <format>","Output format (esm, cjs, both)","both").action(async(z)=>{await bz(z)})}async function bz($){let z=U$(process.cwd(),"src","index.ts");if(!R$(z))console.error("Error: src/index.ts not found"),console.error("Make sure you are in a VeloceTS project directory"),process.exit(1);console.log("Building project for production..."),console.log(`Format: ${$.format||"both"}`),console.log(`Minify: ${$.minify?"yes":"no"}`),console.log(`Sourcemap: ${$.sourcemap?"yes":"no"}`);let q=$.outdir||"dist";try{if(R$(q))await xz(q,{recursive:!0,force:!0});await T$(q,{recursive:!0});let B=$.format||"both",X=B==="both"?["esm","cjs"]:[B];for(let Y of X)console.log(`
|
|
509
|
+
Building ${Y.toUpperCase()}...`),await vz(z,q,Y,$);console.log(`
|
|
510
|
+
\u2713 Build completed successfully!`),console.log(`
|
|
511
|
+
Output directory: ${q}`)}catch(B){console.error("Build failed:",B),process.exit(1)}}async function vz($,z,q,B){let X=U$(z,q);await T$(X,{recursive:!0});let Y=await Bun.build({entrypoints:[$],outdir:X,target:"bun",format:q==="esm"?"esm":"cjs",minify:B.minify||!1,sourcemap:B.sourcemap!==!1?"external":"none",splitting:q==="esm",external:["hono","zod","reflect-metadata","commander","zod-to-json-schema"]});if(!Y.success){console.error(`Failed to build ${q}:`);for(let Q of Y.logs)console.error(Q);throw Error(`Build failed for ${q}`)}console.log(` \u2713 ${q.toUpperCase()} build complete`),console.log(` Files: ${Y.outputs.length}`);let Z=Y.outputs.reduce((Q,R)=>Q+R.size,0);console.log(` Size: ${(Z/1024).toFixed(2)} KB`)}var M$=()=>{};var W$={};y(W$,{registerGenerateCommand:()=>hz});import{writeFile as v,mkdir as uz}from"fs/promises";import{join as I}from"path";import{existsSync as L$}from"fs";function hz($){let z=$.command("generate").description("Generate code and documentation").alias("g");z.command("openapi").description("Generate OpenAPI specification").option("-o, --output <file>","Output file path","openapi.json").action(async(q)=>{await gz(q)}),z.command("client").description("Generate TypeScript client from OpenAPI spec").option("-i, --input <file>","OpenAPI spec file","openapi.json").option("-o, --output <dir>","Output directory","src/client").action(async(q)=>{await mz(q)})}async function gz($){console.log("Generating OpenAPI specification...");try{let z=I(process.cwd(),"src","index.ts");if(!L$(z))console.error("Error: src/index.ts not found"),console.error("Make sure you are in a FastAPI-TS project directory"),process.exit(1);let q=await import(z),B=q.default||q.app;if(!B||typeof B.getMetadata!=="function")console.error("Error: Could not find VeloceTS app instance"),console.error("Make sure your src/index.ts exports the app or sets it as default"),process.exit(1);let X=B.getMetadata(),Y=lz(X,B),Z=I(process.cwd(),$.output);await v(Z,JSON.stringify(Y,null,2)),console.log(`\u2713 OpenAPI spec generated: ${$.output}`)}catch(z){console.error("Failed to generate OpenAPI spec:",z),process.exit(1)}}function lz($,z){let q=$.getRoutes(),B={openapi:"3.0.0",info:{title:z.config?.title||"Veloce API",version:z.config?.version||"1.0.0",description:z.config?.description||"API built with Veloce"},paths:{},components:{schemas:{}}};for(let X of q){let Y=X.path,Z=X.method.toLowerCase();if(!B.paths[Y])B.paths[Y]={};B.paths[Y][Z]={summary:X.docs?.summary||`${Z.toUpperCase()} ${Y}`,description:X.docs?.description,tags:X.docs?.tags||[],parameters:cz(X),requestBody:dz(X),responses:{"200":{description:"Successful response",content:{"application/json":{schema:{type:"object"}}}}}}}return B}function cz($){let z=[];for(let q of $.parameters||[])if(q.type==="query"||q.type==="param"||q.type==="header")z.push({name:q.name||"unknown",in:q.type==="param"?"path":q.type,required:q.required||!1,schema:{type:"string"}});return z}function dz($){if(!$.parameters?.find((q)=>q.type==="body"))return;return{required:!0,content:{"application/json":{schema:{type:"object"}}}}}async function mz($){console.log("Generating TypeScript client...");try{let z=I(process.cwd(),$.input);if(!L$(z))console.error(`Error: OpenAPI spec not found at ${$.input}`),console.error('Run "veloce generate openapi" first'),process.exit(1);let q=await Bun.file(z).text(),B=JSON.parse(q),X=I(process.cwd(),$.output);await uz(X,{recursive:!0});let Y=sz(B),Z=I(X,"client.ts");await v(Z,Y);let Q=pz(B),R=I(X,"types.ts");await v(R,Q),console.log(`\u2713 TypeScript client generated in ${$.output}`),console.log(` - ${$.output}/client.ts`),console.log(` - ${$.output}/types.ts`)}catch(z){console.error("Failed to generate client:",z),process.exit(1)}}function sz($){let z=$.servers?.[0]?.url||"http://localhost:3000",q=`// Generated TypeScript client for ${$.info.title}
|
|
512
|
+
// Version: ${$.info.version}
|
|
513
|
+
|
|
514
|
+
import type * as Types from './types';
|
|
515
|
+
|
|
516
|
+
export class APIClient {
|
|
517
|
+
constructor(private baseUrl: string = '${z}') {}
|
|
518
|
+
|
|
519
|
+
private async request<T>(
|
|
520
|
+
method: string,
|
|
521
|
+
path: string,
|
|
522
|
+
options?: {
|
|
523
|
+
params?: Record<string, any>;
|
|
524
|
+
body?: any;
|
|
525
|
+
headers?: Record<string, string>;
|
|
526
|
+
}
|
|
527
|
+
): Promise<T> {
|
|
528
|
+
const url = new URL(path, this.baseUrl);
|
|
529
|
+
|
|
530
|
+
if (options?.params) {
|
|
531
|
+
Object.entries(options.params).forEach(([key, value]) => {
|
|
532
|
+
url.searchParams.append(key, String(value));
|
|
533
|
+
});
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
const response = await fetch(url.toString(), {
|
|
537
|
+
method,
|
|
538
|
+
headers: {
|
|
539
|
+
'Content-Type': 'application/json',
|
|
540
|
+
...options?.headers,
|
|
541
|
+
},
|
|
542
|
+
body: options?.body ? JSON.stringify(options.body) : undefined,
|
|
543
|
+
});
|
|
544
|
+
|
|
545
|
+
if (!response.ok) {
|
|
546
|
+
throw new Error(\`API request failed: \${response.statusText}\`);
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
return response.json();
|
|
550
|
+
}
|
|
551
|
+
|
|
552
|
+
`;for(let[B,X]of Object.entries($.paths||{}))for(let[Y,Z]of Object.entries(X)){let Q=G$(Y,B,Z),R=iz(Y,B,Z);q+=R+`
|
|
553
|
+
`}return q+=`}
|
|
554
|
+
`,q}function G$($,z,q){if(q.operationId)return q.operationId;let B=z.replace(/\{|\}/g,"").replace(/\//g,"_").replace(/^_/,"").replace(/_([a-z])/g,(X,Y)=>Y.toUpperCase());return`${$}${B.charAt(0).toUpperCase()+B.slice(1)}`}function iz($,z,q){let B=G$($,z,q),X=$==="post"||$==="put"||$==="patch",Y=q.parameters?.some((U)=>U.in==="query"),Z=q.parameters?.some((U)=>U.in==="path"),Q=[],R=[];if(Z){let U=q.parameters.filter((L)=>L.in==="path");R=U.map((L)=>L.name),Q.push(...U.map((L)=>`${L.name}: string`))}if(X)Q.push("body: any");if(Y)Q.push("params?: Record<string, any>");let _=Q.length>0?Q.join(", "):"",J=z;for(let U of R)J=J.replace(`{${U}}`,`\${${U}}`);return` async ${B}(${_}): Promise<any> {
|
|
555
|
+
return this.request('${$.toUpperCase()}', \`${J}\`, {
|
|
556
|
+
${X?"body,":""}
|
|
557
|
+
${Y?"params,":""}
|
|
558
|
+
});
|
|
559
|
+
}
|
|
560
|
+
`}function pz($){let z=`// Generated types for ${$.info.title}
|
|
561
|
+
// Version: ${$.info.version}
|
|
562
|
+
|
|
563
|
+
`;if($.components?.schemas)for(let[q,B]of Object.entries($.components.schemas))z+=`export interface ${q} {
|
|
564
|
+
`,z+=rz(B),z+=`}
|
|
565
|
+
|
|
566
|
+
`;return z}function rz($,z=" "){let q="";if($.properties)for(let[B,X]of Object.entries($.properties)){let Y=X,Z=!$.required?.includes(B),Q=K$(Y);q+=`${z}${B}${Z?"?":""}: ${Q};
|
|
567
|
+
`}return q}function K$($){if($.type==="string")return"string";if($.type==="number"||$.type==="integer")return"number";if($.type==="boolean")return"boolean";if($.type==="array")return`${$.items?K$($.items):"any"}[]`;if($.type==="object")return"Record<string, any>";return"any"}var E$=()=>{};var B$=y$(q$(),1),{program:Zq,createCommand:Qq,createArgument:_q,createOption:Jq,CommanderError:Rq,InvalidArgumentError:Uq,InvalidOptionArgumentError:Tq,Command:X$,Argument:Hq,Option:Mq,Help:Lq}=B$.default;import{readFileSync as I$}from"fs";import{join as S$}from"path";var __dirname="C:\\Users\\mejia\\Desktop\\prueba-real\\fastTS\\src\\cli",nz=()=>{try{let $=S$(__dirname,"..","..","package.json");return JSON.parse(I$($,"utf-8")).version||"0.3.0"}catch{try{let $=S$(process.cwd(),"package.json");return JSON.parse(I$($,"utf-8")).version||"0.3.0"}catch{return"0.3.0"}}},S=new X$;S.name("veloce").description("A modern, fast web framework for TypeScript inspired by FastAPI").version(nz(),"-v, --version","Display version number").helpOption("-h, --help","Display help for command");async function tz(){let{registerNewCommand:$}=await Promise.resolve().then(() => (Q$(),Z$)),{registerDevCommand:z}=await Promise.resolve().then(() => (J$(),_$)),{registerBuildCommand:q}=await Promise.resolve().then(() => (M$(),H$)),{registerGenerateCommand:B}=await Promise.resolve().then(() => (E$(),W$));$(S),z(S),q(S),B(S),S.parse(process.argv)}tz().catch(($)=>{console.error("CLI error:",$),process.exit(1)});
|
|
568
|
+
|
|
569
|
+
//# debugId=7398DA7C3F0FE90E64756E2164756E21
|