@kubb/cli 4.23.0 → 4.24.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/dist/agent-Buz_5Op4.cjs +22 -0
  2. package/dist/agent-Buz_5Op4.cjs.map +1 -0
  3. package/dist/agent-C9MWOHKX.js +22 -0
  4. package/dist/agent-C9MWOHKX.js.map +1 -0
  5. package/dist/{chunk-jHaXqnEa.js → chunk-EyRqdYP6.js} +4 -1
  6. package/dist/{generate-Cv8oibM4.cjs → generate-BYLZgOxz.cjs} +440 -13
  7. package/dist/generate-BYLZgOxz.cjs.map +1 -0
  8. package/dist/{generate-DhFw-owG.js → generate-DoM5hz_l.js} +435 -8
  9. package/dist/generate-DoM5hz_l.js.map +1 -0
  10. package/dist/index.cjs +8 -8
  11. package/dist/index.cjs.map +1 -1
  12. package/dist/index.d.ts +1 -1
  13. package/dist/index.js +10 -10
  14. package/dist/index.js.map +1 -1
  15. package/dist/{init-CiYFzdzt.js → init-CGHonZd1.js} +4 -4
  16. package/dist/{init-CiYFzdzt.js.map → init-CGHonZd1.js.map} +1 -1
  17. package/dist/{init-BKWuXKMO.cjs → init-CIr2otlG.cjs} +3 -3
  18. package/dist/{init-BKWuXKMO.cjs.map → init-CIr2otlG.cjs.map} +1 -1
  19. package/dist/{mcp-BdwwUv36.js → mcp-85caBdzd.js} +2 -2
  20. package/dist/{mcp-BdwwUv36.js.map → mcp-85caBdzd.js.map} +1 -1
  21. package/dist/{mcp-Hy_PYnFp.cjs → mcp-DGyip5BX.cjs} +1 -1
  22. package/dist/{mcp-Hy_PYnFp.cjs.map → mcp-DGyip5BX.cjs.map} +1 -1
  23. package/dist/package-DbleONiT.js +6 -0
  24. package/dist/package-DbleONiT.js.map +1 -0
  25. package/dist/{package-BfNquhL9.cjs → package-JlnkYQn6.cjs} +2 -2
  26. package/dist/package-JlnkYQn6.cjs.map +1 -0
  27. package/dist/start-DdvHHe8S.js +76 -0
  28. package/dist/start-DdvHHe8S.js.map +1 -0
  29. package/dist/start-Vf8kCm8g.cjs +80 -0
  30. package/dist/start-Vf8kCm8g.cjs.map +1 -0
  31. package/dist/{validate-YI4YkVTl.js → validate-DaGKH-63.js} +2 -2
  32. package/dist/{validate-YI4YkVTl.js.map → validate-DaGKH-63.js.map} +1 -1
  33. package/package.json +6 -5
  34. package/src/commands/agent/start.ts +85 -0
  35. package/src/commands/agent.ts +27 -0
  36. package/src/index.ts +2 -2
  37. package/dist/generate-Cv8oibM4.cjs.map +0 -1
  38. package/dist/generate-DhFw-owG.js.map +0 -1
  39. package/dist/getCosmiConfig-Co29x0Wv.cjs +0 -458
  40. package/dist/getCosmiConfig-Co29x0Wv.cjs.map +0 -1
  41. package/dist/getCosmiConfig-y2n_oW_y.js +0 -438
  42. package/dist/getCosmiConfig-y2n_oW_y.js.map +0 -1
  43. package/dist/package-BfNquhL9.cjs.map +0 -1
  44. package/dist/package-_Sd-Chc0.js +0 -6
  45. package/dist/package-_Sd-Chc0.js.map +0 -1
  46. package/dist/start-BtAU-_Gn.cjs +0 -128
  47. package/dist/start-BtAU-_Gn.cjs.map +0 -1
  48. package/dist/start-ugFADwjK.js +0 -125
  49. package/dist/start-ugFADwjK.js.map +0 -1
  50. package/src/commands/start.ts +0 -149
@@ -1,125 +0,0 @@
1
- import { t as __name } from "./chunk-jHaXqnEa.js";
2
- import { t as version } from "./package-_Sd-Chc0.js";
3
- import { n as getConfigs, r as generate, t as getCosmiConfig } from "./getCosmiConfig-y2n_oW_y.js";
4
- import { defineCommand, showUsage } from "citty";
5
- import * as process$1 from "node:process";
6
- import * as clack from "@clack/prompts";
7
- import { LogLevel, startServer } from "@kubb/core";
8
- import { AsyncEventEmitter } from "@kubb/core/utils";
9
- import pc from "picocolors";
10
-
11
- //#region src/commands/start.ts
12
- const command = defineCommand({
13
- meta: {
14
- name: "start",
15
- description: "[input] Start HTTP server with SSE streaming based on a 'kubb.config.ts' file"
16
- },
17
- args: {
18
- config: {
19
- type: "string",
20
- description: "Path to the Kubb config",
21
- alias: "c"
22
- },
23
- logLevel: {
24
- type: "string",
25
- description: "Info, silent, verbose or debug",
26
- alias: "l",
27
- default: "info",
28
- valueHint: "silent|info|verbose|debug"
29
- },
30
- debug: {
31
- type: "boolean",
32
- description: "Override logLevel to debug",
33
- alias: "d",
34
- default: false
35
- },
36
- verbose: {
37
- type: "boolean",
38
- description: "Override logLevel to verbose",
39
- alias: "v",
40
- default: false
41
- },
42
- silent: {
43
- type: "boolean",
44
- description: "Override logLevel to silent",
45
- alias: "s",
46
- default: false
47
- },
48
- port: {
49
- type: "string",
50
- description: "Port for the server. If not specified, an available port is automatically selected.",
51
- alias: "p"
52
- },
53
- host: {
54
- type: "string",
55
- description: "Host for the server",
56
- default: "localhost"
57
- },
58
- help: {
59
- type: "boolean",
60
- description: "Show help",
61
- alias: "h",
62
- default: false
63
- }
64
- },
65
- async run(commandContext) {
66
- const { args } = commandContext;
67
- const input = args._[0];
68
- if (args.help) return showUsage(command);
69
- if (args.debug) args.logLevel = "debug";
70
- if (args.verbose) args.logLevel = "verbose";
71
- if (args.silent) args.logLevel = "silent";
72
- try {
73
- const result = await getCosmiConfig("kubb", args.config);
74
- const configs = await getConfigs(result, {
75
- ...args,
76
- watch: false
77
- });
78
- if (configs.length > 1) clack.log.warn(pc.yellow("Stream mode only supports a single configuration. Only the first config will be used."));
79
- const port = args.port ? Number.parseInt(args.port, 10) : 0;
80
- const host = args.host;
81
- const config = configs[0];
82
- const logLevel = LogLevel[args.logLevel] || 3;
83
- const events = new AsyncEventEmitter();
84
- events.on("server:start", (serverUrl, configPath) => {
85
- clack.log.success(pc.green(`Stream server started on ${pc.bold(serverUrl)}`));
86
- clack.log.info(pc.dim(`Config: ${configPath}`));
87
- clack.log.info(pc.dim(`Connect: ${serverUrl}/api/info`));
88
- clack.log.info(pc.dim(`Generate: ${serverUrl}/api/generate`));
89
- clack.log.info(pc.dim(`Health: ${serverUrl}/api/health`));
90
- clack.log.step(pc.yellow("Waiting for requests... (Press Ctrl+C to stop)"));
91
- });
92
- events.on("server:shutdown", () => {
93
- clack.log.info("Shutting down stream server...");
94
- });
95
- events.on("server:stopped", () => {
96
- clack.log.success("Server stopped");
97
- });
98
- await startServer({
99
- port,
100
- host,
101
- configPath: result.filepath,
102
- config,
103
- version,
104
- events,
105
- onGenerate: async () => {
106
- await generate({
107
- input,
108
- config,
109
- logLevel,
110
- events
111
- });
112
- }
113
- });
114
- } catch (error) {
115
- clack.log.error(pc.red("Failed to start stream server"));
116
- console.error(error);
117
- process$1.exit(1);
118
- }
119
- }
120
- });
121
- var start_default = command;
122
-
123
- //#endregion
124
- export { start_default as default };
125
- //# sourceMappingURL=start-ugFADwjK.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"start-ugFADwjK.js","names":[],"sources":["../src/commands/start.ts"],"sourcesContent":["import * as process from 'node:process'\nimport * as clack from '@clack/prompts'\nimport { LogLevel, type ServerEvents, startServer } from '@kubb/core'\nimport { AsyncEventEmitter } from '@kubb/core/utils'\nimport type { ArgsDef } from 'citty'\nimport { defineCommand, showUsage } from 'citty'\nimport pc from 'picocolors'\nimport { version } from '../../package.json'\nimport { generate } from '../runners/generate.ts'\nimport { getConfigs } from '../utils/getConfigs.ts'\nimport { getCosmiConfig } from '../utils/getCosmiConfig.ts'\nimport type { Args as GenerateArgs } from './generate.ts'\n\nconst args = {\n config: {\n type: 'string',\n description: 'Path to the Kubb config',\n alias: 'c',\n },\n logLevel: {\n type: 'string',\n description: 'Info, silent, verbose or debug',\n alias: 'l',\n default: 'info',\n valueHint: 'silent|info|verbose|debug',\n },\n debug: {\n type: 'boolean',\n description: 'Override logLevel to debug',\n alias: 'd',\n default: false,\n },\n verbose: {\n type: 'boolean',\n description: 'Override logLevel to verbose',\n alias: 'v',\n default: false,\n },\n silent: {\n type: 'boolean',\n description: 'Override logLevel to silent',\n alias: 's',\n default: false,\n },\n port: {\n type: 'string',\n description: 'Port for the server. If not specified, an available port is automatically selected.',\n alias: 'p',\n },\n host: {\n type: 'string',\n description: 'Host for the server',\n default: 'localhost',\n },\n help: {\n type: 'boolean',\n description: 'Show help',\n alias: 'h',\n default: false,\n },\n} as const satisfies ArgsDef\n\nconst command = defineCommand({\n meta: {\n name: 'start',\n description: \"[input] Start HTTP server with SSE streaming based on a 'kubb.config.ts' file\",\n },\n args,\n async run(commandContext) {\n const { args } = commandContext\n const input = args._[0]\n\n if (args.help) {\n return showUsage(command)\n }\n\n if (args.debug) {\n args.logLevel = 'debug'\n }\n\n if (args.verbose) {\n args.logLevel = 'verbose'\n }\n\n if (args.silent) {\n args.logLevel = 'silent'\n }\n\n try {\n const result = await getCosmiConfig('kubb', args.config)\n // Create args compatible with getConfigs/startStreamServer (needs watch property)\n const generateArgs = { ...args, watch: false } as unknown as GenerateArgs\n const configs = await getConfigs(result, generateArgs)\n\n if (configs.length > 1) {\n clack.log.warn(pc.yellow('Stream mode only supports a single configuration. Only the first config will be used.'))\n }\n\n const port = args.port ? Number.parseInt(args.port, 10) : 0\n const host = args.host\n const config = configs[0]!\n const logLevel = LogLevel[args.logLevel as keyof typeof LogLevel] || 3\n\n const events = new AsyncEventEmitter<ServerEvents>()\n\n events.on('server:start', (serverUrl: string, configPath: string) => {\n clack.log.success(pc.green(`Stream server started on ${pc.bold(serverUrl)}`))\n clack.log.info(pc.dim(`Config: ${configPath}`))\n clack.log.info(pc.dim(`Connect: ${serverUrl}/api/info`))\n clack.log.info(pc.dim(`Generate: ${serverUrl}/api/generate`))\n clack.log.info(pc.dim(`Health: ${serverUrl}/api/health`))\n clack.log.step(pc.yellow('Waiting for requests... (Press Ctrl+C to stop)'))\n })\n\n events.on('server:shutdown', () => {\n clack.log.info('Shutting down stream server...')\n })\n\n events.on('server:stopped', () => {\n clack.log.success('Server stopped')\n })\n\n await startServer({\n port,\n host,\n configPath: result.filepath,\n config,\n version,\n events,\n onGenerate: async () => {\n await generate({\n input,\n config,\n logLevel,\n events,\n })\n },\n })\n\n // Server is running, don't exit\n } catch (error) {\n clack.log.error(pc.red('Failed to start stream server'))\n console.error(error)\n process.exit(1)\n }\n },\n})\n\nexport default command\n"],"mappings":";;;;;;;;;;;AA8DA,MAAM,UAAU,cAAc;CAC5B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAtDW;EACX,QAAQ;GACN,MAAM;GACN,aAAa;GACb,OAAO;GACR;EACD,UAAU;GACR,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACT,WAAW;GACZ;EACD,OAAO;GACL,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,SAAS;GACP,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,QAAQ;GACN,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,MAAM;GACJ,MAAM;GACN,aAAa;GACb,OAAO;GACR;EACD,MAAM;GACJ,MAAM;GACN,aAAa;GACb,SAAS;GACV;EACD,MAAM;GACJ,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACF;CAQC,MAAM,IAAI,gBAAgB;EACxB,MAAM,EAAE,SAAS;EACjB,MAAM,QAAQ,KAAK,EAAE;AAErB,MAAI,KAAK,KACP,QAAO,UAAU,QAAQ;AAG3B,MAAI,KAAK,MACP,MAAK,WAAW;AAGlB,MAAI,KAAK,QACP,MAAK,WAAW;AAGlB,MAAI,KAAK,OACP,MAAK,WAAW;AAGlB,MAAI;GACF,MAAM,SAAS,MAAM,eAAe,QAAQ,KAAK,OAAO;GAGxD,MAAM,UAAU,MAAM,WAAW,QADZ;IAAE,GAAG;IAAM,OAAO;IAAO,CACQ;AAEtD,OAAI,QAAQ,SAAS,EACnB,OAAM,IAAI,KAAK,GAAG,OAAO,wFAAwF,CAAC;GAGpH,MAAM,OAAO,KAAK,OAAO,OAAO,SAAS,KAAK,MAAM,GAAG,GAAG;GAC1D,MAAM,OAAO,KAAK;GAClB,MAAM,SAAS,QAAQ;GACvB,MAAM,WAAW,SAAS,KAAK,aAAsC;GAErE,MAAM,SAAS,IAAI,mBAAiC;AAEpD,UAAO,GAAG,iBAAiB,WAAmB,eAAuB;AACnE,UAAM,IAAI,QAAQ,GAAG,MAAM,4BAA4B,GAAG,KAAK,UAAU,GAAG,CAAC;AAC7E,UAAM,IAAI,KAAK,GAAG,IAAI,WAAW,aAAa,CAAC;AAC/C,UAAM,IAAI,KAAK,GAAG,IAAI,YAAY,UAAU,WAAW,CAAC;AACxD,UAAM,IAAI,KAAK,GAAG,IAAI,aAAa,UAAU,eAAe,CAAC;AAC7D,UAAM,IAAI,KAAK,GAAG,IAAI,WAAW,UAAU,aAAa,CAAC;AACzD,UAAM,IAAI,KAAK,GAAG,OAAO,iDAAiD,CAAC;KAC3E;AAEF,UAAO,GAAG,yBAAyB;AACjC,UAAM,IAAI,KAAK,iCAAiC;KAChD;AAEF,UAAO,GAAG,wBAAwB;AAChC,UAAM,IAAI,QAAQ,iBAAiB;KACnC;AAEF,SAAM,YAAY;IAChB;IACA;IACA,YAAY,OAAO;IACnB;IACA;IACA;IACA,YAAY,YAAY;AACtB,WAAM,SAAS;MACb;MACA;MACA;MACA;MACD,CAAC;;IAEL,CAAC;WAGK,OAAO;AACd,SAAM,IAAI,MAAM,GAAG,IAAI,gCAAgC,CAAC;AACxD,WAAQ,MAAM,MAAM;AACpB,aAAQ,KAAK,EAAE;;;CAGpB,CAAC;AAEF,oBAAe"}
@@ -1,149 +0,0 @@
1
- import * as process from 'node:process'
2
- import * as clack from '@clack/prompts'
3
- import { LogLevel, type ServerEvents, startServer } from '@kubb/core'
4
- import { AsyncEventEmitter } from '@kubb/core/utils'
5
- import type { ArgsDef } from 'citty'
6
- import { defineCommand, showUsage } from 'citty'
7
- import pc from 'picocolors'
8
- import { version } from '../../package.json'
9
- import { generate } from '../runners/generate.ts'
10
- import { getConfigs } from '../utils/getConfigs.ts'
11
- import { getCosmiConfig } from '../utils/getCosmiConfig.ts'
12
- import type { Args as GenerateArgs } from './generate.ts'
13
-
14
- const args = {
15
- config: {
16
- type: 'string',
17
- description: 'Path to the Kubb config',
18
- alias: 'c',
19
- },
20
- logLevel: {
21
- type: 'string',
22
- description: 'Info, silent, verbose or debug',
23
- alias: 'l',
24
- default: 'info',
25
- valueHint: 'silent|info|verbose|debug',
26
- },
27
- debug: {
28
- type: 'boolean',
29
- description: 'Override logLevel to debug',
30
- alias: 'd',
31
- default: false,
32
- },
33
- verbose: {
34
- type: 'boolean',
35
- description: 'Override logLevel to verbose',
36
- alias: 'v',
37
- default: false,
38
- },
39
- silent: {
40
- type: 'boolean',
41
- description: 'Override logLevel to silent',
42
- alias: 's',
43
- default: false,
44
- },
45
- port: {
46
- type: 'string',
47
- description: 'Port for the server. If not specified, an available port is automatically selected.',
48
- alias: 'p',
49
- },
50
- host: {
51
- type: 'string',
52
- description: 'Host for the server',
53
- default: 'localhost',
54
- },
55
- help: {
56
- type: 'boolean',
57
- description: 'Show help',
58
- alias: 'h',
59
- default: false,
60
- },
61
- } as const satisfies ArgsDef
62
-
63
- const command = defineCommand({
64
- meta: {
65
- name: 'start',
66
- description: "[input] Start HTTP server with SSE streaming based on a 'kubb.config.ts' file",
67
- },
68
- args,
69
- async run(commandContext) {
70
- const { args } = commandContext
71
- const input = args._[0]
72
-
73
- if (args.help) {
74
- return showUsage(command)
75
- }
76
-
77
- if (args.debug) {
78
- args.logLevel = 'debug'
79
- }
80
-
81
- if (args.verbose) {
82
- args.logLevel = 'verbose'
83
- }
84
-
85
- if (args.silent) {
86
- args.logLevel = 'silent'
87
- }
88
-
89
- try {
90
- const result = await getCosmiConfig('kubb', args.config)
91
- // Create args compatible with getConfigs/startStreamServer (needs watch property)
92
- const generateArgs = { ...args, watch: false } as unknown as GenerateArgs
93
- const configs = await getConfigs(result, generateArgs)
94
-
95
- if (configs.length > 1) {
96
- clack.log.warn(pc.yellow('Stream mode only supports a single configuration. Only the first config will be used.'))
97
- }
98
-
99
- const port = args.port ? Number.parseInt(args.port, 10) : 0
100
- const host = args.host
101
- const config = configs[0]!
102
- const logLevel = LogLevel[args.logLevel as keyof typeof LogLevel] || 3
103
-
104
- const events = new AsyncEventEmitter<ServerEvents>()
105
-
106
- events.on('server:start', (serverUrl: string, configPath: string) => {
107
- clack.log.success(pc.green(`Stream server started on ${pc.bold(serverUrl)}`))
108
- clack.log.info(pc.dim(`Config: ${configPath}`))
109
- clack.log.info(pc.dim(`Connect: ${serverUrl}/api/info`))
110
- clack.log.info(pc.dim(`Generate: ${serverUrl}/api/generate`))
111
- clack.log.info(pc.dim(`Health: ${serverUrl}/api/health`))
112
- clack.log.step(pc.yellow('Waiting for requests... (Press Ctrl+C to stop)'))
113
- })
114
-
115
- events.on('server:shutdown', () => {
116
- clack.log.info('Shutting down stream server...')
117
- })
118
-
119
- events.on('server:stopped', () => {
120
- clack.log.success('Server stopped')
121
- })
122
-
123
- await startServer({
124
- port,
125
- host,
126
- configPath: result.filepath,
127
- config,
128
- version,
129
- events,
130
- onGenerate: async () => {
131
- await generate({
132
- input,
133
- config,
134
- logLevel,
135
- events,
136
- })
137
- },
138
- })
139
-
140
- // Server is running, don't exit
141
- } catch (error) {
142
- clack.log.error(pc.red('Failed to start stream server'))
143
- console.error(error)
144
- process.exit(1)
145
- }
146
- },
147
- })
148
-
149
- export default command