UNPKG

next-rest-framework

Version:

Next REST Framework - Type-safe, self-documenting APIs for Next.js

51 lines (49 loc) 1.64 kB
#!/usr/bin/env node import { generate } from "../chunk-IQJASJ36.mjs"; import { validate } from "../chunk-XYTBPH6D.mjs"; import "../chunk-HH655YUH.mjs"; import "../chunk-W4JGICKV.mjs"; import "../chunk-F4RHMFSH.mjs"; import "../chunk-SPFPWZVF.mjs"; // src/cli/index.ts import { Command } from "commander"; import chalk from "chalk"; var program = new Command(); program.command("generate").option( "--configPath <string>", "In case you have multiple docs handlers with different configurations, you can specify which configuration you want to use by providing the path to the API. Example: `/api/my-configuration`." ).description("Generate an OpenAPI spec with Next REST Framework.").action(async (options) => { const configPath = options.configPath ?? ""; try { console.info(chalk.yellowBright("Generating OpenAPI spec...")); await generate({ configPath }); } catch (e) { console.error(e); process.exit(1); } }); program.command("validate").option( "--configPath <string>", "In case you have multiple docs handlers with different configurations, you can specify which configuration you want to use by providing the path to the API. Example: `/api/my-configuration`." ).description("Validate an OpenAPI spec with Next REST Framework.").action(async (options) => { const configPath = options.configPath ?? ""; try { console.info(chalk.yellowBright("Validating OpenAPI spec...")); const valid = await validate({ configPath }); if (!valid) { process.exit(1); } } catch (e) { console.error(e); process.exit(1); } }); program.parse(process.argv);