@visulima/api-platform 1.2.3 → 1.2.4
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 +18 -0
- package/dist/chunk-2ZMPKWQQ.mjs +5 -0
- package/dist/chunk-4GBB2H25.mjs +13 -0
- package/dist/chunk-4GBB2H25.mjs.map +1 -0
- package/dist/chunk-4ZTB2SHJ.mjs +9 -0
- package/dist/chunk-4ZTB2SHJ.mjs.map +1 -0
- package/dist/chunk-A2BQLJ5W.mjs +7 -0
- package/dist/chunk-A2BQLJ5W.mjs.map +1 -0
- package/dist/chunk-BIZOICFF.js +13 -0
- package/dist/chunk-BIZOICFF.js.map +1 -0
- package/dist/chunk-DELU3TYG.js +8 -0
- package/dist/chunk-NH4B62H7.js +25 -0
- package/dist/chunk-NH4B62H7.js.map +1 -0
- package/dist/chunk-QJNODCPR.js +13 -0
- package/dist/chunk-QJNODCPR.js.map +1 -0
- package/dist/chunk-S26T4TPK.mjs +17 -0
- package/dist/chunk-S26T4TPK.mjs.map +1 -0
- package/dist/chunk-SNOJMSHW.js +24 -0
- package/dist/chunk-SNOJMSHW.js.map +1 -0
- package/dist/framework/cli/commander/index.js +3 -3
- package/dist/framework/cli/commander/index.mjs +2 -2
- package/dist/framework/cli/index.js +3 -3
- package/dist/framework/cli/index.mjs +2 -2
- package/dist/framework/next/index-browser.d.ts +1 -3
- package/dist/framework/next/index-browser.js +3 -11
- package/dist/framework/next/index-browser.mjs +2 -2
- package/dist/framework/next/index-server.d.ts +3 -5
- package/dist/framework/next/index-server.js +13 -16
- package/dist/framework/next/index-server.js.map +1 -1
- package/dist/framework/next/index-server.mjs +7 -7
- package/dist/framework/next/index-server.mjs.map +1 -1
- package/dist/framework/next/routes/pages/redoc/index.d.ts +7 -0
- package/dist/framework/next/routes/pages/redoc/index.js +20 -0
- package/dist/framework/next/routes/pages/redoc/index.js.map +1 -0
- package/dist/framework/next/routes/pages/redoc/index.mjs +14 -0
- package/dist/framework/next/routes/pages/redoc/index.mjs.map +1 -0
- package/dist/framework/next/routes/pages/swagger/index.d.ts +7 -0
- package/dist/framework/next/routes/pages/swagger/index.js +21 -0
- package/dist/framework/next/routes/pages/swagger/index.js.map +1 -0
- package/dist/framework/next/routes/pages/swagger/index.mjs +14 -0
- package/dist/framework/next/routes/pages/swagger/index.mjs.map +1 -0
- package/dist/get-static-properties-swagger-546ee3ba.d.ts +5 -0
- package/dist/index-browser.js +3 -3
- package/dist/index-browser.mjs +2 -2
- package/dist/index-server.d.ts +3 -3
- package/dist/index-server.js +22 -10
- package/dist/index-server.js.map +1 -1
- package/dist/index-server.mjs +4 -4
- package/dist/index-server.mjs.map +1 -1
- package/next/pages/redoc/package.json +19 -0
- package/next/pages/swagger/package.json +19 -0
- package/package.json +77 -63
- package/dist/chunk-EP2A5R2C.js +0 -13
- package/dist/chunk-EP2A5R2C.js.map +0 -1
- package/dist/chunk-ESKLEDNF.mjs +0 -13
- package/dist/chunk-ESKLEDNF.mjs.map +0 -1
- package/dist/chunk-IMU5ULVF.js +0 -18
- package/dist/chunk-IMU5ULVF.js.map +0 -1
- package/dist/chunk-OC7L637G.js +0 -23
- package/dist/chunk-OC7L637G.js.map +0 -1
- package/dist/chunk-OUWZ2PU5.js +0 -7
- package/dist/chunk-PXVY7JQL.js +0 -19
- package/dist/chunk-PXVY7JQL.js.map +0 -1
- package/dist/chunk-R22PP2JL.mjs +0 -17
- package/dist/chunk-R22PP2JL.mjs.map +0 -1
- package/dist/chunk-SCOIFGN7.mjs +0 -19
- package/dist/chunk-SCOIFGN7.mjs.map +0 -1
- package/dist/chunk-WJDS32PO.mjs +0 -9
- package/dist/chunk-WJDS32PO.mjs.map +0 -1
- package/dist/chunk-YOXCJZNX.mjs +0 -5
- package/dist/swagger-b2ff43e0.d.ts +0 -11
- /package/dist/{chunk-OUWZ2PU5.js.map → chunk-2ZMPKWQQ.mjs.map} +0 -0
- /package/dist/{chunk-YOXCJZNX.mjs.map → chunk-DELU3TYG.js.map} +0 -0
package/dist/index-server.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
require('./chunk-
|
|
3
|
+
var chunkQJNODCPR_js = require('./chunk-QJNODCPR.js');
|
|
4
|
+
var chunkNH4B62H7_js = require('./chunk-NH4B62H7.js');
|
|
5
|
+
require('./chunk-DELU3TYG.js');
|
|
6
6
|
var k = require('http-errors');
|
|
7
7
|
var connect = require('@visulima/connect');
|
|
8
8
|
var httpStatusCodes = require('http-status-codes');
|
|
@@ -12,27 +12,36 @@ var $ = require('accepts');
|
|
|
12
12
|
var G = require('jstoxml');
|
|
13
13
|
var pe = require('cors');
|
|
14
14
|
|
|
15
|
-
|
|
15
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
16
|
+
|
|
17
|
+
var k__default = /*#__PURE__*/_interopDefault(k);
|
|
18
|
+
var g__default = /*#__PURE__*/_interopDefault(g);
|
|
19
|
+
var Y__default = /*#__PURE__*/_interopDefault(Y);
|
|
20
|
+
var $__default = /*#__PURE__*/_interopDefault($);
|
|
21
|
+
var G__default = /*#__PURE__*/_interopDefault(G);
|
|
22
|
+
var pe__default = /*#__PURE__*/_interopDefault(pe);
|
|
23
|
+
|
|
24
|
+
var f=(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));},u=(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 v="An error occurred",J=(e,o,t)=>{if(u(t,e),f(t,e),e instanceof g__default.default.JapiError||g__default.default.JapiError.isLikeJapiError(e)){let r=new g__default.default.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof k.HttpError){let{statusCode:r,title:a,message:n}=e;p(t,{errors:[{code:r,title:a||httpStatusCodes.getReasonPhrase(r)||v,detail:n}]});}else {let{message:r}=e;p(t,{errors:[{code:"500",title:httpStatusCodes.getReasonPhrase(t.statusCode)||v,detail:r}]});}},z=J;var A="https://tools.ietf.org/html/rfc2616#section-10",M="An error occurred",W=(e,o,t)=>{let{stack:r,message:a}=e;if(e instanceof k.HttpError){let{statusCode:n,expose:s,title:i,type:d}=e;t.statusCode=n,f(t,e),p(t,{type:d||A,title:i||httpStatusCodes.getReasonPhrase(n)||M,details:a,...s?{trace:r}:{}});}else u(t,e),p(t,{type:A,title:httpStatusCodes.getReasonPhrase(t.statusCode)||M,details:a,...e.expose?{trace:r}:{}});},C=W;var x=(e,o)=>async(t,r,a)=>{let n=r.headers.accept,s=C;n==="application/vnd.api+json"&&(s=z);for(let{regex:i,handler:d}of e)if(i.test(n)){s=d;break}t.expose=o,s(t,r,a);},h=async(e,o,t)=>{let r=[...new Set(t.map(a=>a.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,k__default.default(405,`No route with [${e.method}] method found.`)};var I={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"},X=(e,o)=>{let t=e.toLowerCase();return o?I[t]?I[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},K={canonical:!1,normalizeHeaderKey:X},Z=e=>{let o={...K,...e};return async(t,r,a)=>{let n={},s={};return Object.keys(t.headers).forEach(i=>{n[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=n,a()}},H=Z;var B=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}},S=B;var _=e=>G__default.default.toXML(e,{header:!0,indent:" "}),R=_;var y="Content-Type",Q=(e,o,t,r,a)=>{if(typeof t.getHeader(y)=="string")return r;let i=[...$__default.default(o).types(),a.defaultContentType],d=r,w=!1;return i.forEach(l=>{e.forEach(({regex:O,serializer:q})=>{O.test(l)&&(t.setHeader(y,l),d=q(d),w=!0);}),w||(/yaml|yml/.test(l)?(t.setHeader(y,l),d=chunkNH4B62H7_js.b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(y,l),d=R({[chunkNH4B62H7_js.a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},m=Q;var ee=Y__default.default("api-platform:connect:serializers-middleware"),te=(e=[],o="application/json; charset=utf-8")=>async(t,r,a)=>{if(typeof r.send=="function"){let n=r.send;r.send=s=>(r.send=n,s=m(e,t,r,s,{defaultContentType:o}),r.send(s));}else if(typeof r.json=="function")ee("response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.");else {let n=r.end;r.end=(s,...i)=>(r.end=n,s=m(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return a()},E=te;var oe=(e={})=>new connect.NodeRouter({onNoMatch:h,onError:x(e.errorHandlers??[],e.showTrace??!1)}).use(H(e.middlewares?.["http-header-normalizer"]??{})).use(E(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),se=oe;var ne=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.connection.remoteAddress,ae=(e,o)=>async(t,r,a)=>{let n=ne(t);if(n===void 0)throw k__default.default(400,"Missing IP");try{let s=await e.consume(n),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 a();}catch{throw k__default.default(429,"Too Many Requests")}},ie=ae;var le=e=>connect.expressWrapper(pe__default.default(e)),me=le;
|
|
16
25
|
|
|
17
26
|
Object.defineProperty(exports, 'dateIn', {
|
|
18
27
|
enumerable: true,
|
|
19
|
-
get: function () { return
|
|
28
|
+
get: function () { return chunkQJNODCPR_js.a; }
|
|
20
29
|
});
|
|
21
30
|
Object.defineProperty(exports, 'dateOut', {
|
|
22
31
|
enumerable: true,
|
|
23
|
-
get: function () { return
|
|
32
|
+
get: function () { return chunkQJNODCPR_js.b; }
|
|
24
33
|
});
|
|
25
34
|
Object.defineProperty(exports, 'zod', {
|
|
26
35
|
enumerable: true,
|
|
27
|
-
get: function () { return
|
|
36
|
+
get: function () { return chunkQJNODCPR_js.c; }
|
|
28
37
|
});
|
|
29
38
|
Object.defineProperty(exports, 'swaggerHandler', {
|
|
30
39
|
enumerable: true,
|
|
31
|
-
get: function () { return
|
|
40
|
+
get: function () { return chunkNH4B62H7_js.c; }
|
|
32
41
|
});
|
|
33
42
|
Object.defineProperty(exports, 'yamlTransformer', {
|
|
34
43
|
enumerable: true,
|
|
35
|
-
get: function () { return
|
|
44
|
+
get: function () { return chunkNH4B62H7_js.b; }
|
|
36
45
|
});
|
|
37
46
|
Object.defineProperty(exports, 'BadGateway', {
|
|
38
47
|
enumerable: true,
|
|
@@ -194,7 +203,10 @@ Object.defineProperty(exports, 'VariantAlsoNegotiates', {
|
|
|
194
203
|
enumerable: true,
|
|
195
204
|
get: function () { return k.VariantAlsoNegotiates; }
|
|
196
205
|
});
|
|
197
|
-
exports
|
|
206
|
+
Object.defineProperty(exports, 'createHttpError', {
|
|
207
|
+
enumerable: true,
|
|
208
|
+
get: function () { return k__default.default; }
|
|
209
|
+
});
|
|
198
210
|
Object.defineProperty(exports, 'EdgeRouter', {
|
|
199
211
|
enumerable: true,
|
|
200
212
|
get: function () { return connect.EdgeRouter; }
|
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/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/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","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","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 type { Serializers, Serializer } from \"./serializers\";\nexport { serialize, yamlTransformer, xmlTransformer } from \"./serializers\";\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/api/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport type { Serializers } from \"../serializers\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\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 ): NodeRouter<Request, Response, Schema> => {\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 Error & { expose: boolean }).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: Error | HttpError | tsJapi.JapiError, _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 type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: unknown): void => {\n const headers: { [key: string]: ReadonlyArray<string> | number | string } = (error as HttpError).headers ?? {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as ReadonlyArray<string> | number | 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: unknown): 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: unknown): void => {\n // respect err.statusCode\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).status !== undefined) {\n response.statusCode = (error as HttpError).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: Error | HttpError, _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 Error & { expose: boolean }).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage, ServerResponse } 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_?: {\n canonical?: boolean;\n normalizeHeaderKey?: (key: string, canonical: boolean) => string;\n}): ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\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) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-expect-error\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializers } from \"../../serializers\";\nimport { serialize } from \"../../serializers\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst log = debug(\"api-platform:connect:serializers-middleware\");\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: NextApiResponse | Response, next: NextHandler): Promise<ValueOrPromise<void>> => {\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, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return (response as NextApiResponse).send(data);\n };\n } else if (typeof (response as NextApiResponse).json === \"function\") {\n log(\"response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.\");\n } else {\n const oldEnd = response.end;\n\n // @ts-expect-error\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-expect-error TS2345: Argument of type 'unknown' is not assignable to parameter of type 'BufferEncoding'.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return response.end(data, ...arguments_);\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return next();\n};\n\nexport default serializersMiddleware;\n","import accepts from \"accepts\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../utils\";\nimport hasJsonStructure from \"./has-json-structure\";\nimport xmlTransformer from \"./transformer/xml\";\nimport yamlTransformer from \"./transformer/yaml\";\nimport type { Serializers } from \"./types\";\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,\n data: unknown,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n): Buffer | Uint8Array | string => {\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 as string;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n let breakTypes = false;\n\n // eslint-disable-next-line no-restricted-syntax\n types.forEach((type) => {\n serializers.forEach(({ regex, serializer }) => {\n if (regex.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = serializer(serializedData);\n breakTypes = true;\n }\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 as string) : data);\n } else if (type.includes(\"xml\")) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data as string) : data,\n });\n }\n }\n });\n\n return serializedData as Buffer | Uint8Array | string;\n};\n\nexport default serialize;\n","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\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\nexport default hasJsonStructure;\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 = ReadonlyArray<string> | number | 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: NextApiResponse | Response, next: NextHandler): Promise<void> => {\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,@typescript-eslint/explicit-module-boundary-types\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/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/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","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","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 type { Serializers, Serializer } from \"./serializers\";\nexport { serialize, yamlTransformer, xmlTransformer } from \"./serializers\";\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/api/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport type { Serializers } from \"../serializers\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\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 ): NodeRouter<Request, Response, Schema> => {\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 Error & { expose: boolean }).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: Error | HttpError | tsJapi.JapiError, _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 type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: unknown): void => {\n const headers: { [key: string]: ReadonlyArray<string> | number | string } = (error as HttpError).headers ?? {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as ReadonlyArray<string> | number | 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: unknown): 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: unknown): void => {\n // respect err.statusCode\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).status !== undefined) {\n response.statusCode = (error as HttpError).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: Error | HttpError, _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 Error & { expose: boolean }).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage, ServerResponse } 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_?: {\n canonical?: boolean;\n normalizeHeaderKey?: (key: string, canonical: boolean) => string;\n}): ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\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) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-expect-error\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializers } from \"../../serializers\";\nimport { serialize } from \"../../serializers\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst log = debug(\"api-platform:connect:serializers-middleware\");\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: NextApiResponse | Response, next: NextHandler): Promise<ValueOrPromise<void>> => {\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, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return (response as NextApiResponse).send(data);\n };\n } else if (typeof (response as NextApiResponse).json === \"function\") {\n log(\"response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.\");\n } else {\n const oldEnd = response.end;\n\n // @ts-expect-error\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-expect-error TS2345: Argument of type 'unknown' is not assignable to parameter of type 'BufferEncoding'.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return response.end(data, ...arguments_);\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return next();\n};\n\nexport default serializersMiddleware;\n","import accepts from \"accepts\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../utils\";\nimport hasJsonStructure from \"./has-json-structure\";\nimport xmlTransformer from \"./transformer/xml\";\nimport yamlTransformer from \"./transformer/yaml\";\nimport type { Serializers } from \"./types\";\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,\n data: unknown,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Buffer | Uint8Array | string => {\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 as string;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n let breakTypes = false;\n\n // eslint-disable-next-line no-restricted-syntax\n types.forEach((type) => {\n serializers.forEach(({ regex, serializer }) => {\n if (regex.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = serializer(serializedData);\n breakTypes = true;\n }\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 as string) : data);\n } else if (type.includes(\"xml\")) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data as string) : data,\n });\n }\n }\n });\n\n return serializedData as Buffer | Uint8Array | string;\n};\n\nexport default serialize;\n","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\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\nexport default hasJsonStructure;\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 = ReadonlyArray<string> | number | 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: NextApiResponse | Response, next: NextHandler): Promise<void> => {\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,@typescript-eslint/explicit-module-boundary-types\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,7 +1,7 @@
|
|
|
1
|
-
export { a as dateIn, b as dateOut, c as zod } from './chunk-
|
|
2
|
-
import { b, a } from './chunk-
|
|
3
|
-
export { c as swaggerHandler, b as yamlTransformer } from './chunk-
|
|
4
|
-
import './chunk-
|
|
1
|
+
export { a as dateIn, b as dateOut, c as zod } from './chunk-4ZTB2SHJ.mjs';
|
|
2
|
+
import { b, a } from './chunk-4GBB2H25.mjs';
|
|
3
|
+
export { c as swaggerHandler, b as yamlTransformer } from './chunk-4GBB2H25.mjs';
|
|
4
|
+
import './chunk-2ZMPKWQQ.mjs';
|
|
5
5
|
import k, { HttpError } from 'http-errors';
|
|
6
6
|
export { BadGateway, BadRequest, BandwidthLimitExceeded, Conflict, ExpectationFailed, FailedDependency, Forbidden, GatewayTimeout, Gone, HTTPVersionNotSupported, ImATeapot, InsufficientStorage, InternalServerError, LengthRequired, Locked, LoopDetected, MethodNotAllowed, MisdirectedRequest, NetworkAuthenticationRequire, NotAcceptable, NotExtended, NotFound, NotImplemented, PayloadTooLarge, PaymentRequired, PreconditionFailed, PreconditionRequired, ProxyAuthenticationRequired, RangeNotSatisfiable, RequestHeaderFieldsTooLarge, RequestTimeout, ServiceUnavailable, TooManyRequests, URITooLong, Unauthorized, UnavailableForLegalReasons, UnprocessableEntity, UnsupportedMediaType, UpgradeRequired, VariantAlsoNegotiates, default as createHttpError } from 'http-errors';
|
|
7
7
|
import { NodeRouter, expressWrapper } from '@visulima/connect';
|
|
@@ -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/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/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","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","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 type { Serializers, Serializer } from \"./serializers\";\nexport { serialize, yamlTransformer, xmlTransformer } from \"./serializers\";\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/api/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport type { Serializers } from \"../serializers\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\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 ): NodeRouter<Request, Response, Schema> => {\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 Error & { expose: boolean }).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: Error | HttpError | tsJapi.JapiError, _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 type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: unknown): void => {\n const headers: { [key: string]: ReadonlyArray<string> | number | string } = (error as HttpError).headers ?? {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as ReadonlyArray<string> | number | 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: unknown): 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: unknown): void => {\n // respect err.statusCode\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).status !== undefined) {\n response.statusCode = (error as HttpError).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: Error | HttpError, _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 Error & { expose: boolean }).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage, ServerResponse } 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_?: {\n canonical?: boolean;\n normalizeHeaderKey?: (key: string, canonical: boolean) => string;\n}): ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\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) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-expect-error\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializers } from \"../../serializers\";\nimport { serialize } from \"../../serializers\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst log = debug(\"api-platform:connect:serializers-middleware\");\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: NextApiResponse | Response, next: NextHandler): Promise<ValueOrPromise<void>> => {\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, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return (response as NextApiResponse).send(data);\n };\n } else if (typeof (response as NextApiResponse).json === \"function\") {\n log(\"response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.\");\n } else {\n const oldEnd = response.end;\n\n // @ts-expect-error\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-expect-error TS2345: Argument of type 'unknown' is not assignable to parameter of type 'BufferEncoding'.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return response.end(data, ...arguments_);\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return next();\n};\n\nexport default serializersMiddleware;\n","import accepts from \"accepts\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../utils\";\nimport hasJsonStructure from \"./has-json-structure\";\nimport xmlTransformer from \"./transformer/xml\";\nimport yamlTransformer from \"./transformer/yaml\";\nimport type { Serializers } from \"./types\";\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,\n data: unknown,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n): Buffer | Uint8Array | string => {\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 as string;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n let breakTypes = false;\n\n // eslint-disable-next-line no-restricted-syntax\n types.forEach((type) => {\n serializers.forEach(({ regex, serializer }) => {\n if (regex.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = serializer(serializedData);\n breakTypes = true;\n }\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 as string) : data);\n } else if (type.includes(\"xml\")) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data as string) : data,\n });\n }\n }\n });\n\n return serializedData as Buffer | Uint8Array | string;\n};\n\nexport default serialize;\n","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\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\nexport default hasJsonStructure;\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 = ReadonlyArray<string> | number | 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: NextApiResponse | Response, next: NextHandler): Promise<void> => {\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,@typescript-eslint/explicit-module-boundary-types\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/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/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","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","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 type { Serializers, Serializer } from \"./serializers\";\nexport { serialize, yamlTransformer, xmlTransformer } from \"./serializers\";\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/api/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport type { Serializers } from \"../serializers\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\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 ): NodeRouter<Request, Response, Schema> => {\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 Error & { expose: boolean }).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: Error | HttpError | tsJapi.JapiError, _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 type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: unknown): void => {\n const headers: { [key: string]: ReadonlyArray<string> | number | string } = (error as HttpError).headers ?? {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as ReadonlyArray<string> | number | 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: unknown): 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: unknown): void => {\n // respect err.statusCode\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if ((error as HttpError).status !== undefined) {\n response.statusCode = (error as HttpError).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: Error | HttpError, _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 Error & { expose: boolean }).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage, ServerResponse } 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_?: {\n canonical?: boolean;\n normalizeHeaderKey?: (key: string, canonical: boolean) => string;\n}): ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\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) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-expect-error\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializers } from \"../../serializers\";\nimport { serialize } from \"../../serializers\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst log = debug(\"api-platform:connect:serializers-middleware\");\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: NextApiResponse | Response, next: NextHandler): Promise<ValueOrPromise<void>> => {\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, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return (response as NextApiResponse).send(data);\n };\n } else if (typeof (response as NextApiResponse).json === \"function\") {\n log(\"response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.\");\n } else {\n const oldEnd = response.end;\n\n // @ts-expect-error\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-expect-error TS2345: Argument of type 'unknown' is not assignable to parameter of type 'BufferEncoding'.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return response.end(data, ...arguments_);\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return next();\n};\n\nexport default serializersMiddleware;\n","import accepts from \"accepts\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../utils\";\nimport hasJsonStructure from \"./has-json-structure\";\nimport xmlTransformer from \"./transformer/xml\";\nimport yamlTransformer from \"./transformer/yaml\";\nimport type { Serializers } from \"./types\";\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,\n data: unknown,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Buffer | Uint8Array | string => {\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 as string;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n let breakTypes = false;\n\n // eslint-disable-next-line no-restricted-syntax\n types.forEach((type) => {\n serializers.forEach(({ regex, serializer }) => {\n if (regex.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = serializer(serializedData);\n breakTypes = true;\n }\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 as string) : data);\n } else if (type.includes(\"xml\")) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data as string) : data,\n });\n }\n }\n });\n\n return serializedData as Buffer | Uint8Array | string;\n};\n\nexport default serialize;\n","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\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\nexport default hasJsonStructure;\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 = ReadonlyArray<string> | number | 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: NextApiResponse | Response, next: NextHandler): Promise<void> => {\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,@typescript-eslint/explicit-module-boundary-types\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@visulima/api-platform-next-pages-redoc",
|
|
3
|
+
"version": "0.0.0",
|
|
4
|
+
"description": "Visulima API platform is a set of tools to build and consume web APIs; Next.js version",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": {
|
|
8
|
+
"types": "./../../../dist/framework/next/routes/pages/redoc/index.d.ts",
|
|
9
|
+
"browser": "./../../../dist/framework/next/routes/pages/redoc/index.js",
|
|
10
|
+
"require": "./../../../dist/framework/next/routes/pages/redoc/index.js",
|
|
11
|
+
"import": "./../../../dist/framework/next/routes/pages/redoc/index.mjs"
|
|
12
|
+
},
|
|
13
|
+
"./package.json": "./package.json"
|
|
14
|
+
},
|
|
15
|
+
"main": "../../../dist/framework/next/routes/pages/redoc/index.js",
|
|
16
|
+
"module": "../../../dist/framework/next/routes/pages/redoc/index.mjs",
|
|
17
|
+
"browser": "../../../dist/framework/next/routes/pages/redoc/index.mjs",
|
|
18
|
+
"types": "../../../dist/framework/next/routes/pages/redoc/index.d.ts"
|
|
19
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@visulima/api-platform-next-pages-swagger",
|
|
3
|
+
"version": "0.0.0",
|
|
4
|
+
"description": "Visulima API platform is a set of tools to build and consume web APIs; Next.js version",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": {
|
|
8
|
+
"types": "./../../../dist/framework/next/routes/pages/swagger/index.d.ts",
|
|
9
|
+
"browser": "./../../../dist/framework/next/routes/pages/swagger/index.js",
|
|
10
|
+
"require": "./../../../dist/framework/next/routes/pages/swagger/index.js",
|
|
11
|
+
"import": "./../../../dist/framework/next/routes/pages/swagger/index.mjs"
|
|
12
|
+
},
|
|
13
|
+
"./package.json": "./package.json"
|
|
14
|
+
},
|
|
15
|
+
"main": "../../../dist/framework/next/routes/pages/swagger/index.js",
|
|
16
|
+
"module": "../../../dist/framework/next/routes/pages/swagger/index.mjs",
|
|
17
|
+
"browser": "../../../dist/framework/next/routes/pages/swagger/index.mjs",
|
|
18
|
+
"types": "../../../dist/framework/next/routes/pages/swagger/index.d.ts"
|
|
19
|
+
}
|