feat: add tag/endpoint selection mechanism

This commit is contained in:
2026-03-24 19:51:48 +01:00
parent a90f7ba078
commit b8d2fd8582
5 changed files with 144 additions and 6 deletions

23
main.ts
View File

@@ -10,10 +10,11 @@ import { checkOpenApiGenerator, installOpenApiGenerator } from './src/utils/open
import { createDirectoryStructure, cleanup } from './src/utils/filesystem';
import { analyzeSwagger } from './src/swagger/analyzer';
import { generateCode, organizeFiles, addDtoImports } from './src/generators/dto.generator';
import { generateCleanArchitecture, extractTagsFromAnalysis } from './src/generators/clean-arch.generator';
import { generateCleanArchitecture, extractTagsWithOperations } from './src/generators/clean-arch.generator';
import { generateReport } from './src/generators/report.generator';
import { findEnvironmentFile, parseApiKeys } from './src/utils/environment-finder';
import { askApiKeysForTags } from './src/utils/prompt';
import { askApiKeysForTags, askSelectionFilter } from './src/utils/prompt';
import type { SelectionFilter } from './src/types';
import type { CliOptions } from './src/types';
import packageJson from './package.json';
@@ -37,6 +38,7 @@ program
)
.option('--skip-install', 'No instalar dependencias')
.option('--dry-run', 'Simular sin generar archivos')
.option('-s, --select-endpoints', 'Seleccionar interactivamente qué tags y endpoints generar')
.parse(process.argv);
const options = program.opts<CliOptions>();
@@ -85,8 +87,19 @@ async function main(): Promise<void> {
createDirectoryStructure(options.output);
// ── SELECTION: tags and endpoints ─────────────────────────────────────────
const tagSummaries = extractTagsWithOperations(analysis);
let selectionFilter: SelectionFilter = {};
if (options.selectEndpoints) {
selectionFilter = await askSelectionFilter(tagSummaries);
}
const selectedTags = options.selectEndpoints
? Object.keys(selectionFilter)
: tagSummaries.map((t) => t.tag);
// ── ENVIRONMENT API KEY SELECTION ──────────────────────────────────────────
const tags = extractTagsFromAnalysis(analysis);
const envFile = findEnvironmentFile(process.cwd());
let apiKeys: ReturnType<typeof parseApiKeys> = [];
@@ -103,13 +116,13 @@ async function main(): Promise<void> {
logWarning('No se encontró environment.ts. Se solicitará la clave manualmente por repositorio.');
}
const tagApiKeyMap = await askApiKeysForTags(tags, apiKeys);
const tagApiKeyMap = await askApiKeysForTags(selectedTags, apiKeys);
// ──────────────────────────────────────────────────────────────────────────
const tempDir = generateCode(options.input, options.templates);
organizeFiles(tempDir, options.output);
addDtoImports(options.output);
generateCleanArchitecture(analysis, options.output, options.templates, tagApiKeyMap);
generateCleanArchitecture(analysis, options.output, options.templates, tagApiKeyMap, selectionFilter);
cleanup(tempDir);
const report = generateReport(options.output, analysis);