@visulima/api-platform 1.2.12 → 1.2.13

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.
Files changed (78) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/bin/index.js +6 -8
  3. package/dist/{chunk-5B2CCUEK.js → chunk-3GKT5H3V.js} +2 -2
  4. package/dist/chunk-3GKT5H3V.js.map +1 -0
  5. package/dist/{chunk-OUWZ2PU5.js → chunk-4D6JZ4TL.js} +1 -1
  6. package/dist/chunk-AB7BFRZY.mjs +9 -0
  7. package/dist/chunk-AB7BFRZY.mjs.map +1 -0
  8. package/dist/chunk-CQXODW6L.mjs +13 -0
  9. package/dist/chunk-CQXODW6L.mjs.map +1 -0
  10. package/dist/{chunk-2BDDP26Z.mjs → chunk-IGJDNXIE.mjs} +2 -2
  11. package/dist/chunk-IGJDNXIE.mjs.map +1 -0
  12. package/dist/chunk-J3RIDYN3.mjs +17 -0
  13. package/dist/chunk-J3RIDYN3.mjs.map +1 -0
  14. package/dist/chunk-PEE2NOLZ.js +25 -0
  15. package/dist/chunk-PEE2NOLZ.js.map +1 -0
  16. package/dist/chunk-QTZRF77U.js +24 -0
  17. package/dist/chunk-QTZRF77U.js.map +1 -0
  18. package/dist/chunk-WYXGSYH5.js +13 -0
  19. package/dist/chunk-WYXGSYH5.js.map +1 -0
  20. package/dist/{chunk-YOXCJZNX.mjs → chunk-XIJ2ZQRX.mjs} +1 -1
  21. package/dist/framework/cli/commander/index.d.mts +5 -0
  22. package/dist/framework/cli/commander/index.js +3 -3
  23. package/dist/framework/cli/commander/index.js.map +1 -1
  24. package/dist/framework/cli/commander/index.mjs +3 -3
  25. package/dist/framework/cli/commander/index.mjs.map +1 -1
  26. package/dist/framework/cli/index.d.mts +11 -0
  27. package/dist/framework/cli/index.d.ts +4 -4
  28. package/dist/framework/cli/index.js +3 -3
  29. package/dist/framework/cli/index.mjs +2 -2
  30. package/dist/framework/next/index-browser.d.mts +5 -0
  31. package/dist/framework/next/index-browser.js +3 -3
  32. package/dist/framework/next/index-browser.mjs +2 -2
  33. package/dist/framework/next/index-server.d.mts +20 -0
  34. package/dist/framework/next/index-server.d.ts +5 -5
  35. package/dist/framework/next/index-server.js +11 -11
  36. package/dist/framework/next/index-server.js.map +1 -1
  37. package/dist/framework/next/index-server.mjs +7 -7
  38. package/dist/framework/next/index-server.mjs.map +1 -1
  39. package/dist/framework/next/routes/pages/redoc/index.d.mts +8 -0
  40. package/dist/framework/next/routes/pages/redoc/index.d.ts +3 -2
  41. package/dist/framework/next/routes/pages/redoc/index.js +4 -4
  42. package/dist/framework/next/routes/pages/redoc/index.js.map +1 -1
  43. package/dist/framework/next/routes/pages/redoc/index.mjs +4 -4
  44. package/dist/framework/next/routes/pages/redoc/index.mjs.map +1 -1
  45. package/dist/framework/next/routes/pages/swagger/index.d.mts +7 -0
  46. package/dist/framework/next/routes/pages/swagger/index.js +7 -7
  47. package/dist/framework/next/routes/pages/swagger/index.js.map +1 -1
  48. package/dist/framework/next/routes/pages/swagger/index.mjs +5 -5
  49. package/dist/framework/next/routes/pages/swagger/index.mjs.map +1 -1
  50. package/dist/index-browser.d.mts +2 -0
  51. package/dist/index-browser.d.ts +1 -1
  52. package/dist/index-browser.js +3 -3
  53. package/dist/index-browser.mjs +2 -2
  54. package/dist/index-server.d.mts +84 -0
  55. package/dist/index-server.d.ts +12 -14
  56. package/dist/index-server.js +87 -87
  57. package/dist/index-server.js.map +1 -1
  58. package/dist/index-server.mjs +10 -10
  59. package/dist/index-server.mjs.map +1 -1
  60. package/dist/{swagger-handler-8947e0f1.d.ts → swagger-handler-47360cd1.d.ts} +4 -6
  61. package/package.json +64 -56
  62. package/dist/chunk-2BDDP26Z.mjs.map +0 -1
  63. package/dist/chunk-5B2CCUEK.js.map +0 -1
  64. package/dist/chunk-EP2A5R2C.js +0 -13
  65. package/dist/chunk-EP2A5R2C.js.map +0 -1
  66. package/dist/chunk-JC55W6OX.js +0 -25
  67. package/dist/chunk-JC55W6OX.js.map +0 -1
  68. package/dist/chunk-MAUWX6TE.mjs +0 -13
  69. package/dist/chunk-MAUWX6TE.mjs.map +0 -1
  70. package/dist/chunk-RK2WQGNS.js +0 -24
  71. package/dist/chunk-RK2WQGNS.js.map +0 -1
  72. package/dist/chunk-S2NV4N4L.mjs +0 -17
  73. package/dist/chunk-S2NV4N4L.mjs.map +0 -1
  74. package/dist/chunk-WJDS32PO.mjs +0 -9
  75. package/dist/chunk-WJDS32PO.mjs.map +0 -1
  76. package/dist/{chunk-OUWZ2PU5.js.map → chunk-4D6JZ4TL.js.map} +0 -0
  77. package/dist/{chunk-YOXCJZNX.mjs.map → chunk-XIJ2ZQRX.mjs.map} +0 -0
  78. package/dist/{index-browser-bd61921e.d.ts → index-browser-48644724.d.ts} +2 -2
@@ -1,247 +1,247 @@
1
1
  'use strict';
2
2
 
3
- var chunkEP2A5R2C_js = require('./chunk-EP2A5R2C.js');
4
- var chunkJC55W6OX_js = require('./chunk-JC55W6OX.js');
5
- require('./chunk-OUWZ2PU5.js');
6
- var k = require('http-errors');
3
+ var chunkWYXGSYH5_js = require('./chunk-WYXGSYH5.js');
4
+ var chunkPEE2NOLZ_js = require('./chunk-PEE2NOLZ.js');
5
+ require('./chunk-4D6JZ4TL.js');
7
6
  var connect = require('@visulima/connect');
7
+ var O = require('http-errors');
8
8
  var httpStatusCodes = require('http-status-codes');
9
- var g = require('ts-japi');
9
+ var y = require('ts-japi');
10
10
  var Y = require('debug');
11
11
  var $ = require('accepts');
12
12
  var G = require('jstoxml');
13
- var pe = require('cors');
13
+ var ae = require('cors');
14
14
 
15
15
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
16
16
 
17
- var k__default = /*#__PURE__*/_interopDefault(k);
18
- var g__default = /*#__PURE__*/_interopDefault(g);
17
+ var O__default = /*#__PURE__*/_interopDefault(O);
18
+ var y__default = /*#__PURE__*/_interopDefault(y);
19
19
  var Y__default = /*#__PURE__*/_interopDefault(Y);
20
20
  var $__default = /*#__PURE__*/_interopDefault($);
21
21
  var G__default = /*#__PURE__*/_interopDefault(G);
22
- var pe__default = /*#__PURE__*/_interopDefault(pe);
22
+ var ae__default = /*#__PURE__*/_interopDefault(ae);
23
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=chunkJC55W6OX_js.b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(y,l),d=R({[chunkJC55W6OX_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;
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 y__default.default.JapiError||y__default.default.JapiError.isLikeJapiError(e)){let r=new y__default.default.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof O.HttpError){let{message:r,statusCode:n,title:a}=e;p(t,{errors:[{code:n,title:a||httpStatusCodes.getReasonPhrase(n)||v,detail:r}]});}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{message:r,stack:n}=e;if(e instanceof O.HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,f(t,e),p(t,{type:d||A,title:i||httpStatusCodes.getReasonPhrase(s)||M,details:r,...a?{trace:n}:{}});}else u(t,e),p(t,{type:A,title:httpStatusCodes.getReasonPhrase(t.statusCode)||M,details:r,...e.expose?{trace:n}:{}});},C=W;var x=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=C;a==="application/vnd.api+json"&&(s=z);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},h=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,O__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-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",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,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},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 g="Content-Type",Q=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...$__default.default(o).types(),n.defaultContentType],d=r,w=!1;return i.forEach(l=>{e.forEach(({regex:q,serializer:P})=>{q.test(l)&&(t.setHeader(g,l),d=P(d),w=!0);}),w||(/yaml|yml/.test(l)?(t.setHeader(g,l),d=chunkPEE2NOLZ_js.b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(g,l),d=R({[chunkPEE2NOLZ_js.a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},c=Q;var ee=Y__default.default("api-platform:connect:serializers-middleware"),te=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=c(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 a=r.end;r.end=(s,...i)=>(r.end=a,s=c(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},E=te;var oe=(e={})=>new connect.NodeRouter({onError:x(e.errorHandlers??[],e.showTrace??!1),onNoMatch:h}).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 ie=e=>connect.expressWrapper(ae__default.default(e)),de=ie;var pe=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,le=(e,o)=>async(t,r,n)=>{let a=pe(t);if(a===void 0)throw O__default.default(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw O__default.default(429,"Too Many Requests")}},ce=le;
25
25
 
26
26
  Object.defineProperty(exports, 'dateIn', {
27
27
  enumerable: true,
28
- get: function () { return chunkEP2A5R2C_js.a; }
28
+ get: function () { return chunkWYXGSYH5_js.a; }
29
29
  });
30
30
  Object.defineProperty(exports, 'dateOut', {
31
31
  enumerable: true,
32
- get: function () { return chunkEP2A5R2C_js.b; }
32
+ get: function () { return chunkWYXGSYH5_js.b; }
33
33
  });
34
34
  Object.defineProperty(exports, 'zod', {
35
35
  enumerable: true,
36
- get: function () { return chunkEP2A5R2C_js.c; }
36
+ get: function () { return chunkWYXGSYH5_js.c; }
37
37
  });
38
38
  Object.defineProperty(exports, 'swaggerHandler', {
39
39
  enumerable: true,
40
- get: function () { return chunkJC55W6OX_js.c; }
40
+ get: function () { return chunkPEE2NOLZ_js.c; }
41
41
  });
42
42
  Object.defineProperty(exports, 'yamlTransformer', {
43
43
  enumerable: true,
44
- get: function () { return chunkJC55W6OX_js.b; }
44
+ get: function () { return chunkPEE2NOLZ_js.b; }
45
+ });
46
+ Object.defineProperty(exports, 'EdgeRouter', {
47
+ enumerable: true,
48
+ get: function () { return connect.EdgeRouter; }
49
+ });
50
+ Object.defineProperty(exports, 'NodeRouter', {
51
+ enumerable: true,
52
+ get: function () { return connect.NodeRouter; }
53
+ });
54
+ Object.defineProperty(exports, 'Router', {
55
+ enumerable: true,
56
+ get: function () { return connect.Router; }
57
+ });
58
+ Object.defineProperty(exports, 'createEdgeRouter', {
59
+ enumerable: true,
60
+ get: function () { return connect.createEdgeRouter; }
61
+ });
62
+ Object.defineProperty(exports, 'expressWrapper', {
63
+ enumerable: true,
64
+ get: function () { return connect.expressWrapper; }
65
+ });
66
+ Object.defineProperty(exports, 'sendJson', {
67
+ enumerable: true,
68
+ get: function () { return connect.sendJson; }
69
+ });
70
+ Object.defineProperty(exports, 'withZod', {
71
+ enumerable: true,
72
+ get: function () { return connect.withZod; }
45
73
  });
46
74
  Object.defineProperty(exports, 'BadGateway', {
47
75
  enumerable: true,
48
- get: function () { return k.BadGateway; }
76
+ get: function () { return O.BadGateway; }
49
77
  });
50
78
  Object.defineProperty(exports, 'BadRequest', {
51
79
  enumerable: true,
52
- get: function () { return k.BadRequest; }
80
+ get: function () { return O.BadRequest; }
53
81
  });
54
82
  Object.defineProperty(exports, 'BandwidthLimitExceeded', {
55
83
  enumerable: true,
56
- get: function () { return k.BandwidthLimitExceeded; }
84
+ get: function () { return O.BandwidthLimitExceeded; }
57
85
  });
58
86
  Object.defineProperty(exports, 'Conflict', {
59
87
  enumerable: true,
60
- get: function () { return k.Conflict; }
88
+ get: function () { return O.Conflict; }
61
89
  });
62
90
  Object.defineProperty(exports, 'ExpectationFailed', {
63
91
  enumerable: true,
64
- get: function () { return k.ExpectationFailed; }
92
+ get: function () { return O.ExpectationFailed; }
65
93
  });
66
94
  Object.defineProperty(exports, 'FailedDependency', {
67
95
  enumerable: true,
68
- get: function () { return k.FailedDependency; }
96
+ get: function () { return O.FailedDependency; }
69
97
  });
70
98
  Object.defineProperty(exports, 'Forbidden', {
71
99
  enumerable: true,
72
- get: function () { return k.Forbidden; }
100
+ get: function () { return O.Forbidden; }
73
101
  });
74
102
  Object.defineProperty(exports, 'GatewayTimeout', {
75
103
  enumerable: true,
76
- get: function () { return k.GatewayTimeout; }
104
+ get: function () { return O.GatewayTimeout; }
77
105
  });
78
106
  Object.defineProperty(exports, 'Gone', {
79
107
  enumerable: true,
80
- get: function () { return k.Gone; }
108
+ get: function () { return O.Gone; }
81
109
  });
82
110
  Object.defineProperty(exports, 'HTTPVersionNotSupported', {
83
111
  enumerable: true,
84
- get: function () { return k.HTTPVersionNotSupported; }
112
+ get: function () { return O.HTTPVersionNotSupported; }
85
113
  });
86
114
  Object.defineProperty(exports, 'ImATeapot', {
87
115
  enumerable: true,
88
- get: function () { return k.ImATeapot; }
116
+ get: function () { return O.ImATeapot; }
89
117
  });
90
118
  Object.defineProperty(exports, 'InsufficientStorage', {
91
119
  enumerable: true,
92
- get: function () { return k.InsufficientStorage; }
120
+ get: function () { return O.InsufficientStorage; }
93
121
  });
94
122
  Object.defineProperty(exports, 'InternalServerError', {
95
123
  enumerable: true,
96
- get: function () { return k.InternalServerError; }
124
+ get: function () { return O.InternalServerError; }
97
125
  });
98
126
  Object.defineProperty(exports, 'LengthRequired', {
99
127
  enumerable: true,
100
- get: function () { return k.LengthRequired; }
128
+ get: function () { return O.LengthRequired; }
101
129
  });
102
130
  Object.defineProperty(exports, 'Locked', {
103
131
  enumerable: true,
104
- get: function () { return k.Locked; }
132
+ get: function () { return O.Locked; }
105
133
  });
106
134
  Object.defineProperty(exports, 'LoopDetected', {
107
135
  enumerable: true,
108
- get: function () { return k.LoopDetected; }
136
+ get: function () { return O.LoopDetected; }
109
137
  });
110
138
  Object.defineProperty(exports, 'MethodNotAllowed', {
111
139
  enumerable: true,
112
- get: function () { return k.MethodNotAllowed; }
140
+ get: function () { return O.MethodNotAllowed; }
113
141
  });
114
142
  Object.defineProperty(exports, 'MisdirectedRequest', {
115
143
  enumerable: true,
116
- get: function () { return k.MisdirectedRequest; }
144
+ get: function () { return O.MisdirectedRequest; }
117
145
  });
118
146
  Object.defineProperty(exports, 'NetworkAuthenticationRequire', {
119
147
  enumerable: true,
120
- get: function () { return k.NetworkAuthenticationRequire; }
148
+ get: function () { return O.NetworkAuthenticationRequire; }
121
149
  });
122
150
  Object.defineProperty(exports, 'NotAcceptable', {
123
151
  enumerable: true,
124
- get: function () { return k.NotAcceptable; }
152
+ get: function () { return O.NotAcceptable; }
125
153
  });
126
154
  Object.defineProperty(exports, 'NotExtended', {
127
155
  enumerable: true,
128
- get: function () { return k.NotExtended; }
156
+ get: function () { return O.NotExtended; }
129
157
  });
130
158
  Object.defineProperty(exports, 'NotFound', {
131
159
  enumerable: true,
132
- get: function () { return k.NotFound; }
160
+ get: function () { return O.NotFound; }
133
161
  });
134
162
  Object.defineProperty(exports, 'NotImplemented', {
135
163
  enumerable: true,
136
- get: function () { return k.NotImplemented; }
164
+ get: function () { return O.NotImplemented; }
137
165
  });
138
166
  Object.defineProperty(exports, 'PayloadTooLarge', {
139
167
  enumerable: true,
140
- get: function () { return k.PayloadTooLarge; }
168
+ get: function () { return O.PayloadTooLarge; }
141
169
  });
142
170
  Object.defineProperty(exports, 'PaymentRequired', {
143
171
  enumerable: true,
144
- get: function () { return k.PaymentRequired; }
172
+ get: function () { return O.PaymentRequired; }
145
173
  });
146
174
  Object.defineProperty(exports, 'PreconditionFailed', {
147
175
  enumerable: true,
148
- get: function () { return k.PreconditionFailed; }
176
+ get: function () { return O.PreconditionFailed; }
149
177
  });
150
178
  Object.defineProperty(exports, 'PreconditionRequired', {
151
179
  enumerable: true,
152
- get: function () { return k.PreconditionRequired; }
180
+ get: function () { return O.PreconditionRequired; }
153
181
  });
154
182
  Object.defineProperty(exports, 'ProxyAuthenticationRequired', {
155
183
  enumerable: true,
156
- get: function () { return k.ProxyAuthenticationRequired; }
184
+ get: function () { return O.ProxyAuthenticationRequired; }
157
185
  });
158
186
  Object.defineProperty(exports, 'RangeNotSatisfiable', {
159
187
  enumerable: true,
160
- get: function () { return k.RangeNotSatisfiable; }
188
+ get: function () { return O.RangeNotSatisfiable; }
161
189
  });
162
190
  Object.defineProperty(exports, 'RequestHeaderFieldsTooLarge', {
163
191
  enumerable: true,
164
- get: function () { return k.RequestHeaderFieldsTooLarge; }
192
+ get: function () { return O.RequestHeaderFieldsTooLarge; }
165
193
  });
166
194
  Object.defineProperty(exports, 'RequestTimeout', {
167
195
  enumerable: true,
168
- get: function () { return k.RequestTimeout; }
196
+ get: function () { return O.RequestTimeout; }
169
197
  });
170
198
  Object.defineProperty(exports, 'ServiceUnavailable', {
171
199
  enumerable: true,
172
- get: function () { return k.ServiceUnavailable; }
200
+ get: function () { return O.ServiceUnavailable; }
173
201
  });
174
202
  Object.defineProperty(exports, 'TooManyRequests', {
175
203
  enumerable: true,
176
- get: function () { return k.TooManyRequests; }
204
+ get: function () { return O.TooManyRequests; }
177
205
  });
178
206
  Object.defineProperty(exports, 'URITooLong', {
179
207
  enumerable: true,
180
- get: function () { return k.URITooLong; }
208
+ get: function () { return O.URITooLong; }
181
209
  });
182
210
  Object.defineProperty(exports, 'Unauthorized', {
183
211
  enumerable: true,
184
- get: function () { return k.Unauthorized; }
212
+ get: function () { return O.Unauthorized; }
185
213
  });
186
214
  Object.defineProperty(exports, 'UnavailableForLegalReasons', {
187
215
  enumerable: true,
188
- get: function () { return k.UnavailableForLegalReasons; }
216
+ get: function () { return O.UnavailableForLegalReasons; }
189
217
  });
190
218
  Object.defineProperty(exports, 'UnprocessableEntity', {
191
219
  enumerable: true,
192
- get: function () { return k.UnprocessableEntity; }
220
+ get: function () { return O.UnprocessableEntity; }
193
221
  });
194
222
  Object.defineProperty(exports, 'UnsupportedMediaType', {
195
223
  enumerable: true,
196
- get: function () { return k.UnsupportedMediaType; }
224
+ get: function () { return O.UnsupportedMediaType; }
197
225
  });
198
226
  Object.defineProperty(exports, 'UpgradeRequired', {
199
227
  enumerable: true,
200
- get: function () { return k.UpgradeRequired; }
228
+ get: function () { return O.UpgradeRequired; }
201
229
  });
202
230
  Object.defineProperty(exports, 'VariantAlsoNegotiates', {
203
231
  enumerable: true,
204
- get: function () { return k.VariantAlsoNegotiates; }
232
+ get: function () { return O.VariantAlsoNegotiates; }
205
233
  });
206
234
  Object.defineProperty(exports, 'createHttpError', {
207
235
  enumerable: true,
208
- get: function () { return k__default.default; }
209
- });
210
- Object.defineProperty(exports, 'EdgeRouter', {
211
- enumerable: true,
212
- get: function () { return connect.EdgeRouter; }
213
- });
214
- Object.defineProperty(exports, 'NodeRouter', {
215
- enumerable: true,
216
- get: function () { return connect.NodeRouter; }
217
- });
218
- Object.defineProperty(exports, 'Router', {
219
- enumerable: true,
220
- get: function () { return connect.Router; }
221
- });
222
- Object.defineProperty(exports, 'createEdgeRouter', {
223
- enumerable: true,
224
- get: function () { return connect.createEdgeRouter; }
225
- });
226
- Object.defineProperty(exports, 'expressWrapper', {
227
- enumerable: true,
228
- get: function () { return connect.expressWrapper; }
229
- });
230
- Object.defineProperty(exports, 'sendJson', {
231
- enumerable: true,
232
- get: function () { return connect.sendJson; }
233
- });
234
- Object.defineProperty(exports, 'withZod', {
235
- enumerable: true,
236
- get: function () { return connect.withZod; }
236
+ get: function () { return O__default.default; }
237
237
  });
238
- exports.corsMiddleware = me;
238
+ exports.corsMiddleware = de;
239
239
  exports.createNodeRouter = se;
240
240
  exports.httpHeaderNormalizerMiddleware = H;
241
241
  exports.onError = x;
242
242
  exports.onNoMatch = h;
243
- exports.rateLimiterMiddleware = ie;
244
- exports.serialize = m;
243
+ exports.rateLimiterMiddleware = ce;
244
+ exports.serialize = c;
245
245
  exports.serializersMiddleware = E;
246
246
  exports.xmlTransformer = R;
247
247
  //# sourceMappingURL=out.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/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>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n): 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>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n): 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/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/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/index-server.ts"],"names":["NodeRouter","createHttpError","HttpError","getReasonPhrase","tsJapi","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","message","statusCode","title","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","handler","regex","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","expressWrapper","cors","corsMiddleware","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","EdgeRouter","Router","createEdgeRouter","withZod","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"],"mappings":"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","sourcesContent":["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 errorHandlers?: ErrorHandlers;\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n defaultContentType?: string;\n serializers?: Serializers;\n };\n };\n showTrace?: boolean;\n } = {},\n): NodeRouter<Request, Response, Schema> => {\n const router = new NodeRouter<Request, Response, Schema>({\n onError: onError(options.errorHandlers ?? [], options.showTrace ?? false),\n onNoMatch,\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 { FunctionLike, Nextable, Route, ValueOrPromise } 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\nexport const onError =\n <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) =>\n 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 { handler, regex } 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 { message, statusCode, title } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\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 // eslint-disable-next-line perfectionist/sort-objects\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: Record<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\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n\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 { message, stack } = error;\n\n if (error instanceof HttpError) {\n const { expose, statusCode, title, type } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n // eslint-disable-next-line perfectionist/sort-objects\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n // eslint-disable-next-line perfectionist/sort-objects\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\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-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\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 lowerCaseKey\n .split(\"-\")\n\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\");\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 - `rawHeaders` is not a property of `Request`\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\nconst log = debug(\"api-platform:connect:serializers-middleware\");\n\nconst serializersMiddleware =\n (serializers: Serializers = [], defaultContentType = \"application/json; charset=utf-8\") =>\n async <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n ): 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 (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 TS2322: Type\n (response as 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 return response.end(data, ...arguments_);\n };\n }\n\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\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 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[]) =>\n xml.toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import { expressWrapper } from \"@visulima/connect\";\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 @typescript-eslint/explicit-module-boundary-types\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) =>\n expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\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\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) =>\n request.ip ??\n (request.headers[\"x-forwarded-for\"] as string | undefined) ??\n (request.headers[\"x-real-ip\"] as string | undefined) ??\n request.socket.remoteAddress;\n\ntype HeaderValue = ReadonlyArray<string> | number | string;\n\nconst rateLimiterMiddleware =\n (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) =>\n async <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n ): 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: Record<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","export * from \"./index-browser\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\n\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\n\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { serialize, xmlTransformer, yamlTransformer } from \"./serializers\";\n\nexport type { Serializer, Serializers } from \"./serializers\";\nexport { default as swaggerHandler } from \"./swagger/api/swagger-handler\";\nexport { dateIn, dateOut } from \"./zod\";\nexport { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from \"@visulima/connect\";\n\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n NextHandler,\n Nextable,\n NodeRequestHandler,\n Route,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"@visulima/connect\";\n\nexport {\n BadGateway,\n BadRequest,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n Forbidden,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n LengthRequired,\n Locked,\n LoopDetected,\n MethodNotAllowed,\n MisdirectedRequest,\n NetworkAuthenticationRequire,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n ProxyAuthenticationRequired,\n RangeNotSatisfiable,\n RequestHeaderFieldsTooLarge,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n URITooLong,\n Unauthorized,\n UnavailableForLegalReasons,\n UnprocessableEntity,\n UnsupportedMediaType,\n UpgradeRequired,\n VariantAlsoNegotiates,\n default as createHttpError,\n} from \"http-errors\";\n"]}
@@ -1,20 +1,20 @@
1
- export { a as dateIn, b as dateOut, c as zod } from './chunk-WJDS32PO.mjs';
2
- import { b, a } from './chunk-MAUWX6TE.mjs';
3
- export { c as swaggerHandler, b as yamlTransformer } from './chunk-MAUWX6TE.mjs';
4
- import './chunk-YOXCJZNX.mjs';
5
- import k, { HttpError } from 'http-errors';
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';
1
+ export { a as dateIn, b as dateOut, c as zod } from './chunk-AB7BFRZY.mjs';
2
+ import { b, a } from './chunk-CQXODW6L.mjs';
3
+ export { c as swaggerHandler, b as yamlTransformer } from './chunk-CQXODW6L.mjs';
4
+ import './chunk-XIJ2ZQRX.mjs';
7
5
  import { NodeRouter, expressWrapper } from '@visulima/connect';
8
6
  export { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from '@visulima/connect';
7
+ import O, { HttpError } from 'http-errors';
8
+ 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';
9
9
  import { getReasonPhrase, StatusCodes } from 'http-status-codes';
10
- import g from 'ts-japi';
10
+ import y from 'ts-japi';
11
11
  import Y from 'debug';
12
12
  import $ from 'accepts';
13
13
  import G from 'jstoxml';
14
- import pe from 'cors';
14
+ import ae from 'cors';
15
15
 
16
- 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=StatusCodes.INTERNAL_SERVER_ERROR);};var v="An error occurred",J=(e,o,t)=>{if(u(t,e),f(t,e),e instanceof g.JapiError||g.JapiError.isLikeJapiError(e)){let r=new g.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof HttpError){let{statusCode:r,title:a,message:n}=e;p(t,{errors:[{code:r,title:a||getReasonPhrase(r)||v,detail:n}]});}else {let{message:r}=e;p(t,{errors:[{code:"500",title: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 HttpError){let{statusCode:n,expose:s,title:i,type:d}=e;t.statusCode=n,f(t,e),p(t,{type:d||A,title:i||getReasonPhrase(n)||M,details:a,...s?{trace:r}:{}});}else u(t,e),p(t,{type:A,title: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(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.toXML(e,{header:!0,indent:" "}),R=_;var y="Content-Type",Q=(e,o,t,r,a$1)=>{if(typeof t.getHeader(y)=="string")return r;let i=[...$(o).types(),a$1.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=b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(y,l),d=R({[a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},m=Q;var ee=Y("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 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(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(429,"Too Many Requests")}},ie=ae;var le=e=>expressWrapper(pe(e)),me=le;
16
+ 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=StatusCodes.INTERNAL_SERVER_ERROR);};var v="An error occurred",J=(e,o,t)=>{if(u(t,e),f(t,e),e instanceof y.JapiError||y.JapiError.isLikeJapiError(e)){let r=new y.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof HttpError){let{message:r,statusCode:n,title:a}=e;p(t,{errors:[{code:n,title:a||getReasonPhrase(n)||v,detail:r}]});}else {let{message:r}=e;p(t,{errors:[{code:"500",title: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{message:r,stack:n}=e;if(e instanceof HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,f(t,e),p(t,{type:d||A,title:i||getReasonPhrase(s)||M,details:r,...a?{trace:n}:{}});}else u(t,e),p(t,{type:A,title:getReasonPhrase(t.statusCode)||M,details:r,...e.expose?{trace:n}:{}});},C=W;var x=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=C;a==="application/vnd.api+json"&&(s=z);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},h=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,O(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-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",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,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},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.toXML(e,{header:!0,indent:" "}),R=_;var g="Content-Type",Q=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...$(o).types(),n.defaultContentType],d=r,w=!1;return i.forEach(l=>{e.forEach(({regex:q,serializer:P})=>{q.test(l)&&(t.setHeader(g,l),d=P(d),w=!0);}),w||(/yaml|yml/.test(l)?(t.setHeader(g,l),d=b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(g,l),d=R({[a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},c=Q;var ee=Y("api-platform:connect:serializers-middleware"),te=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=c(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 a=r.end;r.end=(s,...i)=>(r.end=a,s=c(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},E=te;var oe=(e={})=>new NodeRouter({onError:x(e.errorHandlers??[],e.showTrace??!1),onNoMatch:h}).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 ie=e=>expressWrapper(ae(e)),de=ie;var pe=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,le=(e,o)=>async(t,r,n)=>{let a=pe(t);if(a===void 0)throw O(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw O(429,"Too Many Requests")}},ce=le;
17
17
 
18
- export { me as corsMiddleware, se as createNodeRouter, H as httpHeaderNormalizerMiddleware, x as onError, h as onNoMatch, ie as rateLimiterMiddleware, m as serialize, E as serializersMiddleware, R as xmlTransformer };
18
+ export { de as corsMiddleware, se as createNodeRouter, H as httpHeaderNormalizerMiddleware, x as onError, h as onNoMatch, ce as rateLimiterMiddleware, c as serialize, E as serializersMiddleware, R as xmlTransformer };
19
19
  //# sourceMappingURL=out.js.map
20
20
  //# sourceMappingURL=index-server.mjs.map