@brainfish-ai/devdoc 0.1.45 → 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.
- package/README.md +45 -2
- package/dist/cli/commands/create.js +25 -8
- package/dist/cli/commands/sdk.d.ts +30 -0
- package/dist/cli/commands/sdk.js +365 -0
- package/dist/cli/index.js +28 -1
- package/dist/sdk/index.d.ts +126 -0
- package/dist/sdk/index.js +871 -0
- package/package.json +7 -3
- package/renderer/app/api/collections/route.js +38 -9
- package/renderer/components/docs-viewer/agent/agent-chat.js +146 -109
- package/renderer/components/docs-viewer/index.js +21 -3
|
@@ -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>;
|