@kubb/cli 5.0.0-beta.7 → 5.0.0-beta.70

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 (133) hide show
  1. package/LICENSE +17 -10
  2. package/README.md +45 -77
  3. package/bin/kubb.js +9 -3
  4. package/dist/Telemetry-CfPP7MYq.cjs +321 -0
  5. package/dist/Telemetry-CfPP7MYq.cjs.map +1 -0
  6. package/dist/Telemetry-uAr3lK_-.js +284 -0
  7. package/dist/Telemetry-uAr3lK_-.js.map +1 -0
  8. package/dist/{define-Bdn8j5VM.cjs → defineCommand-Bo3yZTWI.cjs} +3 -21
  9. package/dist/defineCommand-Bo3yZTWI.cjs.map +1 -0
  10. package/dist/{define-m_fp-Aqm.js → defineCommand-DMEeqliP.js} +4 -16
  11. package/dist/defineCommand-DMEeqliP.js.map +1 -0
  12. package/dist/{errors-CINO1EIv.js → errors-Dc_d7BfX.js} +2 -2
  13. package/dist/{errors-CINO1EIv.js.map → errors-Dc_d7BfX.js.map} +1 -1
  14. package/dist/{errors-CLCjoSg0.cjs → errors-gxFK0vrp.cjs} +2 -2
  15. package/dist/{errors-CLCjoSg0.cjs.map → errors-gxFK0vrp.cjs.map} +1 -1
  16. package/dist/{generate-BY-juRdH.js → generate-BdxIouwm.js} +21 -16
  17. package/dist/generate-BdxIouwm.js.map +1 -0
  18. package/dist/{generate-Bod9YCbF.cjs → generate-tRupKbnI.cjs} +21 -16
  19. package/dist/generate-tRupKbnI.cjs.map +1 -0
  20. package/dist/index.cjs +34 -81
  21. package/dist/index.cjs.map +1 -1
  22. package/dist/index.d.ts +6 -1
  23. package/dist/index.js +34 -81
  24. package/dist/index.js.map +1 -1
  25. package/dist/{init-Cs3Fp6nN.js → init-D_9I495E.js} +5 -5
  26. package/dist/{init-Cs3Fp6nN.js.map → init-D_9I495E.js.map} +1 -1
  27. package/dist/{init-BIkZU6mB.cjs → init-XlS3aia7.cjs} +6 -6
  28. package/dist/{init-BIkZU6mB.cjs.map → init-XlS3aia7.cjs.map} +1 -1
  29. package/dist/mcp-BlKi3z04.js +21 -0
  30. package/dist/mcp-BlKi3z04.js.map +1 -0
  31. package/dist/mcp-DSo5Ccwz.cjs +21 -0
  32. package/dist/mcp-DSo5Ccwz.cjs.map +1 -0
  33. package/dist/package-CsDaFmfZ.js +6 -0
  34. package/dist/package-CsDaFmfZ.js.map +1 -0
  35. package/dist/{package-DrUndPET.cjs → package-HWZRLSO4.cjs} +2 -2
  36. package/dist/package-HWZRLSO4.cjs.map +1 -0
  37. package/dist/{chunk-BvFE5Tac.js → rolldown-runtime-C0LytTxp.js} +0 -1
  38. package/dist/{run-YsoCk5we.cjs → run-AYlRjIX5.cjs} +136 -98
  39. package/dist/run-AYlRjIX5.cjs.map +1 -0
  40. package/dist/run-BM1t8CSM.cjs +33 -0
  41. package/dist/run-BM1t8CSM.cjs.map +1 -0
  42. package/dist/run-BlFVmIJl.js +32 -0
  43. package/dist/run-BlFVmIJl.js.map +1 -0
  44. package/dist/{run-CQbj3ley.cjs → run-CBc896in.cjs} +6 -6
  45. package/dist/run-CBc896in.cjs.map +1 -0
  46. package/dist/{run-CF97BWVa.js → run-D9mQoQHA.js} +123 -85
  47. package/dist/run-D9mQoQHA.js.map +1 -0
  48. package/dist/{run-CCZ24VKk.js → run-D_dWNFhX.js} +5 -5
  49. package/dist/run-D_dWNFhX.js.map +1 -0
  50. package/dist/run-DwylXpzM.cjs +1380 -0
  51. package/dist/run-DwylXpzM.cjs.map +1 -0
  52. package/dist/run-KlHwxNTr.js +1377 -0
  53. package/dist/run-KlHwxNTr.js.map +1 -0
  54. package/dist/tools-CZT9wSA6.cjs +175 -0
  55. package/dist/tools-CZT9wSA6.cjs.map +1 -0
  56. package/dist/tools-D0UogMU3.js +152 -0
  57. package/dist/tools-D0UogMU3.js.map +1 -0
  58. package/dist/{validate-Bfpf_UIh.cjs → validate-3gu3yglv.cjs} +6 -6
  59. package/dist/{validate-Bfpf_UIh.cjs.map → validate-3gu3yglv.cjs.map} +1 -1
  60. package/dist/{validate-lbUkWQ5o.js → validate-DBqdV14W.js} +5 -5
  61. package/dist/{validate-lbUkWQ5o.js.map → validate-DBqdV14W.js.map} +1 -1
  62. package/package.json +13 -25
  63. package/dist/agent-DN7o8nlE.js +0 -68
  64. package/dist/agent-DN7o8nlE.js.map +0 -1
  65. package/dist/agent-Fm9_8BBH.cjs +0 -70
  66. package/dist/agent-Fm9_8BBH.cjs.map +0 -1
  67. package/dist/constants-B2JTeRBb.js +0 -42
  68. package/dist/constants-B2JTeRBb.js.map +0 -1
  69. package/dist/constants-BINTA5VZ.cjs +0 -77
  70. package/dist/constants-BINTA5VZ.cjs.map +0 -1
  71. package/dist/constants-BYGmiFs0.cjs +0 -139
  72. package/dist/constants-BYGmiFs0.cjs.map +0 -1
  73. package/dist/constants-DSJ-Xrbv.js +0 -116
  74. package/dist/constants-DSJ-Xrbv.js.map +0 -1
  75. package/dist/define-Bdn8j5VM.cjs.map +0 -1
  76. package/dist/define-m_fp-Aqm.js.map +0 -1
  77. package/dist/generate-BY-juRdH.js.map +0 -1
  78. package/dist/generate-Bod9YCbF.cjs.map +0 -1
  79. package/dist/mcp-BSNulBcC.js +0 -39
  80. package/dist/mcp-BSNulBcC.js.map +0 -1
  81. package/dist/mcp-DcSrFhhP.cjs +0 -39
  82. package/dist/mcp-DcSrFhhP.cjs.map +0 -1
  83. package/dist/package-D5wmvFl4.js +0 -6
  84. package/dist/package-D5wmvFl4.js.map +0 -1
  85. package/dist/package-DrUndPET.cjs.map +0 -1
  86. package/dist/run-BAJubgdA.js +0 -1735
  87. package/dist/run-BAJubgdA.js.map +0 -1
  88. package/dist/run-BzpYYOQs.js +0 -121
  89. package/dist/run-BzpYYOQs.js.map +0 -1
  90. package/dist/run-CCZ24VKk.js.map +0 -1
  91. package/dist/run-CF97BWVa.js.map +0 -1
  92. package/dist/run-CQbj3ley.cjs.map +0 -1
  93. package/dist/run-CqKd6JNc.cjs +0 -1738
  94. package/dist/run-CqKd6JNc.cjs.map +0 -1
  95. package/dist/run-D0hmRpHy.js +0 -49
  96. package/dist/run-D0hmRpHy.js.map +0 -1
  97. package/dist/run-DwdAwnLG.cjs +0 -125
  98. package/dist/run-DwdAwnLG.cjs.map +0 -1
  99. package/dist/run-Lr0Ctnu0.cjs +0 -50
  100. package/dist/run-Lr0Ctnu0.cjs.map +0 -1
  101. package/dist/run-YsoCk5we.cjs.map +0 -1
  102. package/dist/shell-475fQKaX.cjs +0 -62
  103. package/dist/shell-475fQKaX.cjs.map +0 -1
  104. package/dist/shell-CN6DNqeC.js +0 -51
  105. package/dist/shell-CN6DNqeC.js.map +0 -1
  106. package/dist/telemetry-B2iWkY5e.cjs +0 -280
  107. package/dist/telemetry-B2iWkY5e.cjs.map +0 -1
  108. package/dist/telemetry-BkektVz6.js +0 -243
  109. package/dist/telemetry-BkektVz6.js.map +0 -1
  110. package/src/commands/agent/start.ts +0 -50
  111. package/src/commands/agent.ts +0 -10
  112. package/src/commands/generate.ts +0 -59
  113. package/src/commands/init.ts +0 -51
  114. package/src/commands/mcp.ts +0 -36
  115. package/src/commands/validate.ts +0 -22
  116. package/src/constants.ts +0 -48
  117. package/src/index.ts +0 -45
  118. package/src/loggers/clackLogger.ts +0 -460
  119. package/src/loggers/fileSystemLogger.ts +0 -148
  120. package/src/loggers/githubActionsLogger.ts +0 -367
  121. package/src/loggers/plainLogger.ts +0 -243
  122. package/src/loggers/types.ts +0 -7
  123. package/src/loggers/utils.ts +0 -252
  124. package/src/runners/agent/run.ts +0 -113
  125. package/src/runners/agent/utils.ts +0 -98
  126. package/src/runners/generate/run.ts +0 -276
  127. package/src/runners/generate/utils.ts +0 -209
  128. package/src/runners/init/run.ts +0 -211
  129. package/src/runners/init/utils.ts +0 -33
  130. package/src/runners/mcp/run.ts +0 -55
  131. package/src/runners/validate/run.ts +0 -63
  132. package/src/telemetry.ts +0 -280
  133. /package/dist/{chunk-ByKO4r7w.cjs → rolldown-runtime-Bx3C2hgW.cjs} +0 -0
@@ -0,0 +1,21 @@
1
+ import "./rolldown-runtime-C0LytTxp.js";
2
+ import { t as defineCommand } from "./defineCommand-DMEeqliP.js";
3
+ import { t as version } from "./package-CsDaFmfZ.js";
4
+ //#region src/commands/mcp.ts
5
+ const command = defineCommand({
6
+ name: "mcp",
7
+ description: "Start a Model Context Protocol (MCP) server that exposes Kubb code generation as tools for AI assistants. Once running, configure your AI client (Claude, Cursor, Windsurf, etc.) to connect to it — the assistant can then call kubb generate directly without leaving the chat.",
8
+ examples: [
9
+ "kubb mcp",
10
+ "# Then add to your MCP client config:",
11
+ "# { \"mcpServers\": { \"kubb\": { \"command\": \"npx\", \"args\": [\"kubb\", \"mcp\"] } } }"
12
+ ],
13
+ async run() {
14
+ const { run } = await import("./run-BlFVmIJl.js");
15
+ await run({ version });
16
+ }
17
+ });
18
+ //#endregion
19
+ export { command };
20
+
21
+ //# sourceMappingURL=mcp-BlKi3z04.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp-BlKi3z04.js","names":[],"sources":["../src/commands/mcp.ts"],"sourcesContent":["import { defineCommand } from '@internals/utils'\nimport { version } from '../../package.json'\n\nexport const command = defineCommand({\n name: 'mcp',\n description:\n 'Start a Model Context Protocol (MCP) server that exposes Kubb code generation as tools for AI assistants. Once running, configure your AI client (Claude, Cursor, Windsurf, etc.) to connect to it — the assistant can then call kubb generate directly without leaving the chat.',\n examples: ['kubb mcp', '# Then add to your MCP client config:', '# { \"mcpServers\": { \"kubb\": { \"command\": \"npx\", \"args\": [\"kubb\", \"mcp\"] } } }'],\n async run() {\n const { run } = await import('../runners/mcp/run.ts')\n\n await run({ version })\n },\n})\n"],"mappings":";;;;AAGA,MAAa,UAAU,cAAc;CACnC,MAAM;CACN,aACE;CACF,UAAU;EAAC;EAAY;EAAyC;CAA+E;CAC/I,MAAM,MAAM;EACV,MAAM,EAAE,QAAQ,MAAM,OAAO;EAE7B,MAAM,IAAI,EAAE,QAAQ,CAAC;CACvB;AACF,CAAC"}
@@ -0,0 +1,21 @@
1
+ require("./rolldown-runtime-Bx3C2hgW.cjs");
2
+ const require_defineCommand = require("./defineCommand-Bo3yZTWI.cjs");
3
+ const require_package = require("./package-HWZRLSO4.cjs");
4
+ //#region src/commands/mcp.ts
5
+ const command = require_defineCommand.defineCommand({
6
+ name: "mcp",
7
+ description: "Start a Model Context Protocol (MCP) server that exposes Kubb code generation as tools for AI assistants. Once running, configure your AI client (Claude, Cursor, Windsurf, etc.) to connect to it — the assistant can then call kubb generate directly without leaving the chat.",
8
+ examples: [
9
+ "kubb mcp",
10
+ "# Then add to your MCP client config:",
11
+ "# { \"mcpServers\": { \"kubb\": { \"command\": \"npx\", \"args\": [\"kubb\", \"mcp\"] } } }"
12
+ ],
13
+ async run() {
14
+ const { run } = await Promise.resolve().then(() => require("./run-BM1t8CSM.cjs"));
15
+ await run({ version: require_package.version });
16
+ }
17
+ });
18
+ //#endregion
19
+ exports.command = command;
20
+
21
+ //# sourceMappingURL=mcp-DSo5Ccwz.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp-DSo5Ccwz.cjs","names":["defineCommand"],"sources":["../src/commands/mcp.ts"],"sourcesContent":["import { defineCommand } from '@internals/utils'\nimport { version } from '../../package.json'\n\nexport const command = defineCommand({\n name: 'mcp',\n description:\n 'Start a Model Context Protocol (MCP) server that exposes Kubb code generation as tools for AI assistants. Once running, configure your AI client (Claude, Cursor, Windsurf, etc.) to connect to it — the assistant can then call kubb generate directly without leaving the chat.',\n examples: ['kubb mcp', '# Then add to your MCP client config:', '# { \"mcpServers\": { \"kubb\": { \"command\": \"npx\", \"args\": [\"kubb\", \"mcp\"] } } }'],\n async run() {\n const { run } = await import('../runners/mcp/run.ts')\n\n await run({ version })\n },\n})\n"],"mappings":";;;;AAGA,MAAa,UAAUA,sBAAAA,cAAc;CACnC,MAAM;CACN,aACE;CACF,UAAU;EAAC;EAAY;EAAyC;CAA+E;CAC/I,MAAM,MAAM;EACV,MAAM,EAAE,QAAQ,MAAA,QAAA,QAAA,CAAA,CAAA,WAAA,QAAM,oBAAA,CAAA;EAEtB,MAAM,IAAI,EAAE,SAAA,gBAAA,QAAQ,CAAC;CACvB;AACF,CAAC"}
@@ -0,0 +1,6 @@
1
+ //#region package.json
2
+ var version = "5.0.0-beta.70";
3
+ //#endregion
4
+ export { version as t };
5
+
6
+ //# sourceMappingURL=package-CsDaFmfZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"package-CsDaFmfZ.js","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
@@ -1,5 +1,5 @@
1
1
  //#region package.json
2
- var version = "5.0.0-beta.7";
2
+ var version = "5.0.0-beta.70";
3
3
  //#endregion
4
4
  Object.defineProperty(exports, "version", {
5
5
  enumerable: true,
@@ -8,4 +8,4 @@ Object.defineProperty(exports, "version", {
8
8
  }
9
9
  });
10
10
 
11
- //# sourceMappingURL=package-DrUndPET.cjs.map
11
+ //# sourceMappingURL=package-HWZRLSO4.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"package-HWZRLSO4.cjs","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
@@ -1,4 +1,3 @@
1
- import "node:module";
2
1
  //#region \0rolldown/runtime.js
3
2
  var __defProp = Object.defineProperty;
4
3
  var __name = (target, value) => __defProp(target, "name", {
@@ -1,70 +1,95 @@
1
- const require_chunk = require("./chunk-ByKO4r7w.cjs");
2
- const require_shell = require("./shell-475fQKaX.cjs");
3
- const require_constants = require("./constants-BYGmiFs0.cjs");
1
+ const require_rolldown_runtime = require("./rolldown-runtime-Bx3C2hgW.cjs");
2
+ const require_tools = require("./tools-CZT9wSA6.cjs");
4
3
  let node_util = require("node:util");
5
4
  let node_fs = require("node:fs");
6
- node_fs = require_chunk.__toESM(node_fs, 1);
5
+ node_fs = require_rolldown_runtime.__toESM(node_fs, 1);
7
6
  let node_path = require("node:path");
8
- node_path = require_chunk.__toESM(node_path, 1);
7
+ node_path = require_rolldown_runtime.__toESM(node_path, 1);
9
8
  let node_process = require("node:process");
10
- node_process = require_chunk.__toESM(node_process, 1);
9
+ node_process = require_rolldown_runtime.__toESM(node_process, 1);
11
10
  let _clack_prompts = require("@clack/prompts");
12
- _clack_prompts = require_chunk.__toESM(_clack_prompts, 1);
13
- //#region ../../internals/utils/src/packageManager.ts
14
- /**
15
- * Metadata for each supported package manager, keyed by its short name.
16
- *
17
- * @example
18
- * ```ts
19
- * packageManagers.pnpm.installCommand // ['add', '-D']
20
- * packageManagers.npm.lockFile // 'package-lock.json'
21
- * ```
22
- */
23
- const packageManagers = {
24
- pnpm: {
25
- name: "pnpm",
26
- lockFile: "pnpm-lock.yaml",
27
- installCommand: ["add", "-D"]
11
+ _clack_prompts = require_rolldown_runtime.__toESM(_clack_prompts, 1);
12
+ let tinyexec = require("tinyexec");
13
+ //#region ../../internals/shared/src/constants.ts
14
+ const KUBB_CONFIG_FILENAME = "kubb.config.ts";
15
+ const initDefaults = {
16
+ inputPath: "./openapi.yaml",
17
+ outputPath: "./src/gen",
18
+ plugins: ["plugin-ts"]
19
+ };
20
+ const availablePlugins = [
21
+ {
22
+ value: "plugin-ts",
23
+ label: "TypeScript",
24
+ hint: "Recommended",
25
+ packageName: "@kubb/plugin-ts",
26
+ importName: "pluginTs",
27
+ category: "types"
28
+ },
29
+ {
30
+ value: "plugin-client",
31
+ label: "Client (Fetch/Axios)",
32
+ packageName: "@kubb/plugin-client",
33
+ importName: "pluginClient",
34
+ category: "client"
35
+ },
36
+ {
37
+ value: "plugin-react-query",
38
+ label: "React Query / TanStack Query",
39
+ packageName: "@kubb/plugin-react-query",
40
+ importName: "pluginReactQuery",
41
+ category: "framework"
42
+ },
43
+ {
44
+ value: "plugin-vue-query",
45
+ label: "Vue Query",
46
+ packageName: "@kubb/plugin-vue-query",
47
+ importName: "pluginVueQuery",
48
+ category: "framework"
49
+ },
50
+ {
51
+ value: "plugin-zod",
52
+ label: "Zod Schemas",
53
+ packageName: "@kubb/plugin-zod",
54
+ importName: "pluginZod",
55
+ category: "validation"
56
+ },
57
+ {
58
+ value: "plugin-faker",
59
+ label: "Faker.js Mocks",
60
+ packageName: "@kubb/plugin-faker",
61
+ importName: "pluginFaker",
62
+ category: "mocks"
63
+ },
64
+ {
65
+ value: "plugin-msw",
66
+ label: "MSW Handlers",
67
+ packageName: "@kubb/plugin-msw",
68
+ importName: "pluginMsw",
69
+ category: "mocks"
28
70
  },
29
- yarn: {
30
- name: "yarn",
31
- lockFile: "yarn.lock",
32
- installCommand: ["add", "-D"]
71
+ {
72
+ value: "plugin-cypress",
73
+ label: "Cypress Tests",
74
+ packageName: "@kubb/plugin-cypress",
75
+ importName: "pluginCypress",
76
+ category: "testing"
33
77
  },
34
- bun: {
35
- name: "bun",
36
- lockFile: "bun.lockb",
37
- installCommand: ["add", "-d"]
78
+ {
79
+ value: "plugin-mcp",
80
+ label: "MCP Server (AI / Model Context Protocol)",
81
+ packageName: "@kubb/plugin-mcp",
82
+ importName: "pluginMcp",
83
+ category: "ai"
38
84
  },
39
- npm: {
40
- name: "npm",
41
- lockFile: "package-lock.json",
42
- installCommand: ["install", "--save-dev"]
85
+ {
86
+ value: "plugin-redoc",
87
+ label: "ReDoc Documentation",
88
+ packageName: "@kubb/plugin-redoc",
89
+ importName: "pluginRedoc",
90
+ category: "documentation"
43
91
  }
44
- };
45
- /**
46
- * Detects the active package manager for the given directory.
47
- * Resolution order: `packageManager` field in `package.json`, then presence of a lock file.
48
- * Falls back to `npm` when no signal is found.
49
- *
50
- * @example
51
- * ```ts
52
- * detectPackageManager('/my/project') // { name: 'pnpm', lockFile: 'pnpm-lock.yaml', ... }
53
- * detectPackageManager() // falls back to npm when no lock file is found
54
- * ```
55
- */
56
- function detectPackageManager(cwd = process.cwd()) {
57
- const packageJsonPath = (0, node_path.join)(cwd, "package.json");
58
- if ((0, node_fs.existsSync)(packageJsonPath)) try {
59
- const pmField = JSON.parse((0, node_fs.readFileSync)(packageJsonPath, "utf-8")).packageManager;
60
- if (typeof pmField === "string") {
61
- const name = pmField.split("@")[0];
62
- if (name && name in packageManagers) return packageManagers[name];
63
- }
64
- } catch {}
65
- for (const pm of Object.values(packageManagers)) if ((0, node_fs.existsSync)((0, node_path.join)(cwd, pm.lockFile))) return pm;
66
- return packageManagers.npm;
67
- }
92
+ ];
68
93
  //#endregion
69
94
  //#region ../../internals/shared/src/init.ts
70
95
  function generateConfigFile({ selectedPlugins, inputPath, outputPath }) {
@@ -81,9 +106,7 @@ export default defineConfig({
81
106
  clean: true,
82
107
  },
83
108
  plugins: [
84
- ${selectedPlugins.map((plugin) => {
85
- return ` ${require_constants.pluginDefaultConfigs[plugin.value] ?? `${plugin.importName}()`},`;
86
- }).join("\n")}
109
+ ${selectedPlugins.map((plugin) => ` ${plugin.importName}(),`).join("\n")}
87
110
  ],
88
111
  })
89
112
  `;
@@ -100,22 +123,34 @@ function hasPackageJson(cwd = node_process.default.cwd()) {
100
123
  * Initializes a new `package.json` at `cwd` using the detected package manager.
101
124
  */
102
125
  async function initPackageJson(cwd, packageManager) {
103
- await require_shell.spawnAsync(packageManager.name, {
126
+ await (0, tinyexec.x)(packageManager.name, {
104
127
  npm: ["init", "-y"],
105
128
  pnpm: ["init"],
106
129
  yarn: ["init", "-y"],
107
130
  bun: ["init", "-y"]
108
- }[packageManager.name], { cwd });
131
+ }[packageManager.name], {
132
+ nodeOptions: {
133
+ cwd,
134
+ stdio: "inherit"
135
+ },
136
+ throwOnError: true
137
+ });
109
138
  }
110
139
  /**
111
140
  * Installs the given packages at `cwd` using the detected package manager.
112
141
  */
113
142
  async function installPackages(packages, packageManager, cwd = node_process.default.cwd()) {
114
- await require_shell.spawnAsync(packageManager.name, [...packageManager.installCommand, ...packages], { cwd });
143
+ await (0, tinyexec.x)(packageManager.name, [...packageManager.installCommand, ...packages], {
144
+ nodeOptions: {
145
+ cwd,
146
+ stdio: "inherit"
147
+ },
148
+ throwOnError: true
149
+ });
115
150
  }
116
151
  //#endregion
117
152
  //#region src/runners/init/run.ts
118
- function cancelAndExit(message = "Operation cancelled.") {
153
+ function cancelAndExit(message = "Operation canceled.") {
119
154
  _clack_prompts.cancel(message);
120
155
  node_process.default.exit(0);
121
156
  }
@@ -153,57 +188,60 @@ async function run({ yes, version, input: inputFlag, output: outputFlag, plugins
153
188
  });
154
189
  if (_clack_prompts.isCancel(shouldInit) || !shouldInit) cancelAndExit();
155
190
  }
156
- const packageManager = detectPackageManager(cwd);
191
+ const packageManager = require_tools.detectPackageManager(cwd);
157
192
  const spinner = _clack_prompts.spinner();
158
193
  spinner.start(`Initializing package.json with ${packageManager.name}`);
159
194
  await initPackageJson(cwd, packageManager);
160
195
  spinner.stop(`Created package.json with ${packageManager.name}`);
161
196
  }
162
- const packageManager = detectPackageManager(cwd);
197
+ const packageManager = require_tools.detectPackageManager(cwd);
163
198
  if (hasPackageJson(cwd)) _clack_prompts.log.info(`Detected package manager: ${(0, node_util.styleText)("cyan", packageManager.name)}`);
164
- const inputPath = await resolveOrPrompt(inputFlag, require_constants.initDefaults.inputPath, "Using input path", () => _clack_prompts.text({
199
+ const inputPath = await resolveOrPrompt(inputFlag, initDefaults.inputPath, "Using input path", () => _clack_prompts.text({
165
200
  message: "Where is your OpenAPI specification located?",
166
- placeholder: require_constants.initDefaults.inputPath,
167
- defaultValue: require_constants.initDefaults.inputPath,
201
+ placeholder: initDefaults.inputPath,
202
+ defaultValue: initDefaults.inputPath,
168
203
  validate: (value) => {
169
204
  if (!value) return "Input path is required";
170
205
  }
171
206
  }));
172
- const outputPath = await resolveOrPrompt(outputFlag, require_constants.initDefaults.outputPath, "Using output path", () => _clack_prompts.text({
207
+ const outputPath = await resolveOrPrompt(outputFlag, initDefaults.outputPath, "Using output path", () => _clack_prompts.text({
173
208
  message: "Where should the generated files be output?",
174
- placeholder: require_constants.initDefaults.outputPath,
175
- defaultValue: require_constants.initDefaults.outputPath,
209
+ placeholder: initDefaults.outputPath,
210
+ defaultValue: initDefaults.outputPath,
176
211
  validate: (value) => {
177
212
  if (!value) return "Output path is required";
178
213
  }
179
214
  }));
180
- const defaultPlugins = require_constants.availablePlugins.filter((p) => require_constants.initDefaults.plugins.includes(p.value));
215
+ const defaultPlugins = availablePlugins.filter((p) => initDefaults.plugins.includes(p.value));
181
216
  const pluginLabel = (plugins) => (0, node_util.styleText)("cyan", plugins.map((p) => p.label).join(", "));
182
- let selectedPlugins;
183
- if (pluginsFlag) {
184
- const requested = pluginsFlag.split(",").map((v) => v.trim()).filter(Boolean);
185
- selectedPlugins = require_constants.availablePlugins.filter((p) => requested.includes(p.value));
186
- if (selectedPlugins.length === 0) {
187
- selectedPlugins = defaultPlugins;
188
- _clack_prompts.log.warn(`No valid plugins found in --plugins value; falling back to default: ${pluginLabel(defaultPlugins)}`);
189
- } else _clack_prompts.log.info(`Using plugins: ${pluginLabel(selectedPlugins)}`);
190
- } else if (yes) {
191
- selectedPlugins = defaultPlugins;
192
- _clack_prompts.log.info(`Using plugins: ${pluginLabel(defaultPlugins)}`);
193
- } else {
217
+ const selectedPlugins = await (async () => {
218
+ if (pluginsFlag) {
219
+ const requested = pluginsFlag.split(",").map((v) => v.trim()).filter(Boolean);
220
+ const plugins = availablePlugins.filter((p) => requested.includes(p.value));
221
+ if (plugins.length === 0) {
222
+ _clack_prompts.log.warn(`No valid plugins found in --plugins value; falling back to default: ${pluginLabel(defaultPlugins)}`);
223
+ return defaultPlugins;
224
+ }
225
+ _clack_prompts.log.info(`Using plugins: ${pluginLabel(plugins)}`);
226
+ return plugins;
227
+ }
228
+ if (yes) {
229
+ _clack_prompts.log.info(`Using plugins: ${pluginLabel(defaultPlugins)}`);
230
+ return defaultPlugins;
231
+ }
194
232
  const values = await _clack_prompts.multiselect({
195
233
  message: "Select plugins to use:",
196
- options: require_constants.availablePlugins.map(({ value, label, hint }) => ({
234
+ options: availablePlugins.map(({ value, label, hint }) => ({
197
235
  value,
198
236
  label,
199
237
  hint
200
238
  })),
201
- initialValues: [...require_constants.initDefaults.plugins],
239
+ initialValues: [...initDefaults.plugins],
202
240
  required: true
203
241
  });
204
242
  if (_clack_prompts.isCancel(values)) cancelAndExit();
205
- selectedPlugins = require_constants.availablePlugins.filter((p) => values.includes(p.value));
206
- }
243
+ return availablePlugins.filter((p) => values.includes(p.value));
244
+ })();
207
245
  const packagesToInstall = ["kubb", ...selectedPlugins.map((p) => p.packageName)];
208
246
  const spinner = _clack_prompts.spinner();
209
247
  spinner.start(`Installing ${packagesToInstall.length} packages with ${packageManager.name}`);
@@ -215,27 +253,27 @@ async function run({ yes, version, input: inputFlag, output: outputFlag, plugins
215
253
  throw error;
216
254
  }
217
255
  const configSpinner = _clack_prompts.spinner();
218
- configSpinner.start(`Creating ${require_constants.KUBB_CONFIG_FILENAME}`);
256
+ configSpinner.start(`Creating ${KUBB_CONFIG_FILENAME}`);
219
257
  const configContent = generateConfigFile({
220
258
  selectedPlugins,
221
259
  inputPath,
222
260
  outputPath
223
261
  });
224
- const configPath = node_path.default.join(cwd, require_constants.KUBB_CONFIG_FILENAME);
262
+ const configPath = node_path.default.join(cwd, KUBB_CONFIG_FILENAME);
225
263
  if (node_fs.default.existsSync(configPath)) {
226
- configSpinner.stop(`${require_constants.KUBB_CONFIG_FILENAME} already exists`);
264
+ configSpinner.stop(`${KUBB_CONFIG_FILENAME} already exists`);
227
265
  if (!yes) {
228
266
  const shouldOverwrite = await _clack_prompts.confirm({
229
- message: `${require_constants.KUBB_CONFIG_FILENAME} already exists. Overwrite?`,
267
+ message: `${KUBB_CONFIG_FILENAME} already exists. Overwrite?`,
230
268
  initialValue: false
231
269
  });
232
270
  if (_clack_prompts.isCancel(shouldOverwrite) || !shouldOverwrite) cancelAndExit("Keeping existing configuration. Packages have been installed.");
233
271
  }
234
- configSpinner.start(`Overwriting ${require_constants.KUBB_CONFIG_FILENAME}`);
272
+ configSpinner.start(`Overwriting ${KUBB_CONFIG_FILENAME}`);
235
273
  }
236
274
  await node_fs.default.promises.writeFile(configPath, configContent, "utf-8");
237
- configSpinner.stop(`Created ${require_constants.KUBB_CONFIG_FILENAME}`);
238
- _clack_prompts.outro((0, node_util.styleText)("green", "✓ All set!") + "\n\n" + (0, node_util.styleText)("dim", "Next steps:") + "\n" + (0, node_util.styleText)("cyan", ` 1. Make sure your OpenAPI spec is at: ${inputPath}`) + "\n" + (0, node_util.styleText)("cyan", " 2. Generate code with: npx kubb generate") + "\n" + (0, node_util.styleText)("cyan", " Or start a stream server with: npx kubb agent start") + "\n" + (0, node_util.styleText)("cyan", ` 3. Find generated files in: ${outputPath}`) + "\n\n" + (0, node_util.styleText)("dim", `Using ${packageManager.name} • Kubb v${version}`));
275
+ configSpinner.stop(`Created ${KUBB_CONFIG_FILENAME}`);
276
+ _clack_prompts.outro((0, node_util.styleText)("green", "✓ All set!") + "\n\n" + (0, node_util.styleText)("dim", "Next steps:") + "\n" + (0, node_util.styleText)("cyan", ` 1. Make sure your OpenAPI spec is at: ${inputPath}`) + "\n" + (0, node_util.styleText)("cyan", " 2. Generate code with: npx kubb generate") + "\n" + (0, node_util.styleText)("cyan", ` 3. Find generated files in: ${outputPath}`) + "\n\n" + (0, node_util.styleText)("dim", `Using ${packageManager.name} • Kubb v${version}`));
239
277
  } catch (error) {
240
278
  _clack_prompts.log.error((0, node_util.styleText)("red", "An error occurred during initialization"));
241
279
  if (error instanceof Error) _clack_prompts.log.error(error.message);
@@ -245,4 +283,4 @@ async function run({ yes, version, input: inputFlag, output: outputFlag, plugins
245
283
  //#endregion
246
284
  exports.run = run;
247
285
 
248
- //# sourceMappingURL=run-YsoCk5we.cjs.map
286
+ //# sourceMappingURL=run-AYlRjIX5.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-AYlRjIX5.cjs","names":["process","fs","path","process","clack","detectPackageManager","path","fs"],"sources":["../../../internals/shared/src/constants.ts","../../../internals/shared/src/init.ts","../src/runners/init/utils.ts","../src/runners/init/run.ts"],"sourcesContent":["import type { PluginOption } from './types.ts'\n\nexport const KUBB_CONFIG_FILENAME = 'kubb.config.ts' as const\n\nexport const initDefaults = {\n inputPath: './openapi.yaml',\n outputPath: './src/gen',\n plugins: ['plugin-ts'],\n} as const\n\nexport const availablePlugins: Array<PluginOption> = [\n {\n value: 'plugin-ts',\n label: 'TypeScript',\n hint: 'Recommended',\n packageName: '@kubb/plugin-ts',\n importName: 'pluginTs',\n category: 'types',\n },\n {\n value: 'plugin-client',\n label: 'Client (Fetch/Axios)',\n packageName: '@kubb/plugin-client',\n importName: 'pluginClient',\n category: 'client',\n },\n {\n value: 'plugin-react-query',\n label: 'React Query / TanStack Query',\n packageName: '@kubb/plugin-react-query',\n importName: 'pluginReactQuery',\n category: 'framework',\n },\n {\n value: 'plugin-vue-query',\n label: 'Vue Query',\n packageName: '@kubb/plugin-vue-query',\n importName: 'pluginVueQuery',\n category: 'framework',\n },\n {\n value: 'plugin-zod',\n label: 'Zod Schemas',\n packageName: '@kubb/plugin-zod',\n importName: 'pluginZod',\n category: 'validation',\n },\n {\n value: 'plugin-faker',\n label: 'Faker.js Mocks',\n packageName: '@kubb/plugin-faker',\n importName: 'pluginFaker',\n category: 'mocks',\n },\n {\n value: 'plugin-msw',\n label: 'MSW Handlers',\n packageName: '@kubb/plugin-msw',\n importName: 'pluginMsw',\n category: 'mocks',\n },\n {\n value: 'plugin-cypress',\n label: 'Cypress Tests',\n packageName: '@kubb/plugin-cypress',\n importName: 'pluginCypress',\n category: 'testing',\n },\n {\n value: 'plugin-mcp',\n label: 'MCP Server (AI / Model Context Protocol)',\n packageName: '@kubb/plugin-mcp',\n importName: 'pluginMcp',\n category: 'ai',\n },\n {\n value: 'plugin-redoc',\n label: 'ReDoc Documentation',\n packageName: '@kubb/plugin-redoc',\n importName: 'pluginRedoc',\n category: 'documentation',\n },\n]\n","import type { PluginOption } from './types.ts'\n\nexport function generateConfigFile({\n selectedPlugins,\n inputPath,\n outputPath,\n}: {\n selectedPlugins: Array<PluginOption>\n inputPath: string\n outputPath: string\n}): string {\n const imports = selectedPlugins.map((plugin) => `import { ${plugin.importName} } from '${plugin.packageName}'`).join('\\n')\n\n const pluginConfigs = selectedPlugins.map((plugin) => ` ${plugin.importName}(),`).join('\\n')\n\n return `import { defineConfig } from 'kubb'\n${imports}\n\nexport default defineConfig({\n root: '.',\n input: {\n path: '${inputPath}',\n },\n output: {\n path: '${outputPath}',\n clean: true,\n },\n plugins: [\n${pluginConfigs}\n ],\n})\n`\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport process from 'node:process'\nimport type { PackageManagerInfo, PackageManagerName } from '@internals/utils'\nimport { x } from 'tinyexec'\n\n/**\n * Returns `true` when a `package.json` exists at `cwd`.\n */\nexport function hasPackageJson(cwd: string = process.cwd()): boolean {\n return fs.existsSync(path.join(cwd, 'package.json'))\n}\n\n/**\n * Initializes a new `package.json` at `cwd` using the detected package manager.\n */\nexport async function initPackageJson(cwd: string, packageManager: PackageManagerInfo): Promise<void> {\n const commands: Record<PackageManagerName, Array<string>> = {\n npm: ['init', '-y'],\n pnpm: ['init'],\n yarn: ['init', '-y'],\n bun: ['init', '-y'],\n }\n\n await x(packageManager.name, commands[packageManager.name], {\n nodeOptions: { cwd, stdio: 'inherit' },\n throwOnError: true,\n })\n}\n\n/**\n * Installs the given packages at `cwd` using the detected package manager.\n */\nexport async function installPackages(packages: Array<string>, packageManager: PackageManagerInfo, cwd: string = process.cwd()): Promise<void> {\n await x(packageManager.name, [...packageManager.installCommand, ...packages], {\n nodeOptions: { cwd, stdio: 'inherit' },\n throwOnError: true,\n })\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { detectPackageManager } from '@internals/utils'\nimport { availablePlugins, generateConfigFile, initDefaults, KUBB_CONFIG_FILENAME, type PluginOption } from '@internals/shared'\nimport { hasPackageJson, initPackageJson, installPackages } from './utils.ts'\n\nfunction cancelAndExit(message = 'Operation canceled.'): never {\n clack.cancel(message)\n process.exit(0)\n}\n\ntype InitOptions = {\n /**\n * When `true`, skips all interactive prompts and uses default values.\n */\n yes: boolean\n /**\n * Current `@kubb/cli` version string, shown in the closing outro.\n */\n version: string\n /**\n * Input path flag value from `--input`. When provided, skips the input prompt.\n */\n input?: string\n /**\n * Output directory flag value from `--output`. When provided, skips the output prompt.\n */\n output?: string\n /**\n * Comma-separated plugin list from `--plugins`, e.g. `'plugin-ts,plugin-zod'`. When provided, skips the plugin selection prompt.\n */\n plugins?: string\n}\n\n/**\n * Runs the interactive Kubb scaffolding wizard.\n * Detects the package manager, prompts for input/output paths and plugins, installs packages, and writes `kubb.config.ts`.\n * Pass `yes: true` to skip all prompts and use defaults.\n */\nexport async function run({ yes, version, input: inputFlag, output: outputFlag, plugins: pluginsFlag }: InitOptions): Promise<void> {\n const cwd = process.cwd()\n\n clack.intro(styleText('bgCyan', styleText('black', ' Kubb Init ')))\n\n /**\n * Returns `flag` when provided, the `defaultValue` when `yes` is set,\n * or calls `prompt()` for interactive input. Exits on cancellation.\n */\n async function resolveOrPrompt<T>(flag: T | undefined, defaultValue: T, logLabel: string, prompt: () => Promise<T | symbol>): Promise<T> {\n if (flag !== undefined) {\n clack.log.info(`${logLabel}: ${styleText('cyan', String(flag))}`)\n return flag\n }\n if (yes) {\n clack.log.info(`${logLabel}: ${styleText('cyan', String(defaultValue))}`)\n return defaultValue\n }\n const result = await prompt()\n if (clack.isCancel(result)) cancelAndExit()\n return result as T\n }\n\n try {\n // Check/create package.json, detect package manager once after the block\n if (!hasPackageJson(cwd)) {\n if (!yes) {\n const shouldInit = await clack.confirm({\n message: 'No package.json found. Would you like to create one?',\n initialValue: true,\n })\n\n if (clack.isCancel(shouldInit) || !shouldInit) {\n cancelAndExit()\n }\n }\n\n const packageManager = detectPackageManager(cwd)\n const spinner = clack.spinner()\n spinner.start(`Initializing package.json with ${packageManager.name}`)\n await initPackageJson(cwd, packageManager)\n spinner.stop(`Created package.json with ${packageManager.name}`)\n }\n\n const packageManager = detectPackageManager(cwd)\n if (hasPackageJson(cwd)) {\n clack.log.info(`Detected package manager: ${styleText('cyan', packageManager.name)}`)\n }\n\n // Prompt for OpenAPI spec path\n const inputPath = await resolveOrPrompt(inputFlag, initDefaults.inputPath, 'Using input path', () =>\n clack.text({\n message: 'Where is your OpenAPI specification located?',\n placeholder: initDefaults.inputPath,\n defaultValue: initDefaults.inputPath,\n validate: (value) => {\n if (!value) return 'Input path is required'\n },\n }),\n )\n\n // Prompt for output directory\n const outputPath = await resolveOrPrompt(outputFlag, initDefaults.outputPath, 'Using output path', () =>\n clack.text({\n message: 'Where should the generated files be output?',\n placeholder: initDefaults.outputPath,\n defaultValue: initDefaults.outputPath,\n validate: (value) => {\n if (!value) return 'Output path is required'\n },\n }),\n )\n\n // Plugin selection\n const defaultPlugins = availablePlugins.filter((p) => (initDefaults.plugins as ReadonlyArray<string>).includes(p.value))\n const pluginLabel = (plugins: Array<PluginOption>) => styleText('cyan', plugins.map((p) => p.label).join(', '))\n\n const selectedPlugins: Array<PluginOption> = await (async () => {\n if (pluginsFlag) {\n const requested = pluginsFlag\n .split(',')\n .map((v) => v.trim())\n .filter(Boolean)\n const plugins = availablePlugins.filter((p) => requested.includes(p.value))\n if (plugins.length === 0) {\n clack.log.warn(`No valid plugins found in --plugins value; falling back to default: ${pluginLabel(defaultPlugins)}`)\n return defaultPlugins\n }\n clack.log.info(`Using plugins: ${pluginLabel(plugins)}`)\n return plugins\n }\n if (yes) {\n clack.log.info(`Using plugins: ${pluginLabel(defaultPlugins)}`)\n return defaultPlugins\n }\n const values = await clack.multiselect({\n message: 'Select plugins to use:',\n options: availablePlugins.map(({ value, label, hint }) => ({ value, label, hint })),\n initialValues: [...initDefaults.plugins],\n required: true,\n })\n if (clack.isCancel(values)) cancelAndExit()\n return availablePlugins.filter((p) => (values as Array<string>).includes(p.value))\n })()\n\n // Install packages\n const packagesToInstall = ['kubb', ...selectedPlugins.map((p) => p.packageName)]\n\n const spinner = clack.spinner()\n spinner.start(`Installing ${packagesToInstall.length} packages with ${packageManager.name}`)\n\n try {\n await installPackages(packagesToInstall, packageManager, cwd)\n spinner.stop(`Installed ${packagesToInstall.length} packages`)\n } catch (error) {\n spinner.stop('Installation failed')\n throw error\n }\n\n // Generate config file\n const configSpinner = clack.spinner()\n configSpinner.start(`Creating ${KUBB_CONFIG_FILENAME}`)\n\n const configContent = generateConfigFile({ selectedPlugins, inputPath, outputPath })\n const configPath = path.join(cwd, KUBB_CONFIG_FILENAME)\n\n if (fs.existsSync(configPath)) {\n configSpinner.stop(`${KUBB_CONFIG_FILENAME} already exists`)\n\n if (!yes) {\n const shouldOverwrite = await clack.confirm({\n message: `${KUBB_CONFIG_FILENAME} already exists. Overwrite?`,\n initialValue: false,\n })\n\n if (clack.isCancel(shouldOverwrite) || !shouldOverwrite) {\n cancelAndExit('Keeping existing configuration. Packages have been installed.')\n }\n }\n\n configSpinner.start(`Overwriting ${KUBB_CONFIG_FILENAME}`)\n }\n\n await fs.promises.writeFile(configPath, configContent, 'utf-8')\n\n configSpinner.stop(`Created ${KUBB_CONFIG_FILENAME}`)\n\n clack.outro(\n styleText('green', '✓ All set!') +\n '\\n\\n' +\n styleText('dim', 'Next steps:') +\n '\\n' +\n styleText('cyan', ` 1. Make sure your OpenAPI spec is at: ${inputPath}`) +\n '\\n' +\n styleText('cyan', ' 2. Generate code with: npx kubb generate') +\n '\\n' +\n styleText('cyan', ` 3. Find generated files in: ${outputPath}`) +\n '\\n\\n' +\n styleText('dim', `Using ${packageManager.name} • Kubb v${version}`),\n )\n } catch (error) {\n clack.log.error(styleText('red', 'An error occurred during initialization'))\n if (error instanceof Error) {\n clack.log.error(error.message)\n }\n process.exit(1)\n }\n}\n"],"mappings":";;;;;;;;;;;;;AAEA,MAAa,uBAAuB;AAEpC,MAAa,eAAe;CAC1B,WAAW;CACX,YAAY;CACZ,SAAS,CAAC,WAAW;AACvB;AAEA,MAAa,mBAAwC;CACnD;EACE,OAAO;EACP,OAAO;EACP,MAAM;EACN,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;CACA;EACE,OAAO;EACP,OAAO;EACP,aAAa;EACb,YAAY;EACZ,UAAU;CACZ;AACF;;;AChFA,SAAgB,mBAAmB,EACjC,iBACA,WACA,cAKS;CAKT,OAAO;EAJS,gBAAgB,KAAK,WAAW,YAAY,OAAO,WAAW,WAAW,OAAO,YAAY,EAAE,CAAC,CAAC,KAAK,IAK/G,EAAE;;;;;aAKG,UAAU;;;aAGV,WAAW;;;;EAXA,gBAAgB,KAAK,WAAW,OAAO,OAAO,WAAW,IAAI,CAAC,CAAC,KAAK,IAe9E,EAAE;;;;AAIhB;;;;;;ACvBA,SAAgB,eAAe,MAAcA,aAAAA,QAAQ,IAAI,GAAY;CACnE,OAAOC,QAAAA,QAAG,WAAWC,UAAAA,QAAK,KAAK,KAAK,cAAc,CAAC;AACrD;;;;AAKA,eAAsB,gBAAgB,KAAa,gBAAmD;CAQpG,OAAA,GAAA,SAAA,EAAA,CAAQ,eAAe,MAAM;EAN3B,KAAK,CAAC,QAAQ,IAAI;EAClB,MAAM,CAAC,MAAM;EACb,MAAM,CAAC,QAAQ,IAAI;EACnB,KAAK,CAAC,QAAQ,IAAI;CAGgB,EAAE,eAAe,OAAO;EAC1D,aAAa;GAAE;GAAK,OAAO;EAAU;EACrC,cAAc;CAChB,CAAC;AACH;;;;AAKA,eAAsB,gBAAgB,UAAyB,gBAAoC,MAAcF,aAAAA,QAAQ,IAAI,GAAkB;CAC7I,OAAA,GAAA,SAAA,EAAA,CAAQ,eAAe,MAAM,CAAC,GAAG,eAAe,gBAAgB,GAAG,QAAQ,GAAG;EAC5E,aAAa;GAAE;GAAK,OAAO;EAAU;EACrC,cAAc;CAChB,CAAC;AACH;;;AC7BA,SAAS,cAAc,UAAU,uBAA8B;CAC7D,eAAM,OAAO,OAAO;CACpB,aAAA,QAAQ,KAAK,CAAC;AAChB;;;;;;AA8BA,eAAsB,IAAI,EAAE,KAAK,SAAS,OAAO,WAAW,QAAQ,YAAY,SAAS,eAA2C;CAClI,MAAM,MAAMG,aAAAA,QAAQ,IAAI;CAExB,eAAM,OAAA,GAAA,UAAA,UAAA,CAAgB,WAAA,GAAA,UAAA,UAAA,CAAoB,SAAS,aAAa,CAAC,CAAC;;;;;CAMlE,eAAe,gBAAmB,MAAqB,cAAiB,UAAkB,QAA+C;EACvI,IAAI,SAAS,KAAA,GAAW;GACtB,eAAM,IAAI,KAAK,GAAG,SAAS,KAAA,GAAA,UAAA,UAAA,CAAc,QAAQ,OAAO,IAAI,CAAC,GAAG;GAChE,OAAO;EACT;EACA,IAAI,KAAK;GACP,eAAM,IAAI,KAAK,GAAG,SAAS,KAAA,GAAA,UAAA,UAAA,CAAc,QAAQ,OAAO,YAAY,CAAC,GAAG;GACxE,OAAO;EACT;EACA,MAAM,SAAS,MAAM,OAAO;EAC5B,IAAIC,eAAM,SAAS,MAAM,GAAG,cAAc;EAC1C,OAAO;CACT;CAEA,IAAI;EAEF,IAAI,CAAC,eAAe,GAAG,GAAG;GACxB,IAAI,CAAC,KAAK;IACR,MAAM,aAAa,MAAMA,eAAM,QAAQ;KACrC,SAAS;KACT,cAAc;IAChB,CAAC;IAED,IAAIA,eAAM,SAAS,UAAU,KAAK,CAAC,YACjC,cAAc;GAElB;GAEA,MAAM,iBAAiBC,cAAAA,qBAAqB,GAAG;GAC/C,MAAM,UAAUD,eAAM,QAAQ;GAC9B,QAAQ,MAAM,kCAAkC,eAAe,MAAM;GACrE,MAAM,gBAAgB,KAAK,cAAc;GACzC,QAAQ,KAAK,6BAA6B,eAAe,MAAM;EACjE;EAEA,MAAM,iBAAiBC,cAAAA,qBAAqB,GAAG;EAC/C,IAAI,eAAe,GAAG,GACpB,eAAM,IAAI,KAAK,8BAAA,GAAA,UAAA,UAAA,CAAuC,QAAQ,eAAe,IAAI,GAAG;EAItF,MAAM,YAAY,MAAM,gBAAgB,WAAW,aAAa,WAAW,0BACzED,eAAM,KAAK;GACT,SAAS;GACT,aAAa,aAAa;GAC1B,cAAc,aAAa;GAC3B,WAAW,UAAU;IACnB,IAAI,CAAC,OAAO,OAAO;GACrB;EACF,CAAC,CACH;EAGA,MAAM,aAAa,MAAM,gBAAgB,YAAY,aAAa,YAAY,2BAC5EA,eAAM,KAAK;GACT,SAAS;GACT,aAAa,aAAa;GAC1B,cAAc,aAAa;GAC3B,WAAW,UAAU;IACnB,IAAI,CAAC,OAAO,OAAO;GACrB;EACF,CAAC,CACH;EAGA,MAAM,iBAAiB,iBAAiB,QAAQ,MAAO,aAAa,QAAkC,SAAS,EAAE,KAAK,CAAC;EACvH,MAAM,eAAe,aAAA,GAAA,UAAA,UAAA,CAA2C,QAAQ,QAAQ,KAAK,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,IAAI,CAAC;EAE9G,MAAM,kBAAuC,OAAO,YAAY;GAC9D,IAAI,aAAa;IACf,MAAM,YAAY,YACf,MAAM,GAAG,CAAC,CACV,KAAK,MAAM,EAAE,KAAK,CAAC,CAAC,CACpB,OAAO,OAAO;IACjB,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,SAAS,EAAE,KAAK,CAAC;IAC1E,IAAI,QAAQ,WAAW,GAAG;KACxB,eAAM,IAAI,KAAK,uEAAuE,YAAY,cAAc,GAAG;KACnH,OAAO;IACT;IACA,eAAM,IAAI,KAAK,kBAAkB,YAAY,OAAO,GAAG;IACvD,OAAO;GACT;GACA,IAAI,KAAK;IACP,eAAM,IAAI,KAAK,kBAAkB,YAAY,cAAc,GAAG;IAC9D,OAAO;GACT;GACA,MAAM,SAAS,MAAMA,eAAM,YAAY;IACrC,SAAS;IACT,SAAS,iBAAiB,KAAK,EAAE,OAAO,OAAO,YAAY;KAAE;KAAO;KAAO;IAAK,EAAE;IAClF,eAAe,CAAC,GAAG,aAAa,OAAO;IACvC,UAAU;GACZ,CAAC;GACD,IAAIA,eAAM,SAAS,MAAM,GAAG,cAAc;GAC1C,OAAO,iBAAiB,QAAQ,MAAO,OAAyB,SAAS,EAAE,KAAK,CAAC;EACnF,EAAA,CAAG;EAGH,MAAM,oBAAoB,CAAC,QAAQ,GAAG,gBAAgB,KAAK,MAAM,EAAE,WAAW,CAAC;EAE/E,MAAM,UAAUA,eAAM,QAAQ;EAC9B,QAAQ,MAAM,cAAc,kBAAkB,OAAO,iBAAiB,eAAe,MAAM;EAE3F,IAAI;GACF,MAAM,gBAAgB,mBAAmB,gBAAgB,GAAG;GAC5D,QAAQ,KAAK,aAAa,kBAAkB,OAAO,UAAU;EAC/D,SAAS,OAAO;GACd,QAAQ,KAAK,qBAAqB;GAClC,MAAM;EACR;EAGA,MAAM,gBAAgBA,eAAM,QAAQ;EACpC,cAAc,MAAM,YAAY,sBAAsB;EAEtD,MAAM,gBAAgB,mBAAmB;GAAE;GAAiB;GAAW;EAAW,CAAC;EACnF,MAAM,aAAaE,UAAAA,QAAK,KAAK,KAAK,oBAAoB;EAEtD,IAAIC,QAAAA,QAAG,WAAW,UAAU,GAAG;GAC7B,cAAc,KAAK,GAAG,qBAAqB,gBAAgB;GAE3D,IAAI,CAAC,KAAK;IACR,MAAM,kBAAkB,MAAMH,eAAM,QAAQ;KAC1C,SAAS,GAAG,qBAAqB;KACjC,cAAc;IAChB,CAAC;IAED,IAAIA,eAAM,SAAS,eAAe,KAAK,CAAC,iBACtC,cAAc,+DAA+D;GAEjF;GAEA,cAAc,MAAM,eAAe,sBAAsB;EAC3D;EAEA,MAAMG,QAAAA,QAAG,SAAS,UAAU,YAAY,eAAe,OAAO;EAE9D,cAAc,KAAK,WAAW,sBAAsB;EAEpD,eAAM,OAAA,GAAA,UAAA,UAAA,CACM,SAAS,YAAY,IAC7B,UAAA,GAAA,UAAA,UAAA,CACU,OAAO,aAAa,IAC9B,QAAA,GAAA,UAAA,UAAA,CACU,QAAQ,2CAA2C,WAAW,IACxE,QAAA,GAAA,UAAA,UAAA,CACU,QAAQ,4CAA4C,IAC9D,QAAA,GAAA,UAAA,UAAA,CACU,QAAQ,iCAAiC,YAAY,IAC/D,UAAA,GAAA,UAAA,UAAA,CACU,OAAO,SAAS,eAAe,KAAK,WAAW,SAAS,CACtE;CACF,SAAS,OAAO;EACd,eAAM,IAAI,OAAA,GAAA,UAAA,UAAA,CAAgB,OAAO,yCAAyC,CAAC;EAC3E,IAAI,iBAAiB,OACnB,eAAM,IAAI,MAAM,MAAM,OAAO;EAE/B,aAAA,QAAQ,KAAK,CAAC;CAChB;AACF"}
@@ -0,0 +1,33 @@
1
+ const require_rolldown_runtime = require("./rolldown-runtime-Bx3C2hgW.cjs");
2
+ const require_errors = require("./errors-gxFK0vrp.cjs");
3
+ const require_Telemetry = require("./Telemetry-CfPP7MYq.cjs");
4
+ let node_util = require("node:util");
5
+ let node_process = require("node:process");
6
+ node_process = require_rolldown_runtime.__toESM(node_process, 1);
7
+ //#region src/runners/mcp/run.ts
8
+ /**
9
+ * Starts the `@kubb/mcp` server over stdio and reports the outcome to telemetry.
10
+ */
11
+ async function run({ version }) {
12
+ const { run: startMcpServer } = await import("@kubb/mcp");
13
+ const hrStart = node_process.default.hrtime();
14
+ const report = (status) => require_Telemetry.Telemetry.send(require_Telemetry.Telemetry.build({
15
+ command: "mcp",
16
+ kubbVersion: version,
17
+ hrStart,
18
+ status
19
+ }));
20
+ try {
21
+ console.log((0, node_util.styleText)("cyan", "⏳ Starting MCP server..."));
22
+ console.warn((0, node_util.styleText)("yellow", "This feature is still under development, use with caution"));
23
+ await startMcpServer();
24
+ await report("success");
25
+ } catch (error) {
26
+ await report("failed");
27
+ console.error(require_errors.getErrorMessage(error));
28
+ }
29
+ }
30
+ //#endregion
31
+ exports.run = run;
32
+
33
+ //# sourceMappingURL=run-BM1t8CSM.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-BM1t8CSM.cjs","names":["process","Telemetry","getErrorMessage"],"sources":["../src/runners/mcp/run.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport { getErrorMessage } from '@internals/utils'\nimport { Telemetry } from '../../Telemetry.ts'\nimport type * as McpModule from '@kubb/mcp'\n\ntype McpOptions = {\n /**\n * Current `@kubb/cli` version string, used for the telemetry payload.\n */\n version: string\n}\n\n/**\n * Starts the `@kubb/mcp` server over stdio and reports the outcome to telemetry.\n */\nexport async function run({ version }: McpOptions): Promise<void> {\n const { run: startMcpServer } = (await import('@kubb/mcp')) as typeof McpModule\n const hrStart = process.hrtime()\n const report = (status: 'success' | 'failed') => Telemetry.send(Telemetry.build({ command: 'mcp', kubbVersion: version, hrStart, status }))\n try {\n console.log(styleText('cyan', '⏳ Starting MCP server...'))\n console.warn(styleText('yellow', 'This feature is still under development, use with caution'))\n await startMcpServer()\n await report('success')\n } catch (error) {\n await report('failed')\n console.error(getErrorMessage(error))\n }\n}\n"],"mappings":";;;;;;;;;;AAgBA,eAAsB,IAAI,EAAE,WAAsC;CAChE,MAAM,EAAE,KAAK,mBAAoB,MAAM,OAAO;CAC9C,MAAM,UAAUA,aAAAA,QAAQ,OAAO;CAC/B,MAAM,UAAU,WAAiCC,kBAAAA,UAAU,KAAKA,kBAAAA,UAAU,MAAM;EAAE,SAAS;EAAO,aAAa;EAAS;EAAS;CAAO,CAAC,CAAC;CAC1I,IAAI;EACF,QAAQ,KAAA,GAAA,UAAA,UAAA,CAAc,QAAQ,0BAA0B,CAAC;EACzD,QAAQ,MAAA,GAAA,UAAA,UAAA,CAAe,UAAU,2DAA2D,CAAC;EAC7F,MAAM,eAAe;EACrB,MAAM,OAAO,SAAS;CACxB,SAAS,OAAO;EACd,MAAM,OAAO,QAAQ;EACrB,QAAQ,MAAMC,eAAAA,gBAAgB,KAAK,CAAC;CACtC;AACF"}
@@ -0,0 +1,32 @@
1
+ import "./rolldown-runtime-C0LytTxp.js";
2
+ import { t as getErrorMessage } from "./errors-Dc_d7BfX.js";
3
+ import { t as Telemetry } from "./Telemetry-uAr3lK_-.js";
4
+ import { styleText } from "node:util";
5
+ import process from "node:process";
6
+ //#region src/runners/mcp/run.ts
7
+ /**
8
+ * Starts the `@kubb/mcp` server over stdio and reports the outcome to telemetry.
9
+ */
10
+ async function run({ version }) {
11
+ const { run: startMcpServer } = await import("@kubb/mcp");
12
+ const hrStart = process.hrtime();
13
+ const report = (status) => Telemetry.send(Telemetry.build({
14
+ command: "mcp",
15
+ kubbVersion: version,
16
+ hrStart,
17
+ status
18
+ }));
19
+ try {
20
+ console.log(styleText("cyan", "⏳ Starting MCP server..."));
21
+ console.warn(styleText("yellow", "This feature is still under development, use with caution"));
22
+ await startMcpServer();
23
+ await report("success");
24
+ } catch (error) {
25
+ await report("failed");
26
+ console.error(getErrorMessage(error));
27
+ }
28
+ }
29
+ //#endregion
30
+ export { run };
31
+
32
+ //# sourceMappingURL=run-BlFVmIJl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-BlFVmIJl.js","names":[],"sources":["../src/runners/mcp/run.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport { getErrorMessage } from '@internals/utils'\nimport { Telemetry } from '../../Telemetry.ts'\nimport type * as McpModule from '@kubb/mcp'\n\ntype McpOptions = {\n /**\n * Current `@kubb/cli` version string, used for the telemetry payload.\n */\n version: string\n}\n\n/**\n * Starts the `@kubb/mcp` server over stdio and reports the outcome to telemetry.\n */\nexport async function run({ version }: McpOptions): Promise<void> {\n const { run: startMcpServer } = (await import('@kubb/mcp')) as typeof McpModule\n const hrStart = process.hrtime()\n const report = (status: 'success' | 'failed') => Telemetry.send(Telemetry.build({ command: 'mcp', kubbVersion: version, hrStart, status }))\n try {\n console.log(styleText('cyan', '⏳ Starting MCP server...'))\n console.warn(styleText('yellow', 'This feature is still under development, use with caution'))\n await startMcpServer()\n await report('success')\n } catch (error) {\n await report('failed')\n console.error(getErrorMessage(error))\n }\n}\n"],"mappings":";;;;;;;;;AAgBA,eAAsB,IAAI,EAAE,WAAsC;CAChE,MAAM,EAAE,KAAK,mBAAoB,MAAM,OAAO;CAC9C,MAAM,UAAU,QAAQ,OAAO;CAC/B,MAAM,UAAU,WAAiC,UAAU,KAAK,UAAU,MAAM;EAAE,SAAS;EAAO,aAAa;EAAS;EAAS;CAAO,CAAC,CAAC;CAC1I,IAAI;EACF,QAAQ,IAAI,UAAU,QAAQ,0BAA0B,CAAC;EACzD,QAAQ,KAAK,UAAU,UAAU,2DAA2D,CAAC;EAC7F,MAAM,eAAe;EACrB,MAAM,OAAO,SAAS;CACxB,SAAS,OAAO;EACd,MAAM,OAAO,QAAQ;EACrB,QAAQ,MAAM,gBAAgB,KAAK,CAAC;CACtC;AACF"}
@@ -1,9 +1,9 @@
1
- const require_chunk = require("./chunk-ByKO4r7w.cjs");
2
- const require_errors = require("./errors-CLCjoSg0.cjs");
3
- const require_telemetry = require("./telemetry-B2iWkY5e.cjs");
1
+ const require_rolldown_runtime = require("./rolldown-runtime-Bx3C2hgW.cjs");
2
+ const require_errors = require("./errors-gxFK0vrp.cjs");
3
+ const require_Telemetry = require("./Telemetry-CfPP7MYq.cjs");
4
4
  let node_util = require("node:util");
5
5
  let node_process = require("node:process");
6
- node_process = require_chunk.__toESM(node_process, 1);
6
+ node_process = require_rolldown_runtime.__toESM(node_process, 1);
7
7
  //#region src/runners/validate/run.ts
8
8
  /**
9
9
  * Dynamically loads `@kubb/adapter-oas` for OpenAPI validation.
@@ -17,7 +17,7 @@ function loadValidateModule() {
17
17
  */
18
18
  async function run({ input, version }, dependencies = { loadValidateModule }) {
19
19
  const hrStart = node_process.default.hrtime();
20
- const report = (status) => require_telemetry.sendTelemetry(require_telemetry.buildTelemetryEvent({
20
+ const report = (status) => require_Telemetry.Telemetry.send(require_Telemetry.Telemetry.build({
21
21
  command: "validate",
22
22
  kubbVersion: version,
23
23
  hrStart,
@@ -49,4 +49,4 @@ async function run({ input, version }, dependencies = { loadValidateModule }) {
49
49
  //#endregion
50
50
  exports.run = run;
51
51
 
52
- //# sourceMappingURL=run-CQbj3ley.cjs.map
52
+ //# sourceMappingURL=run-CBc896in.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-CBc896in.cjs","names":["process","Telemetry","getErrorMessage"],"sources":["../src/runners/validate/run.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport { getErrorMessage } from '@internals/utils'\nimport { Telemetry } from '../../Telemetry.ts'\n\ntype ValidateOptions = {\n /**\n * Path or URL to the OpenAPI/Swagger file to validate.\n */\n input: string\n /**\n * Current `@kubb/cli` version string, used for the telemetry payload.\n */\n version: string\n}\n\ntype ValidateModule = typeof import('@kubb/adapter-oas')\ntype ValidateDependencies = {\n /**\n * Loads `@kubb/adapter-oas`. Injected so tests can substitute a mock.\n */\n loadValidateModule: () => Promise<ValidateModule>\n}\n\n/**\n * Dynamically loads `@kubb/adapter-oas` for OpenAPI validation.\n */\nexport function loadValidateModule(): Promise<ValidateModule> {\n return import('@kubb/adapter-oas') as Promise<ValidateModule>\n}\n\n/**\n * Validates an OpenAPI/Swagger file at `input` using `@kubb/adapter-oas`.\n * Exits the process with code 1 on validation failure or missing dependency.\n */\nexport async function run({ input, version }: ValidateOptions, dependencies: ValidateDependencies = { loadValidateModule }): Promise<void> {\n const hrStart = process.hrtime()\n const report = (status: 'success' | 'failed') => Telemetry.send(Telemetry.build({ command: 'validate', kubbVersion: version, hrStart, status }))\n try {\n const { adapterOas } = await dependencies.loadValidateModule()\n const adapter = adapterOas()\n if (!adapter.validate) {\n throw new Error('The loaded adapter does not support validation.')\n }\n await adapter.validate(input, { throwOnError: true })\n await report('success')\n console.log('✅ Validation success')\n } catch (error) {\n await report('failed')\n if (error instanceof Error && /@kubb\\/adapter-oas/.test(error.message)) {\n console.error(styleText('red', 'The @kubb/adapter-oas package is not installed.'))\n console.error('')\n console.error('Install it with:')\n console.error(styleText('cyan', ' npm install @kubb/adapter-oas'))\n console.error(styleText('cyan', ' # or'))\n console.error(styleText('cyan', ' pnpm install @kubb/adapter-oas'))\n console.error('')\n }\n console.error('❌ Validation failed')\n console.error(getErrorMessage(error))\n process.exit(1)\n }\n}\n"],"mappings":";;;;;;;;;;AA2BA,SAAgB,qBAA8C;CAC5D,OAAO,OAAO;AAChB;;;;;AAMA,eAAsB,IAAI,EAAE,OAAO,WAA4B,eAAqC,EAAE,mBAAmB,GAAkB;CACzI,MAAM,UAAUA,aAAAA,QAAQ,OAAO;CAC/B,MAAM,UAAU,WAAiCC,kBAAAA,UAAU,KAAKA,kBAAAA,UAAU,MAAM;EAAE,SAAS;EAAY,aAAa;EAAS;EAAS;CAAO,CAAC,CAAC;CAC/I,IAAI;EACF,MAAM,EAAE,eAAe,MAAM,aAAa,mBAAmB;EAC7D,MAAM,UAAU,WAAW;EAC3B,IAAI,CAAC,QAAQ,UACX,MAAM,IAAI,MAAM,iDAAiD;EAEnE,MAAM,QAAQ,SAAS,OAAO,EAAE,cAAc,KAAK,CAAC;EACpD,MAAM,OAAO,SAAS;EACtB,QAAQ,IAAI,sBAAsB;CACpC,SAAS,OAAO;EACd,MAAM,OAAO,QAAQ;EACrB,IAAI,iBAAiB,SAAS,qBAAqB,KAAK,MAAM,OAAO,GAAG;GACtE,QAAQ,OAAA,GAAA,UAAA,UAAA,CAAgB,OAAO,iDAAiD,CAAC;GACjF,QAAQ,MAAM,EAAE;GAChB,QAAQ,MAAM,kBAAkB;GAChC,QAAQ,OAAA,GAAA,UAAA,UAAA,CAAgB,QAAQ,iCAAiC,CAAC;GAClE,QAAQ,OAAA,GAAA,UAAA,UAAA,CAAgB,QAAQ,QAAQ,CAAC;GACzC,QAAQ,OAAA,GAAA,UAAA,UAAA,CAAgB,QAAQ,kCAAkC,CAAC;GACnE,QAAQ,MAAM,EAAE;EAClB;EACA,QAAQ,MAAM,qBAAqB;EACnC,QAAQ,MAAMC,eAAAA,gBAAgB,KAAK,CAAC;EACpC,aAAA,QAAQ,KAAK,CAAC;CAChB;AACF"}