@kubb/cli 4.33.0 → 4.33.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.
Files changed (137) hide show
  1. package/dist/{agent-D0A3RQho.js → agent-BGWY8Iow.js} +5 -5
  2. package/dist/agent-BGWY8Iow.js.map +1 -0
  3. package/dist/{agent-CduUX7Ye.cjs → agent-Bd1QdPVV.cjs} +7 -7
  4. package/dist/agent-Bd1QdPVV.cjs.map +1 -0
  5. package/dist/{agent-DrnwQBZf.cjs → agent-CmQJU9h7.cjs} +7 -7
  6. package/dist/agent-CmQJU9h7.cjs.map +1 -0
  7. package/dist/{agent-CJ69TqoO.js → agent-u_Ehwz6r.js} +5 -5
  8. package/dist/agent-u_Ehwz6r.js.map +1 -0
  9. package/dist/{constants-CnPOlsJq.cjs → constants-BTUap0zs.cjs} +1 -19
  10. package/dist/{constants-CnPOlsJq.cjs.map → constants-BTUap0zs.cjs.map} +1 -1
  11. package/dist/{constants-CEKRremI.js → constants-CM3dJzjK.js} +2 -14
  12. package/dist/{constants-CEKRremI.js.map → constants-CM3dJzjK.js.map} +1 -1
  13. package/dist/{types-CLtz0jem.js → define--M_JMcDC.js} +6 -6
  14. package/dist/define--M_JMcDC.js.map +1 -0
  15. package/dist/{types-Ck2lzFON.cjs → define-D6Kfm7-Z.cjs} +6 -6
  16. package/dist/define-D6Kfm7-Z.cjs.map +1 -0
  17. package/dist/{errors-bSLTEh4e.js → errors-6mF_WKxg.js} +5 -5
  18. package/dist/errors-6mF_WKxg.js.map +1 -0
  19. package/dist/{errors-BUjJsNoe.cjs → errors-DBW0N9w4.cjs} +5 -5
  20. package/dist/errors-DBW0N9w4.cjs.map +1 -0
  21. package/dist/{generate-ByMgAV76.cjs → generate-6Cm1AK2n.cjs} +275 -153
  22. package/dist/generate-6Cm1AK2n.cjs.map +1 -0
  23. package/dist/{generate-HP5ySfjV.js → generate-DcNp9Owd.js} +271 -149
  24. package/dist/generate-DcNp9Owd.js.map +1 -0
  25. package/dist/{generate-CiUPO5ds.cjs → generate-DqmjK5Lc.cjs} +3 -3
  26. package/dist/generate-DqmjK5Lc.cjs.map +1 -0
  27. package/dist/{generate-DIIxtkWT.js → generate-rtsmgWhO.js} +3 -3
  28. package/dist/generate-rtsmgWhO.js.map +1 -0
  29. package/dist/index.cjs +13 -13
  30. package/dist/index.cjs.map +1 -1
  31. package/dist/index.js +12 -12
  32. package/dist/index.js.map +1 -1
  33. package/dist/{init-DLNrkDF4.js → init--9nMhvx6.js} +4 -4
  34. package/dist/init--9nMhvx6.js.map +1 -0
  35. package/dist/{init-Df_aXezV.cjs → init-BvjtU-sC.cjs} +5 -4
  36. package/dist/init-BvjtU-sC.cjs.map +1 -0
  37. package/dist/{init-DyKK2fTp.js → init-C-InrmSY.js} +42 -31
  38. package/dist/init-C-InrmSY.js.map +1 -0
  39. package/dist/{init-Cd1hCb7q.cjs → init-hmolV6B4.cjs} +47 -37
  40. package/dist/init-hmolV6B4.cjs.map +1 -0
  41. package/dist/{jiti-BdskUHhD.cjs → jiti-Cd3S0xwr.cjs} +1 -1
  42. package/dist/{jiti-BdskUHhD.cjs.map → jiti-Cd3S0xwr.cjs.map} +1 -1
  43. package/dist/{jiti-Cl7t20dO.js → jiti-e08mD2Ph.js} +1 -1
  44. package/dist/{jiti-Cl7t20dO.js.map → jiti-e08mD2Ph.js.map} +1 -1
  45. package/dist/{mcp-Clg-Qnkr.cjs → mcp-Bd-DXHWV.cjs} +5 -4
  46. package/dist/mcp-Bd-DXHWV.cjs.map +1 -0
  47. package/dist/{mcp-Bd9LITaI.js → mcp-CZzxfbHW.js} +4 -4
  48. package/dist/mcp-CZzxfbHW.js.map +1 -0
  49. package/dist/{mcp-B73FC8dF.cjs → mcp-ChHFPRzD.cjs} +4 -4
  50. package/dist/mcp-ChHFPRzD.cjs.map +1 -0
  51. package/dist/{mcp-Cf-1dsB-.js → mcp-D2SHEg_d.js} +4 -4
  52. package/dist/mcp-D2SHEg_d.js.map +1 -0
  53. package/dist/{package-aKgzEJtp.cjs → package-BXijqaX5.cjs} +2 -2
  54. package/dist/package-BXijqaX5.cjs.map +1 -0
  55. package/dist/package-DeOlqJ31.js +6 -0
  56. package/dist/package-DeOlqJ31.js.map +1 -0
  57. package/dist/shell-7HPrTCJ5.cjs +57 -0
  58. package/dist/shell-7HPrTCJ5.cjs.map +1 -0
  59. package/dist/shell-DqqWsHCD.js +46 -0
  60. package/dist/shell-DqqWsHCD.js.map +1 -0
  61. package/dist/{telemetry-T5IA2dWA.cjs → telemetry-Cn9X1I5B.cjs} +46 -9
  62. package/dist/telemetry-Cn9X1I5B.cjs.map +1 -0
  63. package/dist/{telemetry-C4gOKX2x.js → telemetry-DxiR7clS.js} +40 -9
  64. package/dist/telemetry-DxiR7clS.js.map +1 -0
  65. package/dist/{validate-Cr26q5xX.js → validate-BH2Ysgxr.js} +4 -4
  66. package/dist/validate-BH2Ysgxr.js.map +1 -0
  67. package/dist/{validate-DURmg-2Q.cjs → validate-BQvsoQz-.cjs} +5 -4
  68. package/dist/validate-BQvsoQz-.cjs.map +1 -0
  69. package/dist/{validate-Dqi9T_c4.cjs → validate-Bbrn3Q-A.cjs} +4 -4
  70. package/dist/validate-Bbrn3Q-A.cjs.map +1 -0
  71. package/dist/{validate-Chjg23AE.js → validate-l8vLmwKA.js} +4 -4
  72. package/dist/validate-l8vLmwKA.js.map +1 -0
  73. package/package.json +6 -5
  74. package/src/commands/agent/start.ts +1 -1
  75. package/src/commands/agent.ts +1 -1
  76. package/src/commands/generate.ts +1 -1
  77. package/src/commands/init.ts +1 -1
  78. package/src/commands/mcp.ts +1 -1
  79. package/src/commands/validate.ts +1 -1
  80. package/src/constants.ts +0 -1
  81. package/src/index.ts +1 -1
  82. package/src/loggers/clackLogger.ts +26 -28
  83. package/src/loggers/fileSystemLogger.ts +1 -2
  84. package/src/loggers/githubActionsLogger.ts +26 -28
  85. package/src/loggers/plainLogger.ts +25 -26
  86. package/src/loggers/utils.ts +4 -5
  87. package/src/runners/agent.ts +1 -1
  88. package/src/runners/generate.ts +20 -7
  89. package/src/runners/init.ts +2 -1
  90. package/src/runners/mcp.ts +1 -1
  91. package/src/runners/validate.ts +1 -1
  92. package/src/utils/executeHooks.ts +2 -2
  93. package/src/utils/getIntro.ts +1 -80
  94. package/src/utils/getSummary.ts +1 -2
  95. package/src/utils/packageManager.ts +2 -2
  96. package/src/utils/runHook.ts +2 -2
  97. package/src/utils/telemetry.ts +1 -2
  98. package/dist/agent-CJ69TqoO.js.map +0 -1
  99. package/dist/agent-CduUX7Ye.cjs.map +0 -1
  100. package/dist/agent-D0A3RQho.js.map +0 -1
  101. package/dist/agent-DrnwQBZf.cjs.map +0 -1
  102. package/dist/errors-BUjJsNoe.cjs.map +0 -1
  103. package/dist/errors-bSLTEh4e.js.map +0 -1
  104. package/dist/generate-ByMgAV76.cjs.map +0 -1
  105. package/dist/generate-CiUPO5ds.cjs.map +0 -1
  106. package/dist/generate-DIIxtkWT.js.map +0 -1
  107. package/dist/generate-HP5ySfjV.js.map +0 -1
  108. package/dist/init-Cd1hCb7q.cjs.map +0 -1
  109. package/dist/init-DLNrkDF4.js.map +0 -1
  110. package/dist/init-Df_aXezV.cjs.map +0 -1
  111. package/dist/init-DyKK2fTp.js.map +0 -1
  112. package/dist/mcp-B73FC8dF.cjs.map +0 -1
  113. package/dist/mcp-Bd9LITaI.js.map +0 -1
  114. package/dist/mcp-Cf-1dsB-.js.map +0 -1
  115. package/dist/mcp-Clg-Qnkr.cjs.map +0 -1
  116. package/dist/package-681jTtCk.js +0 -6
  117. package/dist/package-681jTtCk.js.map +0 -1
  118. package/dist/package-aKgzEJtp.cjs.map +0 -1
  119. package/dist/telemetry-C4gOKX2x.js.map +0 -1
  120. package/dist/telemetry-T5IA2dWA.cjs.map +0 -1
  121. package/dist/types-CLtz0jem.js.map +0 -1
  122. package/dist/types-Ck2lzFON.cjs.map +0 -1
  123. package/dist/validate-Chjg23AE.js.map +0 -1
  124. package/dist/validate-Cr26q5xX.js.map +0 -1
  125. package/dist/validate-DURmg-2Q.cjs.map +0 -1
  126. package/dist/validate-Dqi9T_c4.cjs.map +0 -1
  127. package/src/cli/adapters/nodeAdapter.ts +0 -159
  128. package/src/cli/help.ts +0 -36
  129. package/src/cli/index.ts +0 -16
  130. package/src/cli/parse.ts +0 -18
  131. package/src/cli/schema.ts +0 -38
  132. package/src/cli/types.ts +0 -95
  133. package/src/utils/envDetection.ts +0 -34
  134. package/src/utils/errors.ts +0 -23
  135. package/src/utils/formatMsWithColor.ts +0 -22
  136. package/src/utils/randomColor.ts +0 -14
  137. package/src/utils/spawnAsync.ts +0 -47
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-HP5ySfjV.js","names":["process","process","process","AsyncEventEmitterClass"],"sources":["../src/utils/formatMsWithColor.ts","../src/utils/getIntro.ts","../src/utils/randomColor.ts","../src/utils/getSummary.ts","../src/utils/runHook.ts","../src/utils/Writables.ts","../src/loggers/clackLogger.ts","../src/loggers/fileSystemLogger.ts","../src/loggers/githubActionsLogger.ts","../src/loggers/plainLogger.ts","../src/loggers/utils.ts","../src/utils/executeHooks.ts","../src/utils/getCosmiConfig.ts","../src/utils/watcher.ts","../src/runners/generate.ts"],"sourcesContent":["import { styleText } from 'node:util'\nimport { formatMs } from '@kubb/core/utils'\n\n/**\n * Formats milliseconds with color based on duration thresholds:\n * - Green: <= 500ms\n * - Yellow: > 500ms and <= 1000ms\n * - Red: > 1000ms\n */\nexport function formatMsWithColor(ms: number): string {\n const formatted = formatMs(ms)\n\n if (ms <= 500) {\n return styleText('green', formatted)\n }\n\n if (ms <= 1000) {\n return styleText('yellow', formatted)\n }\n\n return styleText('red', formatted)\n}\n","import { styleText } from 'node:util'\n\n/**\n * ANSI True Color (24-bit) utilities for terminal output\n * Supports hex color codes without external dependencies like chalk\n */\n\n/** Parse a hex color string into RGB components, defaulting to 255 on invalid input. */\nfunction parseHex(color: string): { r: number; g: number; b: number } {\n const c = color.replace('#', '')\n const r = Number.parseInt(c.slice(0, 2), 16)\n const g = Number.parseInt(c.slice(2, 4), 16)\n const b = Number.parseInt(c.slice(4, 6), 16)\n return {\n r: Number.isNaN(r) ? 255 : r,\n g: Number.isNaN(g) ? 255 : g,\n b: Number.isNaN(b) ? 255 : b,\n }\n}\n\n/**\n * Convert hex color to ANSI 24-bit true color escape sequence\n * @param color - Hex color code (with or without #), e.g., '#FF5500' or 'FF5500'\n * @returns Function that wraps text with the color\n */\nfunction hex(color: string): (text: string) => string {\n const { r, g, b } = parseHex(color)\n return (text: string) => `\\x1b[38;2;${r};${g};${b}m${text}\\x1b[0m`\n}\n\nfunction gradient(colors: string[]) {\n return (text: string) => {\n const chars = [...text]\n return chars\n .map((char, i) => {\n const t = chars.length <= 1 ? 0 : i / (chars.length - 1)\n const seg = Math.min(Math.floor(t * (colors.length - 1)), colors.length - 2)\n const lt = t * (colors.length - 1) - seg\n const from = parseHex(colors[seg]!)\n const to = parseHex(colors[seg + 1]!)\n const r = Math.round(from.r + (to.r - from.r) * lt)\n const g = Math.round(from.g + (to.g - from.g) * lt)\n const b = Math.round(from.b + (to.b - from.b) * lt)\n return `\\x1b[38;2;${r};${g};${b}m${char}\\x1b[0m`\n })\n .join('')\n }\n}\n\n// Custom Color Palette for \"Wooden\" Depth\nconst colors = {\n lid: hex('#F55A17'), // Dark Wood\n woodTop: hex('#F5A217'), // Bright Orange (Light source)\n woodMid: hex('#F58517'), // Main Orange\n woodBase: hex('#B45309'), // Shadow Orange\n eye: hex('#FFFFFF'), // Deep Slate\n highlight: hex('#adadc6'), // Eye shine\n blush: hex('#FDA4AF'), // Soft Rose\n}\n\n/**\n * Generates the Kubb mascot face welcome message\n * @param version - The version string to display\n * @returns Formatted mascot face string\n */\nexport function getIntro({ title, description, version, areEyesOpen }: { title: string; description: string; version: string; areEyesOpen: boolean }): string {\n // Use gradient-string for the KUBB version text\n const kubbVersion = gradient(['#F58517', '#F5A217', '#F55A17'])(`KUBB v${version}`)\n\n const eyeTop = areEyesOpen ? colors.eye('█▀█') : colors.eye('───')\n const eyeBottom = areEyesOpen ? colors.eye('▀▀▀') : colors.eye('───')\n\n return `\n ${colors.lid('▄▄▄▄▄▄▄▄▄▄▄▄▄')}\n ${colors.woodTop('█ ')}${colors.highlight('▄▄')}${colors.woodTop(' ')}${colors.highlight('▄▄')}${colors.woodTop(' █')} ${kubbVersion}\n ${colors.woodMid('█ ')}${eyeTop}${colors.woodMid(' ')}${eyeTop}${colors.woodMid(' █')} ${styleText('gray', title)}\n ${colors.woodMid('█ ')}${eyeBottom}${colors.woodMid(' ')}${colors.blush('◡')}${colors.woodMid(' ')}${eyeBottom}${colors.woodMid(' █')} ${styleText('yellow', '➜')} ${styleText('white', description)}\n ${colors.woodBase('▀▀▀▀▀▀▀▀▀▀▀▀▀')}\n`\n}\n","import { createHash } from 'node:crypto'\nimport { styleText } from 'node:util'\nimport { randomColors } from '../constants.ts'\n\nexport function randomCliColor(text?: string): string {\n if (!text) {\n return ''\n }\n\n const index = createHash('sha256').update(text).digest().readUInt32BE(0) % randomColors.length\n const color = randomColors[index] ?? 'white'\n\n return styleText(color, text)\n}\n","import path from 'node:path'\nimport { styleText } from 'node:util'\nimport type { Config, Plugin } from '@kubb/core'\nimport { formatHrtime } from '@kubb/core/utils'\nimport { SUMMARY_MAX_BAR_LENGTH, SUMMARY_TIME_SCALE_DIVISOR } from '../constants.ts'\nimport { randomCliColor } from './randomColor.ts'\n\ntype SummaryProps = {\n failedPlugins: Set<{ plugin: Plugin; error: Error }>\n status: 'success' | 'failed'\n hrStart: [number, number]\n filesCreated: number\n config: Config\n pluginTimings?: Map<string, number>\n}\n\nexport function getSummary({ failedPlugins, filesCreated, status, hrStart, config, pluginTimings }: SummaryProps): string[] {\n const duration = formatHrtime(hrStart)\n\n const pluginsCount = config.plugins?.length ?? 0\n const successCount = pluginsCount - failedPlugins.size\n\n const meta = {\n plugins:\n status === 'success'\n ? `${styleText('green', `${successCount} successful`)}, ${pluginsCount} total`\n : `${styleText('green', `${successCount} successful`)}, ${styleText('red', `${failedPlugins.size} failed`)}, ${pluginsCount} total`,\n pluginsFailed: status === 'failed' ? [...failedPlugins].map(({ plugin }) => randomCliColor(plugin.name)).join(', ') : undefined,\n filesCreated,\n time: styleText('green', duration),\n output: path.isAbsolute(config.root) ? path.resolve(config.root, config.output.path) : config.root,\n } as const\n\n const labels = {\n plugins: 'Plugins:',\n failed: 'Failed:',\n generated: 'Generated:',\n pluginTimings: 'Plugin Timings:',\n output: 'Output:',\n }\n const maxLength = Math.max(0, ...[...Object.values(labels), ...(pluginTimings ? Array.from(pluginTimings.keys()) : [])].map((s) => s.length))\n\n const summaryLines: string[] = []\n summaryLines.push(`${labels.plugins.padEnd(maxLength + 2)} ${meta.plugins}`)\n\n if (meta.pluginsFailed) {\n summaryLines.push(`${labels.failed.padEnd(maxLength + 2)} ${meta.pluginsFailed}`)\n }\n\n summaryLines.push(`${labels.generated.padEnd(maxLength + 2)} ${meta.filesCreated} files in ${meta.time}`)\n\n if (pluginTimings && pluginTimings.size > 0) {\n const sortedTimings = Array.from(pluginTimings.entries()).sort((a, b) => b[1] - a[1])\n\n summaryLines.push(`${labels.pluginTimings}`)\n\n sortedTimings.forEach(([name, time]) => {\n const timeStr = time >= 1000 ? `${(time / 1000).toFixed(2)}s` : `${Math.round(time)}ms`\n const barLength = Math.min(Math.ceil(time / SUMMARY_TIME_SCALE_DIVISOR), SUMMARY_MAX_BAR_LENGTH)\n const bar = styleText('dim', '█'.repeat(barLength))\n\n summaryLines.push(`${styleText('dim', '•')} ${name.padEnd(maxLength + 1)}${bar} ${timeStr}`)\n })\n }\n\n summaryLines.push(`${labels.output.padEnd(maxLength + 2)} ${meta.output}`)\n\n return summaryLines\n}\n","import type { KubbEvents } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\nimport { NonZeroExitError, x } from 'tinyexec'\nimport { toError } from './errors.ts'\n\ntype HookOutputSink = {\n /** Called for each streamed stdout line while the hook runs (optional). */\n onLine?: (line: string) => void\n /** Called on stderr after failure (optional). */\n onStderr?: (text: string) => void\n /** Called on stdout after failure (optional). */\n onStdout?: (text: string) => void\n}\n\ntype RunHookOptions = {\n id: string\n command: string\n args?: readonly string[]\n commandWithArgs: string\n context: AsyncEventEmitter<KubbEvents>\n /** When true the process output is streamed line-by-line via onLine. */\n stream?: boolean\n sink?: HookOutputSink\n}\n\n/**\n * Execute a hook command, emit debug/hook:end events, and forward output to\n * an optional HookOutputSink. All three logger adapters share this function\n * so the process-spawning logic lives in exactly one place.\n */\nexport async function runHook({ id, command, args, commandWithArgs, context, stream = false, sink }: RunHookOptions): Promise<void> {\n try {\n const proc = x(command, [...(args ?? [])], {\n nodeOptions: { detached: true },\n throwOnError: true,\n })\n\n if (stream && sink?.onLine) {\n for await (const line of proc) {\n sink.onLine(line)\n }\n }\n\n const result = await proc\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout.trimEnd()],\n })\n\n await context.emit('hook:end', { command, args, id, success: true, error: null })\n } catch (err) {\n if (!(err instanceof NonZeroExitError)) {\n await context.emit('hook:end', { command, args, id, success: false, error: toError(err) })\n await context.emit('error', toError(err))\n return\n }\n\n const stderr = err.output?.stderr ?? ''\n const stdout = err.output?.stdout ?? ''\n\n await context.emit('debug', {\n date: new Date(),\n logs: [stdout, stderr].filter(Boolean),\n })\n\n if (stderr) sink?.onStderr?.(stderr)\n if (stdout) sink?.onStdout?.(stdout)\n\n const errorMessage = new Error(`Hook execute failed: ${commandWithArgs}`)\n\n await context.emit('hook:end', { command, args, id, success: false, error: errorMessage })\n await context.emit('error', errorMessage)\n }\n}\n","import type { WritableOptions } from 'node:stream'\nimport { Writable } from 'node:stream'\nimport { styleText } from 'node:util'\nimport type * as clack from '@clack/prompts'\n\nexport class ClackWritable extends Writable {\n taskLog: ReturnType<typeof clack.taskLog>\n constructor(taskLog: ReturnType<typeof clack.taskLog>, opts?: WritableOptions) {\n super(opts)\n\n this.taskLog = taskLog\n }\n _write(chunk: Buffer, _encoding: BufferEncoding, callback: (error?: Error | null) => void): void {\n this.taskLog.message(`${styleText('dim', chunk.toString())}`)\n callback()\n }\n}\n","import { relative } from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { defineLogger, LogLevel } from '@kubb/core'\nimport { formatMs } from '@kubb/core/utils'\nimport { toCause } from '../utils/errors.ts'\nimport { formatMsWithColor } from '../utils/formatMsWithColor.ts'\nimport { getIntro } from '../utils/getIntro.ts'\nimport { getSummary } from '../utils/getSummary.ts'\nimport { runHook } from '../utils/runHook.ts'\nimport { ClackWritable } from '../utils/Writables.ts'\nimport { buildProgressLine, formatCommandWithArgs, formatMessage } from './utils.ts'\n\n/**\n * Clack adapter for local TTY environments\n * Provides a beautiful CLI UI with flat structure inspired by Claude's CLI patterns\n */\nexport const clackLogger = defineLogger({\n name: 'clack',\n install(context, options) {\n const logLevel = options?.logLevel ?? LogLevel.info\n const state = {\n totalPlugins: 0,\n completedPlugins: 0,\n failedPlugins: 0,\n totalFiles: 0,\n processedFiles: 0,\n hrStart: process.hrtime(),\n spinner: clack.spinner(),\n isSpinning: false,\n activeProgress: new Map<string, { interval?: NodeJS.Timeout; progressBar: clack.ProgressResult }>(),\n }\n\n function reset() {\n for (const [_key, active] of state.activeProgress) {\n if (active.interval) {\n clearInterval(active.interval)\n }\n active.progressBar?.stop()\n }\n\n state.totalPlugins = 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.totalFiles = 0\n state.processedFiles = 0\n state.hrStart = process.hrtime()\n state.spinner = clack.spinner()\n state.isSpinning = false\n state.activeProgress.clear()\n }\n\n function showProgressStep() {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const line = buildProgressLine(state)\n if (line) {\n clack.log.step(getMessage(line))\n }\n }\n\n function getMessage(message: string): string {\n return formatMessage(message, logLevel)\n }\n\n function startSpinner(text?: string) {\n state.spinner.start(text)\n state.isSpinning = true\n }\n\n function stopSpinner(text?: string) {\n state.spinner.stop(text)\n state.isSpinning = false\n }\n\n context.on('info', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([styleText('blue', 'ℹ'), message, styleText('dim', info)].join(' '))\n\n if (state.isSpinning) {\n state.spinner.message(text)\n } else {\n clack.log.info(text)\n }\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([styleText('blue', '✓'), message, logLevel >= LogLevel.info ? styleText('dim', info) : undefined].filter(Boolean).join(' '))\n\n if (state.isSpinning) {\n stopSpinner(text)\n } else {\n clack.log.success(text)\n }\n })\n\n context.on('warn', (message, info) => {\n if (logLevel < LogLevel.warn) {\n return\n }\n\n const text = getMessage(\n [styleText('yellow', '⚠'), message, logLevel >= LogLevel.info && info ? styleText('dim', info) : undefined].filter(Boolean).join(' '),\n )\n\n clack.log.warn(text)\n })\n\n context.on('error', (error) => {\n const caused = toCause(error)\n\n const text = [styleText('red', '✗'), error.message].join(' ')\n\n if (state.isSpinning) {\n stopSpinner(getMessage(text))\n } else {\n clack.log.error(getMessage(text))\n }\n\n // Show stack trace in debug mode (first 3 frames)\n if (logLevel >= LogLevel.debug && error.stack) {\n const frames = error.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n clack.log.message(getMessage(styleText('dim', frame.trim())))\n }\n\n if (caused?.stack) {\n clack.log.message(styleText('dim', `└─ caused by ${caused.message}`))\n\n const frames = caused.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n clack.log.message(getMessage(` ${styleText('dim', frame.trim())}`))\n }\n }\n }\n })\n\n context.on('version:new', (version, latestVersion) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n clack.box(\n `\\`v${version}\\` → \\`v${latestVersion}\\`\nRun \\`npm install -g @kubb/cli\\` to update`,\n 'Update available for `Kubb`',\n {\n width: 'auto',\n formatBorder: (s: string) => styleText('yellow', s),\n rounded: true,\n withGuide: false,\n contentAlign: 'center',\n titleAlign: 'center',\n },\n )\n })\n\n context.on('lifecycle:start', async (version) => {\n console.log(`\\n${getIntro({ title: 'The ultimate toolkit for working with APIs', description: 'Ready to start', version, areEyesOpen: true })}\\n`)\n\n reset()\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n clack.intro(text)\n startSpinner(getMessage('Configuration loading'))\n })\n\n context.on('config:end', (_configs) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n clack.outro(text)\n })\n\n context.on('generation:start', (config) => {\n reset()\n\n // Initialize progress tracking for this generation\n state.totalPlugins = config.plugins?.length ?? 0\n\n const text = getMessage(['Generation started', config.name ? `for ${styleText('dim', config.name)}` : undefined].filter(Boolean).join(' '))\n\n clack.intro(text)\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n const progressBar = clack.progress({\n style: 'block',\n max: 100,\n size: 30,\n })\n const text = getMessage(`Generating ${styleText('bold', plugin.name)}`)\n progressBar.start(text)\n\n const interval = setInterval(() => {\n progressBar.advance()\n }, 100)\n\n state.activeProgress.set(plugin.name, { progressBar, interval })\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n stopSpinner()\n\n const active = state.activeProgress.get(plugin.name)\n\n if (!active || logLevel === LogLevel.silent) {\n return\n }\n\n clearInterval(active.interval)\n\n if (success) {\n state.completedPlugins++\n } else {\n state.failedPlugins++\n }\n\n const durationStr = formatMsWithColor(duration)\n const text = getMessage(\n success\n ? `${styleText('bold', plugin.name)} completed in ${durationStr}`\n : `${styleText('bold', plugin.name)} failed in ${styleText('red', formatMs(duration))}`,\n )\n\n active.progressBar.stop(text)\n state.activeProgress.delete(plugin.name)\n\n // Show progress step after each plugin\n showProgressStep()\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n state.totalFiles = files.length\n state.processedFiles = 0\n\n const text = `Writing ${files.length} files`\n const progressBar = clack.progress({\n style: 'block',\n max: files.length,\n size: 30,\n })\n\n context.emit('info', text)\n progressBar.start(getMessage(text))\n state.activeProgress.set('files', { progressBar })\n })\n\n context.on('file:processing:update', ({ file, config }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n state.processedFiles++\n\n const text = `Writing ${relative(config.root, file.path)}`\n const active = state.activeProgress.get('files')\n\n if (!active) {\n return\n }\n\n active.progressBar.advance(undefined, text)\n })\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n const text = getMessage('Files written successfully')\n const active = state.activeProgress.get('files')\n\n if (!active) {\n return\n }\n\n active.progressBar.stop(text)\n state.activeProgress.delete('files')\n\n // Show final progress step after files are written\n showProgressStep()\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(config.name ? `Generation completed for ${styleText('dim', config.name)}` : 'Generation completed')\n\n clack.outro(text)\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n clack.intro(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n clack.outro(text)\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n clack.intro(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n clack.outro(text)\n })\n\n context.on('hook:start', async ({ id, command, args }) => {\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${styleText('dim', commandWithArgs)} started`)\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\n if (logLevel <= LogLevel.silent) {\n await runHook({\n id,\n command,\n args,\n commandWithArgs,\n context,\n sink: {\n onStderr: (s) => console.error(s),\n onStdout: (s) => console.log(s),\n },\n })\n return\n }\n\n clack.intro(text)\n\n const logger = clack.taskLog({\n title: getMessage(['Executing hook', logLevel >= LogLevel.info ? styleText('dim', commandWithArgs) : undefined].filter(Boolean).join(' ')),\n })\n\n const writable = new ClackWritable(logger)\n\n await runHook({\n id,\n command,\n args,\n commandWithArgs,\n context,\n stream: true,\n sink: {\n onLine: (line) => writable.write(line),\n onStderr: (s) => logger.error(s),\n onStdout: (s) => logger.message(s),\n },\n })\n })\n\n context.on('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${styleText('dim', commandWithArgs)} successfully executed`)\n\n clack.outro(text)\n })\n\n context.on('generation:summary', (config, { pluginTimings, failedPlugins, filesCreated, status, hrStart }) => {\n const summary = getSummary({\n failedPlugins,\n filesCreated,\n config,\n status,\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n const title = config.name || ''\n\n summary.unshift('\\n')\n summary.push('\\n')\n\n const borderColor = status === 'success' ? 'green' : 'red'\n clack.box(summary.join('\\n'), getMessage(title), {\n width: 'auto',\n formatBorder: (s: string) => styleText(borderColor, s),\n rounded: true,\n withGuide: false,\n contentAlign: 'left',\n titleAlign: 'center',\n })\n })\n\n context.on('lifecycle:end', () => {\n reset()\n })\n },\n})\n","import { relative, resolve } from 'node:path'\nimport process from 'node:process'\nimport { defineLogger } from '@kubb/core'\nimport { write } from '@kubb/core/fs'\nimport { formatMs } from '@kubb/core/utils'\n\ntype CachedEvent = {\n date: Date\n logs: string[]\n fileName?: string\n}\n\n/**\n * FileSystem logger for debug log persistence\n * Captures debug and verbose events and writes them to files in .kubb directory\n *\n * Note: Logs are written on lifecycle:end or process exit. If the process crashes\n * before these events, some cached logs may be lost.\n */\nexport const fileSystemLogger = defineLogger({\n name: 'filesystem',\n install(context) {\n const state = {\n cachedLogs: new Set<CachedEvent>(),\n startDate: Date.now(),\n }\n\n function reset() {\n state.cachedLogs = new Set<CachedEvent>()\n state.startDate = Date.now()\n }\n\n async function writeLogs(name?: string) {\n if (state.cachedLogs.size === 0) {\n return []\n }\n\n const files: Record<string, string[]> = {}\n\n for (const log of state.cachedLogs) {\n const baseName = log.fileName || `${['kubb', name, state.startDate].filter(Boolean).join('-')}.log`\n const pathName = resolve(process.cwd(), '.kubb', baseName)\n\n if (!files[pathName]) {\n files[pathName] = []\n }\n\n if (log.logs.length > 0) {\n const timestamp = log.date.toLocaleString()\n files[pathName].push(`[${timestamp}]\\n${log.logs.join('\\n')}`)\n }\n }\n\n await Promise.all(\n Object.entries(files).map(async ([fileName, logs]) => {\n return write(fileName, logs.join('\\n\\n'))\n }),\n )\n\n return Object.keys(files)\n }\n\n context.on('info', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`ℹ ${message} ${info}`],\n })\n })\n\n context.on('success', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`✓ ${message} ${info}`],\n })\n })\n\n context.on('warn', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`⚠ ${message} ${info}`],\n })\n })\n\n context.on('error', (error) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`✗ ${error.message}`, error.stack || 'unknown stack'],\n })\n })\n\n context.on('debug', (message) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: message.logs,\n })\n })\n\n context.on('plugin:start', (plugin) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`Generating ${plugin.name}`],\n })\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n const durationStr = formatMs(duration)\n\n state.cachedLogs.add({\n date: new Date(),\n logs: [success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`],\n })\n })\n\n context.on('files:processing:start', (files) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`Start ${files.length} writing:`, ...files.map((file) => file.path)],\n })\n })\n\n context.on('generation:end', async (config) => {\n const writtenFilePaths = await writeLogs(config.name)\n if (writtenFilePaths.length > 0) {\n const files = writtenFilePaths.map((f) => relative(process.cwd(), f))\n await context.emit('info', 'Debug files written to:', files.join(', '))\n }\n reset()\n })\n\n // Fallback: Write logs on process exit to handle crashes\n const exitHandler = () => {\n // Synchronous write on exit - best effort\n if (state.cachedLogs.size > 0) {\n writeLogs().catch(() => {\n // Ignore errors on exit\n })\n }\n }\n\n process.once('exit', exitHandler)\n process.once('SIGINT', exitHandler)\n process.once('SIGTERM', exitHandler)\n },\n})\n","import { styleText } from 'node:util'\nimport { type Config, defineLogger, LogLevel } from '@kubb/core'\nimport { formatHrtime, formatMs } from '@kubb/core/utils'\nimport { toCause } from '../utils/errors.ts'\nimport { formatMsWithColor } from '../utils/formatMsWithColor.ts'\nimport { runHook } from '../utils/runHook.ts'\nimport { buildProgressLine, formatCommandWithArgs, formatMessage } from './utils.ts'\n\n/**\n * GitHub Actions adapter for CI environments\n * Uses Github group annotations for collapsible sections\n */\nexport const githubActionsLogger = defineLogger({\n name: 'github-actions',\n install(context, options) {\n const logLevel = options?.logLevel ?? LogLevel.info\n const state = {\n totalPlugins: 0,\n completedPlugins: 0,\n failedPlugins: 0,\n totalFiles: 0,\n processedFiles: 0,\n hrStart: process.hrtime(),\n currentConfigs: [] as Array<Config>,\n }\n\n function reset() {\n state.totalPlugins = 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.totalFiles = 0\n state.processedFiles = 0\n state.hrStart = process.hrtime()\n state.currentConfigs = []\n }\n\n function showProgressStep() {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const line = buildProgressLine(state)\n if (line) {\n console.log(getMessage(line))\n }\n }\n\n function getMessage(message: string): string {\n return formatMessage(message, logLevel)\n }\n\n function openGroup(name: string) {\n console.log(`::group::${name}`)\n }\n\n function closeGroup(_name: string) {\n console.log('::endgroup::')\n }\n\n context.on('info', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([styleText('blue', 'ℹ'), message, styleText('dim', info)].join(' '))\n\n console.log(text)\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([styleText('blue', '✓'), message, logLevel >= LogLevel.info ? styleText('dim', info) : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('warn', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([styleText('yellow', '⚠'), message, logLevel >= LogLevel.info ? styleText('dim', info) : undefined].filter(Boolean).join(' '))\n\n console.warn(`::warning::${text}`)\n })\n\n context.on('error', (error) => {\n const caused = toCause(error)\n\n if (logLevel <= LogLevel.silent) {\n return\n }\n const message = error.message || String(error)\n console.error(`::error::${message}`)\n\n // Show stack trace in debug mode (first 3 frames)\n if (logLevel >= LogLevel.debug && error.stack) {\n const frames = error.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(styleText('dim', frame.trim())))\n }\n\n if (caused?.stack) {\n console.log(styleText('dim', `└─ caused by ${caused.message}`))\n\n const frames = caused.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(` ${styleText('dim', frame.trim())}`))\n }\n }\n }\n })\n\n context.on('lifecycle:start', (version) => {\n console.log(styleText('yellow', `Kubb ${version} 🧩`))\n reset()\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n openGroup('Configuration')\n\n console.log(text)\n })\n\n context.on('config:end', (configs) => {\n state.currentConfigs = configs\n\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n console.log(text)\n\n closeGroup('Configuration')\n })\n\n context.on('generation:start', (config) => {\n reset()\n\n // Initialize progress tracking for this generation\n state.totalPlugins = config.plugins?.length ?? 0\n\n const text = config.name ? `Generation for ${styleText('bold', config.name)}` : 'Generation'\n\n if (state.currentConfigs.length > 1) {\n openGroup(text)\n }\n\n if (state.currentConfigs.length === 1) {\n console.log(getMessage(text))\n }\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage(`Generating ${styleText('bold', plugin.name)}`)\n\n if (state.currentConfigs.length === 1) {\n openGroup(`Plugin: ${plugin.name}`)\n }\n\n console.log(text)\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n if (success) {\n state.completedPlugins++\n } else {\n state.failedPlugins++\n }\n\n const durationStr = formatMsWithColor(duration)\n const text = getMessage(\n success\n ? `${styleText('bold', plugin.name)} completed in ${durationStr}`\n : `${styleText('bold', plugin.name)} failed in ${styleText('red', formatMs(duration))}`,\n )\n\n console.log(text)\n if (state.currentConfigs.length > 1) {\n console.log(' ')\n }\n\n if (state.currentConfigs.length === 1) {\n closeGroup(`Plugin: ${plugin.name}`)\n }\n\n // Show progress step after each plugin\n showProgressStep()\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n state.totalFiles = files.length\n state.processedFiles = 0\n\n if (state.currentConfigs.length === 1) {\n openGroup('File Generation')\n }\n const text = getMessage(`Writing ${files.length} files`)\n\n console.log(text)\n })\n\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage('Files written successfully')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('File Generation')\n }\n\n // Show final progress step after files are written\n showProgressStep()\n })\n\n context.on('file:processing:update', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n state.processedFiles++\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(\n config.name ? `${styleText('blue', '✓')} Generation completed for ${styleText('dim', config.name)}` : `${styleText('blue', '✓')} Generation completed`,\n )\n\n console.log(text)\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n if (state.currentConfigs.length === 1) {\n openGroup('Formatting')\n }\n\n console.log(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('Formatting')\n }\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n if (state.currentConfigs.length === 1) {\n openGroup('Linting')\n }\n\n console.log(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('Linting')\n }\n })\n\n context.on('hook:start', async ({ id, command, args }) => {\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${styleText('dim', commandWithArgs)} started`)\n\n if (logLevel > LogLevel.silent) {\n if (state.currentConfigs.length === 1) {\n openGroup(`Hook ${commandWithArgs}`)\n }\n console.log(text)\n }\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\n await runHook({\n id,\n command,\n args,\n commandWithArgs,\n context,\n sink: {\n // GHA formats errors with the ::error:: annotation\n onStdout: logLevel > LogLevel.silent ? (s) => console.log(s) : undefined,\n onStderr: logLevel > LogLevel.silent ? (s) => console.error(`::error::${s}`) : undefined,\n },\n })\n })\n\n context.on('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${styleText('dim', commandWithArgs)} completed`)\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup(`Hook ${commandWithArgs}`)\n }\n })\n\n context.on('generation:summary', (config, { status, hrStart, failedPlugins }) => {\n const pluginsCount = config.plugins?.length ?? 0\n const successCount = pluginsCount - failedPlugins.size\n const duration = formatHrtime(hrStart)\n\n if (state.currentConfigs.length > 1) {\n console.log(' ')\n }\n\n console.log(\n status === 'success'\n ? `Kubb Summary: ${styleText('blue', '✓')} ${`${successCount} successful`}, ${pluginsCount} total, ${styleText('green', duration)}`\n : `Kubb Summary: ${styleText('blue', '✓')} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total, ${styleText('green', duration)}`,\n )\n\n if (state.currentConfigs.length > 1) {\n closeGroup(config.name ? `Generation for ${styleText('bold', config.name)}` : 'Generation')\n }\n })\n\n context.on('lifecycle:end', () => {\n reset()\n })\n },\n})\n","import { relative } from 'node:path'\nimport { defineLogger, LogLevel } from '@kubb/core'\nimport { formatMs } from '@kubb/core/utils'\nimport { SUMMARY_SEPARATOR } from '../constants.ts'\nimport { toCause } from '../utils/errors.ts'\nimport { getSummary } from '../utils/getSummary.ts'\nimport { runHook } from '../utils/runHook.ts'\nimport { formatCommandWithArgs, formatMessage } from './utils.ts'\n\n/**\n * Plain console adapter for non-TTY environments\n * Simple console.log output with indentation\n */\nexport const plainLogger = defineLogger({\n name: 'plain',\n install(context, options) {\n const logLevel = options?.logLevel ?? LogLevel.info\n\n function getMessage(message: string): string {\n return formatMessage(message, logLevel)\n }\n\n context.on('info', (message, info) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(['ℹ', message, info].join(' '))\n\n console.log(text)\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(['✓', message, logLevel >= LogLevel.info ? info : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('warn', (message, info) => {\n if (logLevel < LogLevel.warn) {\n return\n }\n\n const text = getMessage(['⚠', message, logLevel >= LogLevel.info ? info : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('error', (error) => {\n const caused = toCause(error)\n\n const text = getMessage(['✗', error.message].join(' '))\n\n console.log(text)\n\n // Show stack trace in debug mode (first 3 frames)\n if (logLevel >= LogLevel.debug && error.stack) {\n const frames = error.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(frame.trim()))\n }\n\n if (caused?.stack) {\n console.log(`└─ caused by ${caused.message}`)\n\n const frames = caused.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(` ${frame.trim()}`))\n }\n }\n }\n })\n\n context.on('lifecycle:start', () => {\n console.log('Kubb CLI 🧩')\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n console.log(text)\n })\n\n context.on('config:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n console.log(text)\n })\n\n context.on('generation:start', () => {\n const text = getMessage('Generation started')\n\n console.log(text)\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage(`Generating ${plugin.name}`)\n\n console.log(text)\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const durationStr = formatMs(duration)\n const text = getMessage(success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`)\n\n console.log(text)\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Writing ${files.length} files`)\n\n console.log(text)\n })\n\n context.on('file:processing:update', ({ file, config }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Writing ${relative(config.root, file.path)}`)\n\n console.log(text)\n })\n\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Files written successfully')\n\n console.log(text)\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(config.name ? `Generation completed for ${config.name}` : 'Generation completed')\n\n console.log(text)\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n console.log(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n console.log(text)\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n console.log(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n console.log(text)\n })\n\n context.on('hook:start', async ({ id, command, args }) => {\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${commandWithArgs} started`)\n\n if (logLevel > LogLevel.silent) {\n console.log(text)\n }\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\n await runHook({\n id,\n command,\n args,\n commandWithArgs,\n context,\n sink: {\n onStdout: logLevel > LogLevel.silent ? (s) => console.log(s) : undefined,\n onStderr: logLevel > LogLevel.silent ? (s) => console.error(s) : undefined,\n },\n })\n })\n\n context.on('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = formatCommandWithArgs(command, args)\n const text = getMessage(`Hook ${commandWithArgs} completed`)\n\n console.log(text)\n })\n\n context.on('generation:summary', (config, { pluginTimings, status, hrStart, failedPlugins, filesCreated }) => {\n const summary = getSummary({\n failedPlugins,\n filesCreated,\n config,\n status,\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n\n console.log(SUMMARY_SEPARATOR)\n console.log(summary.join('\\n'))\n console.log(SUMMARY_SEPARATOR)\n })\n },\n})\n","import { styleText } from 'node:util'\nimport type { Logger, LoggerContext, LoggerOptions } from '@kubb/core'\nimport { LogLevel } from '@kubb/core'\nimport { formatHrtime } from '@kubb/core/utils'\nimport { canUseTTY, isGitHubActions } from '../utils/envDetection.ts'\nimport { clackLogger } from './clackLogger.ts'\nimport { fileSystemLogger } from './fileSystemLogger.ts'\nimport { githubActionsLogger } from './githubActionsLogger.ts'\nimport { plainLogger } from './plainLogger.ts'\nimport type { LoggerType } from './types.ts'\n\n/**\n * Optionally prefix a message with a [HH:MM:SS] timestamp when logLevel >= verbose.\n * Shared across all logger adapters to avoid duplication.\n */\nexport function formatMessage(message: string, logLevel: number): string {\n if (logLevel >= LogLevel.verbose) {\n const timestamp = new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n })\n return `${styleText('dim', `[${timestamp}]`)} ${message}`\n }\n return message\n}\n\ntype ProgressState = {\n totalPlugins: number\n completedPlugins: number\n failedPlugins: number\n totalFiles: number\n processedFiles: number\n hrStart: [number, number]\n}\n\n/**\n * Build the progress summary line shared by clack and GitHub Actions loggers.\n * Returns null when there is nothing to display.\n */\nexport function buildProgressLine(state: ProgressState): string | null {\n const parts: string[] = []\n const duration = formatHrtime(state.hrStart)\n\n if (state.totalPlugins > 0) {\n const pluginStr =\n state.failedPlugins > 0\n ? `Plugins ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins} ${styleText('red', `(${state.failedPlugins} failed)`)}`\n : `Plugins ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins}`\n parts.push(pluginStr)\n }\n\n if (state.totalFiles > 0) {\n parts.push(`Files ${styleText('green', state.processedFiles.toString())}/${state.totalFiles}`)\n }\n\n if (parts.length === 0) {\n return null\n }\n\n parts.push(`${styleText('green', duration)} elapsed`)\n return parts.join(styleText('dim', ' | '))\n}\n\n/**\n * Join a command and its optional args into a single display string.\n * e.g. (\"prettier\", [\"--write\", \".\"]) → \"prettier --write .\"\n */\nexport function formatCommandWithArgs(command: string, args?: readonly string[]): string {\n return args?.length ? `${command} ${args.join(' ')}` : command\n}\n\nfunction detectLogger(): LoggerType {\n if (isGitHubActions()) {\n return 'github-actions'\n }\n if (canUseTTY()) {\n return 'clack'\n }\n return 'plain'\n}\n\nconst logMapper = {\n clack: clackLogger,\n plain: plainLogger,\n 'github-actions': githubActionsLogger,\n} as const satisfies Record<LoggerType, Logger>\n\nexport async function setupLogger(context: LoggerContext, { logLevel }: LoggerOptions): Promise<void> {\n const type = detectLogger()\n\n const logger = logMapper[type] as Logger\n\n if (!logger) {\n throw new Error(`Unknown adapter type: ${type}`)\n }\n\n // Install primary logger\n const cleanup = await logger.install(context, { logLevel })\n\n if (logLevel >= LogLevel.debug) {\n await fileSystemLogger.install(context, { logLevel })\n }\n\n return cleanup\n}\n","import { createHash } from 'node:crypto'\nimport { styleText } from 'node:util'\nimport type { Config, KubbEvents } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\nimport { tokenize } from '@kubb/core/utils'\n\ntype ExecutingHooksProps = {\n hooks: NonNullable<Config['hooks']>\n events: AsyncEventEmitter<KubbEvents>\n}\n\nexport async function executeHooks({ hooks, events }: ExecutingHooksProps): Promise<void> {\n const commands = Array.isArray(hooks.done) ? hooks.done : [hooks.done].filter(Boolean)\n\n for (const command of commands) {\n const [cmd, ...args] = tokenize(command)\n\n if (!cmd) {\n continue\n }\n\n const hookId = createHash('sha256').update(command).digest('hex')\n\n // Wire up the hook:end listener BEFORE emitting hook:start to avoid the race condition\n // where hook:end fires synchronously inside emit('hook:start') before the listener is registered.\n const hookEndPromise = new Promise<void>((resolve, reject) => {\n const handler = ({ id, success, error }: { id?: string; command: string; args?: readonly string[]; success: boolean; error: Error | null }) => {\n if (id !== hookId) return\n events.off('hook:end', handler)\n if (!success) {\n reject(error ?? new Error(`Hook failed: ${command}`))\n return\n }\n events\n .emit('success', `${styleText('dim', command)} successfully executed`)\n .then(resolve)\n .catch(reject)\n }\n events.on('hook:end', handler)\n })\n\n await events.emit('hook:start', { id: hookId, command: cmd, args })\n await hookEndPromise\n }\n}\n","import type { defineConfig, UserConfig } from '@kubb/core'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { createJiti } from 'jiti'\n\ntype CosmiconfigResult = {\n filepath: string\n isEmpty?: boolean\n config: ReturnType<typeof defineConfig> | UserConfig\n}\n\nconst jiti = createJiti(import.meta.url, {\n jsx: {\n runtime: 'automatic',\n importSource: '@kubb/react-fabric',\n },\n sourceMaps: true,\n interopDefault: true,\n})\n\nconst tsLoader = async (configFile: string) => {\n const mod = await jiti.import(configFile, { default: true })\n return mod\n}\n\nexport async function getCosmiConfig(moduleName: string, config?: string): Promise<CosmiconfigResult> {\n let result: CosmiconfigResult\n const searchPlaces = [\n 'package.json',\n `.${moduleName}rc`,\n `.${moduleName}rc.json`,\n `.${moduleName}rc.yaml`,\n `.${moduleName}rc.yml`,\n\n `.${moduleName}rc.ts`,\n `.${moduleName}rc.js`,\n `.${moduleName}rc.mjs`,\n `.${moduleName}rc.cjs`,\n\n `${moduleName}.config.ts`,\n `${moduleName}.config.js`,\n `${moduleName}.config.mjs`,\n `${moduleName}.config.cjs`,\n ]\n const explorer = cosmiconfig(moduleName, {\n cache: false,\n searchPlaces: [\n ...searchPlaces.map((searchPlace) => {\n return `.config/${searchPlace}`\n }),\n ...searchPlaces.map((searchPlace) => {\n return `configs/${searchPlace}`\n }),\n ...searchPlaces,\n ],\n loaders: {\n '.ts': tsLoader,\n },\n })\n\n try {\n result = config ? ((await explorer.load(config)) as CosmiconfigResult) : ((await explorer.search()) as CosmiconfigResult)\n } catch (error) {\n throw new Error('Config failed loading', { cause: error })\n }\n\n if (result?.isEmpty || !result || !result.config) {\n throw new Error('Config not defined, create a kubb.config.js or pass through your config with the option --config')\n }\n\n return result as CosmiconfigResult\n}\n","import { styleText } from 'node:util'\nimport { WATCHER_IGNORED_PATHS } from '../constants.ts'\n\nexport async function startWatcher(path: string[], cb: (path: string[]) => Promise<void>): Promise<void> {\n const { watch } = await import('chokidar')\n const watcher = watch(path, {\n ignorePermissionErrors: true,\n ignored: WATCHER_IGNORED_PATHS,\n })\n watcher.on('all', async (type, file) => {\n console.log(styleText('yellow', styleText('bold', `Change detected: ${type} ${file}`)))\n\n try {\n await cb(path)\n } catch (_e) {\n console.log(styleText('red', 'Watcher failed'))\n }\n })\n}\n","import { createHash } from 'node:crypto'\nimport path from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { type CLIOptions, type Config, isInputPath, type KubbEvents, LogLevel, PromiseManager, safeBuild, setup } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\nimport { AsyncEventEmitter as AsyncEventEmitterClass, detectFormatter, detectLinter, executeIfOnline, formatters, getConfigs, linters } from '@kubb/core/utils'\nimport { version } from '../../package.json'\nimport { KUBB_NPM_PACKAGE_URL } from '../constants.ts'\nimport { setupLogger } from '../loggers/utils.ts'\nimport { toError } from '../utils/errors.ts'\nimport { executeHooks } from '../utils/executeHooks.ts'\nimport { getCosmiConfig } from '../utils/getCosmiConfig.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\nimport { startWatcher } from '../utils/watcher.ts'\n\ntype GenerateProps = {\n input?: string\n config: Config\n events: AsyncEventEmitter<KubbEvents>\n logLevel: number\n}\n\ntype ToolMap = typeof formatters | typeof linters\n\ntype RunToolPassOptions = {\n toolValue: string\n detect: () => Promise<string | undefined>\n toolMap: ToolMap\n /** Short noun used in \"Auto-detected <toolLabel>:\" message, e.g. \"formatter\" or \"linter\". */\n toolLabel: string\n /** Verb prefix for the success message, e.g. \"Formatting\" or \"Linting\". */\n successPrefix: string\n noToolMessage: string\n configName: string | undefined\n outputPath: string\n logLevel: number\n events: AsyncEventEmitter<KubbEvents>\n onStart: () => Promise<void>\n onEnd: () => Promise<void>\n}\n\nasync function runToolPass({\n toolValue,\n detect,\n toolMap,\n toolLabel,\n successPrefix,\n noToolMessage,\n configName,\n outputPath,\n logLevel,\n events,\n onStart,\n onEnd,\n}: RunToolPassOptions) {\n await onStart()\n\n let resolvedTool = toolValue\n if (resolvedTool === 'auto') {\n const detected = await detect()\n if (!detected) {\n await events.emit('warn', noToolMessage)\n } else {\n resolvedTool = detected\n await events.emit('info', `Auto-detected ${toolLabel}: ${styleText('dim', resolvedTool)}`)\n }\n }\n\n if (resolvedTool && resolvedTool !== 'auto' && resolvedTool in toolMap) {\n const toolConfig = toolMap[resolvedTool as keyof ToolMap]\n\n try {\n const hookId = createHash('sha256').update([configName, resolvedTool].filter(Boolean).join('-')).digest('hex')\n\n // Wire up the hook:end listener BEFORE emitting hook:start to avoid the race condition\n // where hook:end fires synchronously inside emit('hook:start') before the listener is registered.\n const hookEndPromise = new Promise<void>((resolve, reject) => {\n const handler = ({ id, success, error }: { id?: string; command: string; args?: readonly string[]; success: boolean; error: Error | null }) => {\n if (id !== hookId) return\n events.off('hook:end', handler)\n if (!success) {\n reject(error ?? new Error(`${toolConfig.errorMessage}`))\n return\n }\n events\n .emit(\n 'success',\n [\n `${successPrefix} with ${styleText('dim', resolvedTool)}`,\n logLevel >= LogLevel.info ? `on ${styleText('dim', outputPath)}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n .then(resolve)\n .catch(reject)\n }\n events.on('hook:end', handler)\n })\n\n await events.emit('hook:start', {\n id: hookId,\n command: toolConfig.command,\n args: toolConfig.args(outputPath),\n })\n\n await hookEndPromise\n } catch (caughtError) {\n const err = new Error(toolConfig.errorMessage)\n err.cause = caughtError\n await events.emit('error', err)\n }\n }\n\n await onEnd()\n}\n\nasync function generate({ input, config: userConfig, events, logLevel }: GenerateProps): Promise<void> {\n const inputPath = input ?? ('path' in userConfig.input ? userConfig.input.path : undefined)\n const hrStart = process.hrtime()\n\n const config: Config = {\n ...userConfig,\n root: userConfig.root || process.cwd(),\n input: inputPath\n ? {\n ...userConfig.input,\n path: inputPath,\n }\n : userConfig.input,\n output: {\n write: true,\n barrelType: 'named',\n extension: {\n '.ts': '.ts',\n },\n format: 'prettier',\n ...userConfig.output,\n },\n }\n\n await events.emit('generation:start', config)\n\n await events.emit('info', config.name ? `Setup generation ${styleText('bold', config.name)}` : 'Setup generation', inputPath)\n\n const { sources, fabric, pluginManager } = await setup({\n config,\n events,\n })\n\n await events.emit('info', config.name ? `Build generation ${styleText('bold', config.name)}` : 'Build generation', inputPath)\n\n const { files, failedPlugins, pluginTimings, error } = await safeBuild(\n {\n config,\n events,\n },\n { pluginManager, fabric, events, sources },\n )\n\n await events.emit('info', 'Load summary')\n\n // Handle build failures (either from failed plugins or general errors)\n\n const hasFailures = failedPlugins.size > 0 || error\n if (hasFailures) {\n // Collect all errors from failed plugins and general error\n const allErrors: Error[] = [\n error,\n ...Array.from(failedPlugins)\n .filter((it) => it.error)\n .map((it) => it.error),\n ].filter(Boolean)\n\n for (const err of allErrors) {\n await events.emit('error', err)\n }\n\n await events.emit('generation:end', config, files, sources)\n\n await events.emit('generation:summary', config, {\n failedPlugins,\n filesCreated: files.length,\n status: 'failed',\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n\n await sendTelemetry(\n buildTelemetryEvent({\n command: 'generate',\n kubbVersion: version,\n plugins: pluginManager.plugins.map((p) => ({ name: p.name, options: p.options as Record<string, unknown> })),\n hrStart,\n filesCreated: files.length,\n status: 'failed',\n }),\n )\n\n process.exit(1)\n }\n\n await events.emit('success', 'Generation successfully', inputPath)\n await events.emit('generation:end', config, files, sources)\n\n const outputPath = path.resolve(config.root, config.output.path)\n\n if (config.output.format) {\n await runToolPass({\n toolValue: config.output.format,\n detect: detectFormatter,\n toolMap: formatters,\n toolLabel: 'formatter',\n successPrefix: 'Formatting',\n noToolMessage: 'No formatter found (biome, prettier, or oxfmt). Skipping formatting.',\n configName: config.name,\n outputPath,\n logLevel,\n events,\n onStart: () => events.emit('format:start'),\n onEnd: () => events.emit('format:end'),\n })\n }\n\n if (config.output.lint) {\n await runToolPass({\n toolValue: config.output.lint,\n detect: detectLinter,\n toolMap: linters,\n toolLabel: 'linter',\n successPrefix: 'Linting',\n noToolMessage: 'No linter found (biome, oxlint, or eslint). Skipping linting.',\n configName: config.name,\n outputPath,\n logLevel,\n events,\n onStart: () => events.emit('lint:start'),\n onEnd: () => events.emit('lint:end'),\n })\n }\n\n if (config.hooks) {\n await events.emit('hooks:start')\n await executeHooks({ hooks: config.hooks, events })\n\n await events.emit('hooks:end')\n }\n\n // Only reached when there are no failures (process.exit(1) is called above otherwise)\n await events.emit('generation:summary', config, {\n failedPlugins,\n filesCreated: files.length,\n status: 'success',\n hrStart,\n pluginTimings,\n })\n\n const telemetryEvent = buildTelemetryEvent({\n command: 'generate',\n kubbVersion: version,\n plugins: pluginManager.plugins.map((p) => ({ name: p.name, options: p.options as Record<string, unknown> })),\n hrStart,\n filesCreated: files.length,\n status: 'success',\n })\n\n await sendTelemetry(telemetryEvent)\n}\n\ntype GenerateCommandOptions = {\n input?: string\n configPath?: string\n logLevel: string\n watch: boolean\n}\n\nexport async function runGenerateCommand({ input, configPath, logLevel: logLevelKey, watch }: GenerateCommandOptions): Promise<void> {\n const logLevel = LogLevel[logLevelKey as keyof typeof LogLevel] ?? LogLevel.info\n const events = new AsyncEventEmitterClass<KubbEvents>()\n const promiseManager = new PromiseManager()\n\n await setupLogger(events, { logLevel })\n\n await executeIfOnline(async () => {\n try {\n const res = await fetch(KUBB_NPM_PACKAGE_URL)\n const data = (await res.json()) as { version: string }\n const latestVersion = data.version\n\n if (latestVersion && version < latestVersion) {\n await events.emit('version:new', version, latestVersion)\n }\n } catch {\n // Ignore network errors for version check\n }\n })\n\n try {\n const result = await getCosmiConfig('kubb', configPath)\n const configs = await getConfigs(result.config, { input } as CLIOptions)\n\n await events.emit('config:start')\n await events.emit('info', 'Config loaded', path.relative(process.cwd(), result.filepath))\n await events.emit('success', 'Config loaded successfully', path.relative(process.cwd(), result.filepath))\n await events.emit('config:end', configs)\n\n await events.emit('lifecycle:start', version)\n\n const promises = configs.map((config) => {\n return async () => {\n if (isInputPath(config) && watch) {\n await startWatcher([input || config.input.path], async (paths) => {\n // remove to avoid duplicate listeners after each change\n events.removeAll()\n\n await generate({ input, config, logLevel, events })\n\n clack.log.step(styleText('yellow', `Watching for changes in ${paths.join(' and ')}`))\n })\n\n return\n }\n\n await generate({ input, config, logLevel, events })\n }\n })\n\n await promiseManager.run('seq', promises)\n\n await events.emit('lifecycle:end')\n } catch (error) {\n await events.emit('error', toError(error))\n process.exit(1)\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"init-Cd1hCb7q.cjs","names":["fs","path","pluginDefaultConfigs","process","clack","initDefaults","path","fs"],"sources":["../src/utils/spawnAsync.ts","../src/utils/packageManager.ts","../src/runners/init.ts"],"sourcesContent":["import { spawn } from 'node:child_process'\n\ntype SpawnOptions = {\n cwd?: string\n env?: NodeJS.ProcessEnv\n /**\n * When `true`, spawns a detached background process and resolves immediately.\n * The child is unref'd so the parent process can exit independently.\n * Defaults to `false` (foreground — inherits stdio and waits for exit).\n */\n detached?: boolean\n}\n\n/**\n * Spawns `cmd args` and returns a promise.\n * - Foreground (default): inherits stdio and resolves when the process exits successfully.\n * - Detached: spawns in its own process group, un-refs the child, and resolves immediately.\n */\nexport function spawnAsync(cmd: string, args: string[], options: SpawnOptions = {}): Promise<void> {\n const { cwd = process.cwd(), env, detached = false } = options\n\n return new Promise((resolve, reject) => {\n const child = spawn(cmd, args, {\n stdio: detached ? 'ignore' : 'inherit',\n cwd,\n env,\n detached,\n })\n\n if (detached) {\n child.unref()\n resolve()\n return\n }\n\n child.on('close', (code, signal) => {\n if (code === 0) {\n resolve()\n } else if (signal !== null) {\n reject(new Error(`\"${cmd} ${args.join(' ')}\" was terminated by signal ${signal}`))\n } else {\n reject(new Error(`\"${cmd} ${args.join(' ')}\" exited with code ${code}`))\n }\n })\n child.on('error', reject)\n })\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport type { PackageManagerInfo, PackageManagerName } from '@kubb/core'\nimport { spawnAsync } from './spawnAsync.ts'\n\nexport function hasPackageJson(cwd: string = process.cwd()): boolean {\n return fs.existsSync(path.join(cwd, 'package.json'))\n}\n\nexport async function initPackageJson(cwd: string, packageManager: PackageManagerInfo): Promise<void> {\n const commands: Record<PackageManagerName, string[]> = {\n npm: ['init', '-y'],\n pnpm: ['init'],\n yarn: ['init', '-y'],\n bun: ['init', '-y'],\n }\n\n await spawnAsync(packageManager.name, commands[packageManager.name], { cwd })\n}\n\nexport async function installPackages(packages: string[], packageManager: PackageManagerInfo, cwd: string = process.cwd()): Promise<void> {\n await spawnAsync(packageManager.name, [...packageManager.installCommand, ...packages], { cwd })\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, type PackageManagerInfo } from '@kubb/core'\nimport { initDefaults, pluginDefaultConfigs } from '../constants.ts'\nimport { hasPackageJson, initPackageJson, installPackages } from '../utils/packageManager.ts'\n\ntype PluginOption = {\n value: string\n label: string\n hint?: string\n packageName: string\n importName: string\n category: 'core' | 'typescript' | 'query' | 'validation' | 'testing' | 'mocking' | 'docs'\n}\n\nconst availablePlugins: PluginOption[] = [\n {\n value: 'plugin-oas',\n label: 'OpenAPI Parser',\n hint: 'Required',\n packageName: '@kubb/plugin-oas',\n importName: 'pluginOas',\n category: 'core',\n },\n {\n value: 'plugin-ts',\n label: 'TypeScript',\n hint: 'Recommended',\n packageName: '@kubb/plugin-ts',\n importName: 'pluginTs',\n category: 'typescript',\n },\n {\n value: 'plugin-client',\n label: 'Client (Fetch/Axios)',\n packageName: '@kubb/plugin-client',\n importName: 'pluginClient',\n category: 'typescript',\n },\n {\n value: 'plugin-react-query',\n label: 'React Query / TanStack Query',\n packageName: '@kubb/plugin-react-query',\n importName: 'pluginReactQuery',\n category: 'query',\n },\n {\n value: 'plugin-solid-query',\n label: 'Solid Query',\n packageName: '@kubb/plugin-solid-query',\n importName: 'pluginSolidQuery',\n category: 'query',\n },\n {\n value: 'plugin-svelte-query',\n label: 'Svelte Query',\n packageName: '@kubb/plugin-svelte-query',\n importName: 'pluginSvelteQuery',\n category: 'query',\n },\n {\n value: 'plugin-vue-query',\n label: 'Vue Query',\n packageName: '@kubb/plugin-vue-query',\n importName: 'pluginVueQuery',\n category: 'query',\n },\n {\n value: 'plugin-swr',\n label: 'SWR',\n packageName: '@kubb/plugin-swr',\n importName: 'pluginSwr',\n category: 'query',\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: 'mocking',\n },\n {\n value: 'plugin-msw',\n label: 'MSW Handlers',\n packageName: '@kubb/plugin-msw',\n importName: 'pluginMsw',\n category: 'mocking',\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-redoc',\n label: 'ReDoc Documentation',\n packageName: '@kubb/plugin-redoc',\n importName: 'pluginRedoc',\n category: 'docs',\n },\n]\n\nfunction generateConfigFile(selectedPlugins: PluginOption[], inputPath: string, outputPath: string): string {\n const imports = selectedPlugins.map((plugin) => `import { ${plugin.importName} } from '${plugin.packageName}'`).join('\\n')\n\n const pluginConfigs = selectedPlugins\n .map((plugin) => {\n const config = (pluginDefaultConfigs as Record<string, string>)[plugin.value] ?? `${plugin.importName}()`\n return ` ${config},`\n })\n .join('\\n')\n\n return `import { defineConfig } from '@kubb/core'\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\nfunction cancelAndExit(message = 'Operation cancelled.'): never {\n clack.cancel(message)\n process.exit(0)\n}\n\ntype InitOptions = {\n yes: boolean\n version: string\n}\n\nexport async function runInit({ yes, version }: InitOptions): Promise<void> {\n const cwd = process.cwd()\n\n clack.intro(styleText('bgCyan', styleText('black', ' Kubb Init ')))\n\n try {\n // Check/create package.json\n let packageManager: PackageManagerInfo\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 packageManager = detectPackageManager(cwd)\n\n const spinner = clack.spinner()\n spinner.start(`Initializing package.json with ${packageManager.name}`)\n\n await initPackageJson(cwd, packageManager)\n\n spinner.stop(`Created package.json with ${packageManager.name}`)\n } else {\n packageManager = detectPackageManager(cwd)\n clack.log.info(`Detected package manager: ${styleText('cyan', packageManager.name)}`)\n }\n\n // Prompt for OpenAPI spec path\n let inputPath: string\n if (yes) {\n inputPath = initDefaults.inputPath\n clack.log.info(`Using input path: ${styleText('cyan', inputPath)}`)\n } else {\n const inputPathResult = await 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 if (clack.isCancel(inputPathResult)) {\n cancelAndExit()\n }\n inputPath = inputPathResult as string\n }\n\n // Prompt for output directory\n let outputPath: string\n if (yes) {\n outputPath = initDefaults.outputPath\n clack.log.info(`Using output path: ${styleText('cyan', outputPath)}`)\n } else {\n const outputPathResult = await 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 if (clack.isCancel(outputPathResult)) {\n cancelAndExit()\n }\n outputPath = outputPathResult as string\n }\n\n // Plugin selection\n let selectedPlugins: PluginOption[]\n if (yes) {\n selectedPlugins = availablePlugins.filter((plugin) => (initDefaults.plugins as readonly string[]).includes(plugin.value))\n clack.log.info(`Using plugins: ${styleText('cyan', selectedPlugins.map((p) => p.label).join(', '))}`)\n } else {\n const selectedPluginValues = await clack.multiselect({\n message: 'Select plugins to use:',\n options: availablePlugins.map((plugin) => ({\n value: plugin.value,\n label: plugin.label,\n hint: plugin.hint,\n })),\n initialValues: [...initDefaults.plugins],\n required: true,\n })\n\n if (clack.isCancel(selectedPluginValues)) {\n cancelAndExit()\n }\n\n selectedPlugins = availablePlugins.filter((plugin) => (selectedPluginValues as string[]).includes(plugin.value))\n }\n\n // Ensure plugin-oas is always included\n if (!selectedPlugins.find((p) => p.value === 'plugin-oas')) {\n selectedPlugins.unshift(availablePlugins.find((p) => p.value === 'plugin-oas')!)\n }\n\n // Install packages\n const packagesToInstall = ['@kubb/core', '@kubb/cli', '@kubb/agent', ...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.ts')\n\n const configContent = generateConfigFile(selectedPlugins, inputPath, outputPath)\n const configPath = path.join(cwd, 'kubb.config.ts')\n\n if (fs.existsSync(configPath)) {\n configSpinner.stop('kubb.config.ts already exists')\n\n if (!yes) {\n const shouldOverwrite = await clack.confirm({\n message: 'kubb.config.ts 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.ts')\n }\n\n fs.writeFileSync(configPath, configContent, 'utf-8')\n\n configSpinner.stop('Created kubb.config.ts')\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', ' Or start a stream server with: npx kubb start') +\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":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"init-DLNrkDF4.js","names":[],"sources":["../src/commands/init.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'init',\n description: 'Initialize a new Kubb project with interactive setup',\n options: {\n yes: { type: 'boolean', description: 'Skip prompts and use default options', short: 'y', default: false },\n },\n async run({ values }) {\n const { runInit } = await import('../runners/init.ts')\n\n await runInit({ yes: values.yes, version })\n },\n})\n"],"mappings":";;;;AAGA,MAAa,UAAU,cAAc;CACnC,MAAM;CACN,aAAa;CACb,SAAS,EACP,KAAK;EAAE,MAAM;EAAW,aAAa;EAAwC,OAAO;EAAK,SAAS;EAAO,EAC1G;CACD,MAAM,IAAI,EAAE,UAAU;EACpB,MAAM,EAAE,YAAY,MAAM,OAAO;AAEjC,QAAM,QAAQ;GAAE,KAAK,OAAO;GAAK;GAAS,CAAC;;CAE9C,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"init-Df_aXezV.cjs","names":["defineCommand"],"sources":["../src/commands/init.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'init',\n description: 'Initialize a new Kubb project with interactive setup',\n options: {\n yes: { type: 'boolean', description: 'Skip prompts and use default options', short: 'y', default: false },\n },\n async run({ values }) {\n const { runInit } = await import('../runners/init.ts')\n\n await runInit({ yes: values.yes, version })\n },\n})\n"],"mappings":";;;AAGA,MAAa,0CAAUA,cAAc;CACnC,MAAM;CACN,aAAa;CACb,SAAS,EACP,KAAK;EAAE,MAAM;EAAW,aAAa;EAAwC,OAAO;EAAK,SAAS;EAAO,EAC1G;CACD,MAAM,IAAI,EAAE,UAAU;EACpB,MAAM,EAAE,YAAY,MAAA,QAAA,SAAA,CAAA,WAAA,QAAM,sBAAA,CAAA;AAE1B,QAAM,QAAQ;GAAE,KAAK,OAAO;GAAK,SAAA,gBAAA;GAAS,CAAC;;CAE9C,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"init-DyKK2fTp.js","names":["process"],"sources":["../src/utils/spawnAsync.ts","../src/utils/packageManager.ts","../src/runners/init.ts"],"sourcesContent":["import { spawn } from 'node:child_process'\n\ntype SpawnOptions = {\n cwd?: string\n env?: NodeJS.ProcessEnv\n /**\n * When `true`, spawns a detached background process and resolves immediately.\n * The child is unref'd so the parent process can exit independently.\n * Defaults to `false` (foreground — inherits stdio and waits for exit).\n */\n detached?: boolean\n}\n\n/**\n * Spawns `cmd args` and returns a promise.\n * - Foreground (default): inherits stdio and resolves when the process exits successfully.\n * - Detached: spawns in its own process group, un-refs the child, and resolves immediately.\n */\nexport function spawnAsync(cmd: string, args: string[], options: SpawnOptions = {}): Promise<void> {\n const { cwd = process.cwd(), env, detached = false } = options\n\n return new Promise((resolve, reject) => {\n const child = spawn(cmd, args, {\n stdio: detached ? 'ignore' : 'inherit',\n cwd,\n env,\n detached,\n })\n\n if (detached) {\n child.unref()\n resolve()\n return\n }\n\n child.on('close', (code, signal) => {\n if (code === 0) {\n resolve()\n } else if (signal !== null) {\n reject(new Error(`\"${cmd} ${args.join(' ')}\" was terminated by signal ${signal}`))\n } else {\n reject(new Error(`\"${cmd} ${args.join(' ')}\" exited with code ${code}`))\n }\n })\n child.on('error', reject)\n })\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport type { PackageManagerInfo, PackageManagerName } from '@kubb/core'\nimport { spawnAsync } from './spawnAsync.ts'\n\nexport function hasPackageJson(cwd: string = process.cwd()): boolean {\n return fs.existsSync(path.join(cwd, 'package.json'))\n}\n\nexport async function initPackageJson(cwd: string, packageManager: PackageManagerInfo): Promise<void> {\n const commands: Record<PackageManagerName, string[]> = {\n npm: ['init', '-y'],\n pnpm: ['init'],\n yarn: ['init', '-y'],\n bun: ['init', '-y'],\n }\n\n await spawnAsync(packageManager.name, commands[packageManager.name], { cwd })\n}\n\nexport async function installPackages(packages: string[], packageManager: PackageManagerInfo, cwd: string = process.cwd()): Promise<void> {\n await spawnAsync(packageManager.name, [...packageManager.installCommand, ...packages], { cwd })\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, type PackageManagerInfo } from '@kubb/core'\nimport { initDefaults, pluginDefaultConfigs } from '../constants.ts'\nimport { hasPackageJson, initPackageJson, installPackages } from '../utils/packageManager.ts'\n\ntype PluginOption = {\n value: string\n label: string\n hint?: string\n packageName: string\n importName: string\n category: 'core' | 'typescript' | 'query' | 'validation' | 'testing' | 'mocking' | 'docs'\n}\n\nconst availablePlugins: PluginOption[] = [\n {\n value: 'plugin-oas',\n label: 'OpenAPI Parser',\n hint: 'Required',\n packageName: '@kubb/plugin-oas',\n importName: 'pluginOas',\n category: 'core',\n },\n {\n value: 'plugin-ts',\n label: 'TypeScript',\n hint: 'Recommended',\n packageName: '@kubb/plugin-ts',\n importName: 'pluginTs',\n category: 'typescript',\n },\n {\n value: 'plugin-client',\n label: 'Client (Fetch/Axios)',\n packageName: '@kubb/plugin-client',\n importName: 'pluginClient',\n category: 'typescript',\n },\n {\n value: 'plugin-react-query',\n label: 'React Query / TanStack Query',\n packageName: '@kubb/plugin-react-query',\n importName: 'pluginReactQuery',\n category: 'query',\n },\n {\n value: 'plugin-solid-query',\n label: 'Solid Query',\n packageName: '@kubb/plugin-solid-query',\n importName: 'pluginSolidQuery',\n category: 'query',\n },\n {\n value: 'plugin-svelte-query',\n label: 'Svelte Query',\n packageName: '@kubb/plugin-svelte-query',\n importName: 'pluginSvelteQuery',\n category: 'query',\n },\n {\n value: 'plugin-vue-query',\n label: 'Vue Query',\n packageName: '@kubb/plugin-vue-query',\n importName: 'pluginVueQuery',\n category: 'query',\n },\n {\n value: 'plugin-swr',\n label: 'SWR',\n packageName: '@kubb/plugin-swr',\n importName: 'pluginSwr',\n category: 'query',\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: 'mocking',\n },\n {\n value: 'plugin-msw',\n label: 'MSW Handlers',\n packageName: '@kubb/plugin-msw',\n importName: 'pluginMsw',\n category: 'mocking',\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-redoc',\n label: 'ReDoc Documentation',\n packageName: '@kubb/plugin-redoc',\n importName: 'pluginRedoc',\n category: 'docs',\n },\n]\n\nfunction generateConfigFile(selectedPlugins: PluginOption[], inputPath: string, outputPath: string): string {\n const imports = selectedPlugins.map((plugin) => `import { ${plugin.importName} } from '${plugin.packageName}'`).join('\\n')\n\n const pluginConfigs = selectedPlugins\n .map((plugin) => {\n const config = (pluginDefaultConfigs as Record<string, string>)[plugin.value] ?? `${plugin.importName}()`\n return ` ${config},`\n })\n .join('\\n')\n\n return `import { defineConfig } from '@kubb/core'\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\nfunction cancelAndExit(message = 'Operation cancelled.'): never {\n clack.cancel(message)\n process.exit(0)\n}\n\ntype InitOptions = {\n yes: boolean\n version: string\n}\n\nexport async function runInit({ yes, version }: InitOptions): Promise<void> {\n const cwd = process.cwd()\n\n clack.intro(styleText('bgCyan', styleText('black', ' Kubb Init ')))\n\n try {\n // Check/create package.json\n let packageManager: PackageManagerInfo\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 packageManager = detectPackageManager(cwd)\n\n const spinner = clack.spinner()\n spinner.start(`Initializing package.json with ${packageManager.name}`)\n\n await initPackageJson(cwd, packageManager)\n\n spinner.stop(`Created package.json with ${packageManager.name}`)\n } else {\n packageManager = detectPackageManager(cwd)\n clack.log.info(`Detected package manager: ${styleText('cyan', packageManager.name)}`)\n }\n\n // Prompt for OpenAPI spec path\n let inputPath: string\n if (yes) {\n inputPath = initDefaults.inputPath\n clack.log.info(`Using input path: ${styleText('cyan', inputPath)}`)\n } else {\n const inputPathResult = await 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 if (clack.isCancel(inputPathResult)) {\n cancelAndExit()\n }\n inputPath = inputPathResult as string\n }\n\n // Prompt for output directory\n let outputPath: string\n if (yes) {\n outputPath = initDefaults.outputPath\n clack.log.info(`Using output path: ${styleText('cyan', outputPath)}`)\n } else {\n const outputPathResult = await 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 if (clack.isCancel(outputPathResult)) {\n cancelAndExit()\n }\n outputPath = outputPathResult as string\n }\n\n // Plugin selection\n let selectedPlugins: PluginOption[]\n if (yes) {\n selectedPlugins = availablePlugins.filter((plugin) => (initDefaults.plugins as readonly string[]).includes(plugin.value))\n clack.log.info(`Using plugins: ${styleText('cyan', selectedPlugins.map((p) => p.label).join(', '))}`)\n } else {\n const selectedPluginValues = await clack.multiselect({\n message: 'Select plugins to use:',\n options: availablePlugins.map((plugin) => ({\n value: plugin.value,\n label: plugin.label,\n hint: plugin.hint,\n })),\n initialValues: [...initDefaults.plugins],\n required: true,\n })\n\n if (clack.isCancel(selectedPluginValues)) {\n cancelAndExit()\n }\n\n selectedPlugins = availablePlugins.filter((plugin) => (selectedPluginValues as string[]).includes(plugin.value))\n }\n\n // Ensure plugin-oas is always included\n if (!selectedPlugins.find((p) => p.value === 'plugin-oas')) {\n selectedPlugins.unshift(availablePlugins.find((p) => p.value === 'plugin-oas')!)\n }\n\n // Install packages\n const packagesToInstall = ['@kubb/core', '@kubb/cli', '@kubb/agent', ...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.ts')\n\n const configContent = generateConfigFile(selectedPlugins, inputPath, outputPath)\n const configPath = path.join(cwd, 'kubb.config.ts')\n\n if (fs.existsSync(configPath)) {\n configSpinner.stop('kubb.config.ts already exists')\n\n if (!yes) {\n const shouldOverwrite = await clack.confirm({\n message: 'kubb.config.ts 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.ts')\n }\n\n fs.writeFileSync(configPath, configContent, 'utf-8')\n\n configSpinner.stop('Created kubb.config.ts')\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', ' Or start a stream server with: npx kubb start') +\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":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mcp-B73FC8dF.cjs","names":["jiti","process","sendTelemetry","buildTelemetryEvent","getErrorMessage"],"sources":["../src/runners/mcp.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport type * as McpModule from '@kubb/mcp'\nimport { getErrorMessage } from '../utils/errors.ts'\nimport { jiti } from '../utils/jiti.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\n\ntype McpOptions = {\n version: string\n}\n\nexport async function runMcp({ version }: McpOptions): Promise<void> {\n let mod: typeof McpModule\n try {\n mod = (await jiti.import('@kubb/mcp', { default: true })) as typeof McpModule\n } catch (_e) {\n console.error(`Import of '@kubb/mcp' is required to start the MCP server`)\n process.exit(1)\n }\n\n const { run } = mod\n const hrStart = process.hrtime()\n try {\n console.log('⏳ Starting MCP server...')\n console.warn(styleText('yellow', 'This feature is still under development — use with caution'))\n run()\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'success' }))\n } catch (error) {\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'failed' }))\n console.error(getErrorMessage(error))\n }\n}\n"],"mappings":";;;;;;;;AAWA,eAAsB,OAAO,EAAE,WAAsC;CACnE,IAAI;AACJ,KAAI;AACF,QAAO,MAAMA,aAAAA,KAAK,OAAO,aAAa,EAAE,SAAS,MAAM,CAAC;UACjD,IAAI;AACX,UAAQ,MAAM,4DAA4D;AAC1E,eAAA,QAAQ,KAAK,EAAE;;CAGjB,MAAM,EAAE,QAAQ;CAChB,MAAM,UAAUC,aAAAA,QAAQ,QAAQ;AAChC,KAAI;AACF,UAAQ,IAAI,2BAA2B;AACvC,UAAQ,MAAA,GAAA,UAAA,WAAe,UAAU,6DAA6D,CAAC;AAC/F,OAAK;AACL,QAAMC,kBAAAA,cAAcC,kBAAAA,oBAAoB;GAAE,SAAS;GAAO,aAAa;GAAS;GAAS,QAAQ;GAAW,CAAC,CAAC;UACvG,OAAO;AACd,QAAMD,kBAAAA,cAAcC,kBAAAA,oBAAoB;GAAE,SAAS;GAAO,aAAa;GAAS;GAAS,QAAQ;GAAU,CAAC,CAAC;AAC7G,UAAQ,MAAMC,eAAAA,gBAAgB,MAAM,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mcp-Bd9LITaI.js","names":[],"sources":["../src/commands/mcp.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'mcp',\n description: 'Start the server to enable the MCP client to interact with the LLM.',\n async run() {\n const { runMcp } = await import('../runners/mcp.ts')\n\n await runMcp({ version })\n },\n})\n"],"mappings":";;;;AAGA,MAAa,UAAU,cAAc;CACnC,MAAM;CACN,aAAa;CACb,MAAM,MAAM;EACV,MAAM,EAAE,WAAW,MAAM,OAAO;AAEhC,QAAM,OAAO,EAAE,SAAS,CAAC;;CAE5B,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mcp-Cf-1dsB-.js","names":[],"sources":["../src/runners/mcp.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport type * as McpModule from '@kubb/mcp'\nimport { getErrorMessage } from '../utils/errors.ts'\nimport { jiti } from '../utils/jiti.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\n\ntype McpOptions = {\n version: string\n}\n\nexport async function runMcp({ version }: McpOptions): Promise<void> {\n let mod: typeof McpModule\n try {\n mod = (await jiti.import('@kubb/mcp', { default: true })) as typeof McpModule\n } catch (_e) {\n console.error(`Import of '@kubb/mcp' is required to start the MCP server`)\n process.exit(1)\n }\n\n const { run } = mod\n const hrStart = process.hrtime()\n try {\n console.log('⏳ Starting MCP server...')\n console.warn(styleText('yellow', 'This feature is still under development — use with caution'))\n run()\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'success' }))\n } catch (error) {\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'failed' }))\n console.error(getErrorMessage(error))\n }\n}\n"],"mappings":";;;;;;;AAWA,eAAsB,OAAO,EAAE,WAAsC;CACnE,IAAI;AACJ,KAAI;AACF,QAAO,MAAM,KAAK,OAAO,aAAa,EAAE,SAAS,MAAM,CAAC;UACjD,IAAI;AACX,UAAQ,MAAM,4DAA4D;AAC1E,UAAQ,KAAK,EAAE;;CAGjB,MAAM,EAAE,QAAQ;CAChB,MAAM,UAAU,QAAQ,QAAQ;AAChC,KAAI;AACF,UAAQ,IAAI,2BAA2B;AACvC,UAAQ,KAAK,UAAU,UAAU,6DAA6D,CAAC;AAC/F,OAAK;AACL,QAAM,cAAc,oBAAoB;GAAE,SAAS;GAAO,aAAa;GAAS;GAAS,QAAQ;GAAW,CAAC,CAAC;UACvG,OAAO;AACd,QAAM,cAAc,oBAAoB;GAAE,SAAS;GAAO,aAAa;GAAS;GAAS,QAAQ;GAAU,CAAC,CAAC;AAC7G,UAAQ,MAAM,gBAAgB,MAAM,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mcp-Clg-Qnkr.cjs","names":["defineCommand"],"sources":["../src/commands/mcp.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'mcp',\n description: 'Start the server to enable the MCP client to interact with the LLM.',\n async run() {\n const { runMcp } = await import('../runners/mcp.ts')\n\n await runMcp({ version })\n },\n})\n"],"mappings":";;;AAGA,MAAa,0CAAUA,cAAc;CACnC,MAAM;CACN,aAAa;CACb,MAAM,MAAM;EACV,MAAM,EAAE,WAAW,MAAA,QAAA,SAAA,CAAA,WAAA,QAAM,qBAAA,CAAA;AAEzB,QAAM,OAAO,EAAE,SAAA,gBAAA,SAAS,CAAC;;CAE5B,CAAC"}
@@ -1,6 +0,0 @@
1
- //#region package.json
2
- var version = "4.33.0";
3
- //#endregion
4
- export { version as t };
5
-
6
- //# sourceMappingURL=package-681jTtCk.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"package-681jTtCk.js","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"package-aKgzEJtp.cjs","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"telemetry-C4gOKX2x.js","names":["process"],"sources":["../src/utils/envDetection.ts","../src/utils/telemetry.ts"],"sourcesContent":["/**\n * Check if running in GitHub Actions environment\n */\nexport function isGitHubActions(): boolean {\n return !!process.env.GITHUB_ACTIONS\n}\n\n/**\n * Check if running in any CI environment.\n * Covers all major CI systems via their well-known environment variables.\n */\nexport function isCIEnvironment(): boolean {\n return !!(\n (\n process.env.CI || // Generic (GitHub Actions, GitLab CI, CircleCI, Travis CI, etc.)\n process.env.GITHUB_ACTIONS || // GitHub Actions\n process.env.GITLAB_CI || // GitLab CI\n process.env.BITBUCKET_BUILD_NUMBER || // Bitbucket Pipelines\n process.env.JENKINS_URL || // Jenkins\n process.env.CIRCLECI || // CircleCI\n process.env.TRAVIS || // Travis CI\n process.env.TEAMCITY_VERSION || // TeamCity\n process.env.BUILDKITE || // Buildkite\n process.env.TF_BUILD\n ) // Azure Pipelines\n )\n}\n\n/**\n * Check if TTY is available for interactive output\n */\nexport function canUseTTY(): boolean {\n return !!process.stdout.isTTY && !isCIEnvironment()\n}\n","import { randomBytes } from 'node:crypto'\nimport os from 'node:os'\nimport process from 'node:process'\nimport { executeIfOnline } from '@kubb/core/utils'\nimport { OTLP_ENDPOINT } from '../constants.ts'\nimport { isCIEnvironment } from './envDetection.ts'\n\n// OpenTelemetry OTLP JSON types\n// https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/trace/v1/trace.proto\n// https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/common/v1/common.proto\n\ntype OtlpStringValue = { stringValue: string }\ntype OtlpBoolValue = { boolValue: boolean }\ntype OtlpIntValue = { intValue: number }\ntype OtlpDoubleValue = { doubleValue: number }\ntype OtlpBytesValue = { bytesValue: string }\ntype OtlpArrayValue = { arrayValue: { values: OtlpAnyValue[] } }\ntype OtlpKvListValue = { kvlistValue: { values: OtlpKeyValue[] } }\n\ntype OtlpAnyValue = OtlpStringValue | OtlpBoolValue | OtlpIntValue | OtlpDoubleValue | OtlpBytesValue | OtlpArrayValue | OtlpKvListValue\n\ntype OtlpKeyValue = {\n key: string\n value: OtlpAnyValue\n}\n\ntype OtlpResource = {\n attributes: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpInstrumentationScope = {\n name: string\n version?: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\n/** https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/trace/v1/trace.proto#L103 */\ntype OtlpSpanKind = 0 | 1 | 2 | 3 | 4 | 5\n\n/** 0 = STATUS_CODE_UNSET, 1 = STATUS_CODE_OK, 2 = STATUS_CODE_ERROR */\ntype OtlpStatusCode = 0 | 1 | 2\n\ntype OtlpStatus = {\n code: OtlpStatusCode\n message?: string\n}\n\ntype OtlpSpan = {\n traceId: string\n spanId: string\n traceState?: string\n parentSpanId?: string\n name: string\n kind: OtlpSpanKind\n startTimeUnixNano: string\n endTimeUnixNano: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n events?: OtlpSpanEvent[]\n droppedEventsCount?: number\n links?: OtlpSpanLink[]\n droppedLinksCount?: number\n status?: OtlpStatus\n}\n\ntype OtlpSpanEvent = {\n timeUnixNano: string\n name: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpSpanLink = {\n traceId: string\n spanId: string\n traceState?: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpScopeSpans = {\n scope: OtlpInstrumentationScope\n spans: OtlpSpan[]\n schemaUrl?: string\n}\n\ntype OtlpResourceSpans = {\n resource: OtlpResource\n scopeSpans: OtlpScopeSpans[]\n schemaUrl?: string\n}\n\n/** Root payload sent to POST /v1/traces */\ntype OtlpExportTraceServiceRequest = {\n resourceSpans: OtlpResourceSpans[]\n}\n\nexport type TelemetryPlugin = {\n name: string\n options: Record<string, unknown>\n}\n\ntype TelemetryEvent = {\n command: string\n kubbVersion: string\n nodeVersion: string\n platform: string\n ci: boolean\n plugins: TelemetryPlugin[]\n duration: number\n filesCreated: number\n status: 'success' | 'failed'\n}\n\n/**\n * Detect whether the current process is running inside a CI environment.\n * Delegates to the canonical isCIEnvironment() from envDetection.\n */\nexport function isCi(): boolean {\n return isCIEnvironment()\n}\n\n/**\n * Check if telemetry is disabled via DO_NOT_TRACK or KUBB_DISABLE_TELEMETRY.\n * Respects the standard DO_NOT_TRACK convention used across development tools.\n */\nexport function isTelemetryDisabled(): boolean {\n return (\n process.env['DO_NOT_TRACK'] === '1' ||\n process.env['DO_NOT_TRACK'] === 'true' ||\n process.env['KUBB_DISABLE_TELEMETRY'] === '1' ||\n process.env['KUBB_DISABLE_TELEMETRY'] === 'true'\n )\n}\n\n/**\n * Convert a TelemetryEvent into an OTLP-compatible JSON trace payload.\n * See https://opentelemetry.io/docs/languages/sdk-configuration/otlp-exporter/\n */\nexport function buildOtlpPayload(event: TelemetryEvent): OtlpExportTraceServiceRequest {\n const traceId = randomBytes(16).toString('hex')\n const spanId = randomBytes(8).toString('hex')\n const endTimeNs = BigInt(Date.now()) * 1_000_000n\n const startTimeNs = endTimeNs - BigInt(event.duration) * 1_000_000n\n\n const attributes: OtlpKeyValue[] = [\n { key: 'kubb.command', value: { stringValue: event.command } },\n { key: 'kubb.version', value: { stringValue: event.kubbVersion } },\n { key: 'kubb.node_version', value: { stringValue: event.nodeVersion } },\n { key: 'kubb.platform', value: { stringValue: event.platform } },\n { key: 'kubb.ci', value: { boolValue: event.ci } },\n { key: 'kubb.files_created', value: { intValue: event.filesCreated } },\n { key: 'kubb.status', value: { stringValue: event.status } },\n {\n key: 'kubb.plugins',\n value: {\n arrayValue: {\n values: event.plugins.map(\n (p): OtlpKvListValue => ({\n kvlistValue: {\n values: [\n { key: 'name', value: { stringValue: p.name } },\n { key: 'options', value: { stringValue: JSON.stringify({ ...p.options, usedEnumNames: undefined }) } },\n ],\n },\n }),\n ),\n },\n },\n },\n ]\n\n return {\n resourceSpans: [\n {\n resource: {\n attributes: [\n { key: 'service.name', value: { stringValue: 'kubb-cli' } },\n { key: 'service.version', value: { stringValue: event.kubbVersion } },\n { key: 'telemetry.sdk.language', value: { stringValue: 'nodejs' } },\n ],\n },\n scopeSpans: [\n {\n scope: { name: 'kubb-cli', version: event.kubbVersion },\n spans: [\n {\n traceId,\n spanId,\n name: event.command,\n kind: 1 satisfies OtlpSpanKind,\n startTimeUnixNano: String(startTimeNs),\n endTimeUnixNano: String(endTimeNs),\n attributes,\n status: { code: (event.status === 'success' ? 1 : 2) satisfies OtlpStatusCode },\n },\n ],\n },\n ],\n },\n ],\n }\n}\n\n/**\n * Send an anonymous telemetry event to the Kubb OTLP endpoint.\n * Respects DO_NOT_TRACK and KUBB_DISABLE_TELEMETRY environment variables.\n * Fails silently to never interrupt the generation process.\n */\nexport async function sendTelemetry(event: TelemetryEvent): Promise<void> {\n if (isTelemetryDisabled()) {\n return\n }\n\n await executeIfOnline(async () => {\n try {\n await fetch(`${OTLP_ENDPOINT}/v1/traces`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'Kubb-Telemetry-Version': '1',\n 'Kubb-Telemetry-Source': 'kubb-cli',\n },\n body: JSON.stringify(buildOtlpPayload(event)),\n signal: AbortSignal.timeout(5_000),\n })\n } catch (_e) {\n // Fail silently – telemetry must never break the CLI\n }\n })\n}\n\n/**\n * Build an anonymous telemetry payload from a completed generation run.\n * No file paths, OpenAPI specs, or secrets are included.\n */\nexport function buildTelemetryEvent(options: {\n command: 'generate' | 'mcp' | 'validate' | 'agent'\n kubbVersion: string\n plugins?: TelemetryPlugin[]\n hrStart: [number, number]\n filesCreated?: number\n status: 'success' | 'failed'\n}): TelemetryEvent {\n const [seconds, nanoseconds] = process.hrtime(options.hrStart)\n const duration = Math.round(seconds * 1000 + nanoseconds / 1e6)\n\n return {\n command: options.command,\n kubbVersion: options.kubbVersion,\n nodeVersion: process.versions.node.split('.')[0] as string,\n platform: os.platform(),\n ci: isCi(),\n plugins: options.plugins ?? [],\n duration,\n filesCreated: options.filesCreated ?? 0,\n status: options.status,\n }\n}\n"],"mappings":";;;;;;;;;;AAGA,SAAgB,kBAA2B;AACzC,QAAO,CAAC,CAAC,QAAQ,IAAI;;;;;;AAOvB,SAAgB,kBAA2B;AACzC,QAAO,CAAC,EAEJ,QAAQ,IAAI,MACZ,QAAQ,IAAI,kBACZ,QAAQ,IAAI,aACZ,QAAQ,IAAI,0BACZ,QAAQ,IAAI,eACZ,QAAQ,IAAI,YACZ,QAAQ,IAAI,UACZ,QAAQ,IAAI,oBACZ,QAAQ,IAAI,aACZ,QAAQ,IAAI;;;;;AAQlB,SAAgB,YAAqB;AACnC,QAAO,CAAC,CAAC,QAAQ,OAAO,SAAS,CAAC,iBAAiB;;;;;;;;ACwFrD,SAAgB,OAAgB;AAC9B,QAAO,iBAAiB;;;;;;AAO1B,SAAgB,sBAA+B;AAC7C,QACEA,UAAQ,IAAI,oBAAoB,OAChCA,UAAQ,IAAI,oBAAoB,UAChCA,UAAQ,IAAI,8BAA8B,OAC1CA,UAAQ,IAAI,8BAA8B;;;;;;AAQ9C,SAAgB,iBAAiB,OAAsD;CACrF,MAAM,UAAU,YAAY,GAAG,CAAC,SAAS,MAAM;CAC/C,MAAM,SAAS,YAAY,EAAE,CAAC,SAAS,MAAM;CAC7C,MAAM,YAAY,OAAO,KAAK,KAAK,CAAC,GAAG;CACvC,MAAM,cAAc,YAAY,OAAO,MAAM,SAAS,GAAG;CAEzD,MAAM,aAA6B;EACjC;GAAE,KAAK;GAAgB,OAAO,EAAE,aAAa,MAAM,SAAS;GAAE;EAC9D;GAAE,KAAK;GAAgB,OAAO,EAAE,aAAa,MAAM,aAAa;GAAE;EAClE;GAAE,KAAK;GAAqB,OAAO,EAAE,aAAa,MAAM,aAAa;GAAE;EACvE;GAAE,KAAK;GAAiB,OAAO,EAAE,aAAa,MAAM,UAAU;GAAE;EAChE;GAAE,KAAK;GAAW,OAAO,EAAE,WAAW,MAAM,IAAI;GAAE;EAClD;GAAE,KAAK;GAAsB,OAAO,EAAE,UAAU,MAAM,cAAc;GAAE;EACtE;GAAE,KAAK;GAAe,OAAO,EAAE,aAAa,MAAM,QAAQ;GAAE;EAC5D;GACE,KAAK;GACL,OAAO,EACL,YAAY,EACV,QAAQ,MAAM,QAAQ,KACnB,OAAwB,EACvB,aAAa,EACX,QAAQ,CACN;IAAE,KAAK;IAAQ,OAAO,EAAE,aAAa,EAAE,MAAM;IAAE,EAC/C;IAAE,KAAK;IAAW,OAAO,EAAE,aAAa,KAAK,UAAU;KAAE,GAAG,EAAE;KAAS,eAAe,KAAA;KAAW,CAAC,EAAE;IAAE,CACvG,EACF,EACF,EACF,EACF,EACF;GACF;EACF;AAED,QAAO,EACL,eAAe,CACb;EACE,UAAU,EACR,YAAY;GACV;IAAE,KAAK;IAAgB,OAAO,EAAE,aAAa,YAAY;IAAE;GAC3D;IAAE,KAAK;IAAmB,OAAO,EAAE,aAAa,MAAM,aAAa;IAAE;GACrE;IAAE,KAAK;IAA0B,OAAO,EAAE,aAAa,UAAU;IAAE;GACpE,EACF;EACD,YAAY,CACV;GACE,OAAO;IAAE,MAAM;IAAY,SAAS,MAAM;IAAa;GACvD,OAAO,CACL;IACE;IACA;IACA,MAAM,MAAM;IACZ,MAAM;IACN,mBAAmB,OAAO,YAAY;IACtC,iBAAiB,OAAO,UAAU;IAClC;IACA,QAAQ,EAAE,MAAO,MAAM,WAAW,YAAY,IAAI,GAA6B;IAChF,CACF;GACF,CACF;EACF,CACF,EACF;;;;;;;AAQH,eAAsB,cAAc,OAAsC;AACxE,KAAI,qBAAqB,CACvB;AAGF,OAAM,gBAAgB,YAAY;AAChC,MAAI;AACF,SAAM,MAAM,GAAG,cAAc,aAAa;IACxC,QAAQ;IACR,SAAS;KACP,gBAAgB;KAChB,0BAA0B;KAC1B,yBAAyB;KAC1B;IACD,MAAM,KAAK,UAAU,iBAAiB,MAAM,CAAC;IAC7C,QAAQ,YAAY,QAAQ,IAAM;IACnC,CAAC;WACK,IAAI;GAGb;;;;;;AAOJ,SAAgB,oBAAoB,SAOjB;CACjB,MAAM,CAAC,SAAS,eAAeA,UAAQ,OAAO,QAAQ,QAAQ;CAC9D,MAAM,WAAW,KAAK,MAAM,UAAU,MAAO,cAAc,IAAI;AAE/D,QAAO;EACL,SAAS,QAAQ;EACjB,aAAa,QAAQ;EACrB,aAAaA,UAAQ,SAAS,KAAK,MAAM,IAAI,CAAC;EAC9C,UAAU,GAAG,UAAU;EACvB,IAAI,MAAM;EACV,SAAS,QAAQ,WAAW,EAAE;EAC9B;EACA,cAAc,QAAQ,gBAAgB;EACtC,QAAQ,QAAQ;EACjB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"telemetry-T5IA2dWA.cjs","names":["process","OTLP_ENDPOINT","os"],"sources":["../src/utils/envDetection.ts","../src/utils/telemetry.ts"],"sourcesContent":["/**\n * Check if running in GitHub Actions environment\n */\nexport function isGitHubActions(): boolean {\n return !!process.env.GITHUB_ACTIONS\n}\n\n/**\n * Check if running in any CI environment.\n * Covers all major CI systems via their well-known environment variables.\n */\nexport function isCIEnvironment(): boolean {\n return !!(\n (\n process.env.CI || // Generic (GitHub Actions, GitLab CI, CircleCI, Travis CI, etc.)\n process.env.GITHUB_ACTIONS || // GitHub Actions\n process.env.GITLAB_CI || // GitLab CI\n process.env.BITBUCKET_BUILD_NUMBER || // Bitbucket Pipelines\n process.env.JENKINS_URL || // Jenkins\n process.env.CIRCLECI || // CircleCI\n process.env.TRAVIS || // Travis CI\n process.env.TEAMCITY_VERSION || // TeamCity\n process.env.BUILDKITE || // Buildkite\n process.env.TF_BUILD\n ) // Azure Pipelines\n )\n}\n\n/**\n * Check if TTY is available for interactive output\n */\nexport function canUseTTY(): boolean {\n return !!process.stdout.isTTY && !isCIEnvironment()\n}\n","import { randomBytes } from 'node:crypto'\nimport os from 'node:os'\nimport process from 'node:process'\nimport { executeIfOnline } from '@kubb/core/utils'\nimport { OTLP_ENDPOINT } from '../constants.ts'\nimport { isCIEnvironment } from './envDetection.ts'\n\n// OpenTelemetry OTLP JSON types\n// https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/trace/v1/trace.proto\n// https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/common/v1/common.proto\n\ntype OtlpStringValue = { stringValue: string }\ntype OtlpBoolValue = { boolValue: boolean }\ntype OtlpIntValue = { intValue: number }\ntype OtlpDoubleValue = { doubleValue: number }\ntype OtlpBytesValue = { bytesValue: string }\ntype OtlpArrayValue = { arrayValue: { values: OtlpAnyValue[] } }\ntype OtlpKvListValue = { kvlistValue: { values: OtlpKeyValue[] } }\n\ntype OtlpAnyValue = OtlpStringValue | OtlpBoolValue | OtlpIntValue | OtlpDoubleValue | OtlpBytesValue | OtlpArrayValue | OtlpKvListValue\n\ntype OtlpKeyValue = {\n key: string\n value: OtlpAnyValue\n}\n\ntype OtlpResource = {\n attributes: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpInstrumentationScope = {\n name: string\n version?: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\n/** https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/trace/v1/trace.proto#L103 */\ntype OtlpSpanKind = 0 | 1 | 2 | 3 | 4 | 5\n\n/** 0 = STATUS_CODE_UNSET, 1 = STATUS_CODE_OK, 2 = STATUS_CODE_ERROR */\ntype OtlpStatusCode = 0 | 1 | 2\n\ntype OtlpStatus = {\n code: OtlpStatusCode\n message?: string\n}\n\ntype OtlpSpan = {\n traceId: string\n spanId: string\n traceState?: string\n parentSpanId?: string\n name: string\n kind: OtlpSpanKind\n startTimeUnixNano: string\n endTimeUnixNano: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n events?: OtlpSpanEvent[]\n droppedEventsCount?: number\n links?: OtlpSpanLink[]\n droppedLinksCount?: number\n status?: OtlpStatus\n}\n\ntype OtlpSpanEvent = {\n timeUnixNano: string\n name: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpSpanLink = {\n traceId: string\n spanId: string\n traceState?: string\n attributes?: OtlpKeyValue[]\n droppedAttributesCount?: number\n}\n\ntype OtlpScopeSpans = {\n scope: OtlpInstrumentationScope\n spans: OtlpSpan[]\n schemaUrl?: string\n}\n\ntype OtlpResourceSpans = {\n resource: OtlpResource\n scopeSpans: OtlpScopeSpans[]\n schemaUrl?: string\n}\n\n/** Root payload sent to POST /v1/traces */\ntype OtlpExportTraceServiceRequest = {\n resourceSpans: OtlpResourceSpans[]\n}\n\nexport type TelemetryPlugin = {\n name: string\n options: Record<string, unknown>\n}\n\ntype TelemetryEvent = {\n command: string\n kubbVersion: string\n nodeVersion: string\n platform: string\n ci: boolean\n plugins: TelemetryPlugin[]\n duration: number\n filesCreated: number\n status: 'success' | 'failed'\n}\n\n/**\n * Detect whether the current process is running inside a CI environment.\n * Delegates to the canonical isCIEnvironment() from envDetection.\n */\nexport function isCi(): boolean {\n return isCIEnvironment()\n}\n\n/**\n * Check if telemetry is disabled via DO_NOT_TRACK or KUBB_DISABLE_TELEMETRY.\n * Respects the standard DO_NOT_TRACK convention used across development tools.\n */\nexport function isTelemetryDisabled(): boolean {\n return (\n process.env['DO_NOT_TRACK'] === '1' ||\n process.env['DO_NOT_TRACK'] === 'true' ||\n process.env['KUBB_DISABLE_TELEMETRY'] === '1' ||\n process.env['KUBB_DISABLE_TELEMETRY'] === 'true'\n )\n}\n\n/**\n * Convert a TelemetryEvent into an OTLP-compatible JSON trace payload.\n * See https://opentelemetry.io/docs/languages/sdk-configuration/otlp-exporter/\n */\nexport function buildOtlpPayload(event: TelemetryEvent): OtlpExportTraceServiceRequest {\n const traceId = randomBytes(16).toString('hex')\n const spanId = randomBytes(8).toString('hex')\n const endTimeNs = BigInt(Date.now()) * 1_000_000n\n const startTimeNs = endTimeNs - BigInt(event.duration) * 1_000_000n\n\n const attributes: OtlpKeyValue[] = [\n { key: 'kubb.command', value: { stringValue: event.command } },\n { key: 'kubb.version', value: { stringValue: event.kubbVersion } },\n { key: 'kubb.node_version', value: { stringValue: event.nodeVersion } },\n { key: 'kubb.platform', value: { stringValue: event.platform } },\n { key: 'kubb.ci', value: { boolValue: event.ci } },\n { key: 'kubb.files_created', value: { intValue: event.filesCreated } },\n { key: 'kubb.status', value: { stringValue: event.status } },\n {\n key: 'kubb.plugins',\n value: {\n arrayValue: {\n values: event.plugins.map(\n (p): OtlpKvListValue => ({\n kvlistValue: {\n values: [\n { key: 'name', value: { stringValue: p.name } },\n { key: 'options', value: { stringValue: JSON.stringify({ ...p.options, usedEnumNames: undefined }) } },\n ],\n },\n }),\n ),\n },\n },\n },\n ]\n\n return {\n resourceSpans: [\n {\n resource: {\n attributes: [\n { key: 'service.name', value: { stringValue: 'kubb-cli' } },\n { key: 'service.version', value: { stringValue: event.kubbVersion } },\n { key: 'telemetry.sdk.language', value: { stringValue: 'nodejs' } },\n ],\n },\n scopeSpans: [\n {\n scope: { name: 'kubb-cli', version: event.kubbVersion },\n spans: [\n {\n traceId,\n spanId,\n name: event.command,\n kind: 1 satisfies OtlpSpanKind,\n startTimeUnixNano: String(startTimeNs),\n endTimeUnixNano: String(endTimeNs),\n attributes,\n status: { code: (event.status === 'success' ? 1 : 2) satisfies OtlpStatusCode },\n },\n ],\n },\n ],\n },\n ],\n }\n}\n\n/**\n * Send an anonymous telemetry event to the Kubb OTLP endpoint.\n * Respects DO_NOT_TRACK and KUBB_DISABLE_TELEMETRY environment variables.\n * Fails silently to never interrupt the generation process.\n */\nexport async function sendTelemetry(event: TelemetryEvent): Promise<void> {\n if (isTelemetryDisabled()) {\n return\n }\n\n await executeIfOnline(async () => {\n try {\n await fetch(`${OTLP_ENDPOINT}/v1/traces`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'Kubb-Telemetry-Version': '1',\n 'Kubb-Telemetry-Source': 'kubb-cli',\n },\n body: JSON.stringify(buildOtlpPayload(event)),\n signal: AbortSignal.timeout(5_000),\n })\n } catch (_e) {\n // Fail silently – telemetry must never break the CLI\n }\n })\n}\n\n/**\n * Build an anonymous telemetry payload from a completed generation run.\n * No file paths, OpenAPI specs, or secrets are included.\n */\nexport function buildTelemetryEvent(options: {\n command: 'generate' | 'mcp' | 'validate' | 'agent'\n kubbVersion: string\n plugins?: TelemetryPlugin[]\n hrStart: [number, number]\n filesCreated?: number\n status: 'success' | 'failed'\n}): TelemetryEvent {\n const [seconds, nanoseconds] = process.hrtime(options.hrStart)\n const duration = Math.round(seconds * 1000 + nanoseconds / 1e6)\n\n return {\n command: options.command,\n kubbVersion: options.kubbVersion,\n nodeVersion: process.versions.node.split('.')[0] as string,\n platform: os.platform(),\n ci: isCi(),\n plugins: options.plugins ?? [],\n duration,\n filesCreated: options.filesCreated ?? 0,\n status: options.status,\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"types-CLtz0jem.js","names":[],"sources":["../src/cli/types.ts"],"sourcesContent":["type BaseOption = {\n /** Single-character short alias, e.g. `'c'` for `--config`. */\n short?: string\n description: string\n hint?: string\n required?: boolean\n /** Allowed values for string options. Used in help output and AI/MCP tool schemas. */\n enum?: string[]\n}\n\nexport type StringOption = BaseOption & { type: 'string'; default?: string }\nexport type BooleanOption = BaseOption & { type: 'boolean'; default?: boolean }\nexport type OptionDefinition = StringOption | BooleanOption\nexport type OptionType = OptionDefinition['type']\n\ntype OptionTypeMap = { string: string; boolean: boolean }\n\ntype IsRequired<O extends OptionDefinition> = O['default'] extends string | boolean ? true : O['required'] extends true ? true : false\n\n/** Infers typed values from an options record. Options with a `default` or `required: true` are always defined. */\ntype InferValues<O extends Record<string, OptionDefinition>> = {\n [K in keyof O as IsRequired<O[K]> extends true ? K : never]: OptionTypeMap[O[K]['type']]\n} & {\n [K in keyof O as IsRequired<O[K]> extends true ? never : K]?: OptionTypeMap[O[K]['type']]\n}\n\nexport type ParsedArgs = {\n values: Record<string, string | boolean | undefined>\n positionals: string[]\n}\n\nexport type CommandDefinition = {\n name: string\n description: string\n /** Positional argument labels shown in usage line, e.g. `['[input]']`. */\n arguments?: string[]\n options?: Record<string, OptionDefinition>\n subCommands?: CommandDefinition[]\n run?: (args: ParsedArgs) => Promise<void>\n}\n\n/**\n * Returns a `CommandDefinition` with typed `values` in `run()`.\n * The callback receives `values` typed from the declared options — no casts needed.\n */\nexport function defineCommand<O extends Record<string, OptionDefinition>>(def: {\n name: string\n description: string\n arguments?: string[]\n options?: O\n subCommands?: CommandDefinition[]\n run?: (args: { values: InferValues<O>; positionals: string[] }) => Promise<void>\n}): CommandDefinition {\n const { run, ...rest } = def\n if (!run) return rest\n return {\n ...rest,\n run: (args) => run({ values: args.values as InferValues<O>, positionals: args.positionals }),\n }\n}\n\nexport type RunOptions = {\n programName: string\n defaultCommandName: string\n version: string\n}\n\nexport type CLIAdapter = {\n run(commands: CommandDefinition[], argv: string[], opts: RunOptions): Promise<void>\n renderHelp(def: CommandDefinition, parentName?: string): void\n}\n\n/** Returns a `CLIAdapter` with type inference. Pass a different adapter to `createCLI` to swap the CLI engine. */\nexport function defineCLIAdapter(adapter: CLIAdapter): CLIAdapter {\n return adapter\n}\n\nexport type OptionSchema = {\n name: string\n flags: string\n type: OptionType\n description: string\n default?: string | boolean\n hint?: string\n required?: boolean\n enum?: string[]\n}\n\nexport type CommandSchema = {\n name: string\n description: string\n arguments?: string[]\n options: OptionSchema[]\n subCommands: CommandSchema[]\n}\n"],"mappings":";;;;;;AA6CA,SAAgB,cAA0D,KAOpD;CACpB,MAAM,EAAE,KAAK,GAAG,SAAS;AACzB,KAAI,CAAC,IAAK,QAAO;AACjB,QAAO;EACL,GAAG;EACH,MAAM,SAAS,IAAI;GAAE,QAAQ,KAAK;GAA0B,aAAa,KAAK;GAAa,CAAC;EAC7F;;;AAeH,SAAgB,iBAAiB,SAAiC;AAChE,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"types-Ck2lzFON.cjs","names":[],"sources":["../src/cli/types.ts"],"sourcesContent":["type BaseOption = {\n /** Single-character short alias, e.g. `'c'` for `--config`. */\n short?: string\n description: string\n hint?: string\n required?: boolean\n /** Allowed values for string options. Used in help output and AI/MCP tool schemas. */\n enum?: string[]\n}\n\nexport type StringOption = BaseOption & { type: 'string'; default?: string }\nexport type BooleanOption = BaseOption & { type: 'boolean'; default?: boolean }\nexport type OptionDefinition = StringOption | BooleanOption\nexport type OptionType = OptionDefinition['type']\n\ntype OptionTypeMap = { string: string; boolean: boolean }\n\ntype IsRequired<O extends OptionDefinition> = O['default'] extends string | boolean ? true : O['required'] extends true ? true : false\n\n/** Infers typed values from an options record. Options with a `default` or `required: true` are always defined. */\ntype InferValues<O extends Record<string, OptionDefinition>> = {\n [K in keyof O as IsRequired<O[K]> extends true ? K : never]: OptionTypeMap[O[K]['type']]\n} & {\n [K in keyof O as IsRequired<O[K]> extends true ? never : K]?: OptionTypeMap[O[K]['type']]\n}\n\nexport type ParsedArgs = {\n values: Record<string, string | boolean | undefined>\n positionals: string[]\n}\n\nexport type CommandDefinition = {\n name: string\n description: string\n /** Positional argument labels shown in usage line, e.g. `['[input]']`. */\n arguments?: string[]\n options?: Record<string, OptionDefinition>\n subCommands?: CommandDefinition[]\n run?: (args: ParsedArgs) => Promise<void>\n}\n\n/**\n * Returns a `CommandDefinition` with typed `values` in `run()`.\n * The callback receives `values` typed from the declared options — no casts needed.\n */\nexport function defineCommand<O extends Record<string, OptionDefinition>>(def: {\n name: string\n description: string\n arguments?: string[]\n options?: O\n subCommands?: CommandDefinition[]\n run?: (args: { values: InferValues<O>; positionals: string[] }) => Promise<void>\n}): CommandDefinition {\n const { run, ...rest } = def\n if (!run) return rest\n return {\n ...rest,\n run: (args) => run({ values: args.values as InferValues<O>, positionals: args.positionals }),\n }\n}\n\nexport type RunOptions = {\n programName: string\n defaultCommandName: string\n version: string\n}\n\nexport type CLIAdapter = {\n run(commands: CommandDefinition[], argv: string[], opts: RunOptions): Promise<void>\n renderHelp(def: CommandDefinition, parentName?: string): void\n}\n\n/** Returns a `CLIAdapter` with type inference. Pass a different adapter to `createCLI` to swap the CLI engine. */\nexport function defineCLIAdapter(adapter: CLIAdapter): CLIAdapter {\n return adapter\n}\n\nexport type OptionSchema = {\n name: string\n flags: string\n type: OptionType\n description: string\n default?: string | boolean\n hint?: string\n required?: boolean\n enum?: string[]\n}\n\nexport type CommandSchema = {\n name: string\n description: string\n arguments?: string[]\n options: OptionSchema[]\n subCommands: CommandSchema[]\n}\n"],"mappings":";;;;;;AA6CA,SAAgB,cAA0D,KAOpD;CACpB,MAAM,EAAE,KAAK,GAAG,SAAS;AACzB,KAAI,CAAC,IAAK,QAAO;AACjB,QAAO;EACL,GAAG;EACH,MAAM,SAAS,IAAI;GAAE,QAAQ,KAAK;GAA0B,aAAa,KAAK;GAAa,CAAC;EAC7F;;;AAeH,SAAgB,iBAAiB,SAAiC;AAChE,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"validate-Chjg23AE.js","names":[],"sources":["../src/runners/validate.ts"],"sourcesContent":["import process from 'node:process'\nimport type * as OasModule from '@kubb/oas'\nimport { getErrorMessage } from '../utils/errors.ts'\nimport { jiti } from '../utils/jiti.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\n\ntype ValidateOptions = {\n input: string\n version: string\n}\n\nexport async function runValidate({ input, version }: ValidateOptions): Promise<void> {\n let mod: typeof OasModule\n try {\n mod = (await jiti.import('@kubb/oas', { default: true })) as typeof OasModule\n } catch (_e) {\n console.error(`Import of '@kubb/oas' is required to do validation`)\n process.exit(1)\n }\n\n const { parse } = mod\n const hrStart = process.hrtime()\n try {\n const oas = await parse(input)\n await oas.validate()\n\n await sendTelemetry(buildTelemetryEvent({ command: 'validate', kubbVersion: version, hrStart, status: 'success' }))\n console.log('✅ Validation success')\n } catch (error) {\n await sendTelemetry(buildTelemetryEvent({ command: 'validate', kubbVersion: version, hrStart, status: 'failed' }))\n console.error('❌ Validation failed')\n console.error(getErrorMessage(error))\n process.exit(1)\n }\n}\n"],"mappings":";;;;;;AAWA,eAAsB,YAAY,EAAE,OAAO,WAA2C;CACpF,IAAI;AACJ,KAAI;AACF,QAAO,MAAM,KAAK,OAAO,aAAa,EAAE,SAAS,MAAM,CAAC;UACjD,IAAI;AACX,UAAQ,MAAM,qDAAqD;AACnE,UAAQ,KAAK,EAAE;;CAGjB,MAAM,EAAE,UAAU;CAClB,MAAM,UAAU,QAAQ,QAAQ;AAChC,KAAI;AAEF,SADY,MAAM,MAAM,MAAM,EACpB,UAAU;AAEpB,QAAM,cAAc,oBAAoB;GAAE,SAAS;GAAY,aAAa;GAAS;GAAS,QAAQ;GAAW,CAAC,CAAC;AACnH,UAAQ,IAAI,uBAAuB;UAC5B,OAAO;AACd,QAAM,cAAc,oBAAoB;GAAE,SAAS;GAAY,aAAa;GAAS;GAAS,QAAQ;GAAU,CAAC,CAAC;AAClH,UAAQ,MAAM,sBAAsB;AACpC,UAAQ,MAAM,gBAAgB,MAAM,CAAC;AACrC,UAAQ,KAAK,EAAE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"validate-Cr26q5xX.js","names":[],"sources":["../src/commands/validate.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'validate',\n description: 'Validate a Swagger/OpenAPI file',\n options: {\n input: { type: 'string', description: 'Path to Swagger/OpenAPI file', short: 'i', required: true },\n },\n async run({ values }) {\n const { runValidate } = await import('../runners/validate.ts')\n\n await runValidate({ input: values.input, version })\n },\n})\n"],"mappings":";;;;AAGA,MAAa,UAAU,cAAc;CACnC,MAAM;CACN,aAAa;CACb,SAAS,EACP,OAAO;EAAE,MAAM;EAAU,aAAa;EAAgC,OAAO;EAAK,UAAU;EAAM,EACnG;CACD,MAAM,IAAI,EAAE,UAAU;EACpB,MAAM,EAAE,gBAAgB,MAAM,OAAO;AAErC,QAAM,YAAY;GAAE,OAAO,OAAO;GAAO;GAAS,CAAC;;CAEtD,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"validate-DURmg-2Q.cjs","names":["defineCommand"],"sources":["../src/commands/validate.ts"],"sourcesContent":["import { version } from '../../package.json'\nimport { defineCommand } from '../cli/index.ts'\n\nexport const command = defineCommand({\n name: 'validate',\n description: 'Validate a Swagger/OpenAPI file',\n options: {\n input: { type: 'string', description: 'Path to Swagger/OpenAPI file', short: 'i', required: true },\n },\n async run({ values }) {\n const { runValidate } = await import('../runners/validate.ts')\n\n await runValidate({ input: values.input, version })\n },\n})\n"],"mappings":";;;AAGA,MAAa,0CAAUA,cAAc;CACnC,MAAM;CACN,aAAa;CACb,SAAS,EACP,OAAO;EAAE,MAAM;EAAU,aAAa;EAAgC,OAAO;EAAK,UAAU;EAAM,EACnG;CACD,MAAM,IAAI,EAAE,UAAU;EACpB,MAAM,EAAE,gBAAgB,MAAA,QAAA,SAAA,CAAA,WAAA,QAAM,0BAAA,CAAA;AAE9B,QAAM,YAAY;GAAE,OAAO,OAAO;GAAO,SAAA,gBAAA;GAAS,CAAC;;CAEtD,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"validate-Dqi9T_c4.cjs","names":["jiti","process","sendTelemetry","buildTelemetryEvent","getErrorMessage"],"sources":["../src/runners/validate.ts"],"sourcesContent":["import process from 'node:process'\nimport type * as OasModule from '@kubb/oas'\nimport { getErrorMessage } from '../utils/errors.ts'\nimport { jiti } from '../utils/jiti.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\n\ntype ValidateOptions = {\n input: string\n version: string\n}\n\nexport async function runValidate({ input, version }: ValidateOptions): Promise<void> {\n let mod: typeof OasModule\n try {\n mod = (await jiti.import('@kubb/oas', { default: true })) as typeof OasModule\n } catch (_e) {\n console.error(`Import of '@kubb/oas' is required to do validation`)\n process.exit(1)\n }\n\n const { parse } = mod\n const hrStart = process.hrtime()\n try {\n const oas = await parse(input)\n await oas.validate()\n\n await sendTelemetry(buildTelemetryEvent({ command: 'validate', kubbVersion: version, hrStart, status: 'success' }))\n console.log('✅ Validation success')\n } catch (error) {\n await sendTelemetry(buildTelemetryEvent({ command: 'validate', kubbVersion: version, hrStart, status: 'failed' }))\n console.error('❌ Validation failed')\n console.error(getErrorMessage(error))\n process.exit(1)\n }\n}\n"],"mappings":";;;;;;;AAWA,eAAsB,YAAY,EAAE,OAAO,WAA2C;CACpF,IAAI;AACJ,KAAI;AACF,QAAO,MAAMA,aAAAA,KAAK,OAAO,aAAa,EAAE,SAAS,MAAM,CAAC;UACjD,IAAI;AACX,UAAQ,MAAM,qDAAqD;AACnE,eAAA,QAAQ,KAAK,EAAE;;CAGjB,MAAM,EAAE,UAAU;CAClB,MAAM,UAAUC,aAAAA,QAAQ,QAAQ;AAChC,KAAI;AAEF,SADY,MAAM,MAAM,MAAM,EACpB,UAAU;AAEpB,QAAMC,kBAAAA,cAAcC,kBAAAA,oBAAoB;GAAE,SAAS;GAAY,aAAa;GAAS;GAAS,QAAQ;GAAW,CAAC,CAAC;AACnH,UAAQ,IAAI,uBAAuB;UAC5B,OAAO;AACd,QAAMD,kBAAAA,cAAcC,kBAAAA,oBAAoB;GAAE,SAAS;GAAY,aAAa;GAAS;GAAS,QAAQ;GAAU,CAAC,CAAC;AAClH,UAAQ,MAAM,sBAAsB;AACpC,UAAQ,MAAMC,eAAAA,gBAAgB,MAAM,CAAC;AACrC,eAAA,QAAQ,KAAK,EAAE"}