@visulima/api-platform 3.0.26 → 3.0.28

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 (52) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/LICENSE.md +6 -0
  3. package/README.md +2 -2
  4. package/dist/chunk-4C666HHU.js +1 -6
  5. package/dist/chunk-66EUOAFS.mjs +1 -8
  6. package/dist/chunk-66EUOAFS.mjs.map +1 -1
  7. package/dist/chunk-7PKKRTN7.mjs +6 -0
  8. package/dist/chunk-7PKKRTN7.mjs.map +1 -0
  9. package/dist/chunk-GI7VS3DY.mjs +1 -6
  10. package/dist/chunk-GI7VS3DY.mjs.map +1 -1
  11. package/dist/chunk-HZWWJL43.mjs +1 -4
  12. package/dist/chunk-MYU5ZKUN.js +1 -12
  13. package/dist/chunk-MYU5ZKUN.js.map +1 -1
  14. package/dist/chunk-NZTDUEZE.js +6 -0
  15. package/dist/chunk-NZTDUEZE.js.map +1 -0
  16. package/dist/chunk-T4ABIWHW.mjs +1 -12
  17. package/dist/chunk-T4ABIWHW.mjs.map +1 -1
  18. package/dist/chunk-UPRO35MO.js +1 -12
  19. package/dist/chunk-UPRO35MO.js.map +1 -1
  20. package/dist/chunk-YG667K32.js +1 -22
  21. package/dist/chunk-YG667K32.js.map +1 -1
  22. package/dist/framework/cli/commander/index.js +1 -10
  23. package/dist/framework/cli/commander/index.js.map +1 -1
  24. package/dist/framework/cli/commander/index.mjs +1 -8
  25. package/dist/framework/cli/commander/index.mjs.map +1 -1
  26. package/dist/framework/cli/index.js +1 -12
  27. package/dist/framework/cli/index.mjs +1 -3
  28. package/dist/framework/next/index-browser.js +1 -12
  29. package/dist/framework/next/index-browser.mjs +1 -3
  30. package/dist/framework/next/index-server.js +1 -22
  31. package/dist/framework/next/index-server.js.map +1 -1
  32. package/dist/framework/next/index-server.mjs +1 -11
  33. package/dist/framework/next/index-server.mjs.map +1 -1
  34. package/dist/framework/next/routes/pages/redoc/index.js +2 -16
  35. package/dist/framework/next/routes/pages/redoc/index.js.map +1 -1
  36. package/dist/framework/next/routes/pages/redoc/index.mjs +2 -10
  37. package/dist/framework/next/routes/pages/redoc/index.mjs.map +1 -1
  38. package/dist/framework/next/routes/pages/swagger/index.js +2 -17
  39. package/dist/framework/next/routes/pages/swagger/index.js.map +1 -1
  40. package/dist/framework/next/routes/pages/swagger/index.mjs +2 -10
  41. package/dist/framework/next/routes/pages/swagger/index.mjs.map +1 -1
  42. package/dist/index-browser.js +1 -12
  43. package/dist/index-browser.mjs +1 -3
  44. package/dist/index-server.js +2 -246
  45. package/dist/index-server.js.map +1 -1
  46. package/dist/index-server.mjs +2 -19
  47. package/dist/index-server.mjs.map +1 -1
  48. package/package.json +42 -42
  49. package/dist/chunk-GLAABR73.mjs +0 -18
  50. package/dist/chunk-GLAABR73.mjs.map +0 -1
  51. package/dist/chunk-INI6VCIA.js +0 -25
  52. package/dist/chunk-INI6VCIA.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/error-handler/utils.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/problem-error-handler.ts","../src/connect/handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/serializers/serialize.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/create-node-router.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts"],"names":["setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","StatusCodes","defaultTitle","jsonapiErrorHandler","_request","tsJapi","serializer","HttpError","message","statusCode","title","getReasonPhrase","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","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","hasJsonStructure","data","result","has_json_structure_default","xmlTransformer","toXML","xml_default","contentTypeKey","serialize","serializers","types","accepts","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","debug","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","NodeRouter","create_node_router_default","corsMiddleware","expressWrapper","cors","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default"],"mappings":"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","file":"index-server.js","sourcesContent":["import type { ServerResponse } from \"node:http\";\n\nimport type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\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\";\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 { 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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { FunctionLike, Nextable, Route, ValueOrPromise } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\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,no-loops/no-loops\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 type { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\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 (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text: string) => 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 - `rawHeaders` is not a property of `Request`\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\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 { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport accepts from \"accepts\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next/types\";\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 type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { NodeRouter } from \"@visulima/connect\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\nimport cors from \"cors\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next/types\";\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"]}
1
+ {"version":3,"sources":["../src/error-handler/utils.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/problem-error-handler.ts","../src/connect/handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/serializers/serialize.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/create-node-router.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts"],"names":["setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","StatusCodes","defaultTitle","jsonapiErrorHandler","_request","tsJapi","serializer","HttpError","message","statusCode","title","getReasonPhrase","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","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","hasJsonStructure","data","result","has_json_structure_default","xmlTransformer","toXML","xml_default","contentTypeKey","serialize","serializers","types","accepts","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","debug","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","NodeRouter","create_node_router_default","corsMiddleware","expressWrapper","cors","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default"],"mappings":"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","file":"index-server.js","sourcesContent":["import type { ServerResponse } from \"node:http\";\n\nimport type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\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\";\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 { 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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { FunctionLike, Nextable, Route, ValueOrPromise } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\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,no-loops/no-loops\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 type { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\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 (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text: string) => 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 - `rawHeaders` is not a property of `Request`\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\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 { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport accepts from \"accepts\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next/types\";\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 type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { NodeRouter } from \"@visulima/connect\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\nimport cors from \"cors\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next/types\";\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"]}
@@ -1,20 +1,3 @@
1
- export { a as dateIn, b as dateOut, c as zod } from './chunk-66EUOAFS.mjs';
2
- import { b, a } from './chunk-T4ABIWHW.mjs';
3
- export { c as swaggerHandler, b as yamlTransformer } from './chunk-T4ABIWHW.mjs';
4
- import './chunk-HZWWJL43.mjs';
5
- import { NodeRouter, expressWrapper } from '@visulima/connect';
6
- export { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from '@visulima/connect';
7
- import P, { 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
- import { getReasonPhrase, StatusCodes } from 'http-status-codes';
10
- import h from 'ts-japi';
11
- import te from 'debug';
12
- import Y from 'accepts';
13
- import { toXML } from 'jstoxml';
14
- import de from 'cors';
15
-
16
- var R=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},c=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},y=(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 T="An error occurred",W=(e,o,t)=>{if(y(t,e),R(t,e),e instanceof h.JapiError||h.JapiError.isLikeJapiError(e)){let r=new h.ErrorSerializer;c(t,r.serialize(e));}else if(e instanceof HttpError){let{message:r,statusCode:n,title:a}=e;c(t,{errors:[{code:n,title:a||getReasonPhrase(n)||T,detail:r}]});}else {let{message:r}=e;c(t,{errors:[{code:"500",title:getReasonPhrase(t.statusCode)||T,detail:r}]});}},A=W;var C="https://tools.ietf.org/html/rfc2616#section-10",I="An error occurred",X=(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,R(t,e),c(t,{type:d||C,title:i||getReasonPhrase(s)||I,details:r,...a?{trace:n}:{}});}else y(t,e),c(t,{type:C,title:getReasonPhrase(t.statusCode)||I,details:r,...e.expose?{trace:n}:{}});},O=X;var H=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=O;a==="application/vnd.api+json"&&(s=A);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},S=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,P(405,`No route with [${e.method}] method found.`)};var q={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"},Z=(e,o)=>{let t=e.toLowerCase();return o?q[t]?q[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},B={canonical:!1,normalizeHeaderKey:Z},G=e=>{let o={...B,...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()}},E=G;var _=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}},w=_;var Q=e=>toXML(e,{header:!0,indent:" "}),g=Q;var x="Content-Type",ee=(e,o,t,r,n)=>{if(typeof t.getHeader(x)=="string")return r;let i=[...Y(o).types(),n.defaultContentType],d=r,b$1=!1;return i.forEach(m=>{e.forEach(({regex:k,serializer:L})=>{k.test(m)&&(t.setHeader(x,m),d=L(d),b$1=!0);}),b$1||(/yaml|yml/.test(m)?(t.setHeader(x,m),d=b(w(r)?JSON.parse(r):r)):m.includes("xml")&&(t.setHeader(x,m),d=g({[a(`${o.url?.replace("/api/","")}`.trim())]:w(r)?JSON.parse(r):r})));}),d},f=ee;var re=te("api-platform:connect:serializers-middleware"),oe=(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=f(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")re("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=f(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},N=oe;var ne=(e={})=>new NodeRouter({onError:H(e.errorHandlers??[],e.showTrace??!1),onNoMatch:S}).use(E(e.middlewares?.["http-header-normalizer"]??{})).use(N(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),ae=ne;var pe=e=>expressWrapper(de(e)),le=pe;var ce=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,me=(e,o)=>async(t,r,n)=>{let a=ce(t);if(a===void 0)throw P(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 P(429,"Too Many Requests")}},fe=me;
17
-
18
- export { le as corsMiddleware, ae as createNodeRouter, E as httpHeaderNormalizerMiddleware, H as onError, S as onNoMatch, fe as rateLimiterMiddleware, f as serialize, N as serializersMiddleware, g as xmlTransformer };
19
- //# sourceMappingURL=index-server.mjs.map
1
+ export{a as dateIn,b as dateOut,c as zod}from'./chunk-66EUOAFS.mjs';import {b,a}from'./chunk-T4ABIWHW.mjs';export{c as swaggerHandler,b as yamlTransformer}from'./chunk-T4ABIWHW.mjs';import'./chunk-HZWWJL43.mjs';import {NodeRouter,expressWrapper}from'@visulima/connect';export{EdgeRouter,NodeRouter,Router,createEdgeRouter,expressWrapper,sendJson,withZod}from'@visulima/connect';import P,{HttpError}from'http-errors';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';import {getReasonPhrase,StatusCodes}from'http-status-codes';import h from'ts-japi';import te from'debug';import Y from'accepts';import {toXML}from'jstoxml';import de from'cors';var R=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},c=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},y=(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 T="An error occurred",W=(e,o,t)=>{if(y(t,e),R(t,e),e instanceof h.JapiError||h.JapiError.isLikeJapiError(e)){let r=new h.ErrorSerializer;c(t,r.serialize(e));}else if(e instanceof HttpError){let{message:r,statusCode:n,title:a}=e;c(t,{errors:[{code:n,title:a||getReasonPhrase(n)||T,detail:r}]});}else {let{message:r}=e;c(t,{errors:[{code:"500",title:getReasonPhrase(t.statusCode)||T,detail:r}]});}},A=W;var C="https://tools.ietf.org/html/rfc2616#section-10",I="An error occurred",X=(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,R(t,e),c(t,{type:d||C,title:i||getReasonPhrase(s)||I,details:r,...a?{trace:n}:{}});}else y(t,e),c(t,{type:C,title:getReasonPhrase(t.statusCode)||I,details:r,...e.expose?{trace:n}:{}});},O=X;var H=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=O;a==="application/vnd.api+json"&&(s=A);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},S=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,P(405,`No route with [${e.method}] method found.`)};var q={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"},Z=(e,o)=>{let t=e.toLowerCase();return o?q[t]?q[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},B={canonical:!1,normalizeHeaderKey:Z},G=e=>{let o={...B,...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()}},E=G;var _=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}},w=_;var Q=e=>toXML(e,{header:!0,indent:" "}),g=Q;var x="Content-Type",ee=(e,o,t,r,n)=>{if(typeof t.getHeader(x)=="string")return r;let i=[...Y(o).types(),n.defaultContentType],d=r,b$1=!1;return i.forEach(m=>{e.forEach(({regex:k,serializer:L})=>{k.test(m)&&(t.setHeader(x,m),d=L(d),b$1=!0);}),b$1||(/yaml|yml/.test(m)?(t.setHeader(x,m),d=b(w(r)?JSON.parse(r):r)):m.includes("xml")&&(t.setHeader(x,m),d=g({[a(`${o.url?.replace("/api/","")}`.trim())]:w(r)?JSON.parse(r):r})));}),d},f=ee;var re=te("api-platform:connect:serializers-middleware"),oe=(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=f(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")re("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=f(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},N=oe;var ne=(e={})=>new NodeRouter({onError:H(e.errorHandlers??[],e.showTrace??!1),onNoMatch:S}).use(E(e.middlewares?.["http-header-normalizer"]??{})).use(N(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),ae=ne;var pe=e=>expressWrapper(de(e)),le=pe;var ce=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,me=(e,o)=>async(t,r,n)=>{let a=ce(t);if(a===void 0)throw P(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 P(429,"Too Many Requests")}},fe=me;
2
+ export{le as corsMiddleware,ae as createNodeRouter,E as httpHeaderNormalizerMiddleware,H as onError,S as onNoMatch,fe as rateLimiterMiddleware,f as serialize,N as serializersMiddleware,g as xmlTransformer};//# sourceMappingURL=index-server.mjs.map
20
3
  //# sourceMappingURL=index-server.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/error-handler/utils.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/problem-error-handler.ts","../src/connect/handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/serializers/serialize.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/create-node-router.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts"],"names":["setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","StatusCodes","defaultTitle","jsonapiErrorHandler","_request","tsJapi","serializer","HttpError","message","statusCode","title","getReasonPhrase","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","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","hasJsonStructure","data","result","has_json_structure_default","xmlTransformer","toXML","xml_default","contentTypeKey","serialize","serializers","types","accepts","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","debug","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","NodeRouter","create_node_router_default","corsMiddleware","expressWrapper","cors","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default"],"mappings":"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","file":"index-server.mjs","sourcesContent":["import type { ServerResponse } from \"node:http\";\n\nimport type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\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\";\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 { 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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { FunctionLike, Nextable, Route, ValueOrPromise } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\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,no-loops/no-loops\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 type { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\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 (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text: string) => 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 - `rawHeaders` is not a property of `Request`\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\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 { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport accepts from \"accepts\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next/types\";\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 type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { NodeRouter } from \"@visulima/connect\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\nimport cors from \"cors\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next/types\";\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"]}
1
+ {"version":3,"sources":["../src/error-handler/utils.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/problem-error-handler.ts","../src/connect/handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/serializers/serialize.ts","../src/connect/middleware/serializers-middleware.ts","../src/connect/create-node-router.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts"],"names":["setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","StatusCodes","defaultTitle","jsonapiErrorHandler","_request","tsJapi","serializer","HttpError","message","statusCode","title","getReasonPhrase","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","createHttpError","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","hasJsonStructure","data","result","has_json_structure_default","xmlTransformer","toXML","xml_default","contentTypeKey","serialize","serializers","types","accepts","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","debug","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","NodeRouter","create_node_router_default","corsMiddleware","expressWrapper","cors","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default"],"mappings":"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","file":"index-server.mjs","sourcesContent":["import type { ServerResponse } from \"node:http\";\n\nimport type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\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\";\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 { 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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { FunctionLike, Nextable, Route, ValueOrPromise } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\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,no-loops/no-loops\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 type { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\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 (\n lowerCaseKey\n .split(\"-\")\n // eslint-disable-next-line no-unsafe-optional-chaining\n .map((text: string) => 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 - `rawHeaders` is not a property of `Request`\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\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 { toXML } from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport accepts from \"accepts\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next/types\";\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 type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { NodeRouter } from \"@visulima/connect\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\nimport cors from \"cors\";\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 { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next/types\";\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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/api-platform",
3
- "version": "3.0.26",
3
+ "version": "3.0.28",
4
4
  "description": "Visulima API platform is a set of tools to build and consume web APIs",
5
5
  "keywords": [
6
6
  "anolilab",
@@ -125,102 +125,102 @@
125
125
  "LICENSE.md"
126
126
  ],
127
127
  "dependencies": {
128
- "@visulima/connect": "3.0.15",
129
- "@visulima/jsdoc-open-api": "2.0.64",
130
- "@visulima/path": "1.1.1",
128
+ "@visulima/connect": "3.0.16",
129
+ "@visulima/jsdoc-open-api": "2.0.66",
130
+ "@visulima/path": "1.1.2",
131
131
  "accepts": "^1.3.8",
132
- "debug": "^4.3.7",
132
+ "debug": "^4.4.0",
133
133
  "http-errors": "^2.0.0",
134
134
  "http-status-codes": "^2.3.0",
135
135
  "jstoxml": "^5.0.2",
136
136
  "lodash.merge": "^4.6.2",
137
137
  "schema-dts": "^1.1.2",
138
138
  "ts-japi": "^1.11.4",
139
- "yaml": "^2.5.1",
139
+ "yaml": "^2.6.1",
140
140
  "zod-to-ts": "^1.2.0"
141
141
  },
142
142
  "devDependencies": {
143
143
  "@anolilab/eslint-config": "^15.0.3",
144
144
  "@anolilab/prettier-config": "^5.0.14",
145
- "@anolilab/semantic-release-pnpm": "^1.1.3",
146
- "@anolilab/semantic-release-preset": "^9.0.0",
147
- "@arthurgeron/eslint-plugin-react-usememo": "^2.4.1",
148
- "@babel/core": "^7.25.7",
149
- "@hapi/hapi": "^21.3.10",
145
+ "@anolilab/semantic-release-pnpm": "^1.1.6",
146
+ "@anolilab/semantic-release-preset": "^9.0.3",
147
+ "@arthurgeron/eslint-plugin-react-usememo": "^2.4.4",
148
+ "@babel/core": "^7.26.0",
149
+ "@hapi/hapi": "^21.3.12",
150
150
  "@koa/router": "^13.1.0",
151
- "@secretlint/secretlint-rule-preset-recommend": "^8.3.0",
152
- "@testing-library/react": "^16.0.1",
151
+ "@secretlint/secretlint-rule-preset-recommend": "^9.0.0",
152
+ "@testing-library/react": "^16.1.0",
153
153
  "@total-typescript/ts-reset": "^0.6.1",
154
154
  "@types/accepts": "^1.3.7",
155
155
  "@types/cors": "^2.8.17",
156
156
  "@types/debug": "^4.1.12",
157
- "@types/express": "^5.0.0",
158
- "@types/express-serve-static-core": "^5.0.0",
157
+ "@types/express": "4.17.21",
158
+ "@types/express-serve-static-core": "4.19.6",
159
159
  "@types/http-errors": "^2.0.4",
160
160
  "@types/jstoxml": "^2.0.4",
161
161
  "@types/koa": "^2.15.0",
162
162
  "@types/koa__router": "^12.0.4",
163
163
  "@types/lodash.merge": "^4.6.9",
164
164
  "@types/node": "18.19.15",
165
- "@types/qs": "^6.9.16",
166
- "@types/react": "^18.3.11",
167
- "@types/react-dom": "^18.3.0",
165
+ "@types/qs": "^6.9.17",
166
+ "@types/react": "^18.3.12",
167
+ "@types/react-dom": "^18.3.1",
168
168
  "@types/swagger-ui-react": "^4.18.3",
169
169
  "@types/webpack": "^5.28.5",
170
- "@visulima/crud": "2.0.32",
171
- "@visulima/fs": "2.3.0",
172
- "@vitest/coverage-v8": "^2.1.2",
173
- "@vitest/ui": "^2.1.2",
170
+ "@visulima/crud": "2.0.33",
171
+ "@visulima/fs": "2.3.2",
172
+ "@vitest/coverage-v8": "^2.1.8",
173
+ "@vitest/ui": "^2.1.8",
174
174
  "chalk": "5.3.0",
175
175
  "commander": "^12.1.0",
176
176
  "conventional-changelog-conventionalcommits": "8.0.0",
177
- "core-js": "^3.38.1",
177
+ "core-js": "^3.39.0",
178
178
  "cors": "^2.8.5",
179
179
  "cross-env": "^7.0.3",
180
180
  "eslint": "8.57.0",
181
181
  "eslint-plugin-deprecation": "^3.0.0",
182
182
  "eslint-plugin-etc": "^2.0.3",
183
183
  "eslint-plugin-import": "npm:eslint-plugin-i@^2.29.1",
184
- "eslint-plugin-jsx-a11y": "^6.10.0",
184
+ "eslint-plugin-jsx-a11y": "^6.10.2",
185
185
  "eslint-plugin-mdx": "^3.1.5",
186
186
  "eslint-plugin-react": "7.34.3",
187
187
  "eslint-plugin-react-hooks": "4.6.2",
188
188
  "eslint-plugin-ssr-friendly": "^1.3.0",
189
- "eslint-plugin-testing-library": "^6.3.0",
189
+ "eslint-plugin-testing-library": "^7.1.1",
190
190
  "eslint-plugin-validate-jsx-nesting": "^0.1.1",
191
191
  "eslint-plugin-vitest": "^0.4.1",
192
192
  "eslint-plugin-vitest-globals": "^1.5.0",
193
193
  "eslint-plugin-zod": "^1.4.0",
194
- "express": "^4.21.0",
195
- "fastify": "^5.0.0",
194
+ "express": "^4.21.2",
195
+ "fastify": "^5.2.0",
196
196
  "koa": "^2.15.3",
197
- "mobx": "^6.13.3",
197
+ "mobx": "^6.13.5",
198
198
  "next": "^14.2.4",
199
- "next-test-api-route-handler": "^4.0.11",
200
- "node-mocks-http": "^1.16.1",
199
+ "next-test-api-route-handler": "^4.0.14",
200
+ "node-mocks-http": "^1.16.2",
201
201
  "openapi-types": "^12.1.3",
202
- "prettier": "^3.3.3",
203
- "rate-limiter-flexible": "^5.0.3",
204
- "react": "^18.3.1",
205
- "react-dom": "^18.3.1",
206
- "redoc": "^2.1.5",
202
+ "prettier": "^3.4.2",
203
+ "rate-limiter-flexible": "^5.0.4",
204
+ "react": "^19.0.0",
205
+ "react-dom": "^19.0.0",
206
+ "redoc": "^2.2.0",
207
207
  "rimraf": "5.0.9",
208
208
  "secretlint": "8.2.4",
209
209
  "semantic-release": "24.0.0",
210
210
  "styled-components": "^6.1.13",
211
211
  "swagger-ui-dist": "^5.17.14",
212
212
  "swagger-ui-react": "^5.17.14",
213
- "tsup": "^8.3.0",
214
- "type-fest": "^4.26.1",
213
+ "tsup": "^8.3.5",
214
+ "type-fest": "^4.31.0",
215
215
  "typescript": "5.4.5",
216
- "vitest": "^2.1.2",
217
- "webpack": "^5.95.0",
218
- "zod": "^3.23.8"
216
+ "vitest": "^2.1.8",
217
+ "webpack": "^5.97.1",
218
+ "zod": "^3.24.1"
219
219
  },
220
220
  "peerDependencies": {
221
221
  "@hapi/hapi": "^21.3.9",
222
222
  "@koa/router": "^12.0.1",
223
- "@visulima/crud": "2.0.32",
223
+ "@visulima/crud": "2.0.33",
224
224
  "@visulima/readdir": "2.0.12",
225
225
  "chalk": "5.3.0",
226
226
  "commander": "^12.0.0",
@@ -298,7 +298,7 @@
298
298
  }
299
299
  },
300
300
  "engines": {
301
- "node": ">=18.* <=22.*"
301
+ "node": ">=18.* <=23.*"
302
302
  },
303
303
  "os": [
304
304
  "darwin",
@@ -1,18 +0,0 @@
1
- import { execSync } from 'node:child_process';
2
- import { existsSync, statSync, rmSync, readdirSync, readFileSync } from 'node:fs';
3
- import se, { cwd } from 'node:process';
4
- import { normalize, basename, resolve, join, extname, parse, toNamespacedPath } from '@visulima/path';
5
- import h from 'chalk';
6
- import { parseFile, jsDocumentCommentsToOpenApi, swaggerJsDocumentCommentsToOpenApi } from '@visulima/jsdoc-open-api';
7
- import { stat, readdir, realpath } from 'node:fs/promises';
8
- import { toPath } from '@visulima/path/utils';
9
-
10
- var ie=(e,t)=>{if(t.length===0)throw new Error("must include at least one key to map");let r=e.toString();return t.forEach(o=>{r=o.optional?r.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):r.replace("(?:([^\\/]+?))",`:${o.name}`);}),r.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/gu,"/")},T=ie;var pe=(e,t)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let r="";t.length>0&&(r=T(e,t));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//u.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/gu,"$1").slice(1):r?r.slice(1):e.toString()},j=pe;var le=(e,t,r)=>{let o=e.route.stack.at(-1),s=t.map(i=>({in:"path",name:i.name,required:!i.optional})),a=e.route.stack.filter(i=>i.handle.metadata);if(a.length>1)throw new Error("Only one metadata middleware is allowed per route");let l=(r+e.route.path).replaceAll(/\/{2,}/gu,"/");return a.length===0?{method:o.method,path:l,pathParams:s}:{metadata:a[0].handle.metadata,method:o.method,path:l,pathParams:s}},L=(e,t,r,o)=>{o=[...o,...r.keys],r.name==="router"&&r.handle&&r.handle.stack.forEach(s=>{t=t||"",L(e,`${t}/${j(r.regexp,r.keys)}`,s,o);}),!(!r.route||r.route.stack.length===0)&&e.push(le(r,o,t));},ce=e=>{let t=e._router||e.router,r=[];return t.stack.forEach(o=>{L(r,"",o,[]);}),r},$=ce;var me=e=>{let t=[];return $(e).forEach(r=>{t.push({file:"unknown",method:r.method.toUpperCase(),path:r.path,tags:[]});}),t},I=me;var C=e=>e.replaceAll(/ \(.*\)/gu,"").trim(),N=e=>e.trim().split(" ")[1].slice(1,-1),ue=e=>{let r=e.printRoutes().replaceAll(/[─│└├]/gu," ").trimEnd().split(`
11
- `),o=r.reduce((a,l,i)=>{let p=C(l);if(C(r[i-1]??"")===p){let R=a.filter(F=>F.index<i&&F.segment===p),{methods:O}=R.at(-1);return O!==null&&O.push(N(l)),a}let c=l.replaceAll(/ \(.*\)/gu,"").match(/ /gu);if(c===null)throw new Error("Invalid spaces");let n=c.length/4,d=l.includes("("),P=d?[N(l)]:null;return a.push({depth:n,index:i,isRoute:d,methods:P,segment:p}),a},[]),s=[];return o.filter(a=>a.isRoute).forEach(a=>{let i=[...o.filter(p=>p.index<a.index&&p.depth<a.depth).filter((p,m,c)=>!c.find(n=>n.depth===p.depth&&n.index>p.index)).map(p=>p.segment),a.segment].join("");if(a.methods===null)throw new Error("Invalid methods");a.methods.forEach(p=>{s.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),s},_=ue;var fe=e=>{let r=e._core.router.routes,o=[];return [...r.keys()].forEach(s=>{r.get(s).routes.forEach(a=>{o.push({file:"unknown",method:a.route.method.toUpperCase(),path:a.path,tags:[]});});}),o},K=fe;var de=e=>{let t=[];return e.middleware.filter(r=>r.router).flatMap(r=>r.router.stack).forEach(r=>{t.push({file:"unknown",method:r.methods.join("|").toUpperCase(),path:r.path,tags:[]});}),t},M=de;var H=/\.(js|ts|mjs|cjs)$/u,xe=(e,t,r=!1)=>{e=toNamespacedPath(e);let o=toNamespacedPath(cwd()),s=[],a=parseFile(e,jsDocumentCommentsToOpenApi,r);s=[...s,...a.map(p=>p.spec)];let l=parseFile(e,swaggerJsDocumentCommentsToOpenApi,r);s=[...s,...l.map(p=>p.spec)];let i=[];return s.length===0?(readFileSync(e,"utf8").split(/\r?\n/u).forEach(m=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/u.exec(m);if(c){let[,n]=c;n==="GET"&&(n="GET|HEAD"),i.push({file:e.replace(`${o}/`,""),method:n,path:toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]});}}),i.length===0&&i.push({file:e.replace(`${o}/`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]}),i):(s.forEach(p=>{Object.entries(p?.paths??{}).forEach(([c,n])=>{Object.entries(n).forEach(([P,R])=>{i.push({file:e.replace(`${o}/`,""),method:P.toUpperCase(),path:toNamespacedPath(c),tags:R.tags});});});}),i)},J=xe;var Se=Object.defineProperty,we=(e,t)=>Se(e,"name",{value:t,configurable:!0}),Pe=Object.defineProperty,Re=we((e,t)=>Pe(e,"name",{value:t,configurable:!0}),"n"),W=Re(e=>{if(!e||!(e instanceof URL)&&typeof e!="string")throw new TypeError("Path must be a non-empty string or URL.")},"assertValidFileOrDirectoryPath");var ke=Object.defineProperty,G=(e,t)=>ke(e,"name",{value:t,configurable:!0}),ve=Object.defineProperty,be=G((e,t)=>ve(e,"name",{value:t,configurable:!0}),"t"),g=class extends Error{static{G(this,"i");}static{be(this,"WalkError");}root;constructor(t,r){super(`${t instanceof Error?t.message:t} for path "${r}"`),this.cause=t,this.root=r;}get name(){return "WalkError"}set name(t){throw new Error("Cannot overwrite name of WalkError")}};var Ae=Object.defineProperty,B=(e,t)=>Ae(e,"name",{value:t,configurable:!0}),De=Object.defineProperty,Oe=B((e,t)=>De(e,"name",{value:t,configurable:!0}),"r"),k=Oe(e=>{let t=e.replace(/\.\*/g,".([^/]*)").replace(/\*\*/g,"(.*)").replace(/(?<!\.)\*(?!\*)/g,"([^/]*)").replace(/\?/g,"[^/]").replace(/\.(?!\*)/g,"\\.").replace(/\{/g,"(").replace(/\}/g,")").replace(/,/g,"|").replace(/\[!(.*?)\]/g,"[^$1]");return new RegExp(`^${t}$`)},"globToRegExp"),Fe=Object.defineProperty,Te=B((e,t)=>Fe(e,"name",{value:t,configurable:!0}),"n"),E=Te((e,t,r,o)=>Array.isArray(t)&&t.length>0&&!t.some(s=>e.endsWith(s))||r&&!r.some(s=>s.test(e))?!1:!o?.some(s=>s.test(e)),"walkInclude");var je=Object.defineProperty,Y=(e,t)=>je(e,"name",{value:t,configurable:!0}),Ue=Object.defineProperty,X=Y((e,t)=>Ue(e,"name",{value:t,configurable:!0}),"f"),He=X(async e=>{let t=normalize(e),r=basename(t),o=await stat(t);return {isDirectory:o.isDirectory,isFile:o.isFile,isSymbolicLink:o.isSymbolicLink,name:r,path:t}},"_createWalkEntry");async function*x(e,{extensions:t,followSymlinks:r=!1,includeDirs:o=!0,includeFiles:s=!0,includeSymlinks:a=!0,match:l,maxDepth:i=Number.POSITIVE_INFINITY,skip:p}={}){if(W(e),i<0)return;let m=l?l.map(n=>typeof n=="string"?k(n):n):void 0,c=p?p.map(n=>typeof n=="string"?k(n):n):void 0;if(e=resolve(toPath(e)),o&&E(e,t,m,c)&&(yield await He(e)),!(i<1||!E(e,void 0,void 0,c)))try{for await(let n of await readdir(e,{withFileTypes:!0})){let d=join(e,n.name);if(n.isSymbolicLink())if(r)d=await realpath(d);else if(a&&E(d,t,m,c))yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d};else continue;n.isSymbolicLink()||n.isDirectory()?yield*x(d,{extensions:t,followSymlinks:r,includeDirs:o,includeFiles:s,includeSymlinks:a,match:m,maxDepth:i-1,skip:c}):n.isFile()&&s&&E(d,t,m,c)&&(yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d});}}catch(n){throw n instanceof g?n:new g(n,e)}}Y(x,"d");X(x,"walk");var Je=Object.defineProperty,We=(e,t)=>Je(e,"name",{value:t,configurable:!0}),Ge=Object.defineProperty,Be=We((e,t)=>Ge(e,"name",{value:t,configurable:!0}),"e"),v=Be(async(e,t={})=>{Array.isArray(t.extensions)||(t.extensions=["js","mjs","cjs","ts"]);let r=[];for await(let o of x(e,t))r.push(o.path);return r},"collect");var w=[".js",".ts",".mjs",".cjs"],z=e=>{let t=parse(e);for(;t.base&&t.root!==t.dir;){if(readdirSync(t.dir).find(s=>s==="package.json"))return t.dir;t=parse(t.dir);}return null},V=e=>{let t=`${e}/package.json`,{dependencies:r}=JSON.parse(readFileSync(t).toString());return r?.express?"express":r?.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r?.next?"next":r?.["@hapi/hapi"]?"hapi":r?.fastify?"fastify":null},Q=(e,t)=>Object.keys(e).length===0?null:t==="hapi"?typeof e.app.app=="string"?e.app:e:e.app??e;var ee=e=>{try{return statSync(e).isDirectory()}catch{return !1}},ze=async(e="")=>{let t=join(e,"pages/api");return !ee(t)&&(t=join(e,"src/pages/api"),!ee(t))?[]:v(t,{extensions:w,includeDirs:!1})},te=ze;var b=async(e,t,r)=>{if(t==="express")return I(e);if(t==="koa")return M(e);if(t==="hapi")return K(e);if(t==="fastify")return _(e);if(t==="next"){let o=await te(e);if(o.length===0)throw new Error(`No API routes found, in "${e}".`);return o.flatMap(s=>J(s,e,r))}return null};var Ve=(e,t)=>{let r=new Map;return e.forEach(o=>{let s=t(o),a=r.get(s);a?a.push(o):r.set(s,[o]);}),r},re=Ve;var Qe=(e,t)=>{let r={ANY:h.redBright,DELETE:h.redBright,GET:h.blue,HEAD:h.hex("#6C7280"),OPTIONS:h.hex("#6C7280"),PATCH:h.yellow,POST:h.yellow,PUT:h.yellow},o;if(e==="GET|HEAD")o=`${h.blue("GET")}${h.grey("|HEAD")}`;else {let m=r[e](e);o=e==="GET"?`${m}${h.grey("|HEAD")}`:m;}let s=e==="GET"?6:14-e.length,a=Array.from({length:s}).fill(" ").join(""),l=process.stdout.columns-16-t.length-4,i=l>0?Array.from({length:l}).fill(".").join(""):"",p=t.split("/").map(m=>[":","["].includes(m[0]??"")?h.yellowBright(m):m).join("/");return ` ${o}${a}${p}${h.grey(i)}`},Ze=(e,t={})=>e.map(r=>{if(!(Array.isArray(t.methods)&&t.methods.includes(r.method)))return r.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(r.method="ANY"),Qe(r.method,r.path.replace("/pages",""))}).filter(Boolean),A=Ze;var rt=async(e,t,r={})=>{let o=join(se.cwd(),t);if(!existsSync(o))throw new Error("No such file, invalid path provided.");let s=z(o);if(!s)throw new Error("Please initialize local package.json.");if(e===void 0){let l=V(s);if(!l)throw new Error("Couldn't detect supported back-end framework.");e=l;}let a=null;if(e==="next")a=await b(o,"next",r.verbose??!1);else {if(!statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!w.includes(extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let l=`${s}/.env`;existsSync(l)&&(await import(`${s}/node_modules/dotenv/lib/main.js`)).config({path:l});let i=extname(o)===".ts",p=join(s,"node_modules/.bin/tsc");if(i&&!existsSync(p))throw new Error(`Please install typescript in ${s}`);try{if(i)try{execSync(`${p} --outDir framework-list >&2`,{cwd:s});}catch(n){console.log(`TSC compilation failed. Please resolve issues in your project.
12
- `),console.log(n),rmSync(join(s,"framework-list"),{recursive:!0});}let m=i?join(s,"framework-list",o.replace(s,"").replace(".ts",".js")):o,{default:c}=await import(m);a=await b(["AsyncFunction","Function"].includes(c.constructor.name)?await c():Q(c,e),e,r.verbose??!1);}finally{i&&rmSync(join(s,"framework-list"),{recursive:!0});}}if(a===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(r.includePaths)&&r.includePaths.length>0&&(a=r.includePaths.flatMap(l=>a.filter(i=>i.path.startsWith(l)))),Array.isArray(r.excludePaths)&&r.excludePaths.length>0&&(a=r.excludePaths.flatMap(l=>a.filter(i=>!i.path.startsWith(l)))),typeof r.group=="string"&&r.group!==""){console.log();let l=re(a,p=>r.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;l.forEach((p,m)=>{i>0&&console.log();let c=(se.stdout.columns-16-m.length)/2,n=c>0?Array.from({length:c}).fill(" ").join(""):"";console.log(n+h.bold.underline(m)),A(p,r).forEach(d=>{console.log(d);}),i+=1;});}else console.log(),A(a,r).forEach(l=>{console.log(l);});console.log(`
13
- Listed ${h.greenBright(String(a.length))} HTTP ${a.length===1?"route":"routes"}.
14
- `);},kr=rt;
15
-
16
- export { kr as a };
17
- //# sourceMappingURL=chunk-GLAABR73.mjs.map
18
- //# sourceMappingURL=chunk-GLAABR73.mjs.map