@visulima/api-platform 1.1.2 → 1.1.3
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 +7 -0
- package/dist/chunk-AG2ROSSA.mjs +2 -0
- package/dist/{chunk-D5JLMBFH.mjs.map → chunk-AG2ROSSA.mjs.map} +1 -1
- package/dist/chunk-HONWWBY6.mjs +2 -0
- package/dist/{chunk-YR2QJYUL.mjs.map → chunk-HONWWBY6.mjs.map} +1 -1
- package/dist/chunk-JXD3457O.js +2 -0
- package/dist/chunk-JXD3457O.js.map +1 -0
- package/dist/chunk-M7LGAQP3.mjs +10 -0
- package/dist/{chunk-EGE7A4ZK.mjs.map → chunk-M7LGAQP3.mjs.map} +1 -1
- package/dist/chunk-OUWZ2PU5.js +2 -0
- package/dist/{chunk-JC4IRQUL.js.map → chunk-OUWZ2PU5.js.map} +0 -0
- package/dist/chunk-QIHOLJVA.js +2 -0
- package/dist/chunk-QIHOLJVA.js.map +1 -0
- package/dist/chunk-UI23SSBN.js +10 -0
- package/dist/chunk-UI23SSBN.js.map +1 -0
- package/dist/chunk-YOXCJZNX.mjs +2 -0
- package/dist/{chunk-5VRACIDE.mjs.map → chunk-YOXCJZNX.mjs.map} +0 -0
- package/dist/index-browser.js +1 -7
- package/dist/index-browser.mjs +1 -7
- package/dist/index-server.d.ts +1 -1
- package/dist/index-server.js +1 -452
- package/dist/index-server.js.map +1 -1
- package/dist/index-server.mjs +1 -452
- package/dist/index-server.mjs.map +1 -1
- package/dist/next/cli/index.js +3 -202
- package/dist/next/cli/index.js.map +1 -1
- package/dist/next/cli/index.mjs +3 -202
- package/dist/next/cli/index.mjs.map +1 -1
- package/dist/next/index-browser.js +1 -11
- package/dist/next/index-browser.mjs +1 -11
- package/dist/next/index-server.js +1 -75
- package/dist/next/index-server.js.map +1 -1
- package/dist/next/index-server.mjs +1 -75
- package/dist/next/index-server.mjs.map +1 -1
- package/package.json +2 -2
- package/dist/chunk-5VRACIDE.mjs +0 -10
- package/dist/chunk-CVURPKKG.js +0 -120
- package/dist/chunk-CVURPKKG.js.map +0 -1
- package/dist/chunk-D5JLMBFH.mjs +0 -284
- package/dist/chunk-EGE7A4ZK.mjs +0 -120
- package/dist/chunk-HOWWQBSN.js +0 -99
- package/dist/chunk-HOWWQBSN.js.map +0 -1
- package/dist/chunk-JC4IRQUL.js +0 -10
- package/dist/chunk-R6HXY2JR.js +0 -284
- package/dist/chunk-R6HXY2JR.js.map +0 -1
- package/dist/chunk-YR2QJYUL.mjs +0 -99
package/dist/index-server.js
CHANGED
|
@@ -1,453 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var _chunkHOWWQBSNjs = require('./chunk-HOWWQBSN.js');
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
var _chunkR6HXY2JRjs = require('./chunk-R6HXY2JR.js');
|
|
10
|
-
require('./chunk-JC4IRQUL.js');
|
|
11
|
-
|
|
12
|
-
// src/index-server.ts
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
var _httperrors = require('http-errors'); var _httperrors2 = _interopRequireDefault(_httperrors);
|
|
57
|
-
|
|
58
|
-
// src/connect/create-node-router.ts
|
|
59
|
-
var _connect = require('@visulima/connect');
|
|
60
|
-
|
|
61
|
-
// src/connect/handler.ts
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
// src/error-handler/jsonapi-error-handler.ts
|
|
65
|
-
|
|
66
|
-
var _httpstatuscodes = require('http-status-codes');
|
|
67
|
-
var _tsjapi = require('ts-japi');
|
|
68
|
-
|
|
69
|
-
// src/error-handler/utils.ts
|
|
70
|
-
|
|
71
|
-
var setErrorHeaders = (response, error) => {
|
|
72
|
-
const headers = error.headers || {};
|
|
73
|
-
Object.keys(headers).forEach((header) => {
|
|
74
|
-
response.setHeader(header, headers[header]);
|
|
75
|
-
});
|
|
76
|
-
};
|
|
77
|
-
var sendJson = (response, jsonBody) => {
|
|
78
|
-
response.setHeader("content-type", "application/json; charset=utf-8");
|
|
79
|
-
response.end(JSON.stringify(jsonBody));
|
|
80
|
-
};
|
|
81
|
-
var addStatusCodeToResponse = (response, error) => {
|
|
82
|
-
if (error.statusCode !== void 0) {
|
|
83
|
-
response.statusCode = error.statusCode;
|
|
84
|
-
}
|
|
85
|
-
if (error.status !== void 0) {
|
|
86
|
-
response.statusCode = error.status;
|
|
87
|
-
}
|
|
88
|
-
if (response.statusCode < 400) {
|
|
89
|
-
response.statusCode = _httpstatuscodes.StatusCodes.INTERNAL_SERVER_ERROR;
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
// src/error-handler/jsonapi-error-handler.ts
|
|
94
|
-
var defaultTitle = "An error occurred";
|
|
95
|
-
var jsonapiErrorHandler = (error, _request, response) => {
|
|
96
|
-
addStatusCodeToResponse(response, error);
|
|
97
|
-
setErrorHeaders(response, error);
|
|
98
|
-
if (error instanceof _tsjapi.JapiError || _tsjapi.JapiError.isLikeJapiError(error)) {
|
|
99
|
-
const serializer = new (0, _tsjapi.ErrorSerializer)();
|
|
100
|
-
sendJson(response, serializer.serialize(error));
|
|
101
|
-
} else if (error instanceof _httperrors.HttpError) {
|
|
102
|
-
const { statusCode, title, message } = error;
|
|
103
|
-
sendJson(response, {
|
|
104
|
-
errors: [
|
|
105
|
-
{
|
|
106
|
-
code: statusCode,
|
|
107
|
-
title: title || _httpstatuscodes.getReasonPhrase.call(void 0, statusCode) || defaultTitle,
|
|
108
|
-
detail: message
|
|
109
|
-
}
|
|
110
|
-
]
|
|
111
|
-
});
|
|
112
|
-
} else {
|
|
113
|
-
const { message } = error;
|
|
114
|
-
sendJson(response, {
|
|
115
|
-
errors: [
|
|
116
|
-
{
|
|
117
|
-
code: "500",
|
|
118
|
-
title: _httpstatuscodes.getReasonPhrase.call(void 0, response.statusCode) || defaultTitle,
|
|
119
|
-
detail: message
|
|
120
|
-
}
|
|
121
|
-
]
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
var jsonapi_error_handler_default = jsonapiErrorHandler;
|
|
126
|
-
|
|
127
|
-
// src/error-handler/problem-error-handler.ts
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
var defaultType = "https://tools.ietf.org/html/rfc2616#section-10";
|
|
131
|
-
var defaultTitle2 = "An error occurred";
|
|
132
|
-
var problemErrorHandler = (error, _request, response) => {
|
|
133
|
-
const { stack, message } = error;
|
|
134
|
-
if (error instanceof _httperrors.HttpError) {
|
|
135
|
-
const {
|
|
136
|
-
statusCode,
|
|
137
|
-
expose,
|
|
138
|
-
title,
|
|
139
|
-
type
|
|
140
|
-
} = error;
|
|
141
|
-
response.statusCode = statusCode;
|
|
142
|
-
setErrorHeaders(response, error);
|
|
143
|
-
sendJson(response, {
|
|
144
|
-
type: type || defaultType,
|
|
145
|
-
title: title || _httpstatuscodes.getReasonPhrase.call(void 0, statusCode) || defaultTitle2,
|
|
146
|
-
details: message,
|
|
147
|
-
...expose ? { trace: stack } : {}
|
|
148
|
-
});
|
|
149
|
-
} else {
|
|
150
|
-
addStatusCodeToResponse(response, error);
|
|
151
|
-
sendJson(response, {
|
|
152
|
-
type: defaultType,
|
|
153
|
-
title: _httpstatuscodes.getReasonPhrase.call(void 0, response.statusCode) || defaultTitle2,
|
|
154
|
-
details: message,
|
|
155
|
-
...error.expose ? { trace: stack } : {}
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
};
|
|
159
|
-
var problem_error_handler_default = problemErrorHandler;
|
|
160
|
-
|
|
161
|
-
// src/connect/handler.ts
|
|
162
|
-
var onError = (errorHandlers, showTrace) => async (error, request, response) => {
|
|
163
|
-
const apiFormat = request.headers.accept;
|
|
164
|
-
let errorHandler = problem_error_handler_default;
|
|
165
|
-
if (apiFormat === "application/vnd.api+json") {
|
|
166
|
-
errorHandler = jsonapi_error_handler_default;
|
|
167
|
-
}
|
|
168
|
-
for (const { regex, handler } of errorHandlers) {
|
|
169
|
-
if (regex.test(apiFormat)) {
|
|
170
|
-
errorHandler = handler;
|
|
171
|
-
break;
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
error.expose = showTrace;
|
|
175
|
-
errorHandler(error, request, response);
|
|
176
|
-
};
|
|
177
|
-
var onNoMatch = async (request, response, routes) => {
|
|
178
|
-
const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(", ");
|
|
179
|
-
response.setHeader("Allow", uniqueMethods);
|
|
180
|
-
response.statusCode = 405;
|
|
181
|
-
throw _httperrors2.default.call(void 0, 405, `No route with [${request.method}] method found.`);
|
|
182
|
-
};
|
|
183
|
-
|
|
184
|
-
// src/connect/middleware/http-header-normalizer.ts
|
|
185
|
-
var exceptions = {
|
|
186
|
-
alpn: "ALPN",
|
|
187
|
-
"c-pep": "C-PEP",
|
|
188
|
-
"c-pep-info": "C-PEP-Info",
|
|
189
|
-
"caldav-timezones": "CalDAV-Timezones",
|
|
190
|
-
"content-id": "Content-ID",
|
|
191
|
-
"content-md5": "Content-MD5",
|
|
192
|
-
dasl: "DASL",
|
|
193
|
-
dav: "DAV",
|
|
194
|
-
dnt: "DNT",
|
|
195
|
-
etag: "ETag",
|
|
196
|
-
getprofile: "GetProfile",
|
|
197
|
-
"http2-settings": "HTTP2-Settings",
|
|
198
|
-
"last-event-id": "Last-Event-ID",
|
|
199
|
-
"mime-version": "MIME-Version",
|
|
200
|
-
"optional-www-authenticate": "Optional-WWW-Authenticate",
|
|
201
|
-
"sec-websocket-accept": "Sec-WebSocket-Accept",
|
|
202
|
-
"sec-websocket-extensions": "Sec-WebSocket-Extensions",
|
|
203
|
-
"sec-webSocket-key": "Sec-WebSocket-Key",
|
|
204
|
-
"sec-webSocket-protocol": "Sec-WebSocket-Protocol",
|
|
205
|
-
"sec-webSocket-version": "Sec-WebSocket-Version",
|
|
206
|
-
slug: "SLUG",
|
|
207
|
-
tcn: "TCN",
|
|
208
|
-
te: "TE",
|
|
209
|
-
ttl: "TTL",
|
|
210
|
-
"www-authenticate": "WWW-Authenticate",
|
|
211
|
-
"x-att-deviceid": "X-ATT-DeviceId",
|
|
212
|
-
"x-dnsprefetch-control": "X-DNSPrefetch-Control",
|
|
213
|
-
"x-uidh": "X-UIDH"
|
|
214
|
-
};
|
|
215
|
-
var normalizeHeaderKey = (key, canonical) => {
|
|
216
|
-
const lowerCaseKey = key.toLowerCase();
|
|
217
|
-
if (!canonical) {
|
|
218
|
-
return lowerCaseKey;
|
|
219
|
-
}
|
|
220
|
-
if (exceptions[lowerCaseKey]) {
|
|
221
|
-
return exceptions[lowerCaseKey];
|
|
222
|
-
}
|
|
223
|
-
return lowerCaseKey.split("-").map((text) => {
|
|
224
|
-
var _a;
|
|
225
|
-
return ((_a = text[0]) == null ? void 0 : _a.toUpperCase()) + text.slice(1);
|
|
226
|
-
}).join("-");
|
|
227
|
-
};
|
|
228
|
-
var defaults = {
|
|
229
|
-
canonical: false,
|
|
230
|
-
normalizeHeaderKey
|
|
231
|
-
};
|
|
232
|
-
var httpHeaderNormalizerMiddleware = (options_) => {
|
|
233
|
-
const options = { ...defaults, ...options_ };
|
|
234
|
-
return async (request, _, next) => {
|
|
235
|
-
if (request.headers) {
|
|
236
|
-
const rawHeaders = {};
|
|
237
|
-
const headers = {};
|
|
238
|
-
Object.keys(request.headers).forEach((key) => {
|
|
239
|
-
rawHeaders[key] = request.headers[key];
|
|
240
|
-
const normalizedKey = options.normalizeHeaderKey(key, options.canonical);
|
|
241
|
-
if (normalizedKey !== void 0) {
|
|
242
|
-
headers[normalizedKey] = request.headers[key];
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
request.headers = headers;
|
|
246
|
-
request.rawHeaders = rawHeaders;
|
|
247
|
-
}
|
|
248
|
-
return next();
|
|
249
|
-
};
|
|
250
|
-
};
|
|
251
|
-
var http_header_normalizer_default = httpHeaderNormalizerMiddleware;
|
|
252
|
-
|
|
253
|
-
// src/connect/middleware/serializers-middleware.ts
|
|
254
|
-
var _accepts = require('accepts'); var _accepts2 = _interopRequireDefault(_accepts);
|
|
255
|
-
var _case = require('case');
|
|
256
|
-
|
|
257
|
-
// src/connect/serializers/xml.ts
|
|
258
|
-
var _jstoxml = require('jstoxml');
|
|
259
|
-
var xmlTransformer = (data) => _jstoxml.toXML.call(void 0, data, {
|
|
260
|
-
header: true,
|
|
261
|
-
indent: " "
|
|
262
|
-
});
|
|
263
|
-
var xml_default = xmlTransformer;
|
|
264
|
-
|
|
265
|
-
// src/connect/middleware/serializers-middleware.ts
|
|
266
|
-
function hasJsonStructure(string_) {
|
|
267
|
-
if (typeof string_ !== "string") {
|
|
268
|
-
return false;
|
|
269
|
-
}
|
|
270
|
-
try {
|
|
271
|
-
const result = JSON.parse(string_);
|
|
272
|
-
const type = Object.prototype.toString.call(result);
|
|
273
|
-
return type === "[object Object]" || type === "[object Array]";
|
|
274
|
-
} catch (e) {
|
|
275
|
-
return false;
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
var contentTypeKey = "Content-Type";
|
|
279
|
-
var serialize = (serializers, request, response, data, options) => {
|
|
280
|
-
const contentType = response.getHeader(contentTypeKey);
|
|
281
|
-
if (typeof contentType === "string") {
|
|
282
|
-
return data;
|
|
283
|
-
}
|
|
284
|
-
const accept = _accepts2.default.call(void 0, request);
|
|
285
|
-
const types = [...accept.types(), options.defaultContentType];
|
|
286
|
-
let serializedData = data;
|
|
287
|
-
types.every((type) => {
|
|
288
|
-
var _a;
|
|
289
|
-
let breakTypes = false;
|
|
290
|
-
serializers.forEach(({ regex, serializer }) => {
|
|
291
|
-
if (!regex.test(type)) {
|
|
292
|
-
return;
|
|
293
|
-
}
|
|
294
|
-
response.setHeader(contentTypeKey, type);
|
|
295
|
-
serializedData = serializer(serializedData);
|
|
296
|
-
breakTypes = true;
|
|
297
|
-
});
|
|
298
|
-
if (!breakTypes) {
|
|
299
|
-
if (/yaml|yml/.test(type)) {
|
|
300
|
-
response.setHeader(contentTypeKey, type);
|
|
301
|
-
serializedData = _chunkR6HXY2JRjs.yaml_default.call(void 0, hasJsonStructure(data) ? JSON.parse(data) : data);
|
|
302
|
-
} else if (/xml/.test(type)) {
|
|
303
|
-
response.setHeader(contentTypeKey, type);
|
|
304
|
-
serializedData = xml_default({
|
|
305
|
-
[_case.header.call(void 0, `${(_a = request.url) == null ? void 0 : _a.replace("/api/", "")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data
|
|
306
|
-
});
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
return breakTypes;
|
|
310
|
-
});
|
|
311
|
-
return serializedData;
|
|
312
|
-
};
|
|
313
|
-
var serializersMiddleware = (serializers = [], defaultContentType = "application/json; charset=utf-8") => async (request, response, next) => {
|
|
314
|
-
if (typeof (response == null ? void 0 : response.send) === "function") {
|
|
315
|
-
const oldSend = response.send;
|
|
316
|
-
response.send = (data) => {
|
|
317
|
-
response.send = oldSend;
|
|
318
|
-
data = serialize(serializers, request, response, data, { defaultContentType });
|
|
319
|
-
return response.send(data);
|
|
320
|
-
};
|
|
321
|
-
} else {
|
|
322
|
-
const oldEnd = response.end;
|
|
323
|
-
response.end = (data, ...arguments_) => {
|
|
324
|
-
response.end = oldEnd;
|
|
325
|
-
data = serialize(serializers, request, response, data, { defaultContentType });
|
|
326
|
-
return response.end(data, ...arguments_);
|
|
327
|
-
};
|
|
328
|
-
}
|
|
329
|
-
return next();
|
|
330
|
-
};
|
|
331
|
-
var serializers_middleware_default = serializersMiddleware;
|
|
332
|
-
|
|
333
|
-
// src/connect/create-node-router.ts
|
|
334
|
-
var createNodeRouter = (options = {}) => {
|
|
335
|
-
var _a, _b, _c, _d, _e;
|
|
336
|
-
const router = new (0, _connect.NodeRouter)({
|
|
337
|
-
onNoMatch,
|
|
338
|
-
onError: onError(options.errorHandlers || [], options.showTrace || false)
|
|
339
|
-
});
|
|
340
|
-
return router.use(http_header_normalizer_default(((_a = options == null ? void 0 : options.middlewares) == null ? void 0 : _a["http-header-normalizer"]) || {})).use(
|
|
341
|
-
serializers_middleware_default(
|
|
342
|
-
((_c = (_b = options == null ? void 0 : options.middlewares) == null ? void 0 : _b.serializers) == null ? void 0 : _c.serializers) || [],
|
|
343
|
-
((_e = (_d = options == null ? void 0 : options.middlewares) == null ? void 0 : _d.serializers) == null ? void 0 : _e.defaultContentType) || "application/json; charset=utf-8"
|
|
344
|
-
)
|
|
345
|
-
);
|
|
346
|
-
};
|
|
347
|
-
var create_node_router_default = createNodeRouter;
|
|
348
|
-
|
|
349
|
-
// src/index-server.ts
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
// src/connect/middleware/rate-limiter-middleware.ts
|
|
361
|
-
|
|
362
|
-
var getIP = (request) => (request == null ? void 0 : request.ip) || request.headers["x-forwarded-for"] || request.headers["x-real-ip"] || request.connection.remoteAddress;
|
|
363
|
-
var rateLimiterMiddleware = (rateLimiter, headers) => async (request, response, next) => {
|
|
364
|
-
const ip = getIP(request);
|
|
365
|
-
if (ip === void 0) {
|
|
366
|
-
throw _httperrors2.default.call(void 0, 400, "Missing IP");
|
|
367
|
-
}
|
|
368
|
-
try {
|
|
369
|
-
const limiter = await rateLimiter.consume(ip);
|
|
370
|
-
const mergedHeaders = {
|
|
371
|
-
"Retry-After": Math.round(limiter.msBeforeNext / 1e3) || 1,
|
|
372
|
-
"X-RateLimit-Remaining": limiter.remainingPoints,
|
|
373
|
-
"X-RateLimit-Reset": new Date(Date.now() + limiter.msBeforeNext).toISOString(),
|
|
374
|
-
...headers
|
|
375
|
-
};
|
|
376
|
-
Object.keys(mergedHeaders).forEach((key) => {
|
|
377
|
-
response.setHeader(key, mergedHeaders[key]);
|
|
378
|
-
});
|
|
379
|
-
await next();
|
|
380
|
-
} catch (e2) {
|
|
381
|
-
throw _httperrors2.default.call(void 0, 429, "Too Many Requests");
|
|
382
|
-
}
|
|
383
|
-
};
|
|
384
|
-
var rate_limiter_middleware_default = rateLimiterMiddleware;
|
|
385
|
-
|
|
386
|
-
// src/connect/middleware/cors-middleware.ts
|
|
387
|
-
|
|
388
|
-
var _cors = require('cors'); var _cors2 = _interopRequireDefault(_cors);
|
|
389
|
-
var corsMiddleware = (options) => _connect.expressWrapper.call(void 0, _cors2.default.call(void 0, options));
|
|
390
|
-
var cors_middleware_default = corsMiddleware;
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
exports.BadGateway = _httperrors.BadGateway; exports.BadRequest = _httperrors.BadRequest; exports.BandwidthLimitExceeded = _httperrors.BandwidthLimitExceeded; exports.Conflict = _httperrors.Conflict; exports.EdgeRouter = _connect.EdgeRouter; exports.ExpectationFailed = _httperrors.ExpectationFailed; exports.FailedDependency = _httperrors.FailedDependency; exports.Forbidden = _httperrors.Forbidden; exports.GatewayTimeout = _httperrors.GatewayTimeout; exports.Gone = _httperrors.Gone; exports.HTTPVersionNotSupported = _httperrors.HTTPVersionNotSupported; exports.ImATeapot = _httperrors.ImATeapot; exports.InsufficientStorage = _httperrors.InsufficientStorage; exports.InternalServerError = _httperrors.InternalServerError; exports.LengthRequired = _httperrors.LengthRequired; exports.Locked = _httperrors.Locked; exports.LoopDetected = _httperrors.LoopDetected; exports.MethodNotAllowed = _httperrors.MethodNotAllowed; exports.MisdirectedRequest = _httperrors.MisdirectedRequest; exports.NetworkAuthenticationRequire = _httperrors.NetworkAuthenticationRequire; exports.NodeRouter = _connect.NodeRouter; exports.NotAcceptable = _httperrors.NotAcceptable; exports.NotExtended = _httperrors.NotExtended; exports.NotFound = _httperrors.NotFound; exports.NotImplemented = _httperrors.NotImplemented; exports.PayloadTooLarge = _httperrors.PayloadTooLarge; exports.PaymentRequired = _httperrors.PaymentRequired; exports.PreconditionFailed = _httperrors.PreconditionFailed; exports.PreconditionRequired = _httperrors.PreconditionRequired; exports.ProxyAuthenticationRequired = _httperrors.ProxyAuthenticationRequired; exports.RangeNotSatisfiable = _httperrors.RangeNotSatisfiable; exports.RequestHeaderFieldsTooLarge = _httperrors.RequestHeaderFieldsTooLarge; exports.RequestTimeout = _httperrors.RequestTimeout; exports.Router = _connect.Router; exports.ServiceUnavailable = _httperrors.ServiceUnavailable; exports.TooManyRequests = _httperrors.TooManyRequests; exports.URITooLong = _httperrors.URITooLong; exports.Unauthorized = _httperrors.Unauthorized; exports.UnavailableForLegalReasons = _httperrors.UnavailableForLegalReasons; exports.UnorderedCollection = _httperrors.UnorderedCollection; exports.UnprocessableEntity = _httperrors.UnprocessableEntity; exports.UnsupportedMediaType = _httperrors.UnsupportedMediaType; exports.UpgradeRequired = _httperrors.UpgradeRequired; exports.VariantAlsoNegotiates = _httperrors.VariantAlsoNegotiates; exports.corsMiddleware = cors_middleware_default; exports.createEdgeRouter = _connect.createEdgeRouter; exports.createHttpError = _httperrors2.default; exports.createNodeRouter = create_node_router_default; exports.dateIn = _chunkHOWWQBSNjs.dateIn; exports.dateOut = _chunkHOWWQBSNjs.dateOut; exports.expressWrapper = _connect.expressWrapper; exports.httpHeaderNormalizerMiddleware = http_header_normalizer_default; exports.onError = onError; exports.onNoMatch = onNoMatch; exports.rateLimiterMiddleware = rate_limiter_middleware_default; exports.sendJson = _connect.sendJson; exports.serializersMiddleware = serializers_middleware_default; exports.swaggerHandler = _chunkR6HXY2JRjs.swagger_handler_default; exports.withZod = _connect.withZod; exports.zod = _chunkHOWWQBSNjs.zod_exports;
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkJXD3457Ojs = require('./chunk-JXD3457O.js');var _chunkQIHOLJVAjs = require('./chunk-QIHOLJVA.js');require('./chunk-OUWZ2PU5.js');var _httperrors = require('http-errors'); var _httperrors2 = _interopRequireDefault(_httperrors);var _connect = require('@visulima/connect');var _httpstatuscodes = require('http-status-codes');var _tsjapi = require('ts-japi');var l=(e,o)=>{let t=o.headers||{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r])})},p=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o))},m=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=_httpstatuscodes.StatusCodes.INTERNAL_SERVER_ERROR)};var b="An error occurred",W=(e,o,t)=>{if(m(t,e),l(t,e),e instanceof _tsjapi.JapiError||_tsjapi.JapiError.isLikeJapiError(e)){let r=new _tsjapi.ErrorSerializer;p(t,r.serialize(e))}else if(e instanceof _httperrors.HttpError){let{statusCode:r,title:n,message:a}=e;p(t,{errors:[{code:r,title:n||_httpstatuscodes.getReasonPhrase.call(void 0, r)||b,detail:a}]})}else{let{message:r}=e;p(t,{errors:[{code:"500",title:_httpstatuscodes.getReasonPhrase.call(void 0, t.statusCode)||b,detail:r}]})}},w=W;var M="https://tools.ietf.org/html/rfc2616#section-10",T="An error occurred",U=(e,o,t)=>{let{stack:r,message:n}=e;if(e instanceof _httperrors.HttpError){let{statusCode:a,expose:s,title:i,type:d}=e;t.statusCode=a,l(t,e),p(t,{type:d||M,title:i||_httpstatuscodes.getReasonPhrase.call(void 0, a)||T,details:n,...s?{trace:r}:{}})}else m(t,e),p(t,{type:M,title:_httpstatuscodes.getReasonPhrase.call(void 0, t.statusCode)||T,details:n,...e.expose?{trace:r}:{}})},A=U;var R=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=A;a==="application/vnd.api+json"&&(s=w);for(let{regex:i,handler:d}of e)if(i.test(a)){s=d;break}t.expose=o,s(t,r,n)},y= exports.onNoMatch =async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,_httperrors2.default.call(void 0, 405,`No route with [${e.method}] method found.`)};var v={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},K=(e,o)=>{let t=e.toLowerCase();return o?v[t]?v[t]:t.split("-").map(r=>{var n;return((n=r[0])==null?void 0:n.toUpperCase())+r.slice(1)}).join("-"):t},Z={canonical:!1,normalizeHeaderKey:K},B=e=>{let o={...Z,...e};return async(t,r,n)=>{if(t.headers){let a={},s={};Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d!==void 0&&(s[d]=t.headers[i])}),t.headers=s,t.rawHeaders=a}return n()}},g= exports.httpHeaderNormalizerMiddleware =B;var _accepts = require('accepts'); var _accepts2 = _interopRequireDefault(_accepts);var _case = require('case');var _jstoxml = require('jstoxml');var _=e=>_jstoxml.toXML.call(void 0, e,{header:!0,indent:" "}),z=_;function C(e){if(typeof e!="string")return!1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch (e2){return!1}}var f="Content-Type",I=(e,o,t,r,n)=>{if(typeof t.getHeader(f)=="string")return r;let i=[..._accepts2.default.call(void 0, o).types(),n.defaultContentType],d=r;return i.every(c=>{var h;let u=!1;return e.forEach(({regex:O,serializer:k})=>{!O.test(c)||(t.setHeader(f,c),d=k(d),u=!0)}),u||(/yaml|yml/.test(c)?(t.setHeader(f,c),d=_chunkQIHOLJVAjs.a.call(void 0, C(r)?JSON.parse(r):r)):/xml/.test(c)&&(t.setHeader(f,c),d=z({[_case.header.call(void 0, `${(h=o.url)==null?void 0:h.replace("/api/","")}`.trim())]:C(r)?JSON.parse(r):r}))),u}),d},Y=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof(r==null?void 0:r.send)=="function"){let a=r.send;r.send=s=>(r.send=a,s=I(e,t,r,s,{defaultContentType:o}),r.send(s))}else{let a=r.end;r.end=(s,...i)=>(r.end=a,s=I(e,t,r,s,{defaultContentType:o}),r.end(s,...i))}return n()},x= exports.serializersMiddleware =Y;var te=(e={})=>{var t,r,n,a,s;return new (0, _connect.NodeRouter)({onNoMatch:y,onError:R(e.errorHandlers||[],e.showTrace||!1)}).use(g(((t=e==null?void 0:e.middlewares)==null?void 0:t["http-header-normalizer"])||{})).use(x(((n=(r=e==null?void 0:e.middlewares)==null?void 0:r.serializers)==null?void 0:n.serializers)||[],((s=(a=e==null?void 0:e.middlewares)==null?void 0:a.serializers)==null?void 0:s.defaultContentType)||"application/json; charset=utf-8"))},re= exports.createNodeRouter =te;var oe=e=>(e==null?void 0:e.ip)||e.headers["x-forwarded-for"]||e.headers["x-real-ip"]||e.connection.remoteAddress,se=(e,o)=>async(t,r,n)=>{let a=oe(t);if(a===void 0)throw _httperrors2.default.call(void 0, 400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d])}),await n()}catch (e3){throw _httperrors2.default.call(void 0, 429,"Too Many Requests")}},ne= exports.rateLimiterMiddleware =se;var _cors = require('cors'); var _cors2 = _interopRequireDefault(_cors);var de=e=>_connect.expressWrapper.call(void 0, _cors2.default.call(void 0, e)),pe= exports.corsMiddleware =de;exports.BadGateway = _httperrors.BadGateway; exports.BadRequest = _httperrors.BadRequest; exports.BandwidthLimitExceeded = _httperrors.BandwidthLimitExceeded; exports.Conflict = _httperrors.Conflict; exports.EdgeRouter = _connect.EdgeRouter; exports.ExpectationFailed = _httperrors.ExpectationFailed; exports.FailedDependency = _httperrors.FailedDependency; exports.Forbidden = _httperrors.Forbidden; exports.GatewayTimeout = _httperrors.GatewayTimeout; exports.Gone = _httperrors.Gone; exports.HTTPVersionNotSupported = _httperrors.HTTPVersionNotSupported; exports.ImATeapot = _httperrors.ImATeapot; exports.InsufficientStorage = _httperrors.InsufficientStorage; exports.InternalServerError = _httperrors.InternalServerError; exports.LengthRequired = _httperrors.LengthRequired; exports.Locked = _httperrors.Locked; exports.LoopDetected = _httperrors.LoopDetected; exports.MethodNotAllowed = _httperrors.MethodNotAllowed; exports.MisdirectedRequest = _httperrors.MisdirectedRequest; exports.NetworkAuthenticationRequire = _httperrors.NetworkAuthenticationRequire; exports.NodeRouter = _connect.NodeRouter; exports.NotAcceptable = _httperrors.NotAcceptable; exports.NotExtended = _httperrors.NotExtended; exports.NotFound = _httperrors.NotFound; exports.NotImplemented = _httperrors.NotImplemented; exports.PayloadTooLarge = _httperrors.PayloadTooLarge; exports.PaymentRequired = _httperrors.PaymentRequired; exports.PreconditionFailed = _httperrors.PreconditionFailed; exports.PreconditionRequired = _httperrors.PreconditionRequired; exports.ProxyAuthenticationRequired = _httperrors.ProxyAuthenticationRequired; exports.RangeNotSatisfiable = _httperrors.RangeNotSatisfiable; exports.RequestHeaderFieldsTooLarge = _httperrors.RequestHeaderFieldsTooLarge; exports.RequestTimeout = _httperrors.RequestTimeout; exports.Router = _connect.Router; exports.ServiceUnavailable = _httperrors.ServiceUnavailable; exports.TooManyRequests = _httperrors.TooManyRequests; exports.URITooLong = _httperrors.URITooLong; exports.Unauthorized = _httperrors.Unauthorized; exports.UnavailableForLegalReasons = _httperrors.UnavailableForLegalReasons; exports.UnprocessableEntity = _httperrors.UnprocessableEntity; exports.UnsupportedMediaType = _httperrors.UnsupportedMediaType; exports.UpgradeRequired = _httperrors.UpgradeRequired; exports.VariantAlsoNegotiates = _httperrors.VariantAlsoNegotiates; exports.corsMiddleware = pe; exports.createEdgeRouter = _connect.createEdgeRouter; exports.createHttpError = _httperrors2.default; exports.createNodeRouter = re; exports.dateIn = _chunkJXD3457Ojs.a; exports.dateOut = _chunkJXD3457Ojs.b; exports.expressWrapper = _connect.expressWrapper; exports.httpHeaderNormalizerMiddleware = g; exports.onError = R; exports.onNoMatch = y; exports.rateLimiterMiddleware = ne; exports.sendJson = _connect.sendJson; exports.serializersMiddleware = x; exports.swaggerHandler = _chunkQIHOLJVAjs.b; exports.withZod = _connect.withZod; exports.zod = _chunkJXD3457Ojs.c;
|
|
453
2
|
//# sourceMappingURL=index-server.js.map
|
package/dist/index-server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"names":["default","HttpError","getReasonPhrase","defaultTitle","expressWrapper","NodeRouter","sendJson","createHttpError"],"mappings":";;;;;;;;;;;;AAEA;AAAA,EACe,WAAXA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACG;;;AC7CP,SAAS,kBAAkB;;;ACG3B,OAAO,qBAAqB;;;ACH5B,SAAS,iBAAiB;AAC1B,SAAS,uBAAuB;AAChC,SAAS,iBAAiB,iBAAiB;;;ACF3C,SAAS,mBAAmB;AAGrB,IAAM,kBAAkB,CAAC,UAA0B,UAAe;AACrE,QAAM,UAAsE,MAAM,WAAW,CAAC;AAE9F,SAAO,KAAK,OAAO,EAAE,QAAQ,CAAC,WAAmB;AAC7C,aAAS,UAAU,QAAQ,QAAQ,OAAkD;AAAA,EACzF,CAAC;AACL;AAOO,IAAM,WAAW,CAAC,UAA0B,aAAwB;AAEvE,WAAS,UAAU,gBAAgB,iCAAiC;AAEpE,WAAS,IAAI,KAAK,UAAU,QAAQ,CAAC;AACzC;AAEO,IAAM,0BAA0B,CAAC,UAA0B,UAAqB;AAEnF,MAAI,MAAM,eAAe,QAAW;AAChC,aAAS,aAAa,MAAM;AAAA,EAChC;AAGA,MAAI,MAAM,WAAW,QAAW;AAC5B,aAAS,aAAa,MAAM;AAAA,EAChC;AAGA,MAAI,SAAS,aAAa,KAAK;AAC3B,aAAS,aAAa,YAAY;AAAA,EACtC;AACJ;;;AD/BA,IAAM,eAAe;AAErB,IAAM,sBAAoC,CAAC,OAAsC,UAAU,aAAa;AACpG,0BAAwB,UAAU,KAAK;AAEvC,kBAAgB,UAAU,KAAK;AAE/B,MAAI,iBAAiB,aAAa,UAAU,gBAAgB,KAAK,GAAG;AAChE,UAAM,aAAa,IAAI,gBAAgB;AAEvC,aAAS,UAAU,WAAW,UAAU,KAAK,CAAC;AAAA,EAClD,WAAW,iBAAiB,WAAW;AACnC,UAAM,EAAE,YAAY,OAAO,QAAQ,IAAI;AAEvC,aAAS,UAAU;AAAA,MACf,QAAQ;AAAA,QACJ;AAAA,UACI,MAAM;AAAA,UACN,OAAO,SAAS,gBAAgB,UAAU,KAAK;AAAA,UAC/C,QAAQ;AAAA,QACZ;AAAA,MACJ;AAAA,IACJ,CAAC;AAAA,EACL,OAAO;AACH,UAAM,EAAE,QAAQ,IAAI;AAEpB,aAAS,UAAU;AAAA,MACf,QAAQ;AAAA,QACJ;AAAA,UACI,MAAM;AAAA,UACN,OAAO,gBAAgB,SAAS,UAAU,KAAK;AAAA,UAC/C,QAAQ;AAAA,QACZ;AAAA,MACJ;AAAA,IACJ,CAAC;AAAA,EACL;AACJ;AAEA,IAAO,gCAAQ;;;AE7Cf,SAAS,aAAAC,kBAAiB;AAC1B,SAAS,mBAAAC,wBAAuB;AAKhC,IAAM,cAAc;AACpB,IAAMC,gBAAe;AAMrB,IAAM,sBAAoC,CAAC,OAA0B,UAAU,aAAa;AACxF,QAAM,EAAE,OAAO,QAAQ,IAAI;AAE3B,MAAI,iBAAiBF,YAAW;AAC5B,UAAM;AAAA,MACF;AAAA,MAAY;AAAA,MAAQ;AAAA,MAAO;AAAA,IAC/B,IAAI;AAEJ,aAAS,aAAa;AAEtB,oBAAgB,UAAU,KAAK;AAE/B,aAAS,UAAU;AAAA,MACf,MAAM,QAAQ;AAAA,MACd,OAAO,SAASC,iBAAgB,UAAU,KAAKC;AAAA,MAC/C,SAAS;AAAA,MACT,GAAI,SAAS,EAAE,OAAO,MAAM,IAAI,CAAC;AAAA,IACrC,CAAC;AAAA,EACL,OAAO;AACH,4BAAwB,UAAU,KAAK;AAEvC,aAAS,UAAU;AAAA,MACf,MAAM;AAAA,MACN,OAAOD,iBAAgB,SAAS,UAAU,KAAKC;AAAA,MAC/C,SAAS;AAAA,MACT,GAAK,MAAsC,SAAS,EAAE,OAAO,MAAM,IAAI,CAAC;AAAA,IAC5E,CAAC;AAAA,EACL;AACJ;AAEA,IAAO,gCAAQ;;;AHhCR,IAAM,UAAU,CAAmE,eAA8B,cAAuB,OAAO,OAAgB,SAAkB,aAAsC;AAC1N,QAAM,YAAoB,QAAQ,QAAQ;AAE1C,MAAI,eAA6B;AAEjC,MAAI,cAAc,4BAA4B;AAC1C,mBAAe;AAAA,EACnB;AAGA,aAAW,EAAE,OAAO,QAAQ,KAAK,eAAe;AAC5C,QAAI,MAAM,KAAK,SAAS,GAAG;AACvB,qBAAe;AACf;AAAA,IACJ;AAAA,EACJ;AAGA,EAAC,MAAsC,SAAS;AAEhD,eAAa,OAAO,SAAS,QAAQ;AACzC;AAEO,IAAM,YAIe,OAAO,SAAS,UAAU,WAAW;AAC7D,QAAM,gBAAgB,CAAC,GAAG,IAAI,IAAI,OAAO,IAAI,CAAC,UAAU,MAAM,MAAM,CAAC,CAAC,EAAE,KAAK,IAAI;AAEjF,WAAS,UAAU,SAAS,aAAa;AACzC,WAAS,aAAa;AAEtB,QAAM,gBAAgB,KAAK,kBAAkB,QAAQ,uBAAuB;AAChF;;;AI1CA,IAAM,aAAa;AAAA,EACf,MAAM;AAAA,EACN,SAAS;AAAA,EACT,cAAc;AAAA,EACd,oBAAoB;AAAA,EACpB,cAAc;AAAA,EACd,eAAe;AAAA,EACf,MAAM;AAAA,EACN,KAAK;AAAA,EACL,KAAK;AAAA,EACL,MAAM;AAAA,EACN,YAAY;AAAA,EACZ,kBAAkB;AAAA,EAClB,iBAAiB;AAAA,EACjB,gBAAgB;AAAA,EAChB,6BAA6B;AAAA,EAC7B,wBAAwB;AAAA,EACxB,4BAA4B;AAAA,EAC5B,qBAAqB;AAAA,EACrB,0BAA0B;AAAA,EAC1B,yBAAyB;AAAA,EACzB,MAAM;AAAA,EACN,KAAK;AAAA,EACL,IAAI;AAAA,EACJ,KAAK;AAAA,EACL,oBAAoB;AAAA,EACpB,kBAAkB;AAAA,EAClB,yBAAyB;AAAA,EACzB,UAAU;AACd;AAEA,IAAM,qBAAqB,CAAC,KAAa,cAAuB;AAC5D,QAAM,eAAe,IAAI,YAAY;AAErC,MAAI,CAAC,WAAW;AACZ,WAAO;AAAA,EACX;AAEA,MAAI,WAAW,eAA0C;AACrD,WAAO,WAAW;AAAA,EACtB;AAEA,SACI,aACK,MAAM,GAAG,EAET,IAAI,CAAC,SAAM;AAjDxB;AAiD2B,uBAAK,OAAL,mBAAS,iBAAgB,KAAK,MAAM,CAAC;AAAA,GAAC,EACpD,KAAK,GAAG;AAErB;AAEA,IAAM,WAAW;AAAA,EACb,WAAW;AAAA,EACX;AACJ;AAOA,IAAM,iCAAiC,CAAC,aAAyG;AAC7I,QAAM,UAAU,EAAE,GAAG,UAAU,GAAG,SAAS;AAE3C,SAAO,OAAwC,SAAkB,GAAQ,SAAsB;AAC3F,QAAI,QAAQ,SAAS;AACjB,YAAM,aAAkC,CAAC;AACzC,YAAM,UAA+B,CAAC;AAEtC,aAAO,KAAK,QAAQ,OAAO,EAAE,QAAQ,CAAC,QAAQ;AAC1C,mBAAW,OAAO,QAAQ,QAAQ;AAElC,cAAM,gBAAgB,QAAQ,mBAAmB,KAAK,QAAQ,SAAS;AAEvE,YAAI,kBAAkB,QAAW;AAC7B,kBAAQ,iBAAiB,QAAQ,QAAQ;AAAA,QAC7C;AAAA,MACJ,CAAC;AAED,cAAQ,UAAU;AAGlB,cAAQ,aAAa;AAAA,IACzB;AAEA,WAAO,KAAK;AAAA,EAChB;AACJ;AAEA,IAAO,iCAAQ;;;AC3Ff,OAAO,aAAa;AACpB,SAAS,UAAU,kBAAkB;;;ACDrC,SAAS,aAAa;AAItB,IAAM,iBAA6B,CAAC,SAAqC,MAAM,MAAM;AAAA,EACjF,QAAQ;AAAA,EACR,QAAQ;AACZ,CAAC;AAED,IAAO,cAAQ;;;ADAf,SAAS,iBAAiB,SAAuB;AAC7C,MAAI,OAAO,YAAY,UAAU;AAC7B,WAAO;AAAA,EACX;AAEA,MAAI;AACA,UAAM,SAAS,KAAK,MAAM,OAAO;AACjC,UAAM,OAAO,OAAO,UAAU,SAAS,KAAK,MAAM;AAElD,WAAO,SAAS,qBAAqB,SAAS;AAAA,EAClD,QAAE;AACE,WAAO;AAAA,EACX;AACJ;AAEA,IAAM,iBAAiB;AAGvB,IAAM,YAAY,CACd,aACA,SACA,UACA,MACA,YAIC;AACD,QAAM,cAAc,SAAS,UAAU,cAAc;AAGrD,MAAI,OAAO,gBAAgB,UAAU;AACjC,WAAO;AAAA,EACX;AAEA,QAAM,SAAS,QAAQ,OAAO;AAC9B,QAAM,QAAkB,CAAC,GAAI,OAAO,MAAM,GAAgB,QAAQ,kBAAkB;AAEpF,MAAI,iBAAiB;AAGrB,QAAM,MAAM,CAAC,SAAS;AAnD1B;AAoDQ,QAAI,aAAa;AAEjB,gBAAY,QAAQ,CAAC,EAAE,OAAO,WAAW,MAAM;AAC3C,UAAI,CAAC,MAAM,KAAK,IAAI,GAAG;AACnB;AAAA,MACJ;AAEA,eAAS,UAAU,gBAAgB,IAAI;AACvC,uBAAiB,WAAW,cAAc;AAC1C,mBAAa;AAAA,IACjB,CAAC;AAED,QAAI,CAAC,YAAY;AACb,UAAI,WAAW,KAAK,IAAI,GAAG;AACvB,iBAAS,UAAU,gBAAgB,IAAI;AAEvC,yBAAiB,aAAgB,iBAAiB,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI,IAAI;AAAA,MACrF,WAAW,MAAM,KAAK,IAAI,GAAG;AACzB,iBAAS,UAAU,gBAAgB,IAAI;AAEvC,yBAAiB,YAAe;AAAA,UAC5B,CAAC,WAAW,IAAG,aAAQ,QAAR,mBAAa,QAAQ,SAAS,MAAM,KAAK,CAAC,IAAI,iBAAiB,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI;AAAA,QAC7G,CAAC;AAAA,MACL;AAAA,IACJ;AAEA,WAAO;AAAA,EACX,CAAC;AAGD,SAAO;AACX;AAGA,IAAM,wBAAwB,CAAC,cAA2B,CAAC,GAAG,qBAA6B,sCAAsC,OAAyE,SAAkB,UAAsC,SAAsB;AACpR,MAAI,QAAQ,qCAA8B,UAAS,YAAY;AAC3D,UAAM,UAAW,SAA6B;AAE9C,IAAC,SAA6B,OAAO,CAAC,SAAS;AAC3C,MAAC,SAA6B,OAAO;AAGrC,aAAO,UAA6B,aAAa,SAAS,UAAU,MAAM,EAAE,mBAAmB,CAAC;AAEhG,aAAQ,SAA6B,KAAK,IAAI;AAAA,IAClD;AAAA,EACJ,OAAO;AACH,UAAM,SAAS,SAAS;AAGxB,aAAS,MAAM,CAAC,SAAS,eAAe;AACpC,eAAS,MAAM;AAGf,aAAO,UAA6B,aAAa,SAAS,UAAU,MAAM,EAAE,mBAAmB,CAAC;AAGhG,aAAO,SAAS,IAAI,MAAM,GAAG,UAAU;AAAA,IAC3C;AAAA,EACJ;AAEA,SAAO,KAAK;AAChB;AAMA,IAAO,iCAAQ;;;AN7Gf,IAAM,mBAAmB,CAKjB,UAUI,CAAC,MACJ;AA3BT;AA4BI,QAAM,SAAS,IAAI,WAAsC;AAAA,IACrD;AAAA,IACA,SAAS,QAAQ,QAAQ,iBAAiB,CAAC,GAAG,QAAQ,aAAa,KAAK;AAAA,EAC5E,CAAC;AAED,SAAO,OACF,IAAI,iCAA+B,wCAAS,gBAAT,mBAAuB,8BAA6B,CAAC,CAAC,CAAC,EAC1F;AAAA,IACG;AAAA,QACI,8CAAS,gBAAT,mBAAsB,gBAAtB,mBAAmC,gBAAe,CAAC;AAAA,QACnD,8CAAS,gBAAT,mBAAsB,gBAAtB,mBAAmC,uBAAsB;AAAA,IAC7D;AAAA,EACJ;AACR;AAEA,IAAO,6BAAQ;;;ADoBf;AAAA,EACI;AAAA,EAAkB;AAAA,EAAY,kBAAAC;AAAA,EAAgB,cAAAC;AAAA,EAAY;AAAA,EAAQ;AAAA,EAAS,YAAAC;AAAA,OACxE;;;AShEP,OAAOC,sBAAqB;AAM5B,IAAM,QAA4E,CAAC,aAAY,mCAAS,OAChG,QAAQ,QAAQ,sBAChB,QAAQ,QAAQ,gBACjB,QAAQ,WAAW;AAK1B,IAAM,wBAAwB,CAAC,aAAkC,YAAkF,OAAyE,SAAkB,UAAsC,SAAsB;AACtS,QAAM,KAAK,MAAM,OAAO;AAExB,MAAI,OAAO,QAAW;AAClB,UAAMA,iBAAgB,KAAK,YAAY;AAAA,EAC3C;AAEA,MAAI;AACA,UAAM,UAAU,MAAM,YAAY,QAAQ,EAAE;AAE5C,UAAM,gBAAgD;AAAA,MAClD,eAAe,KAAK,MAAM,QAAQ,eAAe,GAAI,KAAK;AAAA,MAC1D,yBAAyB,QAAQ;AAAA,MACjC,qBAAqB,IAAI,KAAK,KAAK,IAAI,IAAI,QAAQ,YAAY,EAAE,YAAY;AAAA,MAC7E,GAAG;AAAA,IACP;AAEA,WAAO,KAAK,aAAa,EAAE,QAAQ,CAAC,QAAQ;AACxC,eAAS,UAAU,KAAK,cAAc,IAAmB;AAAA,IAC7D,CAAC;AAED,UAAM,KAAK;AAAA,EACf,QAAE;AACE,UAAMA,iBAAgB,KAAK,mBAAmB;AAAA,EAClD;AACJ;AAEA,IAAO,kCAAQ;;;AC1Cf,SAAS,sBAAsB;AAI/B,OAAO,UAAU;AAIjB,IAAM,iBAAiB,CAAmE,YAAgD,eAAkC,KAAK,OAAO,CAAC;AAEzL,IAAO,0BAAQ","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 UnorderedCollection,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport { ErrorSerializer, JapiError } from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof JapiError || JapiError.isLikeJapiError(error)) {\n const serializer = new ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport { header as headerCase } from \"case\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [headerCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/index-server.ts","../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/serializers/xml.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/connect/middleware/cors-middleware.ts"],"names":["default","BadRequest","Forbidden","BadGateway","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","VariantAlsoNegotiates","ProxyAuthenticationRequired","NetworkAuthenticationRequire","LengthRequired","LoopDetected","Locked","MethodNotAllowed","MisdirectedRequest","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","RequestHeaderFieldsTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","RangeNotSatisfiable","RequestTimeout","ServiceUnavailable","TooManyRequests","Unauthorized","UnprocessableEntity","UnavailableForLegalReasons","UnsupportedMediaType","UpgradeRequired","URITooLong","NodeRouter","createHttpError","HttpError","getReasonPhrase","ErrorSerializer","JapiError","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","statusCode","title","message","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","regex","handler","onNoMatch","routes","uniqueMethods","route","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","_a","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","accepts","headerCase","toXML","xmlTransformer","data","xml_default","hasJsonStructure","string_","result","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","_b","_c","_d","_e","create_node_router_default","createEdgeRouter","EdgeRouter","expressWrapper","Router","withZod","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","cors","corsMiddleware","cors_middleware_default"],"mappings":"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","sourcesContent":["export * from \"./index-browser\";\n\nexport {\n default as createHttpError,\n BadRequest,\n Forbidden,\n BadGateway,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n VariantAlsoNegotiates,\n ProxyAuthenticationRequired,\n NetworkAuthenticationRequire,\n LengthRequired,\n LoopDetected,\n Locked,\n MethodNotAllowed,\n MisdirectedRequest,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n RequestHeaderFieldsTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n RangeNotSatisfiable,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n Unauthorized,\n UnprocessableEntity,\n UnavailableForLegalReasons,\n UnsupportedMediaType,\n UpgradeRequired,\n URITooLong,\n} from \"http-errors\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n NodeRequestHandler,\n Route,\n HandlerOptions,\n NextHandler,\n FunctionLike,\n Nextable,\n ValueOrPromise,\n FindResult,\n RouteShortcutMethod,\n HttpMethod,\n} from \"@visulima/connect\";\nexport {\n createEdgeRouter, EdgeRouter, expressWrapper, NodeRouter, Router, withZod, sendJson,\n} from \"@visulima/connect\";\n\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\n\nexport { default as swaggerHandler } from \"./swagger/swagger-handler\";\n\nexport { dateIn, dateOut } from \"./zod\";\n","import { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject } from \"zod\";\nimport { ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport type { Serializers } from \"./middleware/serializers-middleware\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n serializers?: Serializers;\n defaultContentType?: string;\n };\n };\n errorHandlers?: ErrorHandlers;\n showTrace?: boolean;\n } = {},\n ) => {\n const router = new NodeRouter<Request, Response, Schema>({\n onNoMatch,\n onError: onError(options.errorHandlers || [], options.showTrace || false),\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options?.middlewares?.[\"http-header-normalizer\"] || {}))\n .use(\n serializersMiddleware(\n options?.middlewares?.serializers?.serializers || [],\n options?.middlewares?.serializers?.defaultContentType || \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type {\n FunctionLike, Nextable, Route, ValueOrPromise,\n} from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\n// eslint-disable-next-line unicorn/consistent-function-scoping,max-len\nexport const onError = <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { regex, handler } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as { expose: boolean } & Error).expose = showTrace;\n\n errorHandler(error, request, response);\n};\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport { ErrorSerializer, JapiError } from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: HttpError | JapiError | Error, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof JapiError || JapiError.isLikeJapiError(error)) {\n const serializer = new ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { statusCode, title, message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: any) => {\n const headers: { [key: string]: number | string | ReadonlyArray<string> } = error.headers || {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as number | string | ReadonlyArray<string>);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: any): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: any): void => {\n // respect err.statusCode\n if (error.statusCode !== undefined) {\n response.statusCode = error.statusCode;\n }\n\n // respect err.status\n if (error.status !== undefined) {\n response.statusCode = error.status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: HttpError | Error, _request, response) => {\n const { stack, message } = error;\n\n if (error instanceof HttpError) {\n const {\n statusCode, expose, title, type,\n } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n details: message,\n ...((error as { expose: boolean } & Error).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\")\n );\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string }) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n if (request.headers) {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey !== undefined) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-ignore\n request.rawHeaders = rawHeaders;\n }\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport accepts from \"accepts\";\nimport { header as headerCase } from \"case\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializer } from \"../serializers/types\";\nimport xmlTransformer from \"../serializers/xml\";\nimport yamlTransformer from \"../serializers/yaml\";\n\nfunction hasJsonStructure(string_: any): boolean {\n if (typeof string_ !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(string_);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n}\n\nconst contentTypeKey = \"Content-Type\";\n\n// eslint-disable-next-line max-len\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response | NextApiResponse,\n data: any,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line radar/cognitive-complexity\n) => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n\n // eslint-disable-next-line no-restricted-syntax\n types.every((type) => {\n let breakTypes = false;\n\n serializers.forEach(({ regex, serializer }) => {\n if (!regex.test(type)) {\n return;\n }\n\n response.setHeader(contentTypeKey, type);\n serializedData = serializer(serializedData);\n breakTypes = true;\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data) : data);\n } else if (/xml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [headerCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data) : data,\n });\n }\n }\n\n return breakTypes;\n });\n\n // eslint-disable-next-line no-param-reassign\n return serializedData;\n};\n\n// eslint-disable-next-line max-len\nconst serializersMiddleware = (serializers: Serializers = [], defaultContentType: string = \"application/json; charset=utf-8\") => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n if (typeof (response as NextApiResponse)?.send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n return (response as NextApiResponse).send(data);\n };\n } else {\n const oldEnd = response.end;\n\n // @ts-ignore\n response.end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-ignore\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n};\n\nexport type Serializers = {\n regex: RegExp;\n serializer: Serializer;\n}[];\nexport default serializersMiddleware;\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"./types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) => toXML(data, {\n header: true,\n indent: \" \",\n});\n\nexport default xmlTransformer;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\n// eslint-disable-next-line max-len\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) => request?.ip\n || (request.headers[\"x-forwarded-for\"] as string | undefined)\n || (request.headers[\"x-real-ip\"] as string | undefined)\n || request.connection.remoteAddress;\n\ntype HeaderValue = string | number | ReadonlyArray<string>;\n\n// eslint-disable-next-line max-len\nconst rateLimiterMiddleware = (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => { [key: string]: HeaderValue }) => async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response | NextApiResponse, next: NextHandler) => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: { [key: string]: HeaderValue } = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n};\n\nexport default rateLimiterMiddleware;\n","import { expressWrapper } from \"@visulima/connect\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line max-len\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n"]}
|