From 22e46127c4b7f9cae6f1fa5a5f10d03ab29ee133 Mon Sep 17 00:00:00 2001 From: Swain Molster Date: Tue, 2 Aug 2022 11:14:48 -0400 Subject: [PATCH] fix: generate OpenAPI v3.0.0 specs --- src/bin/cli.ts | 2 +- src/openapi.test.ts | 4 ++-- src/openapi.ts | 28 ++++++++++++++-------------- 3 files changed, 17 insertions(+), 17 deletions(-) diff --git a/src/bin/cli.ts b/src/bin/cli.ts index 2684bac..f9c72ef 100644 --- a/src/bin/cli.ts +++ b/src/bin/cli.ts @@ -174,7 +174,7 @@ const program = yargs(process.argv.slice(2)) ); const openAPISpec = toOpenAPISpec(spec, { - info: { version: argv.apiTitle, title: argv.apiTitle }, + info: { version: argv.apiVersion, title: argv.apiTitle }, }); const output = diff --git a/src/openapi.test.ts b/src/openapi.test.ts index 44240b1..993109e 100644 --- a/src/openapi.test.ts +++ b/src/openapi.test.ts @@ -87,14 +87,14 @@ describe('toOpenAPISpec', () => { // Ensure result is a valid OpenAPI spec const { errors } = new OpenAPIValidator({ - version: '3.1.0', + version: '3.0.0', }).validate(result); expect(errors).toHaveLength(0); // Assert on specific response. expect(result).toStrictEqual({ - openapi: '3.1.0', + openapi: '3.0.0', info: { title: 'test title', version: '1.2.3' }, components: { schemas: { diff --git a/src/openapi.ts b/src/openapi.ts index b940027..c76d33c 100644 --- a/src/openapi.ts +++ b/src/openapi.ts @@ -1,4 +1,4 @@ -import type { OpenAPIV3_1 } from 'openapi-types'; +import type { OpenAPIV3 } from 'openapi-types'; import type { OneSchemaDefinition } from './types'; import { deepCopy } from './generate-endpoints'; import { validateSchema } from './meta-schema'; @@ -21,14 +21,14 @@ const getPathParameters = (koaPath: string) => export const toOpenAPISpec = ( schema: OneSchemaDefinition, config: { - info: OpenAPIV3_1.InfoObject; + info: OpenAPIV3.InfoObject; }, -): OpenAPIV3_1.Document => { +): OpenAPIV3.Document => { validateSchema(schema); // 1. Declare the document. We'll build it as we go. - const openAPIDocument: OpenAPIV3_1.Document = { - openapi: '3.1.0', + const openAPIDocument: OpenAPIV3.Document = { + openapi: '3.0.0', info: config.info, components: {}, paths: {}, @@ -52,7 +52,7 @@ export const toOpenAPISpec = ( ] of Object.entries(Endpoints)) { const [method, path] = endpoint.split(' '); - const operation: OpenAPIV3_1.OperationObject = { + const operation: OpenAPIV3.OperationObject = { operationId: Name, responses: { '200': { @@ -69,14 +69,14 @@ export const toOpenAPISpec = ( }, }; - const parameters: OpenAPIV3_1.ParameterObject[] = getPathParameters( - path, - ).map((name) => ({ - name, - in: 'path', - schema: { type: 'string' }, - required: true, - })); + const parameters: OpenAPIV3.ParameterObject[] = getPathParameters(path).map( + (name) => ({ + name, + in: 'path', + schema: { type: 'string' }, + required: true, + }), + ); if (Request) { if (['GET', 'DELETE'].includes(method)) {