@brainfish-ai/devdoc 0.1.44 → 0.1.46

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.
@@ -0,0 +1,365 @@
1
+ "use strict";
2
+ /**
3
+ * SDK Generation CLI Commands
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.sdkInit = sdkInit;
43
+ exports.sdkGenerate = sdkGenerate;
44
+ exports.sdkValidate = sdkValidate;
45
+ exports.sdkList = sdkList;
46
+ const path_1 = __importDefault(require("path"));
47
+ const fs_extra_1 = __importDefault(require("fs-extra"));
48
+ const logger_1 = require("../../utils/logger");
49
+ const sdk_1 = require("../../sdk");
50
+ // Simple prompt helper
51
+ async function prompt(question, defaultValue) {
52
+ const readline = await Promise.resolve().then(() => __importStar(require('readline')));
53
+ const rl = readline.createInterface({
54
+ input: process.stdin,
55
+ output: process.stdout,
56
+ });
57
+ return new Promise((resolve) => {
58
+ const displayQuestion = defaultValue
59
+ ? `${question} (${defaultValue}): `
60
+ : `${question}: `;
61
+ rl.question(displayQuestion, (answer) => {
62
+ rl.close();
63
+ resolve(answer.trim() || defaultValue || '');
64
+ });
65
+ });
66
+ }
67
+ async function promptMultiSelect(question, choices) {
68
+ console.log(`\n${question}\n`);
69
+ choices.forEach((choice, i) => {
70
+ const marker = choice.checked ? '[x]' : '[ ]';
71
+ console.log(` ${i + 1}. ${marker} ${choice.label}`);
72
+ });
73
+ console.log();
74
+ console.log('Enter numbers separated by commas (e.g., 1,2,3):');
75
+ const readline = await Promise.resolve().then(() => __importStar(require('readline')));
76
+ const rl = readline.createInterface({
77
+ input: process.stdin,
78
+ output: process.stdout,
79
+ });
80
+ return new Promise((resolve) => {
81
+ rl.question('> ', (answer) => {
82
+ rl.close();
83
+ if (!answer.trim()) {
84
+ // Return defaults
85
+ resolve(choices.filter((c) => c.checked).map((c) => c.value));
86
+ return;
87
+ }
88
+ const indices = answer
89
+ .split(',')
90
+ .map((s) => parseInt(s.trim(), 10) - 1)
91
+ .filter((i) => i >= 0 && i < choices.length);
92
+ resolve(indices.map((i) => choices[i].value));
93
+ });
94
+ });
95
+ }
96
+ /**
97
+ * Initialize SDK configuration
98
+ */
99
+ async function sdkInit(options) {
100
+ console.log();
101
+ logger_1.logger.info('🔧 Initialize SDK Generation');
102
+ console.log();
103
+ const projectRoot = process.cwd();
104
+ // Find OpenAPI spec if not provided
105
+ let openapiPath = options.openapi;
106
+ if (!openapiPath) {
107
+ // Look for common OpenAPI spec locations
108
+ const commonPaths = [
109
+ 'openapi.json',
110
+ 'openapi.yaml',
111
+ 'openapi.yml',
112
+ 'api-reference/openapi.json',
113
+ 'api-reference/openapi.yaml',
114
+ 'api-reference/openapi.yml',
115
+ 'docs/openapi.json',
116
+ 'spec/openapi.json',
117
+ ];
118
+ for (const p of commonPaths) {
119
+ if (await fs_extra_1.default.pathExists(path_1.default.join(projectRoot, p))) {
120
+ openapiPath = p;
121
+ logger_1.logger.info(`Found OpenAPI spec at: ${p}`);
122
+ break;
123
+ }
124
+ }
125
+ if (!openapiPath) {
126
+ openapiPath = await prompt('Path to OpenAPI specification', './openapi.json');
127
+ }
128
+ }
129
+ // Validate spec exists
130
+ const fullSpecPath = path_1.default.resolve(projectRoot, openapiPath);
131
+ if (!(await fs_extra_1.default.pathExists(fullSpecPath))) {
132
+ logger_1.logger.error(`OpenAPI specification not found: ${openapiPath}`);
133
+ process.exit(1);
134
+ }
135
+ // Get package name
136
+ let packageName = options.packageName;
137
+ if (!packageName) {
138
+ // Try to get from docs.json or package.json
139
+ const docsJsonPath = path_1.default.join(projectRoot, 'docs.json');
140
+ const pkgJsonPath = path_1.default.join(projectRoot, 'package.json');
141
+ if (await fs_extra_1.default.pathExists(docsJsonPath)) {
142
+ const docsJson = await fs_extra_1.default.readJson(docsJsonPath);
143
+ packageName = docsJson.name?.toLowerCase().replace(/\s+/g, '-');
144
+ }
145
+ else if (await fs_extra_1.default.pathExists(pkgJsonPath)) {
146
+ const pkgJson = await fs_extra_1.default.readJson(pkgJsonPath);
147
+ packageName = pkgJson.name;
148
+ }
149
+ packageName = await prompt('Base package name', packageName || 'api-sdk');
150
+ }
151
+ // Select languages
152
+ const generators = (0, sdk_1.getGeneratorInfo)();
153
+ const languageChoices = generators.map((g) => ({
154
+ value: g.language,
155
+ label: `${g.displayName}${g.native ? ' (recommended)' : g.requiresJava ? ' (requires Java)' : ''}`,
156
+ checked: g.language === 'typescript' || g.language === 'python',
157
+ }));
158
+ const selectedLanguages = (await promptMultiSelect('Select languages to generate:', languageChoices));
159
+ if (selectedLanguages.length === 0) {
160
+ logger_1.logger.error('At least one language must be selected');
161
+ process.exit(1);
162
+ }
163
+ // Create configuration
164
+ try {
165
+ const { configPath, config } = await (0, sdk_1.initSDKConfig)(projectRoot, {
166
+ openapi: openapiPath,
167
+ packageName,
168
+ languages: selectedLanguages,
169
+ force: options.force,
170
+ });
171
+ console.log();
172
+ logger_1.logger.success(`Created ${path_1.default.basename(configPath)}`);
173
+ console.log();
174
+ console.log('Configuration:');
175
+ console.log(` OpenAPI spec: ${config.openapi}`);
176
+ console.log(` Package name: ${config.packageName}`);
177
+ console.log(` Languages: ${selectedLanguages.join(', ')}`);
178
+ console.log(` Output: ${config.output}`);
179
+ console.log();
180
+ console.log('Next steps:');
181
+ console.log(" Run 'devdoc sdk generate' to generate SDKs");
182
+ console.log(" Run 'devdoc sdk generate --preview' to preview without overwriting");
183
+ console.log();
184
+ }
185
+ catch (error) {
186
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
187
+ process.exit(1);
188
+ }
189
+ }
190
+ /**
191
+ * Generate SDKs
192
+ */
193
+ async function sdkGenerate(options) {
194
+ console.log();
195
+ logger_1.logger.info('📦 Generate SDKs');
196
+ console.log();
197
+ const projectRoot = process.cwd();
198
+ // Validate language option if provided
199
+ if (options.lang && !sdk_1.SUPPORTED_LANGUAGES.includes(options.lang)) {
200
+ logger_1.logger.error(`Unsupported language: ${options.lang}`);
201
+ console.log();
202
+ console.log('Supported languages:');
203
+ sdk_1.SUPPORTED_LANGUAGES.forEach((lang) => {
204
+ console.log(` - ${lang}`);
205
+ });
206
+ process.exit(1);
207
+ }
208
+ try {
209
+ // Check if config exists
210
+ const { config, error } = await (0, sdk_1.loadSDKConfig)(projectRoot);
211
+ if (!config) {
212
+ logger_1.logger.error(error || 'SDK configuration not found');
213
+ console.log();
214
+ console.log("Run 'devdoc sdk init' to create a configuration");
215
+ process.exit(1);
216
+ }
217
+ // Validate spec first
218
+ const specPath = (0, sdk_1.resolveSpecPath)(projectRoot, config.openapi);
219
+ logger_1.logger.info('Validating OpenAPI spec...');
220
+ const validation = await (0, sdk_1.validateSpec)(specPath);
221
+ if (!validation.valid) {
222
+ logger_1.logger.error('OpenAPI specification is invalid:');
223
+ validation.errors.forEach((err) => console.log(` - ${err}`));
224
+ process.exit(1);
225
+ }
226
+ if (validation.warnings.length > 0) {
227
+ validation.warnings.forEach((warn) => logger_1.logger.warn(warn));
228
+ }
229
+ logger_1.logger.success('OpenAPI spec is valid');
230
+ console.log();
231
+ // Generate SDKs
232
+ logger_1.logger.info('Generating SDKs...');
233
+ console.log();
234
+ const result = await (0, sdk_1.generateSDKs)(projectRoot, {
235
+ language: options.lang,
236
+ preview: options.preview,
237
+ outputDir: options.output,
238
+ });
239
+ // Display results
240
+ for (const r of result.results) {
241
+ const generator = (0, sdk_1.getGeneratorInfo)().find((g) => g.language === r.language);
242
+ const displayName = generator?.displayName || r.language;
243
+ if (r.success) {
244
+ const relPath = path_1.default.relative(projectRoot, r.outputPath);
245
+ logger_1.logger.success(`${displayName.padEnd(12)} ./${relPath.padEnd(25)} ${(r.duration / 1000).toFixed(1)}s`);
246
+ }
247
+ else {
248
+ logger_1.logger.error(`${displayName.padEnd(12)} Failed: ${r.error}`);
249
+ }
250
+ }
251
+ console.log();
252
+ if (result.failureCount > 0) {
253
+ logger_1.logger.warn(`Generated ${result.successCount} SDK(s), ${result.failureCount} failed`);
254
+ }
255
+ else {
256
+ logger_1.logger.success(`Generated ${result.successCount} SDK(s) in ${(result.totalDuration / 1000).toFixed(1)}s`);
257
+ }
258
+ // Show next steps
259
+ if (result.successCount > 0) {
260
+ console.log();
261
+ console.log('Next steps:');
262
+ for (const r of result.results.filter((r) => r.success)) {
263
+ const relPath = path_1.default.relative(projectRoot, r.outputPath);
264
+ switch (r.language) {
265
+ case 'typescript':
266
+ console.log(` cd ${relPath} && npm install`);
267
+ break;
268
+ case 'python':
269
+ console.log(` cd ${relPath} && pip install -e .`);
270
+ break;
271
+ case 'go':
272
+ console.log(` # Import from ${relPath}`);
273
+ break;
274
+ default:
275
+ console.log(` # See ${relPath}/README.md`);
276
+ }
277
+ }
278
+ console.log();
279
+ }
280
+ }
281
+ catch (error) {
282
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
283
+ process.exit(1);
284
+ }
285
+ }
286
+ /**
287
+ * Validate OpenAPI specification
288
+ */
289
+ async function sdkValidate(specPath) {
290
+ console.log();
291
+ logger_1.logger.info('🔍 Validate OpenAPI Specification');
292
+ console.log();
293
+ const projectRoot = process.cwd();
294
+ // Get spec path from config if not provided
295
+ if (!specPath) {
296
+ const { config } = await (0, sdk_1.loadSDKConfig)(projectRoot);
297
+ if (config) {
298
+ specPath = config.openapi;
299
+ }
300
+ else {
301
+ logger_1.logger.error('No spec path provided and no sdk.json found');
302
+ process.exit(1);
303
+ }
304
+ }
305
+ const fullPath = (0, sdk_1.resolveSpecPath)(projectRoot, specPath);
306
+ logger_1.logger.info(`Validating: ${specPath}`);
307
+ console.log();
308
+ const result = await (0, sdk_1.validateSpec)(fullPath);
309
+ if (result.errors.length > 0) {
310
+ logger_1.logger.error('Errors:');
311
+ result.errors.forEach((err) => console.log(` ✗ ${err}`));
312
+ console.log();
313
+ }
314
+ if (result.warnings.length > 0) {
315
+ logger_1.logger.warn('Warnings:');
316
+ result.warnings.forEach((warn) => console.log(` ⚠ ${warn}`));
317
+ console.log();
318
+ }
319
+ if (result.valid) {
320
+ logger_1.logger.success('Specification is valid');
321
+ }
322
+ else {
323
+ logger_1.logger.error('Specification is invalid');
324
+ process.exit(1);
325
+ }
326
+ }
327
+ /**
328
+ * List available generators and their status
329
+ */
330
+ async function sdkList() {
331
+ console.log();
332
+ logger_1.logger.info('📋 SDK Generators');
333
+ console.log();
334
+ const projectRoot = process.cwd();
335
+ const { config } = await (0, sdk_1.loadSDKConfig)(projectRoot);
336
+ const enabledLanguages = config ? (0, sdk_1.getEnabledGenerators)(config) : [];
337
+ const generators = (0, sdk_1.getGeneratorInfo)();
338
+ console.log('Available generators:\n');
339
+ // Native generators (no Java required)
340
+ console.log('Native (no Java required):');
341
+ for (const g of generators.filter((g) => g.native)) {
342
+ const enabled = enabledLanguages.includes(g.language);
343
+ const status = enabled ? logger_1.logger.green('enabled') : logger_1.logger.yellow('disabled');
344
+ console.log(` ${g.displayName.padEnd(12)} ${status}`);
345
+ }
346
+ console.log();
347
+ // Java-based generators
348
+ console.log('OpenAPI Generator (requires Java):');
349
+ for (const g of generators.filter((g) => g.requiresJava)) {
350
+ const enabled = enabledLanguages.includes(g.language);
351
+ const status = enabled ? logger_1.logger.green('enabled') : logger_1.logger.yellow('disabled');
352
+ console.log(` ${g.displayName.padEnd(12)} ${status}`);
353
+ }
354
+ console.log();
355
+ if (!config) {
356
+ console.log("No sdk.json found. Run 'devdoc sdk init' to configure generators.");
357
+ }
358
+ else {
359
+ console.log(`Configuration: sdk.json`);
360
+ console.log(`OpenAPI spec: ${config.openapi}`);
361
+ console.log(`Enabled: ${enabledLanguages.join(', ') || 'none'}`);
362
+ }
363
+ console.log();
364
+ }
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sdk.js","sourceRoot":"","sources":["../../../src/cli/commands/sdk.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SDK Generation CLI Commands\n */\n\nimport path from 'path';\nimport fs from 'fs-extra';\nimport { logger } from '../../utils/logger';\nimport {\n  generateSDKs,\n  validateSpec,\n  initSDKConfig,\n  loadSDKConfig,\n  getEnabledGenerators,\n  getGeneratorInfo,\n  resolveSpecPath,\n  isNativeGenerator,\n  SDKLanguage,\n  SUPPORTED_LANGUAGES,\n} from '../../sdk';\n\n// Simple prompt helper\nasync function prompt(question: string, defaultValue?: string): Promise<string> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const displayQuestion = defaultValue\n      ? `${question} (${defaultValue}): `\n      : `${question}: `;\n\n    rl.question(displayQuestion, (answer) => {\n      rl.close();\n      resolve(answer.trim() || defaultValue || '');\n    });\n  });\n}\n\nasync function promptMultiSelect(\n  question: string,\n  choices: { value: string; label: string; checked?: boolean }[]\n): Promise<string[]> {\n  console.log(`\\n${question}\\n`);\n  choices.forEach((choice, i) => {\n    const marker = choice.checked ? '[x]' : '[ ]';\n    console.log(`  ${i + 1}. ${marker} ${choice.label}`);\n  });\n  console.log();\n  console.log('Enter numbers separated by commas (e.g., 1,2,3):');\n\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    rl.question('> ', (answer) => {\n      rl.close();\n      if (!answer.trim()) {\n        // Return defaults\n        resolve(choices.filter((c) => c.checked).map((c) => c.value));\n        return;\n      }\n\n      const indices = answer\n        .split(',')\n        .map((s) => parseInt(s.trim(), 10) - 1)\n        .filter((i) => i >= 0 && i < choices.length);\n\n      resolve(indices.map((i) => choices[i].value));\n    });\n  });\n}\n\ninterface SDKInitOptions {\n  openapi?: string;\n  packageName?: string;\n  force?: boolean;\n}\n\n/**\n * Initialize SDK configuration\n */\nexport async function sdkInit(options: SDKInitOptions): Promise<void> {\n  console.log();\n  logger.info('🔧 Initialize SDK Generation');\n  console.log();\n\n  const projectRoot = process.cwd();\n\n  // Find OpenAPI spec if not provided\n  let openapiPath = options.openapi;\n\n  if (!openapiPath) {\n    // Look for common OpenAPI spec locations\n    const commonPaths = [\n      'openapi.json',\n      'openapi.yaml',\n      'openapi.yml',\n      'api-reference/openapi.json',\n      'api-reference/openapi.yaml',\n      'api-reference/openapi.yml',\n      'docs/openapi.json',\n      'spec/openapi.json',\n    ];\n\n    for (const p of commonPaths) {\n      if (await fs.pathExists(path.join(projectRoot, p))) {\n        openapiPath = p;\n        logger.info(`Found OpenAPI spec at: ${p}`);\n        break;\n      }\n    }\n\n    if (!openapiPath) {\n      openapiPath = await prompt('Path to OpenAPI specification', './openapi.json');\n    }\n  }\n\n  // Validate spec exists\n  const fullSpecPath = path.resolve(projectRoot, openapiPath);\n  if (!(await fs.pathExists(fullSpecPath))) {\n    logger.error(`OpenAPI specification not found: ${openapiPath}`);\n    process.exit(1);\n  }\n\n  // Get package name\n  let packageName = options.packageName;\n  if (!packageName) {\n    // Try to get from docs.json or package.json\n    const docsJsonPath = path.join(projectRoot, 'docs.json');\n    const pkgJsonPath = path.join(projectRoot, 'package.json');\n\n    if (await fs.pathExists(docsJsonPath)) {\n      const docsJson = await fs.readJson(docsJsonPath);\n      packageName = docsJson.name?.toLowerCase().replace(/\\s+/g, '-');\n    } else if (await fs.pathExists(pkgJsonPath)) {\n      const pkgJson = await fs.readJson(pkgJsonPath);\n      packageName = pkgJson.name;\n    }\n\n    packageName = await prompt('Base package name', packageName || 'api-sdk');\n  }\n\n  // Select languages\n  const generators = getGeneratorInfo();\n  const languageChoices = generators.map((g) => ({\n    value: g.language,\n    label: `${g.displayName}${g.native ? ' (recommended)' : g.requiresJava ? ' (requires Java)' : ''}`,\n    checked: g.language === 'typescript' || g.language === 'python',\n  }));\n\n  const selectedLanguages = (await promptMultiSelect(\n    'Select languages to generate:',\n    languageChoices\n  )) as SDKLanguage[];\n\n  if (selectedLanguages.length === 0) {\n    logger.error('At least one language must be selected');\n    process.exit(1);\n  }\n\n  // Create configuration\n  try {\n    const { configPath, config } = await initSDKConfig(projectRoot, {\n      openapi: openapiPath,\n      packageName,\n      languages: selectedLanguages,\n      force: options.force,\n    });\n\n    console.log();\n    logger.success(`Created ${path.basename(configPath)}`);\n    console.log();\n    console.log('Configuration:');\n    console.log(`  OpenAPI spec: ${config.openapi}`);\n    console.log(`  Package name: ${config.packageName}`);\n    console.log(`  Languages: ${selectedLanguages.join(', ')}`);\n    console.log(`  Output: ${config.output}`);\n    console.log();\n    console.log('Next steps:');\n    console.log(\"  Run 'devdoc sdk generate' to generate SDKs\");\n    console.log(\"  Run 'devdoc sdk generate --preview' to preview without overwriting\");\n    console.log();\n  } catch (error) {\n    logger.error(error instanceof Error ? error.message : String(error));\n    process.exit(1);\n  }\n}\n\ninterface SDKGenerateOptions {\n  lang?: string;\n  preview?: boolean;\n  output?: string;\n}\n\n/**\n * Generate SDKs\n */\nexport async function sdkGenerate(options: SDKGenerateOptions): Promise<void> {\n  console.log();\n  logger.info('📦 Generate SDKs');\n  console.log();\n\n  const projectRoot = process.cwd();\n\n  // Validate language option if provided\n  if (options.lang && !SUPPORTED_LANGUAGES.includes(options.lang as SDKLanguage)) {\n    logger.error(`Unsupported language: ${options.lang}`);\n    console.log();\n    console.log('Supported languages:');\n    SUPPORTED_LANGUAGES.forEach((lang) => {\n      console.log(`  - ${lang}`);\n    });\n    process.exit(1);\n  }\n\n  try {\n    // Check if config exists\n    const { config, error } = await loadSDKConfig(projectRoot);\n\n    if (!config) {\n      logger.error(error || 'SDK configuration not found');\n      console.log();\n      console.log(\"Run 'devdoc sdk init' to create a configuration\");\n      process.exit(1);\n    }\n\n    // Validate spec first\n    const specPath = resolveSpecPath(projectRoot, config.openapi);\n    logger.info('Validating OpenAPI spec...');\n    \n    const validation = await validateSpec(specPath);\n    \n    if (!validation.valid) {\n      logger.error('OpenAPI specification is invalid:');\n      validation.errors.forEach((err) => console.log(`  - ${err}`));\n      process.exit(1);\n    }\n    \n    if (validation.warnings.length > 0) {\n      validation.warnings.forEach((warn) => logger.warn(warn));\n    }\n    \n    logger.success('OpenAPI spec is valid');\n    console.log();\n\n    // Generate SDKs\n    logger.info('Generating SDKs...');\n    console.log();\n\n    const result = await generateSDKs(projectRoot, {\n      language: options.lang as SDKLanguage | undefined,\n      preview: options.preview,\n      outputDir: options.output,\n    });\n\n    // Display results\n    for (const r of result.results) {\n      const generator = getGeneratorInfo().find((g) => g.language === r.language);\n      const displayName = generator?.displayName || r.language;\n\n      if (r.success) {\n        const relPath = path.relative(projectRoot, r.outputPath);\n        logger.success(`${displayName.padEnd(12)} ./${relPath.padEnd(25)} ${(r.duration / 1000).toFixed(1)}s`);\n      } else {\n        logger.error(`${displayName.padEnd(12)} Failed: ${r.error}`);\n      }\n    }\n\n    console.log();\n\n    if (result.failureCount > 0) {\n      logger.warn(`Generated ${result.successCount} SDK(s), ${result.failureCount} failed`);\n    } else {\n      logger.success(`Generated ${result.successCount} SDK(s) in ${(result.totalDuration / 1000).toFixed(1)}s`);\n    }\n\n    // Show next steps\n    if (result.successCount > 0) {\n      console.log();\n      console.log('Next steps:');\n      \n      for (const r of result.results.filter((r) => r.success)) {\n        const relPath = path.relative(projectRoot, r.outputPath);\n        \n        switch (r.language) {\n          case 'typescript':\n            console.log(`  cd ${relPath} && npm install`);\n            break;\n          case 'python':\n            console.log(`  cd ${relPath} && pip install -e .`);\n            break;\n          case 'go':\n            console.log(`  # Import from ${relPath}`);\n            break;\n          default:\n            console.log(`  # See ${relPath}/README.md`);\n        }\n      }\n      console.log();\n    }\n  } catch (error) {\n    logger.error(error instanceof Error ? error.message : String(error));\n    process.exit(1);\n  }\n}\n\n/**\n * Validate OpenAPI specification\n */\nexport async function sdkValidate(specPath?: string): Promise<void> {\n  console.log();\n  logger.info('🔍 Validate OpenAPI Specification');\n  console.log();\n\n  const projectRoot = process.cwd();\n\n  // Get spec path from config if not provided\n  if (!specPath) {\n    const { config } = await loadSDKConfig(projectRoot);\n    \n    if (config) {\n      specPath = config.openapi;\n    } else {\n      logger.error('No spec path provided and no sdk.json found');\n      process.exit(1);\n    }\n  }\n\n  const fullPath = resolveSpecPath(projectRoot, specPath);\n  logger.info(`Validating: ${specPath}`);\n  console.log();\n\n  const result = await validateSpec(fullPath);\n\n  if (result.errors.length > 0) {\n    logger.error('Errors:');\n    result.errors.forEach((err) => console.log(`  ✗ ${err}`));\n    console.log();\n  }\n\n  if (result.warnings.length > 0) {\n    logger.warn('Warnings:');\n    result.warnings.forEach((warn) => console.log(`  ⚠ ${warn}`));\n    console.log();\n  }\n\n  if (result.valid) {\n    logger.success('Specification is valid');\n  } else {\n    logger.error('Specification is invalid');\n    process.exit(1);\n  }\n}\n\n/**\n * List available generators and their status\n */\nexport async function sdkList(): Promise<void> {\n  console.log();\n  logger.info('📋 SDK Generators');\n  console.log();\n\n  const projectRoot = process.cwd();\n  const { config } = await loadSDKConfig(projectRoot);\n  const enabledLanguages = config ? getEnabledGenerators(config) : [];\n\n  const generators = getGeneratorInfo();\n\n  console.log('Available generators:\\n');\n\n  // Native generators (no Java required)\n  console.log('Native (no Java required):');\n  for (const g of generators.filter((g) => g.native)) {\n    const enabled = enabledLanguages.includes(g.language);\n    const status = enabled ? logger.green('enabled') : logger.yellow('disabled');\n    console.log(`  ${g.displayName.padEnd(12)} ${status}`);\n  }\n\n  console.log();\n\n  // Java-based generators\n  console.log('OpenAPI Generator (requires Java):');\n  for (const g of generators.filter((g) => g.requiresJava)) {\n    const enabled = enabledLanguages.includes(g.language);\n    const status = enabled ? logger.green('enabled') : logger.yellow('disabled');\n    console.log(`  ${g.displayName.padEnd(12)} ${status}`);\n  }\n\n  console.log();\n\n  if (!config) {\n    console.log(\"No sdk.json found. Run 'devdoc sdk init' to configure generators.\");\n  } else {\n    console.log(`Configuration: sdk.json`);\n    console.log(`OpenAPI spec: ${config.openapi}`);\n    console.log(`Enabled: ${enabledLanguages.join(', ') || 'none'}`);\n  }\n\n  console.log();\n}\n"]}
package/dist/cli/index.js CHANGED
@@ -13,6 +13,7 @@ const whoami_1 = require("./commands/whoami");
13
13
  const upload_1 = require("./commands/upload");
14
14
  const ai_1 = require("./commands/ai");
15
15
  const domain_1 = require("./commands/domain");
16
+ const sdk_1 = require("./commands/sdk");
16
17
  const packageJson = require('../../package.json');
17
18
  const program = new commander_1.Command();
18
19
  program
@@ -142,5 +143,31 @@ domainCmd
142
143
  .option('-u, --url <url>', 'API URL')
143
144
  .option('-k, --api-key <key>', 'API key for authentication')
144
145
  .action(domain_1.domainRemove);
146
+ // SDK generation
147
+ const sdkCmd = program
148
+ .command('sdk')
149
+ .description('Generate client SDKs from OpenAPI specification');
150
+ sdkCmd
151
+ .command('init')
152
+ .description('Initialize SDK generation configuration')
153
+ .option('-o, --openapi <path>', 'Path to OpenAPI specification')
154
+ .option('-n, --package-name <name>', 'Base package name for generated SDKs')
155
+ .option('-f, --force', 'Overwrite existing configuration')
156
+ .action(sdk_1.sdkInit);
157
+ sdkCmd
158
+ .command('generate')
159
+ .description('Generate SDKs for configured languages')
160
+ .option('-l, --lang <language>', 'Generate only for specific language')
161
+ .option('-p, --preview', 'Preview what would be generated without writing files')
162
+ .option('-o, --output <dir>', 'Override output directory')
163
+ .action(sdk_1.sdkGenerate);
164
+ sdkCmd
165
+ .command('validate [spec]')
166
+ .description('Validate OpenAPI specification')
167
+ .action(sdk_1.sdkValidate);
168
+ sdkCmd
169
+ .command('list')
170
+ .description('List available generators and their status')
171
+ .action(sdk_1.sdkList);
145
172
  program.parse(process.argv);
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\nimport { domainAdd, domainStatus, domainVerify, domainRemove } from './commands/domain';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-d, --doc-type <type>', 'Documentation type (public, internal)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up or update AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .option('--update', 'Update existing skills/rules to latest version')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\n// Domain management - custom domains (one per project, free)\nconst domainCmd = program\n  .command('domain')\n  .description('Manage custom domain for your documentation');\n\ndomainCmd\n  .command('add <custom-domain>')\n  .description('Add a custom domain (e.g., docs.example.com)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainAdd);\n\ndomainCmd\n  .command('status')\n  .description('Check custom domain status and DNS configuration')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainStatus);\n\ndomainCmd\n  .command('verify')\n  .description('Verify DNS configuration for your custom domain')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainVerify);\n\ndomainCmd\n  .command('remove [custom-domain]')\n  .description('Remove custom domain from project')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainRemove);\n\nprogram.parse(process.argv);\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\nimport { domainAdd, domainStatus, domainVerify, domainRemove } from './commands/domain';\nimport { sdkInit, sdkGenerate, sdkValidate, sdkList } from './commands/sdk';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-d, --doc-type <type>', 'Documentation type (public, internal)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up or update AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .option('--update', 'Update existing skills/rules to latest version')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\n// Domain management - custom domains (one per project, free)\nconst domainCmd = program\n  .command('domain')\n  .description('Manage custom domain for your documentation');\n\ndomainCmd\n  .command('add <custom-domain>')\n  .description('Add a custom domain (e.g., docs.example.com)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainAdd);\n\ndomainCmd\n  .command('status')\n  .description('Check custom domain status and DNS configuration')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainStatus);\n\ndomainCmd\n  .command('verify')\n  .description('Verify DNS configuration for your custom domain')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainVerify);\n\ndomainCmd\n  .command('remove [custom-domain]')\n  .description('Remove custom domain from project')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainRemove);\n\n// SDK generation\nconst sdkCmd = program\n  .command('sdk')\n  .description('Generate client SDKs from OpenAPI specification');\n\nsdkCmd\n  .command('init')\n  .description('Initialize SDK generation configuration')\n  .option('-o, --openapi <path>', 'Path to OpenAPI specification')\n  .option('-n, --package-name <name>', 'Base package name for generated SDKs')\n  .option('-f, --force', 'Overwrite existing configuration')\n  .action(sdkInit);\n\nsdkCmd\n  .command('generate')\n  .description('Generate SDKs for configured languages')\n  .option('-l, --lang <language>', 'Generate only for specific language')\n  .option('-p, --preview', 'Preview what would be generated without writing files')\n  .option('-o, --output <dir>', 'Override output directory')\n  .action(sdkGenerate);\n\nsdkCmd\n  .command('validate [spec]')\n  .description('Validate OpenAPI specification')\n  .action(sdkValidate);\n\nsdkCmd\n  .command('list')\n  .description('List available generators and their status')\n  .action(sdkList);\n\nprogram.parse(process.argv);\n"]}
@@ -0,0 +1,126 @@
1
+ /**
2
+ * SDK Generation Module
3
+ *
4
+ * This module provides functionality for generating client SDKs from OpenAPI specifications.
5
+ * It supports multiple languages using both native generators and OpenAPI Generator.
6
+ */
7
+ /**
8
+ * Supported SDK languages
9
+ */
10
+ export type SDKLanguage = 'typescript' | 'python' | 'go' | 'java' | 'csharp' | 'ruby' | 'php' | 'swift' | 'kotlin' | 'rust';
11
+ /**
12
+ * SDK configuration file (sdk.json)
13
+ */
14
+ export interface SDKConfig {
15
+ openapi: string;
16
+ packageName: string;
17
+ output: string;
18
+ languages: {
19
+ [key in SDKLanguage]?: LanguageConfig;
20
+ };
21
+ }
22
+ /**
23
+ * Language-specific configuration
24
+ */
25
+ export interface LanguageConfig {
26
+ enabled: boolean;
27
+ packageName?: string;
28
+ output?: string;
29
+ additionalOptions?: Record<string, string>;
30
+ }
31
+ /**
32
+ * Generator information
33
+ */
34
+ export interface GeneratorInfo {
35
+ language: SDKLanguage;
36
+ displayName: string;
37
+ native: boolean;
38
+ requiresJava: boolean;
39
+ generatorName?: string;
40
+ }
41
+ /**
42
+ * SDK generation result for a single language
43
+ */
44
+ export interface SDKGenerationResult {
45
+ language: SDKLanguage;
46
+ success: boolean;
47
+ outputPath: string;
48
+ error?: string;
49
+ duration: number;
50
+ }
51
+ /**
52
+ * Overall SDK generation result
53
+ */
54
+ export interface GenerateSDKsResult {
55
+ results: SDKGenerationResult[];
56
+ successCount: number;
57
+ failureCount: number;
58
+ totalDuration: number;
59
+ }
60
+ /**
61
+ * Validation result
62
+ */
63
+ export interface ValidationResult {
64
+ valid: boolean;
65
+ errors: string[];
66
+ warnings: string[];
67
+ }
68
+ /**
69
+ * Options for SDK generation
70
+ */
71
+ export interface GenerateOptions {
72
+ language?: SDKLanguage;
73
+ preview?: boolean;
74
+ outputDir?: string;
75
+ }
76
+ /**
77
+ * Options for SDK config initialization
78
+ */
79
+ export interface InitConfigOptions {
80
+ openapi: string;
81
+ packageName: string;
82
+ languages: SDKLanguage[];
83
+ force?: boolean;
84
+ }
85
+ /**
86
+ * All supported languages
87
+ */
88
+ export declare const SUPPORTED_LANGUAGES: SDKLanguage[];
89
+ /**
90
+ * Load SDK configuration from project directory
91
+ */
92
+ export declare function loadSDKConfig(projectRoot: string): Promise<{
93
+ config: SDKConfig | null;
94
+ error?: string;
95
+ }>;
96
+ /**
97
+ * Initialize SDK configuration
98
+ */
99
+ export declare function initSDKConfig(projectRoot: string, options: InitConfigOptions): Promise<{
100
+ configPath: string;
101
+ config: SDKConfig;
102
+ }>;
103
+ /**
104
+ * Get enabled generators from config
105
+ */
106
+ export declare function getEnabledGenerators(config: SDKConfig): SDKLanguage[];
107
+ /**
108
+ * Get generator information for all languages
109
+ */
110
+ export declare function getGeneratorInfo(): GeneratorInfo[];
111
+ /**
112
+ * Check if a generator is native (doesn't require Java)
113
+ */
114
+ export declare function isNativeGenerator(language: SDKLanguage): boolean;
115
+ /**
116
+ * Resolve OpenAPI spec path relative to project root
117
+ */
118
+ export declare function resolveSpecPath(projectRoot: string, specPath: string): string;
119
+ /**
120
+ * Validate an OpenAPI specification
121
+ */
122
+ export declare function validateSpec(specPath: string): Promise<ValidationResult>;
123
+ /**
124
+ * Generate SDKs for configured languages
125
+ */
126
+ export declare function generateSDKs(projectRoot: string, options?: GenerateOptions): Promise<GenerateSDKsResult>;