@visulima/api-platform 1.1.5 → 1.1.7
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/CHANGELOG.md +21 -0
- package/dist/chunk-LMCCZDNI.js +2 -0
- package/dist/chunk-LMCCZDNI.js.map +1 -0
- package/dist/chunk-XVXFEQ7P.mjs +2 -0
- package/dist/chunk-XVXFEQ7P.mjs.map +1 -0
- package/dist/index-server.js +1 -1
- package/dist/index-server.js.map +1 -1
- package/dist/index-server.mjs +1 -1
- package/dist/index-server.mjs.map +1 -1
- package/dist/next/index-server.js +1 -1
- package/dist/next/index-server.mjs +1 -1
- package/package.json +4 -5
- package/dist/chunk-AG2ROSSA.mjs +0 -2
- package/dist/chunk-AG2ROSSA.mjs.map +0 -1
- package/dist/chunk-QIHOLJVA.js +0 -2
- package/dist/chunk-QIHOLJVA.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,24 @@
|
|
|
1
|
+
## @visulima/api-platform [1.1.7](https://github.com/visulima/visulima/compare/@visulima/api-platform@1.1.6...@visulima/api-platform@1.1.7) (2022-12-20)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Bug Fixes
|
|
5
|
+
|
|
6
|
+
* fixed found issues after upgrading vitest ([3ee9861](https://github.com/visulima/visulima/commit/3ee9861eeae72a6d0cc941e048d3860c5301ddc4))
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
### Dependencies
|
|
11
|
+
|
|
12
|
+
* **@visulima/crud:** upgraded to 1.0.8
|
|
13
|
+
|
|
14
|
+
## @visulima/api-platform [1.1.6](https://github.com/visulima/visulima/compare/@visulima/api-platform@1.1.5...@visulima/api-platform@1.1.6) (2022-12-15)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
### Dependencies
|
|
19
|
+
|
|
20
|
+
* **@visulima/crud:** upgraded to 1.0.7
|
|
21
|
+
|
|
1
22
|
## @visulima/api-platform [1.1.5](https://github.com/visulima/visulima/compare/@visulima/api-platform@1.1.4...@visulima/api-platform@1.1.5) (2022-12-15)
|
|
2
23
|
|
|
3
24
|
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _crud = require('@visulima/crud');var _debug = require('debug'); var _debug2 = _interopRequireDefault(_debug);var _lodashmerge = require('lodash.merge'); var _lodashmerge2 = _interopRequireDefault(_lodashmerge);var _fs = require('fs');var _path = require('path'); var _path2 = _interopRequireDefault(_path);var _yaml = require('yaml');var C=e=>_yaml.stringify.call(void 0, e,{indent:2}),E= exports.b =C;var _jstoxml = require('jstoxml'); var _jstoxml2 = _interopRequireDefault(_jstoxml);var _url = require('url');var m=e=>e.toLowerCase().replace(/[^\s\w]/g," ").trimEnd().replace(/\s+|_/g,"-").replace(/\b\w/g,n=>n.toUpperCase());var I="application/json",V=(e,n,s)=>{var a,c,p,r,t;((c=(a=e==null?void 0:e.responses)==null?void 0:a[n])==null?void 0:c.content)===void 0&&(e.responses[n].content={}),((t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])===void 0&&(e.responses[n].content[s]={})},v=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===void 0&&(e.components.schemas[n]=s)},H=(e,n,s,a,c)=>{var p,r,t,f;V(e,n,s),((f=(t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])==null?void 0:f.schema)===void 0&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=c?{type:"array",items:{$ref:`#/components/schemas/${a}`}}:{$ref:`#/components/schemas/${a}`}},q=(e,n,s,a,c,p)=>{let r,t;return Object.entries(n.content).forEach(([f,o])=>{if(typeof o.schema=="object"){let{schema:O}=o;f===I&&o.examples!==void 0?t=o.examples:f===I&&o.example!==void 0&&(r=o.example);let i=O.type==="array";Object.entries(s||{}).forEach(([b,g])=>{if(!g)return;let l;O.$ref===void 0?(l=`${m(a.trim().replace("/",""))}${b==="application/ld+json"?".jsonld":""}`,v(c,l,O)):l=O.$ref.replace("#/components/schemas/",""),H(e,p,b,l,i)})}}),{examples:t,example:r}},J=(e,n,s,a,c,p)=>{Object.keys(n.content).forEach(r=>{r!==I&&Object.entries(a||{}).forEach(([t,f])=>{var O,i,b,g;if(!f)return;V(e,s,t),((g=(b=(i=(O=e==null?void 0:e.responses)==null?void 0:O[s])==null?void 0:i.content)==null?void 0:b[t])==null?void 0:g.example)===void 0&&(e.responses[s].content[t].example={});let o=!1;c.forEach(({regex:l,transformer:P})=>{!o&&l.test(t)&&(e.responses[s].content[t].example=P(p),o=!0)}),o||(e.responses[s].content[t].example=p)})})},F=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===void 0&&s[n]!==void 0&&(e.components.examples[n]=s[n])},W=(e,n,s,a,c,p)=>{var t,f,o,O;V(n,s,a),((O=(o=(f=(t=n==null?void 0:n.responses)==null?void 0:t[s])==null?void 0:f.content)==null?void 0:o[a])==null?void 0:O.examples)===void 0&&(n.responses[s].content[a].examples={});let r={};Object.entries(p).forEach(([i,b])=>{var l,P;let g=!1;c.forEach(({regex:M,transformer:h})=>{var u,d,y,R,x,w;if(!g&&M.test(a)){let A="";((d=(u=e.components)==null?void 0:u.examples)==null?void 0:d[i])!==void 0?A=((R=(y=e.components)==null?void 0:y.examples)==null?void 0:R[i]).value:b?A=((w=(x=e.components)==null?void 0:x.examples)==null?void 0:w[b.$ref.replace("#/components/examples/","")]).value:typeof(b==null?void 0:b.value)=="string"&&(A=b.value),r[i]={value:h(A)},g=!0}}),g||(r[i]=((P=(l=e.components)==null?void 0:l.examples)==null?void 0:P[i])===void 0?b:{$ref:`#/components/examples/${i}`})}),n.responses[s].content[a].examples=r},z=(e,n,s,a,c,p,r,t)=>{let f=`${m(p.trim().replace("/",""))}`;Object.keys(a.content).forEach(o=>{o!==I&&Object.entries(c||{}).forEach(([O,i])=>{!i||(F(e,f,t),W(e,n,s,O,r,t))})})};function j(e,n,s=[{regex:/xml/,transformer:a=>_jstoxml2.default.toXML(a,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:a=>_yaml.stringify.call(void 0, a,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([a,c])=>{Object.values(c).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([r,t])=>{if(typeof t.content=="object"){let{examples:f,example:o}=q(p,t,n,a,e,r);o!==void 0?J(p,t,r,n,s,o):f!==void 0&&z(e,p,r,t,n,a,s,f)}})})}),e}var _=_debug2.default.call(void 0, "visulima:api-platform:swagger:crud:get-static-properties-swagger"),G=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:a,specs:c}=e;return async(p,r)=>{let t=_path2.default.join(process.cwd(),s||"swagger/swagger.json");if(!_fs.existsSync.call(void 0, t))throw new Error(`Swagger file not found at ${t}. Did you change the output path in "withOpenApi" inside the next.config.js file?`);let f=_fs.readFileSync.call(void 0, t,"utf8"),o=j(JSON.parse(f),n),O={};if(a!==void 0)try{let i=await _crud.modelsToOpenApi.call(void 0, a);O={components:{schemas:i.schemas,examples:i.examples},tags:i.tags,paths:i.paths},O=j(O,n),_(JSON.stringify(O,null,2)),o=_lodashmerge2.default.call(void 0, o,O)}catch(i){throw console.log(i),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(c)&&c.forEach(i=>{o=_lodashmerge2.default.call(void 0, o,j(i,n))}),typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(r.statusCode=200,r.setHeader("Content-Type",p.headers.accept),r.end(E(o))):(r.statusCode=200,r.setHeader("Content-Type","application/json"),r.end(JSON.stringify(o,null,2)))}},fe= exports.c =G;exports.a = m; exports.b = E; exports.c = fe;
|
|
2
|
+
//# sourceMappingURL=chunk-LMCCZDNI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/swagger/swagger-handler.ts","../src/connect/serializers/yaml.ts","../src/swagger/extend-swagger-spec.ts","../src/utils.ts"],"names":["modelsToOpenApi","debug","merge","existsSync","readFileSync","path","stringify","yamlTransformer","data","yaml_default","xml","urlParse","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","_a","_b","_c","_d","_e","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","_f","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","pathSpec","swaggerCrudDebug","swaggerHandler","options","swaggerFilePath","crud","specs","request","response","swaggerPath","fileContents","crudSwagger","modelsOpenApi","error","swagger_handler_default"],"mappings":"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","sourcesContent":["// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../connect/serializers/yaml\";\nimport extendSwaggerSpec from \"./extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = (options: Partial<SwaggerHandlerOptions> = {}) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.join(process.cwd(), swaggerFilePath || \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at ${swaggerPath}. Did you change the output path in \"withOpenApi\" inside the next.config.js file?`);\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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags as OpenAPIV3.TagObject[],\n paths: modelsOpenApi.paths,\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 if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", request.headers.accept);\n response.end(yamlTransformer(spec));\n } else {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(JSON.stringify(spec, null, 2));\n }\n };\n};\n\nexport type SwaggerHandlerOptions = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<string>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","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 xml 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 (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} 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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 as OpenAPIV3.ReferenceObject).$ref === undefined) {\n // eslint-disable-next-line max-len\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 // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\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: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n } = {};\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] as OpenAPIV3.ExampleObject) !== undefined) {\n data = (spec.components?.examples?.[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if (example as OpenAPIV3.ReferenceObject) {\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] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value) => xml.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.PathsObject & OpenAPIV3.OperationObject).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 { examples, example } = 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 { IncomingMessage } from \"node:http\";\nimport { parse as urlParse } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: any, 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<unknown> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax\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): unknown => {\n if (request.query) {\n return request.query;\n }\n return urlParse(request.url ?? \"\", true).query;\n};\n\nexport const toHeaderCase = (string_: string): string => string_\n .toLowerCase()\n .replace(/[^\\s\\w]/g, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replace(/\\s+|_/g, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{modelsToOpenApi as B}from"@visulima/crud";import L from"debug";import k from"lodash.merge";import{existsSync as Q,readFileSync as U}from"fs";import X from"path";import{stringify as T}from"yaml";var C=e=>T(e,{indent:2}),E=C;import D from"jstoxml";import{stringify as $}from"yaml";var m=e=>e.toLowerCase().replace(/[^\s\w]/g," ").trimEnd().replace(/\s+|_/g,"-").replace(/\b\w/g,n=>n.toUpperCase());var I="application/json",V=(e,n,s)=>{var a,c,p,r,t;((c=(a=e==null?void 0:e.responses)==null?void 0:a[n])==null?void 0:c.content)===void 0&&(e.responses[n].content={}),((t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])===void 0&&(e.responses[n].content[s]={})},v=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===void 0&&(e.components.schemas[n]=s)},H=(e,n,s,a,c)=>{var p,r,t,f;V(e,n,s),((f=(t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])==null?void 0:f.schema)===void 0&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=c?{type:"array",items:{$ref:`#/components/schemas/${a}`}}:{$ref:`#/components/schemas/${a}`}},q=(e,n,s,a,c,p)=>{let r,t;return Object.entries(n.content).forEach(([f,o])=>{if(typeof o.schema=="object"){let{schema:O}=o;f===I&&o.examples!==void 0?t=o.examples:f===I&&o.example!==void 0&&(r=o.example);let i=O.type==="array";Object.entries(s||{}).forEach(([b,g])=>{if(!g)return;let l;O.$ref===void 0?(l=`${m(a.trim().replace("/",""))}${b==="application/ld+json"?".jsonld":""}`,v(c,l,O)):l=O.$ref.replace("#/components/schemas/",""),H(e,p,b,l,i)})}}),{examples:t,example:r}},J=(e,n,s,a,c,p)=>{Object.keys(n.content).forEach(r=>{r!==I&&Object.entries(a||{}).forEach(([t,f])=>{var O,i,b,g;if(!f)return;V(e,s,t),((g=(b=(i=(O=e==null?void 0:e.responses)==null?void 0:O[s])==null?void 0:i.content)==null?void 0:b[t])==null?void 0:g.example)===void 0&&(e.responses[s].content[t].example={});let o=!1;c.forEach(({regex:l,transformer:P})=>{!o&&l.test(t)&&(e.responses[s].content[t].example=P(p),o=!0)}),o||(e.responses[s].content[t].example=p)})})},F=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===void 0&&s[n]!==void 0&&(e.components.examples[n]=s[n])},W=(e,n,s,a,c,p)=>{var t,f,o,O;V(n,s,a),((O=(o=(f=(t=n==null?void 0:n.responses)==null?void 0:t[s])==null?void 0:f.content)==null?void 0:o[a])==null?void 0:O.examples)===void 0&&(n.responses[s].content[a].examples={});let r={};Object.entries(p).forEach(([i,b])=>{var l,P;let g=!1;c.forEach(({regex:M,transformer:h})=>{var u,d,y,R,x,w;if(!g&&M.test(a)){let A="";((d=(u=e.components)==null?void 0:u.examples)==null?void 0:d[i])!==void 0?A=((R=(y=e.components)==null?void 0:y.examples)==null?void 0:R[i]).value:b?A=((w=(x=e.components)==null?void 0:x.examples)==null?void 0:w[b.$ref.replace("#/components/examples/","")]).value:typeof(b==null?void 0:b.value)=="string"&&(A=b.value),r[i]={value:h(A)},g=!0}}),g||(r[i]=((P=(l=e.components)==null?void 0:l.examples)==null?void 0:P[i])===void 0?b:{$ref:`#/components/examples/${i}`})}),n.responses[s].content[a].examples=r},z=(e,n,s,a,c,p,r,t)=>{let f=`${m(p.trim().replace("/",""))}`;Object.keys(a.content).forEach(o=>{o!==I&&Object.entries(c||{}).forEach(([O,i])=>{!i||(F(e,f,t),W(e,n,s,O,r,t))})})};function j(e,n,s=[{regex:/xml/,transformer:a=>D.toXML(a,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:a=>$(a,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([a,c])=>{Object.values(c).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([r,t])=>{if(typeof t.content=="object"){let{examples:f,example:o}=q(p,t,n,a,e,r);o!==void 0?J(p,t,r,n,s,o):f!==void 0&&z(e,p,r,t,n,a,s,f)}})})}),e}var _=L("visulima:api-platform:swagger:crud:get-static-properties-swagger"),G=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:a,specs:c}=e;return async(p,r)=>{let t=X.join(process.cwd(),s||"swagger/swagger.json");if(!Q(t))throw new Error(`Swagger file not found at ${t}. Did you change the output path in "withOpenApi" inside the next.config.js file?`);let f=U(t,"utf8"),o=j(JSON.parse(f),n),O={};if(a!==void 0)try{let i=await B(a);O={components:{schemas:i.schemas,examples:i.examples},tags:i.tags,paths:i.paths},O=j(O,n),_(JSON.stringify(O,null,2)),o=k(o,O)}catch(i){throw console.log(i),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(c)&&c.forEach(i=>{o=k(o,j(i,n))}),typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(r.statusCode=200,r.setHeader("Content-Type",p.headers.accept),r.end(E(o))):(r.statusCode=200,r.setHeader("Content-Type","application/json"),r.end(JSON.stringify(o,null,2)))}},Oe=G;export{m as a,E as b,Oe as c};
|
|
2
|
+
//# sourceMappingURL=chunk-XVXFEQ7P.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/swagger/swagger-handler.ts","../src/connect/serializers/yaml.ts","../src/swagger/extend-swagger-spec.ts","../src/utils.ts"],"sourcesContent":["// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../connect/serializers/yaml\";\nimport extendSwaggerSpec from \"./extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = (options: Partial<SwaggerHandlerOptions> = {}) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.join(process.cwd(), swaggerFilePath || \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at ${swaggerPath}. Did you change the output path in \"withOpenApi\" inside the next.config.js file?`);\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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags as OpenAPIV3.TagObject[],\n paths: modelsOpenApi.paths,\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 if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", request.headers.accept);\n response.end(yamlTransformer(spec));\n } else {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(JSON.stringify(spec, null, 2));\n }\n };\n};\n\nexport type SwaggerHandlerOptions = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<string>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","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 xml 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 (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} 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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 as OpenAPIV3.ReferenceObject).$ref === undefined) {\n // eslint-disable-next-line max-len\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 // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\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: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n } = {};\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] as OpenAPIV3.ExampleObject) !== undefined) {\n data = (spec.components?.examples?.[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if (example as OpenAPIV3.ReferenceObject) {\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] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value) => xml.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.PathsObject & OpenAPIV3.OperationObject).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 { examples, example } = 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 { IncomingMessage } from \"node:http\";\nimport { parse as urlParse } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: any, 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<unknown> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax\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): unknown => {\n if (request.query) {\n return request.query;\n }\n return urlParse(request.url ?? \"\", true).query;\n};\n\nexport const toHeaderCase = (string_: string): string => string_\n .toLowerCase()\n .replace(/[^\\s\\w]/g, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replace(/\\s+|_/g, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n"],"mappings":"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","names":["modelsToOpenApi","debug","merge","existsSync","readFileSync","path","stringify","yamlTransformer","data","yaml_default","xml","stringify","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","_a","_b","_c","_d","_e","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","toHeaderCase","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","_f","data","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","xml","stringify","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","allowedMediaTypes","swaggerFilePath","crud","specs","request","response","swaggerPath","path","existsSync","fileContents","readFileSync","spec","extendSwaggerSpec","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","value","yaml_default","swagger_handler_default"]}
|
package/dist/index-server.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkJXD3457Ojs = require('./chunk-JXD3457O.js');var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkJXD3457Ojs = require('./chunk-JXD3457O.js');var _chunkLMCCZDNIjs = require('./chunk-LMCCZDNI.js');require('./chunk-OUWZ2PU5.js');var _httperrors = require('http-errors'); var _httperrors2 = _interopRequireDefault(_httperrors);var _connect = require('@visulima/connect');var _httpstatuscodes = require('http-status-codes');var _tsjapi = require('ts-japi'); var _tsjapi2 = _interopRequireDefault(_tsjapi);var c=(e,o)=>{let t=o.headers||{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r])})},p=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o))},m=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=_httpstatuscodes.StatusCodes.INTERNAL_SERVER_ERROR)};var w="An error occurred",W=(e,o,t)=>{if(m(t,e),c(t,e),e instanceof _tsjapi2.default.JapiError||_tsjapi2.default.JapiError.isLikeJapiError(e)){let r=new _tsjapi2.default.ErrorSerializer;p(t,r.serialize(e))}else if(e instanceof _httperrors.HttpError){let{statusCode:r,title:n,message:a}=e;p(t,{errors:[{code:r,title:n||_httpstatuscodes.getReasonPhrase.call(void 0, r)||w,detail:a}]})}else{let{message:r}=e;p(t,{errors:[{code:"500",title:_httpstatuscodes.getReasonPhrase.call(void 0, t.statusCode)||w,detail:r}]})}},N=W;var T="https://tools.ietf.org/html/rfc2616#section-10",A="An error occurred",U=(e,o,t)=>{let{stack:r,message:n}=e;if(e instanceof _httperrors.HttpError){let{statusCode:a,expose:s,title:i,type:d}=e;t.statusCode=a,c(t,e),p(t,{type:d||T,title:i||_httpstatuscodes.getReasonPhrase.call(void 0, a)||A,details:n,...s?{trace:r}:{}})}else m(t,e),p(t,{type:T,title:_httpstatuscodes.getReasonPhrase.call(void 0, t.statusCode)||A,details:n,...e.expose?{trace:r}:{}})},v=U;var y=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=v;a==="application/vnd.api+json"&&(s=N);for(let{regex:i,handler:d}of e)if(i.test(a)){s=d;break}t.expose=o,s(t,r,n)},g= exports.onNoMatch =async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,_httperrors2.default.call(void 0, 405,`No route with [${e.method}] method found.`)};var z={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},K=(e,o)=>{let t=e.toLowerCase();return o?z[t]?z[t]:t.split("-").map(r=>{var n;return((n=r[0])==null?void 0:n.toUpperCase())+r.slice(1)}).join("-"):t},Z={canonical:!1,normalizeHeaderKey:K},B=e=>{let o={...Z,...e};return async(t,r,n)=>{if(t.headers){let a={},s={};Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d!==void 0&&(s[d]=t.headers[i])}),t.headers=s,t.rawHeaders=a}return n()}},x= exports.httpHeaderNormalizerMiddleware =B;var _accepts = require('accepts'); var _accepts2 = _interopRequireDefault(_accepts);var _jstoxml = require('jstoxml'); var _jstoxml2 = _interopRequireDefault(_jstoxml);var _=e=>_jstoxml2.default.toXML(e,{header:!0,indent:" "}),C=_;function I(e){if(typeof e!="string")return!1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch (e2){return!1}}var f="Content-Type",L=(e,o,t,r,n)=>{if(typeof t.getHeader(f)=="string")return r;let i=[..._accepts2.default.call(void 0, o).types(),n.defaultContentType],d=r;return i.every(l=>{var H;let u=!1;return e.forEach(({regex:k,serializer:P})=>{!k.test(l)||(t.setHeader(f,l),d=P(d),u=!0)}),u||(/yaml|yml/.test(l)?(t.setHeader(f,l),d=_chunkLMCCZDNIjs.b.call(void 0, I(r)?JSON.parse(r):r)):/xml/.test(l)&&(t.setHeader(f,l),d=C({[_chunkLMCCZDNIjs.a.call(void 0, `${(H=o.url)==null?void 0:H.replace("/api/","")}`.trim())]:I(r)?JSON.parse(r):r}))),u}),d},Q=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof(r==null?void 0:r.send)=="function"){let a=r.send;r.send=s=>(r.send=a,s=L(e,t,r,s,{defaultContentType:o}),r.send(s))}else{let a=r.end;r.end=(s,...i)=>(r.end=a,s=L(e,t,r,s,{defaultContentType:o}),r.end(s,...i))}return n()},h= exports.serializersMiddleware =Q;var ee=(e={})=>{var t,r,n,a,s;return new (0, _connect.NodeRouter)({onNoMatch:g,onError:y(e.errorHandlers||[],e.showTrace||!1)}).use(x(((t=e==null?void 0:e.middlewares)==null?void 0:t["http-header-normalizer"])||{})).use(h(((n=(r=e==null?void 0:e.middlewares)==null?void 0:r.serializers)==null?void 0:n.serializers)||[],((s=(a=e==null?void 0:e.middlewares)==null?void 0:a.serializers)==null?void 0:s.defaultContentType)||"application/json; charset=utf-8"))},te= exports.createNodeRouter =ee;var re=e=>(e==null?void 0:e.ip)||e.headers["x-forwarded-for"]||e.headers["x-real-ip"]||e.connection.remoteAddress,oe=(e,o)=>async(t,r,n)=>{let a=re(t);if(a===void 0)throw _httperrors2.default.call(void 0, 400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d])}),await n()}catch (e3){throw _httperrors2.default.call(void 0, 429,"Too Many Requests")}},se= exports.rateLimiterMiddleware =oe;var _cors = require('cors'); var _cors2 = _interopRequireDefault(_cors);var ie=e=>_connect.expressWrapper.call(void 0, _cors2.default.call(void 0, e)),de= exports.corsMiddleware =ie;exports.BadGateway = _httperrors.BadGateway; exports.BadRequest = _httperrors.BadRequest; exports.BandwidthLimitExceeded = _httperrors.BandwidthLimitExceeded; exports.Conflict = _httperrors.Conflict; exports.EdgeRouter = _connect.EdgeRouter; exports.ExpectationFailed = _httperrors.ExpectationFailed; exports.FailedDependency = _httperrors.FailedDependency; exports.Forbidden = _httperrors.Forbidden; exports.GatewayTimeout = _httperrors.GatewayTimeout; exports.Gone = _httperrors.Gone; exports.HTTPVersionNotSupported = _httperrors.HTTPVersionNotSupported; exports.ImATeapot = _httperrors.ImATeapot; exports.InsufficientStorage = _httperrors.InsufficientStorage; exports.InternalServerError = _httperrors.InternalServerError; exports.LengthRequired = _httperrors.LengthRequired; exports.Locked = _httperrors.Locked; exports.LoopDetected = _httperrors.LoopDetected; exports.MethodNotAllowed = _httperrors.MethodNotAllowed; exports.MisdirectedRequest = _httperrors.MisdirectedRequest; exports.NetworkAuthenticationRequire = _httperrors.NetworkAuthenticationRequire; exports.NodeRouter = _connect.NodeRouter; exports.NotAcceptable = _httperrors.NotAcceptable; exports.NotExtended = _httperrors.NotExtended; exports.NotFound = _httperrors.NotFound; exports.NotImplemented = _httperrors.NotImplemented; exports.PayloadTooLarge = _httperrors.PayloadTooLarge; exports.PaymentRequired = _httperrors.PaymentRequired; exports.PreconditionFailed = _httperrors.PreconditionFailed; exports.PreconditionRequired = _httperrors.PreconditionRequired; exports.ProxyAuthenticationRequired = _httperrors.ProxyAuthenticationRequired; exports.RangeNotSatisfiable = _httperrors.RangeNotSatisfiable; exports.RequestHeaderFieldsTooLarge = _httperrors.RequestHeaderFieldsTooLarge; exports.RequestTimeout = _httperrors.RequestTimeout; exports.Router = _connect.Router; exports.ServiceUnavailable = _httperrors.ServiceUnavailable; exports.TooManyRequests = _httperrors.TooManyRequests; exports.URITooLong = _httperrors.URITooLong; exports.Unauthorized = _httperrors.Unauthorized; exports.UnavailableForLegalReasons = _httperrors.UnavailableForLegalReasons; exports.UnprocessableEntity = _httperrors.UnprocessableEntity; exports.UnsupportedMediaType = _httperrors.UnsupportedMediaType; exports.UpgradeRequired = _httperrors.UpgradeRequired; exports.VariantAlsoNegotiates = _httperrors.VariantAlsoNegotiates; exports.corsMiddleware = de; exports.createEdgeRouter = _connect.createEdgeRouter; exports.createHttpError = _httperrors2.default; exports.createNodeRouter = te; exports.dateIn = _chunkJXD3457Ojs.a; exports.dateOut = _chunkJXD3457Ojs.b; exports.expressWrapper = _connect.expressWrapper; exports.httpHeaderNormalizerMiddleware = x; exports.onError = y; exports.onNoMatch = g; exports.rateLimiterMiddleware = se; exports.sendJson = _connect.sendJson; exports.serializersMiddleware = h; exports.swaggerHandler = _chunkLMCCZDNIjs.c; exports.withZod = _connect.withZod; exports.zod = _chunkJXD3457Ojs.c;
|
|
2
2
|
//# sourceMappingURL=index-server.js.map
|
package/dist/index-server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"names":["default","BadRequest","Forbidden","BadGateway","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","VariantAlsoNegotiates","ProxyAuthenticationRequired","NetworkAuthenticationRequire","LengthRequired","LoopDetected","Locked","MethodNotAllowed","MisdirectedRequest","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","RequestHeaderFieldsTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","RangeNotSatisfiable","RequestTimeout","ServiceUnavailable","TooManyRequests","Unauthorized","UnprocessableEntity","UnavailableForLegalReasons","UnsupportedMediaType","UpgradeRequired","URITooLong","NodeRouter","createHttpError","HttpError","getReasonPhrase","ErrorSerializer","JapiError","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","statusCode","title","message","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","regex","handler","onNoMatch","routes","uniqueMethods","route","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","_a","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","accepts","headerCase","toXML","xmlTransformer","data","xml_default","hasJsonStructure","string_","result","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","_b","_c","_d","_e","create_node_router_default","createEdgeRouter","EdgeRouter","expressWrapper","Router","withZod","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","cors","corsMiddleware","cors_middleware_default"],"mappings":"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","sourcesContent":["export * from \"./index-browser\";\n\nexport {\n default as createHttpError,\n BadRequest,\n Forbidden,\n BadGateway,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n VariantAlsoNegotiates,\n ProxyAuthenticationRequired,\n NetworkAuthenticationRequire,\n LengthRequired,\n LoopDetected,\n Locked,\n MethodNotAllowed,\n MisdirectedRequest,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n RequestHeaderFieldsTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n RangeNotSatisfiable,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n Unauthorized,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport { ErrorSerializer, JapiError } from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof JapiError || JapiError.isLikeJapiError(error)) {\n const serializer = new ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport { header as headerCase } from \"case\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [headerCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"names":["default","BadRequest","Forbidden","BadGateway","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","VariantAlsoNegotiates","ProxyAuthenticationRequired","NetworkAuthenticationRequire","LengthRequired","LoopDetected","Locked","MethodNotAllowed","MisdirectedRequest","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","RequestHeaderFieldsTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","RangeNotSatisfiable","RequestTimeout","ServiceUnavailable","TooManyRequests","Unauthorized","UnprocessableEntity","UnavailableForLegalReasons","UnsupportedMediaType","UpgradeRequired","URITooLong","NodeRouter","createHttpError","HttpError","getReasonPhrase","tsJapi","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","statusCode","title","message","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","regex","handler","onNoMatch","routes","uniqueMethods","route","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","_a","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","accepts","xml","xmlTransformer","data","xml_default","hasJsonStructure","string_","result","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","_b","_c","_d","_e","create_node_router_default","createEdgeRouter","EdgeRouter","expressWrapper","Router","withZod","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","cors","corsMiddleware","cors_middleware_default"],"mappings":"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","sourcesContent":["export * from \"./index-browser\";\n\nexport {\n default as createHttpError,\n BadRequest,\n Forbidden,\n BadGateway,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n VariantAlsoNegotiates,\n ProxyAuthenticationRequired,\n NetworkAuthenticationRequire,\n LengthRequired,\n LoopDetected,\n Locked,\n MethodNotAllowed,\n MisdirectedRequest,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n RequestHeaderFieldsTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n RangeNotSatisfiable,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n Unauthorized,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport tsJapi from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | tsJapi.JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof tsJapi.JapiError || tsJapi.JapiError.isLikeJapiError(error)) {\n const serializer = new tsJapi.ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../../utils\";\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => xml.toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"]}
|
package/dist/index-server.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as q,b as j,c as pe}from"./chunk-HONWWBY6.mjs";import{a as E,b as S,c as D}from"./chunk-XVXFEQ7P.mjs";import"./chunk-YOXCJZNX.mjs";import{default as Ke,BadRequest as Ze,Forbidden as Be,BadGateway as Ge,BandwidthLimitExceeded as _e,Conflict as $e,ExpectationFailed as Qe,FailedDependency as Ye,GatewayTimeout as et,Gone as tt,HTTPVersionNotSupported as rt,ImATeapot as ot,InsufficientStorage as st,InternalServerError as nt,VariantAlsoNegotiates as at,ProxyAuthenticationRequired as it,NetworkAuthenticationRequire as dt,LengthRequired as pt,LoopDetected as lt,Locked as ct,MethodNotAllowed as mt,MisdirectedRequest as ft,NotAcceptable as ut,NotExtended as Rt,NotFound as yt,NotImplemented as gt,PayloadTooLarge as xt,RequestHeaderFieldsTooLarge as ht,PaymentRequired as Ht,PreconditionFailed as Et,PreconditionRequired as St,RangeNotSatisfiable as bt,RequestTimeout as wt,ServiceUnavailable as Nt,TooManyRequests as Mt,Unauthorized as Tt,UnprocessableEntity as At,UnavailableForLegalReasons as vt,UnsupportedMediaType as zt,UpgradeRequired as Ct,URITooLong as It}from"http-errors";import{NodeRouter as Y}from"@visulima/connect";import X from"http-errors";import{HttpError as V}from"http-errors";import{getReasonPhrase as b}from"http-status-codes";import R from"ts-japi";import{StatusCodes as J}from"http-status-codes";var c=(e,o)=>{let t=o.headers||{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r])})},p=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o))},m=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=J.INTERNAL_SERVER_ERROR)};var w="An error occurred",W=(e,o,t)=>{if(m(t,e),c(t,e),e instanceof R.JapiError||R.JapiError.isLikeJapiError(e)){let r=new R.ErrorSerializer;p(t,r.serialize(e))}else if(e instanceof V){let{statusCode:r,title:n,message:a}=e;p(t,{errors:[{code:r,title:n||b(r)||w,detail:a}]})}else{let{message:r}=e;p(t,{errors:[{code:"500",title:b(t.statusCode)||w,detail:r}]})}},N=W;import{HttpError as F}from"http-errors";import{getReasonPhrase as M}from"http-status-codes";var T="https://tools.ietf.org/html/rfc2616#section-10",A="An error occurred",U=(e,o,t)=>{let{stack:r,message:n}=e;if(e instanceof F){let{statusCode:a,expose:s,title:i,type:d}=e;t.statusCode=a,c(t,e),p(t,{type:d||T,title:i||M(a)||A,details:n,...s?{trace:r}:{}})}else m(t,e),p(t,{type:T,title:M(t.statusCode)||A,details:n,...e.expose?{trace:r}:{}})},v=U;var y=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=v;a==="application/vnd.api+json"&&(s=N);for(let{regex:i,handler:d}of e)if(i.test(a)){s=d;break}t.expose=o,s(t,r,n)},g=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,X(405,`No route with [${e.method}] method found.`)};var z={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},K=(e,o)=>{let t=e.toLowerCase();return o?z[t]?z[t]:t.split("-").map(r=>{var n;return((n=r[0])==null?void 0:n.toUpperCase())+r.slice(1)}).join("-"):t},Z={canonical:!1,normalizeHeaderKey:K},B=e=>{let o={...Z,...e};return async(t,r,n)=>{if(t.headers){let a={},s={};Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d!==void 0&&(s[d]=t.headers[i])}),t.headers=s,t.rawHeaders=a}return n()}},x=B;import $ from"accepts";import G from"jstoxml";var _=e=>G.toXML(e,{header:!0,indent:" "}),C=_;function I(e){if(typeof e!="string")return!1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch{return!1}}var f="Content-Type",L=(e,o,t,r,n)=>{if(typeof t.getHeader(f)=="string")return r;let i=[...$(o).types(),n.defaultContentType],d=r;return i.every(l=>{var H;let u=!1;return e.forEach(({regex:k,serializer:P})=>{!k.test(l)||(t.setHeader(f,l),d=P(d),u=!0)}),u||(/yaml|yml/.test(l)?(t.setHeader(f,l),d=S(I(r)?JSON.parse(r):r)):/xml/.test(l)&&(t.setHeader(f,l),d=C({[E(`${(H=o.url)==null?void 0:H.replace("/api/","")}`.trim())]:I(r)?JSON.parse(r):r}))),u}),d},Q=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof(r==null?void 0:r.send)=="function"){let a=r.send;r.send=s=>(r.send=a,s=L(e,t,r,s,{defaultContentType:o}),r.send(s))}else{let a=r.end;r.end=(s,...i)=>(r.end=a,s=L(e,t,r,s,{defaultContentType:o}),r.end(s,...i))}return n()},h=Q;var ee=(e={})=>{var t,r,n,a,s;return new Y({onNoMatch:g,onError:y(e.errorHandlers||[],e.showTrace||!1)}).use(x(((t=e==null?void 0:e.middlewares)==null?void 0:t["http-header-normalizer"])||{})).use(h(((n=(r=e==null?void 0:e.middlewares)==null?void 0:r.serializers)==null?void 0:n.serializers)||[],((s=(a=e==null?void 0:e.middlewares)==null?void 0:a.serializers)==null?void 0:s.defaultContentType)||"application/json; charset=utf-8"))},te=ee;import{createEdgeRouter as Pt,EdgeRouter as qt,expressWrapper as jt,NodeRouter as Dt,Router as Jt,withZod as Vt,sendJson as Wt}from"@visulima/connect";import O from"http-errors";var re=e=>(e==null?void 0:e.ip)||e.headers["x-forwarded-for"]||e.headers["x-real-ip"]||e.connection.remoteAddress,oe=(e,o)=>async(t,r,n)=>{let a=re(t);if(a===void 0)throw O(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d])}),await n()}catch{throw O(429,"Too Many Requests")}},se=oe;import{expressWrapper as ne}from"@visulima/connect";import ae from"cors";var ie=e=>ne(ae(e)),de=ie;export{Ge as BadGateway,Ze as BadRequest,_e as BandwidthLimitExceeded,$e as Conflict,qt as EdgeRouter,Qe as ExpectationFailed,Ye as FailedDependency,Be as Forbidden,et as GatewayTimeout,tt as Gone,rt as HTTPVersionNotSupported,ot as ImATeapot,st as InsufficientStorage,nt as InternalServerError,pt as LengthRequired,ct as Locked,lt as LoopDetected,mt as MethodNotAllowed,ft as MisdirectedRequest,dt as NetworkAuthenticationRequire,Dt as NodeRouter,ut as NotAcceptable,Rt as NotExtended,yt as NotFound,gt as NotImplemented,xt as PayloadTooLarge,Ht as PaymentRequired,Et as PreconditionFailed,St as PreconditionRequired,it as ProxyAuthenticationRequired,bt as RangeNotSatisfiable,ht as RequestHeaderFieldsTooLarge,wt as RequestTimeout,Jt as Router,Nt as ServiceUnavailable,Mt as TooManyRequests,It as URITooLong,Tt as Unauthorized,vt as UnavailableForLegalReasons,At as UnprocessableEntity,zt as UnsupportedMediaType,Ct as UpgradeRequired,at as VariantAlsoNegotiates,de as corsMiddleware,Pt as createEdgeRouter,Ke as createHttpError,te as createNodeRouter,q as dateIn,j as dateOut,jt as expressWrapper,x as httpHeaderNormalizerMiddleware,y as onError,g as onNoMatch,se as rateLimiterMiddleware,Wt as sendJson,h as serializersMiddleware,D as swaggerHandler,Vt as withZod,pe as zod};
|
|
2
2
|
//# sourceMappingURL=index-server.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"sourcesContent":["export * from \"./index-browser\";\n\nexport {\n default as createHttpError,\n BadRequest,\n Forbidden,\n BadGateway,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n VariantAlsoNegotiates,\n ProxyAuthenticationRequired,\n NetworkAuthenticationRequire,\n LengthRequired,\n LoopDetected,\n Locked,\n MethodNotAllowed,\n MisdirectedRequest,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n RequestHeaderFieldsTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n RangeNotSatisfiable,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n Unauthorized,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport { ErrorSerializer, JapiError } from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof JapiError || JapiError.isLikeJapiError(error)) {\n const serializer = new ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport { header as headerCase } from \"case\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [headerCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"],"mappings":"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","names":["default","BadRequest","Forbidden","BadGateway","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","VariantAlsoNegotiates","ProxyAuthenticationRequired","NetworkAuthenticationRequire","LengthRequired","LoopDetected","Locked","MethodNotAllowed","MisdirectedRequest","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","RequestHeaderFieldsTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","RangeNotSatisfiable","RequestTimeout","ServiceUnavailable","TooManyRequests","Unauthorized","UnprocessableEntity","UnavailableForLegalReasons","UnsupportedMediaType","UpgradeRequired","URITooLong","NodeRouter","createHttpError","HttpError","getReasonPhrase","ErrorSerializer","JapiError","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","error","_request","response","addStatusCodeToResponse","setErrorHeaders","JapiError","serializer","ErrorSerializer","sendJson","HttpError","statusCode","title","message","getReasonPhrase","jsonapi_error_handler_default","HttpError","getReasonPhrase","defaultType","defaultTitle","problemErrorHandler","error","_request","response","stack","message","HttpError","statusCode","expose","title","type","setErrorHeaders","sendJson","getReasonPhrase","addStatusCodeToResponse","problem_error_handler_default","onError","errorHandlers","showTrace","error","request","response","apiFormat","errorHandler","problem_error_handler_default","jsonapi_error_handler_default","regex","handler","onNoMatch","routes","uniqueMethods","route","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","_a","defaults","httpHeaderNormalizerMiddleware","options_","options","request","_","next","rawHeaders","headers","normalizedKey","http_header_normalizer_default","accepts","headerCase","toXML","xmlTransformer","data","xml_default","hasJsonStructure","string_","result","type","contentTypeKey","serialize","serializers","request","response","data","options","types","accepts","serializedData","_a","breakTypes","regex","serializer","yaml_default","xml_default","headerCase","serializersMiddleware","defaultContentType","next","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","options","_a","_b","_c","_d","_e","NodeRouter","onNoMatch","onError","http_header_normalizer_default","serializers_middleware_default","create_node_router_default","createEdgeRouter","EdgeRouter","expressWrapper","NodeRouter","Router","withZod","sendJson","createHttpError","getIP","request","rateLimiterMiddleware","rateLimiter","headers","response","next","ip","limiter","mergedHeaders","key","rate_limiter_middleware_default","expressWrapper","cors","corsMiddleware","options","cors_middleware_default"]}
|
|
1
|
+
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"sourcesContent":["export * from \"./index-browser\";\n\nexport {\n default as createHttpError,\n BadRequest,\n Forbidden,\n BadGateway,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n VariantAlsoNegotiates,\n ProxyAuthenticationRequired,\n NetworkAuthenticationRequire,\n LengthRequired,\n LoopDetected,\n Locked,\n MethodNotAllowed,\n MisdirectedRequest,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n RequestHeaderFieldsTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n RangeNotSatisfiable,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n Unauthorized,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport tsJapi from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | tsJapi.JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof tsJapi.JapiError || tsJapi.JapiError.isLikeJapiError(error)) {\n const serializer = new tsJapi.ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../../utils\";\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => xml.toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"],"mappings":"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","names":["default","BadRequest","Forbidden","BadGateway","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","VariantAlsoNegotiates","ProxyAuthenticationRequired","NetworkAuthenticationRequire","LengthRequired","LoopDetected","Locked","MethodNotAllowed","MisdirectedRequest","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","RequestHeaderFieldsTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","RangeNotSatisfiable","RequestTimeout","ServiceUnavailable","TooManyRequests","Unauthorized","UnprocessableEntity","UnavailableForLegalReasons","UnsupportedMediaType","UpgradeRequired","URITooLong","NodeRouter","createHttpError","HttpError","getReasonPhrase","tsJapi","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","error","_request","response","addStatusCodeToResponse","setErrorHeaders","tsJapi","serializer","sendJson","HttpError","statusCode","title","message","getReasonPhrase","jsonapi_error_handler_default","HttpError","getReasonPhrase","defaultType","defaultTitle","problemErrorHandler","error","_request","response","stack","message","HttpError","statusCode","expose","title","type","setErrorHeaders","sendJson","getReasonPhrase","addStatusCodeToResponse","problem_error_handler_default","onError","errorHandlers","showTrace","error","request","response","apiFormat","errorHandler","problem_error_handler_default","jsonapi_error_handler_default","regex","handler","onNoMatch","routes","uniqueMethods","route","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","_a","defaults","httpHeaderNormalizerMiddleware","options_","options","request","_","next","rawHeaders","headers","normalizedKey","http_header_normalizer_default","accepts","xml","xmlTransformer","data","xml_default","hasJsonStructure","string_","result","type","contentTypeKey","serialize","serializers","request","response","data","options","types","accepts","serializedData","_a","breakTypes","regex","serializer","yaml_default","xml_default","toHeaderCase","serializersMiddleware","defaultContentType","next","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","options","_a","_b","_c","_d","_e","NodeRouter","onNoMatch","onError","http_header_normalizer_default","serializers_middleware_default","create_node_router_default","createEdgeRouter","EdgeRouter","expressWrapper","NodeRouter","Router","withZod","sendJson","createHttpError","getIP","request","rateLimiterMiddleware","rateLimiter","headers","response","next","ip","limiter","mergedHeaders","key","rate_limiter_middleware_default","expressWrapper","cors","corsMiddleware","options","cors_middleware_default"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkLMCCZDNIjs = require('../chunk-LMCCZDNI.js');var _chunkUI23SSBNjs = require('../chunk-UI23SSBN.js');require('../chunk-OUWZ2PU5.js');var _jsdocopenapi = require('@visulima/jsdoc-open-api');var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs);var _path = require('path'); var _path2 = _interopRequireDefault(_path);var l=({definition:i,sources:o,verbose:p,output:r="swagger/swagger.json"})=>n=>({...n,webpack:(e,t)=>{if(!t.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new (0, _jsdocopenapi.SwaggerCompilerPlugin)(`${t.dir}/${r}`,o.map(m=>{let a=_path2.default.join(t.dir,m.replace("./",""));return _fs2.default.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...i},{verbose:p})]},typeof n.webpack=="function"?n.webpack(e,t):e}}),d= exports.withOpenApi =l;var _connect = require('@visulima/connect');var c=(i={})=>{let o=_chunkLMCCZDNIjs.c.call(void 0, i);return _connect.createNodeRouter.call(void 0, ).get(o).handler()},h= exports.swaggerApiRoute =c;exports.RedocPage = _chunkUI23SSBNjs.a; exports.SwaggerPage = _chunkUI23SSBNjs.b; exports.getSwaggerStaticProps = _chunkUI23SSBNjs.c; exports.swaggerApiRoute = h; exports.withOpenApi = d;
|
|
2
2
|
//# sourceMappingURL=index-server.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{c as s}from"../chunk-XVXFEQ7P.mjs";import{a as x,b as y,c as A}from"../chunk-M7LGAQP3.mjs";import"../chunk-YOXCJZNX.mjs";import{SwaggerCompilerPlugin as f}from"@visulima/jsdoc-open-api";import u from"fs";import g from"path";var l=({definition:i,sources:o,verbose:p,output:r="swagger/swagger.json"})=>n=>({...n,webpack:(e,t)=>{if(!t.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new f(`${t.dir}/${r}`,o.map(m=>{let a=g.join(t.dir,m.replace("./",""));return u.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...i},{verbose:p})]},typeof n.webpack=="function"?n.webpack(e,t):e}}),d=l;import{createNodeRouter as w}from"@visulima/connect";var c=(i={})=>{let o=s(i);return w().get(o).handler()},h=c;export{x as RedocPage,y as SwaggerPage,A as getSwaggerStaticProps,h as swaggerApiRoute,d as withOpenApi};
|
|
2
2
|
//# sourceMappingURL=index-server.mjs.map
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@visulima/api-platform",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.7",
|
|
4
4
|
"description": "visulima api platform",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"anolilab",
|
|
@@ -93,7 +93,6 @@
|
|
|
93
93
|
"@visulima/connect": "1.3.1",
|
|
94
94
|
"@visulima/jsdoc-open-api": "1.2.2",
|
|
95
95
|
"accepts": "^1.3.8",
|
|
96
|
-
"case": "^1.6.3",
|
|
97
96
|
"debug": "^4.3.4",
|
|
98
97
|
"http-errors": "^2.0.0",
|
|
99
98
|
"http-status-codes": "^2.2.0",
|
|
@@ -125,7 +124,7 @@
|
|
|
125
124
|
"@types/webpack": "^5.28.0",
|
|
126
125
|
"@typescript-eslint/eslint-plugin": "^5.40.0",
|
|
127
126
|
"@typescript-eslint/parser": "^5.40.0",
|
|
128
|
-
"@visulima/crud": "1.0.
|
|
127
|
+
"@visulima/crud": "1.0.8",
|
|
129
128
|
"@visulima/readdir": "1.3.2",
|
|
130
129
|
"chalk": "5.2.0",
|
|
131
130
|
"commander": "^9.4.1",
|
|
@@ -170,7 +169,7 @@
|
|
|
170
169
|
"swagger-ui-react": "^4.14.3",
|
|
171
170
|
"tsup": "^6.2.3",
|
|
172
171
|
"typescript": "^4.8.4",
|
|
173
|
-
"vitest": "^0.
|
|
172
|
+
"vitest": "^0.26.1",
|
|
174
173
|
"webpack": "^5.74.0",
|
|
175
174
|
"zod": "^3.19.1"
|
|
176
175
|
},
|
|
@@ -180,7 +179,7 @@
|
|
|
180
179
|
"zod": "^3.19.1"
|
|
181
180
|
},
|
|
182
181
|
"optionalDependencies": {
|
|
183
|
-
"@visulima/crud": "1.0.
|
|
182
|
+
"@visulima/crud": "1.0.8",
|
|
184
183
|
"@visulima/readdir": "1.3.2",
|
|
185
184
|
"chalk": "4.1.2",
|
|
186
185
|
"commander": "^9.4.1",
|
package/dist/chunk-AG2ROSSA.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{modelsToOpenApi as X}from"@visulima/crud";import q from"debug";import M from"lodash.merge";import{existsSync as B,readFileSync as G}from"fs";import Q from"path";import{stringify as T}from"yaml";var D=e=>T(e,{indent:2}),w=D;import{header as E}from"case";import{toXML as $}from"jstoxml";import{stringify as C}from"yaml";var I="application/json",V=(e,n,s)=>{var a,c,p,r,t;((c=(a=e==null?void 0:e.responses)==null?void 0:a[n])==null?void 0:c.content)===void 0&&(e.responses[n].content={}),((t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])===void 0&&(e.responses[n].content[s]={})},v=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===void 0&&(e.components.schemas[n]=s)},H=(e,n,s,a,c)=>{var p,r,t,f;V(e,n,s),((f=(t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])==null?void 0:f.schema)===void 0&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=c?{type:"array",items:{$ref:`#/components/schemas/${a}`}}:{$ref:`#/components/schemas/${a}`}},F=(e,n,s,a,c,p)=>{let r,t;return Object.entries(n.content).forEach(([f,o])=>{if(typeof o.schema=="object"){let{schema:i}=o;f===I&&o.examples!==void 0?t=o.examples:f===I&&o.example!==void 0&&(r=o.example);let O=i.type==="array";Object.entries(s||{}).forEach(([j,b])=>{if(!b)return;let P;i.$ref===void 0?(P=`${E(a.trim().replace("/",""))}${j==="application/ld+json"?".jsonld":""}`,v(c,P,i)):P=i.$ref.replace("#/components/schemas/",""),H(e,p,j,P,O)})}}),{examples:t,example:r}},J=(e,n,s,a,c,p)=>{Object.keys(n.content).forEach(r=>{r!==I&&Object.entries(a||{}).forEach(([t,f])=>{var i,O,j,b;if(!f)return;V(e,s,t),((b=(j=(O=(i=e==null?void 0:e.responses)==null?void 0:i[s])==null?void 0:O.content)==null?void 0:j[t])==null?void 0:b.example)===void 0&&(e.responses[s].content[t].example={});let o=!1;c.forEach(({regex:P,transformer:A})=>{!o&&P.test(t)&&(e.responses[s].content[t].example=A(p),o=!0)}),o||(e.responses[s].content[t].example=p)})})},W=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===void 0&&s[n]!==void 0&&(e.components.examples[n]=s[n])},z=(e,n,s,a,c,p)=>{var t,f,o,i;V(n,s,a),((i=(o=(f=(t=n==null?void 0:n.responses)==null?void 0:t[s])==null?void 0:f.content)==null?void 0:o[a])==null?void 0:i.examples)===void 0&&(n.responses[s].content[a].examples={});let r={};Object.entries(p).forEach(([O,j])=>{var P,A;let b=!1;c.forEach(({regex:k,transformer:h})=>{var m,u,d,y,R,x;if(!b&&k.test(a)){let g="";((u=(m=e.components)==null?void 0:m.examples)==null?void 0:u[O])!==void 0?g=((y=(d=e.components)==null?void 0:d.examples)==null?void 0:y[O]).value:j?g=((x=(R=e.components)==null?void 0:R.examples)==null?void 0:x[j.$ref.replace("#/components/examples/","")]).value:typeof(j==null?void 0:j.value)=="string"&&(g=j.value),r[O]={value:h(g)},b=!0}}),b||(r[O]=((A=(P=e.components)==null?void 0:P.examples)==null?void 0:A[O])===void 0?j:{$ref:`#/components/examples/${O}`})}),n.responses[s].content[a].examples=r},L=(e,n,s,a,c,p,r,t)=>{let f=`${E(p.trim().replace("/",""))}`;Object.keys(a.content).forEach(o=>{o!==I&&Object.entries(c||{}).forEach(([i,O])=>{!O||(W(e,f,t),z(e,n,s,i,r,t))})})};function l(e,n,s=[{regex:/xml/,transformer:a=>$(a,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:a=>C(a,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([a,c])=>{Object.values(c).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([r,t])=>{if(typeof t.content=="object"){let{examples:f,example:o}=F(p,t,n,a,e,r);o!==void 0?J(p,t,r,n,s,o):f!==void 0&&L(e,p,r,t,n,a,s,f)}})})}),e}var U=q("visulima:api-platform:swagger:crud:get-static-properties-swagger"),Y=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:a,specs:c}=e;return async(p,r)=>{let t=Q.join(process.cwd(),s||"swagger/swagger.json");if(!B(t))throw new Error(`Swagger file not found at ${t}. Did you change the output path in "withOpenApi" inside the next.config.js file?`);let f=G(t,"utf8"),o=l(JSON.parse(f),n),i={};if(a!==void 0)try{let O=await X(a);i={components:{schemas:O.schemas,examples:O.examples},tags:O.tags,paths:O.paths},i=l(i,n),U(JSON.stringify(i,null,2)),o=M(o,i)}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(c)&&c.forEach(O=>{o=M(o,l(O,n))}),typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(r.statusCode=200,r.setHeader("Content-Type",p.headers.accept),r.end(w(o))):(r.statusCode=200,r.setHeader("Content-Type","application/json"),r.end(JSON.stringify(o,null,2)))}},Oe=Y;export{w as a,Oe as b};
|
|
2
|
-
//# sourceMappingURL=chunk-AG2ROSSA.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/swagger/swagger-handler.ts","../src/connect/serializers/yaml.ts","../src/swagger/extend-swagger-spec.ts"],"sourcesContent":["// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../connect/serializers/yaml\";\nimport extendSwaggerSpec from \"./extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = (options: Partial<SwaggerHandlerOptions> = {}) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.join(process.cwd(), swaggerFilePath || \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at ${swaggerPath}. Did you change the output path in \"withOpenApi\" inside the next.config.js file?`);\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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags as OpenAPIV3.TagObject[],\n paths: modelsOpenApi.paths,\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 if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", request.headers.accept);\n response.end(yamlTransformer(spec));\n } else {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(JSON.stringify(spec, null, 2));\n }\n };\n};\n\nexport type SwaggerHandlerOptions = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<string>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"./types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","/* eslint-disable no-param-reassign */\nimport { header as headerCase } from \"case\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\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 ((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 (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\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 (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 as OpenAPIV3.ReferenceObject).$ref === undefined) {\n // eslint-disable-next-line max-len\n schemaName = `${headerCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n) => {\n if (typeof spec.components !== \"object\") {\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\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: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n } = {};\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] as OpenAPIV3.ExampleObject) !== undefined) {\n data = (spec.components?.examples?.[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if (example as OpenAPIV3.ReferenceObject) {\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] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n) => {\n const examplesName = `${headerCase(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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value) => 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.PathsObject & OpenAPIV3.OperationObject).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 { examples, example } = 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\n/* eslint-enable no-param-reassign */\n"],"mappings":"AAGA,OAAS,mBAAAA,MAAuB,iBAChC,OAAOC,MAAW,QAClB,OAAOC,MAAW,eAClB,OAAS,cAAAC,EAAY,gBAAAC,MAAoB,KAEzC,OAAOC,MAAU,OCRjB,OAAS,aAAAC,MAAiB,OAI1B,IAAMC,EAA+BC,GAASF,EAAUE,EAAM,CAAE,OAAQ,CAAE,CAAC,EAEpEC,EAAQF,ECLf,OAAS,UAAUG,MAAkB,OACrC,OAAS,SAAAC,MAAa,UAEtB,OAAS,aAAAC,MAAiB,OAI1B,IAAMC,EAAgB,mBAEhBC,EAAuB,CAACC,EAA2CC,EAAgBC,IAAsB,CAV/G,IAAAC,EAAAC,EAAAC,EAAAC,EAAAC,IAWUH,GAAAD,EAAAH,GAAA,YAAAA,EAAY,YAAZ,YAAAG,EAAiEF,KAAjE,YAAAG,EAAuG,WAAY,SACnHJ,EAAW,UAAmDC,GAAqC,QAAU,CAAC,KAG9GM,GAAAD,GAAAD,EAAAL,GAAA,YAAAA,EAAY,YAAZ,YAAAK,EAAiEJ,KAAjE,YAAAK,EAAuG,UAAvG,YAAAC,EAAiHL,MAAe,SAE5HF,EAAW,UAAmDC,GAAqC,QAGvGC,GAAa,CAAC,EAExB,EAEMM,EAAyB,CAACC,EAAmCC,EAAoBC,IAAmC,CAClH,OAAOF,EAAK,YAAe,WAC3BA,EAAK,WAAa,CAAC,GAGnB,OAAOA,EAAK,WAAW,SAAY,WACnCA,EAAK,WAAW,QAAU,CAAC,GAG3BA,EAAK,WAAW,QAAQC,KAAgB,SACxCD,EAAK,WAAW,QAAQC,GAAcC,EAE9C,EAEMC,EAAuB,CAACZ,EAAuCC,EAAgBC,EAAmBQ,EAAoBG,IAA2B,CAtCvJ,IAAAV,EAAAC,EAAAC,EAAAC,EAuCIP,EAAqBC,EAAYC,EAAQC,CAAS,IAE5CI,GAAAD,GAAAD,GAAAD,EAAAH,GAAA,YAAAA,EAAY,YAAZ,YAAAG,EAAiEF,KAAjE,YAAAG,EAAuG,UAAvG,YAAAC,EAAiHH,KAAjH,YAAAI,EAA6H,UAAW,SAGhIN,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,OAAS,CAAC,GAKNF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,OAASW,EACL,CACE,KAAM,QACN,MAAO,CACH,KAAM,wBAAwBH,GAClC,CACJ,EACE,CACE,KAAM,wBAAwBA,GAClC,CACR,EAEMI,EAAmC,CACrCd,EACAe,EACAC,EACAC,EACAR,EACAR,IAMC,CACD,IAAIiB,EACAC,EAOJ,cAAO,QAAQJ,EAAa,OAAiB,EAAE,QAAQ,CAAC,CAACK,EAAWC,CAAW,IAAM,CACjF,GAAI,OAAOA,EAAY,QAAW,SAAU,CACxC,GAAM,CAAE,OAAAV,CAAO,EAAIU,EAEfD,IAActB,GAAiBuB,EAAY,WAAa,OACxDF,EAAWE,EAAY,SAChBD,IAActB,GAAiBuB,EAAY,UAAY,SAC9DH,EAAUG,EAAY,SAG1B,IAAMR,EAAiBF,EAAkC,OAAS,QAElE,OAAO,QAAQK,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACd,EAAWoB,CAAO,IAAM,CACtE,GAAI,CAACA,EACD,OAGJ,IAAIZ,EAECC,EAAqC,OAAS,QAE/CD,EAAa,GAAGf,EAAWsB,EAAQ,KAAK,EAAE,QAAQ,IAAK,EAAE,CAAC,IAAIf,IAAc,sBAAwB,UAAY,KAEhHM,EAAuBC,EAA4BC,EAAYC,CAAgC,GAG/FD,EAAcC,EAAqC,KAAK,QAAQ,wBAAyB,EAAE,EAG/FC,EAAqBZ,EAAYC,EAAQC,EAAWQ,EAAYG,CAAa,CACjF,CAAC,CACL,CACJ,CAAC,EAEM,CAAE,SAAAM,EAAU,QAAAD,CAAQ,CAC/B,EAEMK,EAAoC,CACtCvB,EACAe,EACAd,EACAe,EACAQ,EACAN,IACC,CACD,OAAO,KAAKH,EAAa,OAAiB,EAAE,QAASK,GAAc,CAC3DA,IAActB,GAIlB,OAAO,QAAQkB,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACd,EAAWoB,CAAO,IAAM,CA5IlF,IAAAnB,EAAAC,EAAAC,EAAAC,EA6IY,GAAI,CAACgB,EACD,OAGJvB,EAAqBC,EAAYC,EAAQC,CAAS,IAG5CI,GAAAD,GAAAD,GAAAD,EAAAH,GAAA,YAAAA,EAAY,YAAZ,YAAAG,EAAiEF,KAAjE,YAAAG,EAAuG,UAAvG,YAAAC,EAAiHH,KAAjH,YAAAI,EAA6H,WAC3H,SAIMN,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAU,CAAC,GAGjB,IAAIuB,EAAc,GAElBD,EAAa,QAAQ,CAAC,CAAE,MAAAE,EAAO,YAAAC,CAAY,IAAM,CACzC,CAACF,GAAeC,EAAM,KAAKxB,CAAS,IAG1BF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAUyB,EAAYT,CAAO,EAE/BO,EAAc,GAEtB,CAAC,EAEIA,IAGSzB,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAUgB,EAEpB,CAAC,CACL,CAAC,CACL,EAEMU,EAA0B,CAC5BnB,EACAoB,EACAV,IAGC,CACG,OAAOV,EAAK,YAAe,WAC3BA,EAAK,WAAa,CAAC,GAGnB,OAAOA,EAAK,WAAW,UAAa,WACpCA,EAAK,WAAW,SAAW,CAAC,GAG5BA,EAAK,WAAW,SAASoB,KAAiB,QAAaV,EAASU,KAAiB,SACjFpB,EAAK,WAAW,SAASoB,GAAeV,EAASU,GAEzD,EAEMC,EAA0B,CAC5BrB,EACAT,EACAC,EACAC,EACAsB,EACAL,IAIC,CA3NL,IAAAhB,EAAAC,EAAAC,EAAAC,EA4NIP,EAAqBC,EAAYC,EAAQC,CAAS,IAE5CI,GAAAD,GAAAD,GAAAD,EAAAH,GAAA,YAAAA,EAAY,YAAZ,YAAAG,EAAiEF,KAAjE,YAAAG,EAAuG,UAAvG,YAAAC,EAAiHH,KAAjH,YAAAI,EAA6H,YAAa,SAGlIN,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,SAAW,CAAC,GAGlB,IAAM6B,EAEF,CAAC,EAEL,OAAO,QAAQZ,CAAQ,EAAE,QAAQ,CAAC,CAACU,EAAaX,CAAO,IAAM,CA5OjE,IAAAf,EAAAC,EA6OQ,IAAIqB,EAAc,GAElBD,EAAa,QAAQ,CAAC,CAAE,MAAAE,EAAO,YAAAC,CAAY,IAAM,CA/OzD,IAAAxB,EAAAC,EAAAC,EAAAC,EAAAC,EAAAyB,EAgPY,GAAI,CAACP,GAAeC,EAAM,KAAKxB,CAAS,EAAG,CACvC,IAAI+B,EAAY,KAEX7B,GAAAD,EAAAM,EAAK,aAAL,YAAAN,EAAiB,WAAjB,YAAAC,EAA4ByB,MAA6C,OAC1EI,IAAQ3B,GAAAD,EAAAI,EAAK,aAAL,YAAAJ,EAAiB,WAAjB,YAAAC,EAA4BuB,IAAyC,MACtEX,EACPe,IACID,GAAAzB,EAAAE,EAAK,aAAL,YAAAF,EAAiB,WAAjB,YAAAyB,EACKd,EAAsC,KAAK,QAAQ,yBAA0B,EAAE,IAEtF,MACK,OAAQA,GAAA,YAAAA,EAAqC,QAAU,WAC9De,EAAQf,EAAoC,OAGhDa,EAAoBF,GAAe,CAC/B,MAAOF,EAAYM,CAAI,CAC3B,EAEAR,EAAc,EAClB,CACJ,CAAC,EAEIA,IACDM,EAAoBF,KAAezB,GAAAD,EAAAM,EAAK,aAAL,YAAAN,EAAiB,WAAjB,YAAAC,EAA4ByB,MAAiB,OAC1EX,EACA,CACE,KAAM,yBAAyBW,GACnC,EAEZ,CAAC,EAIS7B,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,SAAW6B,CACjB,EAEMG,EAAqC,CACvCzB,EACAT,EACAC,EACAc,EACAC,EACAC,EACAO,EACAL,IAGC,CACD,IAAMgB,EAAe,GAAGxC,EAAWsB,EAAQ,KAAK,EAAE,QAAQ,IAAK,EAAE,CAAC,IAElE,OAAO,KAAKF,EAAa,OAAiB,EAAE,QAASK,GAAc,CAC3DA,IAActB,GAIlB,OAAO,QAAQkB,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACd,EAAWoB,CAAO,IAAM,CAClE,CAACA,IAILM,EAAwBnB,EAAM0B,EAAchB,CAAQ,EAEpDW,EAAwBrB,EAAMT,EAAYC,EAAQC,EAAWsB,EAAcL,CAAQ,EACvF,CAAC,CACL,CAAC,CACL,EAGe,SAARiB,EACH3B,EACAO,EACAQ,EAA6B,CACzB,CACI,MAAO,MACP,YAAca,GAAUzC,EAAMyC,EAAO,CACjC,OAAQ,GACR,OAAQ,IACZ,CAAC,CACL,EACA,CACI,MAAO,WACP,YAAcA,GAAUxC,EAAUwC,EAAO,CAAE,OAAQ,CAAE,CAAC,CAC1D,CACJ,EAC2B,CAC3B,OAAI,OAAO5B,GAAS,UAAY,OAAOA,EAAK,OAAU,UAClD,OAAO,QAAQA,EAAK,KAAK,EAAE,QAAQ,CAAC,CAACQ,EAASqB,CAAQ,IAAM,CACxD,OAAO,OAAOA,CAA6D,EAAE,QAAStC,GAAe,CAC7F,OAAQA,EAAyC,WAAc,UAC/D,OAAO,QAASA,EAAyC,SAAS,EAAE,QAAQ,CAAC,CAACC,EAAQc,CAAY,IAAM,CACpG,GAAI,OAAQA,EAA0C,SAAY,SAAU,CACxE,GAAM,CAAE,SAAAI,EAAU,QAAAD,CAAQ,EAAIJ,EAC1Bd,EACAe,EACAC,EACAC,EACAR,EACAR,CACJ,EAEIiB,IAAY,OACZK,EACIvB,EACAe,EACAd,EACAe,EACAQ,EACAN,CACJ,EACOC,IAAa,QACpBe,EACIzB,EACAT,EACAC,EACAc,EACAC,EACAC,EACAO,EACAL,CACJ,CAER,CACJ,CAAC,CAET,CAAC,CACL,CAAC,EAGEV,CACX,CFvWA,IAAM8B,EAAmBC,EAAM,kEAAkE,EAE3FC,EAAiB,CAACC,EAA0C,CAAC,IAAM,CACrE,GAAM,CACF,kBAAAC,EAAoB,CAChB,mBAAoB,EACxB,EACA,gBAAAC,EACA,KAAAC,EACA,MAAAC,CACJ,EAAIJ,EAEJ,MAAO,OAAyEK,EAAkBC,IAAuB,CACrH,IAAMC,EAAcC,EAAK,KAAK,QAAQ,IAAI,EAAGN,GAAmB,sBAAsB,EAEtF,GAAI,CAACO,EAAWF,CAAW,EACvB,MAAM,IAAI,MAAM,6BAA6BA,oFAA8F,EAG/I,IAAMG,EAAeC,EAAaJ,EAAa,MAAM,EAEjDK,EAAOC,EAAkB,KAAK,MAAMH,CAAY,EAAyBT,CAAiB,EAC1Fa,EAA2C,CAAC,EAEhD,GAAIX,IAAS,OACT,GAAI,CACA,IAAMY,EAAgB,MAAMC,EAAgBb,CAAI,EAEhDW,EAAc,CACV,WAAY,CAAE,QAASC,EAAc,QAAS,SAAUA,EAAc,QAAS,EAC/E,KAAMA,EAAc,KACpB,MAAOA,EAAc,KACzB,EAEAD,EAAcD,EAAkBC,EAAab,CAAiB,EAE9DJ,EAAiB,KAAK,UAAUiB,EAAa,KAAM,CAAC,CAAC,EAErDF,EAAOK,EAAML,EAAME,CAAW,CAClC,OAASI,EAAP,CAEE,cAAQ,IAAIA,CAAK,EAEX,IAAI,MAAM,kEAAkE,CACtF,CAGA,MAAM,QAAQd,CAAK,GACnBA,EAAM,QAASe,GAAU,CACrBP,EAAOK,EAAML,EAAMC,EAAkBM,EAAOlB,CAAiB,CAAC,CAClE,CAAC,EAGD,OAAOI,EAAQ,QAAQ,QAAW,UAAY,WAAW,KAAKA,EAAQ,QAAQ,MAAM,GACpFC,EAAS,WAAa,IACtBA,EAAS,UAAU,eAAgBD,EAAQ,QAAQ,MAAM,EACzDC,EAAS,IAAIc,EAAgBR,CAAI,CAAC,IAElCN,EAAS,WAAa,IACtBA,EAAS,UAAU,eAAgB,kBAAkB,EACrDA,EAAS,IAAI,KAAK,UAAUM,EAAM,KAAM,CAAC,CAAC,EAElD,CACJ,EAaOS,GAAQtB","names":["modelsToOpenApi","debug","merge","existsSync","readFileSync","path","stringify","yamlTransformer","data","yaml_default","headerCase","toXML","stringify","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","_a","_b","_c","_d","_e","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","_f","data","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","allowedMediaTypes","swaggerFilePath","crud","specs","request","response","swaggerPath","path","existsSync","fileContents","readFileSync","spec","extendSwaggerSpec","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","value","yaml_default","swagger_handler_default"]}
|
package/dist/chunk-QIHOLJVA.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _crud = require('@visulima/crud');var _debug = require('debug'); var _debug2 = _interopRequireDefault(_debug);var _lodashmerge = require('lodash.merge'); var _lodashmerge2 = _interopRequireDefault(_lodashmerge);var _fs = require('fs');var _path = require('path'); var _path2 = _interopRequireDefault(_path);var _yaml = require('yaml');var D=e=>_yaml.stringify.call(void 0, e,{indent:2}),w= exports.a =D;var _case = require('case');var _jstoxml = require('jstoxml');var I="application/json",V=(e,n,s)=>{var a,c,p,r,t;((c=(a=e==null?void 0:e.responses)==null?void 0:a[n])==null?void 0:c.content)===void 0&&(e.responses[n].content={}),((t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])===void 0&&(e.responses[n].content[s]={})},v=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===void 0&&(e.components.schemas[n]=s)},H=(e,n,s,a,c)=>{var p,r,t,f;V(e,n,s),((f=(t=(r=(p=e==null?void 0:e.responses)==null?void 0:p[n])==null?void 0:r.content)==null?void 0:t[s])==null?void 0:f.schema)===void 0&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=c?{type:"array",items:{$ref:`#/components/schemas/${a}`}}:{$ref:`#/components/schemas/${a}`}},F=(e,n,s,a,c,p)=>{let r,t;return Object.entries(n.content).forEach(([f,o])=>{if(typeof o.schema=="object"){let{schema:i}=o;f===I&&o.examples!==void 0?t=o.examples:f===I&&o.example!==void 0&&(r=o.example);let O=i.type==="array";Object.entries(s||{}).forEach(([j,b])=>{if(!b)return;let P;i.$ref===void 0?(P=`${_case.header.call(void 0, a.trim().replace("/",""))}${j==="application/ld+json"?".jsonld":""}`,v(c,P,i)):P=i.$ref.replace("#/components/schemas/",""),H(e,p,j,P,O)})}}),{examples:t,example:r}},J=(e,n,s,a,c,p)=>{Object.keys(n.content).forEach(r=>{r!==I&&Object.entries(a||{}).forEach(([t,f])=>{var i,O,j,b;if(!f)return;V(e,s,t),((b=(j=(O=(i=e==null?void 0:e.responses)==null?void 0:i[s])==null?void 0:O.content)==null?void 0:j[t])==null?void 0:b.example)===void 0&&(e.responses[s].content[t].example={});let o=!1;c.forEach(({regex:P,transformer:A})=>{!o&&P.test(t)&&(e.responses[s].content[t].example=A(p),o=!0)}),o||(e.responses[s].content[t].example=p)})})},W=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===void 0&&s[n]!==void 0&&(e.components.examples[n]=s[n])},z=(e,n,s,a,c,p)=>{var t,f,o,i;V(n,s,a),((i=(o=(f=(t=n==null?void 0:n.responses)==null?void 0:t[s])==null?void 0:f.content)==null?void 0:o[a])==null?void 0:i.examples)===void 0&&(n.responses[s].content[a].examples={});let r={};Object.entries(p).forEach(([O,j])=>{var P,A;let b=!1;c.forEach(({regex:k,transformer:h})=>{var m,u,d,y,R,x;if(!b&&k.test(a)){let g="";((u=(m=e.components)==null?void 0:m.examples)==null?void 0:u[O])!==void 0?g=((y=(d=e.components)==null?void 0:d.examples)==null?void 0:y[O]).value:j?g=((x=(R=e.components)==null?void 0:R.examples)==null?void 0:x[j.$ref.replace("#/components/examples/","")]).value:typeof(j==null?void 0:j.value)=="string"&&(g=j.value),r[O]={value:h(g)},b=!0}}),b||(r[O]=((A=(P=e.components)==null?void 0:P.examples)==null?void 0:A[O])===void 0?j:{$ref:`#/components/examples/${O}`})}),n.responses[s].content[a].examples=r},L=(e,n,s,a,c,p,r,t)=>{let f=`${_case.header.call(void 0, p.trim().replace("/",""))}`;Object.keys(a.content).forEach(o=>{o!==I&&Object.entries(c||{}).forEach(([i,O])=>{!O||(W(e,f,t),z(e,n,s,i,r,t))})})};function l(e,n,s=[{regex:/xml/,transformer:a=>_jstoxml.toXML.call(void 0, a,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:a=>_yaml.stringify.call(void 0, a,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([a,c])=>{Object.values(c).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([r,t])=>{if(typeof t.content=="object"){let{examples:f,example:o}=F(p,t,n,a,e,r);o!==void 0?J(p,t,r,n,s,o):f!==void 0&&L(e,p,r,t,n,a,s,f)}})})}),e}var U=_debug2.default.call(void 0, "visulima:api-platform:swagger:crud:get-static-properties-swagger"),Y=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:a,specs:c}=e;return async(p,r)=>{let t=_path2.default.join(process.cwd(),s||"swagger/swagger.json");if(!_fs.existsSync.call(void 0, t))throw new Error(`Swagger file not found at ${t}. Did you change the output path in "withOpenApi" inside the next.config.js file?`);let f=_fs.readFileSync.call(void 0, t,"utf8"),o=l(JSON.parse(f),n),i={};if(a!==void 0)try{let O=await _crud.modelsToOpenApi.call(void 0, a);i={components:{schemas:O.schemas,examples:O.examples},tags:O.tags,paths:O.paths},i=l(i,n),U(JSON.stringify(i,null,2)),o=_lodashmerge2.default.call(void 0, o,i)}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(c)&&c.forEach(O=>{o=_lodashmerge2.default.call(void 0, o,l(O,n))}),typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(r.statusCode=200,r.setHeader("Content-Type",p.headers.accept),r.end(w(o))):(r.statusCode=200,r.setHeader("Content-Type","application/json"),r.end(JSON.stringify(o,null,2)))}},Oe= exports.b =Y;exports.a = w; exports.b = Oe;
|
|
2
|
-
//# sourceMappingURL=chunk-QIHOLJVA.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/swagger/swagger-handler.ts","../src/connect/serializers/yaml.ts","../src/swagger/extend-swagger-spec.ts"],"names":["modelsToOpenApi","debug","merge","existsSync","readFileSync","path","stringify","yamlTransformer","data","yaml_default","headerCase","toXML","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","_a","_b","_c","_d","_e","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","_f","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","pathSpec","swaggerCrudDebug","swaggerHandler","options","swaggerFilePath","crud","specs","request","response","swaggerPath","fileContents","crudSwagger","modelsOpenApi","error","swagger_handler_default"],"mappings":"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","sourcesContent":["// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../connect/serializers/yaml\";\nimport extendSwaggerSpec from \"./extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = (options: Partial<SwaggerHandlerOptions> = {}) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.join(process.cwd(), swaggerFilePath || \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at ${swaggerPath}. Did you change the output path in \"withOpenApi\" inside the next.config.js file?`);\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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags as OpenAPIV3.TagObject[],\n paths: modelsOpenApi.paths,\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 if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", request.headers.accept);\n response.end(yamlTransformer(spec));\n } else {\n response.statusCode = 200;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(JSON.stringify(spec, null, 2));\n }\n };\n};\n\nexport type SwaggerHandlerOptions = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<string>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"./types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","/* eslint-disable no-param-reassign */\nimport { header as headerCase } from \"case\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\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 ((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 (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\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 (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 as OpenAPIV3.ReferenceObject).$ref === undefined) {\n // eslint-disable-next-line max-len\n schemaName = `${headerCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n) => {\n if (typeof spec.components !== \"object\") {\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\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: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n } = {};\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] as OpenAPIV3.ExampleObject) !== undefined) {\n data = (spec.components?.examples?.[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if (example as OpenAPIV3.ReferenceObject) {\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] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ReferenceObject | OpenAPIV3.ExampleObject;\n },\n) => {\n const examplesName = `${headerCase(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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value) => 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.PathsObject & OpenAPIV3.OperationObject).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 { examples, example } = 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\n/* eslint-enable no-param-reassign */\n"]}
|