@visulima/api-platform
Version:
Visulima API platform is a set of tools to build and consume web APIs
1 lines • 32 kB
Source Map (JSON)
{"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/utils.ts","../src/swagger/extend-swagger-spec.ts","../src/swagger/api/swagger-handler.ts"],"names":["yamlTransformer","data","stringify","yaml_default","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","toXML","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","join","existsSync","fileContents","readFileSync","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","swagger_handler_default"],"mappings":"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","file":"chunk-67LLYNYS.mjs","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { URL } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax,no-loops/no-loops\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): Record<string, unknown> => {\n if (request.query) {\n return request.query;\n }\n\n if (!request.url) {\n return {};\n }\n\n // Note: Fake protocol is required to parse query string\n const url = new URL(`https://${request.headers.host?.replace(/\\/$/u, \"\")}/${request.url}`);\n\n return Object.fromEntries(url.searchParams.entries());\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/gu, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/gu, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/gu, (c) => c.toUpperCase());\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = toHeaderCase(pathKey.trim().replace(\"/\", \"\"));\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/u,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport { join } from \"@visulima/path\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n"]}