@visulima/api-platform 1.2.15 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +37 -0
- package/dist/{chunk-AB7BFRZY.mjs → chunk-FP5U4CV5.mjs} +3 -3
- package/dist/chunk-GI7VS3DY.mjs +7 -0
- package/dist/chunk-GI7VS3DY.mjs.map +1 -0
- package/dist/{chunk-JBHGHBWN.js → chunk-IRR5W2VO.js} +13 -13
- package/dist/chunk-IRR5W2VO.js.map +1 -0
- package/dist/{chunk-WYXGSYH5.js → chunk-JSH2MOOI.js} +5 -5
- package/dist/{chunk-CFLRDDCI.mjs → chunk-L4XBKO3Q.mjs} +7 -7
- package/dist/{chunk-CFLRDDCI.mjs.map → chunk-L4XBKO3Q.mjs.map} +1 -1
- package/dist/chunk-MYU5ZKUN.js +13 -0
- package/dist/chunk-MYU5ZKUN.js.map +1 -0
- package/dist/chunk-TTZOSRGR.mjs +17 -0
- package/dist/{chunk-7PP5RUGR.js.map → chunk-TTZOSRGR.mjs.map} +1 -1
- package/dist/chunk-U6GO6MGJ.js +24 -0
- package/dist/{chunk-FGLO2Y7X.mjs.map → chunk-U6GO6MGJ.js.map} +1 -1
- package/dist/framework/cli/commander/index.js +3 -3
- package/dist/framework/cli/commander/index.mjs +3 -3
- package/dist/framework/cli/index.js +2 -2
- package/dist/framework/cli/index.mjs +1 -1
- package/dist/framework/next/index-browser.d.mts +1 -1
- package/dist/framework/next/index-browser.d.ts +1 -1
- package/dist/framework/next/index-browser.js +2 -2
- package/dist/framework/next/index-browser.mjs +1 -1
- package/dist/framework/next/index-server.d.mts +1 -1
- package/dist/framework/next/index-server.d.ts +1 -1
- package/dist/framework/next/index-server.js +9 -9
- package/dist/framework/next/index-server.js.map +1 -1
- package/dist/framework/next/index-server.mjs +6 -6
- package/dist/framework/next/index-server.mjs.map +1 -1
- package/dist/framework/next/routes/pages/redoc/index.d.mts +1 -1
- package/dist/framework/next/routes/pages/redoc/index.d.ts +1 -1
- package/dist/framework/next/routes/pages/redoc/index.js +3 -3
- package/dist/framework/next/routes/pages/redoc/index.js.map +1 -1
- package/dist/framework/next/routes/pages/redoc/index.mjs +3 -3
- package/dist/framework/next/routes/pages/redoc/index.mjs.map +1 -1
- package/dist/framework/next/routes/pages/swagger/index.d.mts +1 -1
- package/dist/framework/next/routes/pages/swagger/index.d.ts +1 -1
- package/dist/framework/next/routes/pages/swagger/index.js +5 -5
- package/dist/framework/next/routes/pages/swagger/index.js.map +1 -1
- package/dist/framework/next/routes/pages/swagger/index.mjs +4 -4
- package/dist/framework/next/routes/pages/swagger/index.mjs.map +1 -1
- package/dist/index-browser.js +2 -2
- package/dist/index-browser.mjs +1 -1
- package/dist/index-server.d.mts +1 -1
- package/dist/index-server.d.ts +1 -1
- package/dist/index-server.js +71 -71
- package/dist/index-server.js.map +1 -1
- package/dist/index-server.mjs +11 -11
- package/dist/index-server.mjs.map +1 -1
- package/package.json +86 -55
- package/dist/chunk-3GKT5H3V.js +0 -13
- package/dist/chunk-3GKT5H3V.js.map +0 -1
- package/dist/chunk-7PP5RUGR.js +0 -24
- package/dist/chunk-FGLO2Y7X.mjs +0 -17
- package/dist/chunk-IGJDNXIE.mjs +0 -7
- package/dist/chunk-IGJDNXIE.mjs.map +0 -1
- package/dist/chunk-JBHGHBWN.js.map +0 -1
- /package/dist/{chunk-AB7BFRZY.mjs.map → chunk-FP5U4CV5.mjs.map} +0 -0
- /package/dist/{chunk-WYXGSYH5.js.map → chunk-JSH2MOOI.js.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/index-server.ts"],"names":["NodeRouter","createHttpError","HttpError","getReasonPhrase","tsJapi","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","message","statusCode","title","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","handler","regex","onNoMatch","routes","uniqueMethods","route","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","create_node_router_default","expressWrapper","cors","corsMiddleware","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","EdgeRouter","Router","createEdgeRouter","withZod","BadGateway","BadRequest","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","Forbidden","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","LengthRequired","Locked","LoopDetected","MethodNotAllowed","MisdirectedRequest","NetworkAuthenticationRequire","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","ProxyAuthenticationRequired","RangeNotSatisfiable","RequestHeaderFieldsTooLarge","RequestTimeout","ServiceUnavailable","TooManyRequests","URITooLong","Unauthorized","UnavailableForLegalReasons","UnprocessableEntity","UnsupportedMediaType","UpgradeRequired","VariantAlsoNegotiates","default"],"mappings":"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","sourcesContent":["import type { IncomingMessage, ServerResponse } from \"node:http\";\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\";\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\n for (const { handler, regex } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as Error & { expose: boolean }).expose = showTrace;\n\n errorHandler(error, request, response);\n };\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport tsJapi from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: Error | HttpError | tsJapi.JapiError, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof tsJapi.JapiError || tsJapi.JapiError.isLikeJapiError(error)) {\n const serializer = new tsJapi.ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { message, statusCode, title } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import type { ServerResponse } from \"node:http\";\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\";\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 { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\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\";\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","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n};\n\nexport default hasJsonStructure;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n xml.toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\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\";\nimport type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) =>\n request.ip ??\n (request.headers[\"x-forwarded-for\"] as string | undefined) ??\n (request.headers[\"x-real-ip\"] as string | undefined) ??\n request.socket.remoteAddress;\n\ntype HeaderValue = ReadonlyArray<string> | number | string;\n\nconst rateLimiterMiddleware =\n (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) =>\n async <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n ): Promise<void> => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: Record<string, HeaderValue> = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n };\n\nexport default rateLimiterMiddleware;\n","export * from \"./index-browser\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\n\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\n\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { serialize, xmlTransformer, yamlTransformer } from \"./serializers\";\n\nexport type { Serializer, Serializers } from \"./serializers\";\nexport { default as swaggerHandler } from \"./swagger/api/swagger-handler\";\nexport { dateIn, dateOut } from \"./zod\";\nexport { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from \"@visulima/connect\";\n\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n NextHandler,\n Nextable,\n NodeRequestHandler,\n Route,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"@visulima/connect\";\n\nexport {\n BadGateway,\n BadRequest,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n Forbidden,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n LengthRequired,\n Locked,\n LoopDetected,\n MethodNotAllowed,\n MisdirectedRequest,\n NetworkAuthenticationRequire,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n ProxyAuthenticationRequired,\n RangeNotSatisfiable,\n RequestHeaderFieldsTooLarge,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n URITooLong,\n Unauthorized,\n UnavailableForLegalReasons,\n UnprocessableEntity,\n UnsupportedMediaType,\n UpgradeRequired,\n VariantAlsoNegotiates,\n default as createHttpError,\n} from \"http-errors\";\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/connect/create-node-router.ts","../src/connect/handler.ts","../src/error-handler/jsonapi-error-handler.ts","../src/error-handler/utils.ts","../src/error-handler/problem-error-handler.ts","../src/connect/middleware/http-header-normalizer.ts","../src/connect/middleware/serializers-middleware.ts","../src/serializers/serialize.ts","../src/serializers/has-json-structure.ts","../src/serializers/transformer/xml.ts","../src/connect/middleware/cors-middleware.ts","../src/connect/middleware/rate-limiter-middleware.ts","../src/index-server.ts"],"names":["NodeRouter","createHttpError","HttpError","getReasonPhrase","tsJapi","StatusCodes","setErrorHeaders","response","error","headers","header","sendJson","jsonBody","addStatusCodeToResponse","defaultTitle","jsonapiErrorHandler","_request","serializer","message","statusCode","title","jsonapi_error_handler_default","defaultType","problemErrorHandler","stack","expose","type","problem_error_handler_default","onError","errorHandlers","showTrace","request","apiFormat","errorHandler","handler","regex","onNoMatch","routes","uniqueMethods","route","exceptions","normalizeHeaderKey","key","canonical","lowerCaseKey","text","defaults","httpHeaderNormalizerMiddleware","options_","options","_","next","rawHeaders","normalizedKey","http_header_normalizer_default","debug","accepts","hasJsonStructure","data","result","has_json_structure_default","xml","xmlTransformer","xml_default","contentTypeKey","serialize","serializers","types","serializedData","breakTypes","yaml_default","toHeaderCase","serialize_default","log","serializersMiddleware","defaultContentType","oldSend","oldEnd","arguments_","serializers_middleware_default","createNodeRouter","create_node_router_default","expressWrapper","cors","corsMiddleware","cors_middleware_default","getIP","rateLimiterMiddleware","rateLimiter","ip","limiter","mergedHeaders","rate_limiter_middleware_default","EdgeRouter","Router","createEdgeRouter","withZod","BadGateway","BadRequest","BandwidthLimitExceeded","Conflict","ExpectationFailed","FailedDependency","Forbidden","GatewayTimeout","Gone","HTTPVersionNotSupported","ImATeapot","InsufficientStorage","InternalServerError","LengthRequired","Locked","LoopDetected","MethodNotAllowed","MisdirectedRequest","NetworkAuthenticationRequire","NotAcceptable","NotExtended","NotFound","NotImplemented","PayloadTooLarge","PaymentRequired","PreconditionFailed","PreconditionRequired","ProxyAuthenticationRequired","RangeNotSatisfiable","RequestHeaderFieldsTooLarge","RequestTimeout","ServiceUnavailable","TooManyRequests","URITooLong","Unauthorized","UnavailableForLegalReasons","UnprocessableEntity","UnsupportedMediaType","UpgradeRequired","VariantAlsoNegotiates","default"],"mappings":"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","sourcesContent":["import type { IncomingMessage, ServerResponse } from \"node:http\";\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\";\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\n for (const { handler, regex } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as Error & { expose: boolean }).expose = showTrace;\n\n errorHandler(error, request, response);\n };\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport tsJapi from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: Error | HttpError | tsJapi.JapiError, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof tsJapi.JapiError || tsJapi.JapiError.isLikeJapiError(error)) {\n const serializer = new tsJapi.ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { message, statusCode, title } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import type { ServerResponse } from \"node:http\";\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\";\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 { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\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","import type { IncomingMessage, ServerResponse } from \"node:http\";\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 // eslint-disable-next-line @typescript-eslint/unbound-method\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\";\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","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n};\n\nexport default hasJsonStructure;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n xml.toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\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\";\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","export * from \"./index-browser\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\n\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\n\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { serialize, xmlTransformer, yamlTransformer } from \"./serializers\";\n\nexport type { Serializer, Serializers } from \"./serializers\";\nexport { default as swaggerHandler } from \"./swagger/api/swagger-handler\";\nexport { dateIn, dateOut } from \"./zod\";\nexport { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from \"@visulima/connect\";\n\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n NextHandler,\n Nextable,\n NodeRequestHandler,\n Route,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"@visulima/connect\";\n\nexport {\n BadGateway,\n BadRequest,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n Forbidden,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n LengthRequired,\n Locked,\n LoopDetected,\n MethodNotAllowed,\n MisdirectedRequest,\n NetworkAuthenticationRequire,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n ProxyAuthenticationRequired,\n RangeNotSatisfiable,\n RequestHeaderFieldsTooLarge,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n URITooLong,\n Unauthorized,\n UnavailableForLegalReasons,\n UnprocessableEntity,\n UnsupportedMediaType,\n UpgradeRequired,\n VariantAlsoNegotiates,\n default as createHttpError,\n} from \"http-errors\";\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@visulima/api-platform",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.1",
|
|
4
4
|
"description": "Visulima API platform is a set of tools to build and consume web APIs",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"anolilab",
|
|
@@ -56,31 +56,61 @@
|
|
|
56
56
|
".": {
|
|
57
57
|
"types": "./dist/index-server.d.ts",
|
|
58
58
|
"browser": "./dist/index-browser.js",
|
|
59
|
-
"require":
|
|
60
|
-
|
|
59
|
+
"require": {
|
|
60
|
+
"types": "./dist/index-server.d.ts",
|
|
61
|
+
"default": "./dist/index-server.js"
|
|
62
|
+
},
|
|
63
|
+
"import": {
|
|
64
|
+
"types": "./dist/index-server.d.mts",
|
|
65
|
+
"default": "./dist/index-server.mjs"
|
|
66
|
+
}
|
|
61
67
|
},
|
|
62
68
|
"./next": {
|
|
63
69
|
"types": "./dist/framework/next/index-server.d.ts",
|
|
64
70
|
"browser": "./dist/framework/next/index-browser.js",
|
|
65
|
-
"require":
|
|
66
|
-
|
|
71
|
+
"require": {
|
|
72
|
+
"types": "./dist/framework/next/index-server.d.ts",
|
|
73
|
+
"default": "./dist/framework/next/index-server.js"
|
|
74
|
+
},
|
|
75
|
+
"import": {
|
|
76
|
+
"types": "./dist/framework/next/index-server.d.mts",
|
|
77
|
+
"default": "./dist/framework/next/index-server.mjs"
|
|
78
|
+
}
|
|
67
79
|
},
|
|
68
80
|
"./next/pages/swagger": {
|
|
69
81
|
"types": "./dist/framework/next/routes/pages/swagger/index.d.ts",
|
|
70
82
|
"browser": "./dist/framework/next/routes/pages/swagger/index.js",
|
|
71
|
-
"require":
|
|
72
|
-
|
|
83
|
+
"require": {
|
|
84
|
+
"types": "./dist/framework/next/routes/pages/swagger/index.d.ts",
|
|
85
|
+
"default": "./dist/framework/next/routes/pages/swagger/index.js"
|
|
86
|
+
},
|
|
87
|
+
"import": {
|
|
88
|
+
"types": "./dist/framework/next/routes/pages/swagger/index.d.mts",
|
|
89
|
+
"default": "./dist/framework/next/routes/pages/swagger/index.mjs"
|
|
90
|
+
}
|
|
73
91
|
},
|
|
74
92
|
"./next/pages/redoc": {
|
|
75
93
|
"types": "./dist/framework/next/routes/pages/redoc/index.d.ts",
|
|
76
94
|
"browser": "./dist/framework/next/routes/pages/redoc/index.js",
|
|
77
|
-
"require":
|
|
78
|
-
|
|
95
|
+
"require": {
|
|
96
|
+
"types": "./dist/framework/next/routes/pages/redoc/index.d.ts",
|
|
97
|
+
"default": "./dist/framework/next/routes/pages/redoc/index.js"
|
|
98
|
+
},
|
|
99
|
+
"import": {
|
|
100
|
+
"types": "./dist/framework/next/routes/pages/redoc/index.d.mts",
|
|
101
|
+
"default": "./dist/framework/next/routes/pages/redoc/index.mjs"
|
|
102
|
+
}
|
|
79
103
|
},
|
|
80
104
|
"./cli": {
|
|
81
105
|
"types": "./dist/framework/cli/index-server.d.ts",
|
|
82
|
-
"require":
|
|
83
|
-
|
|
106
|
+
"require": {
|
|
107
|
+
"types": "./dist/framework/cli/index-server.d.ts",
|
|
108
|
+
"default": "./dist/framework/cli/index-server.js"
|
|
109
|
+
},
|
|
110
|
+
"import": {
|
|
111
|
+
"types": "./dist/framework/cli/index-server.d.mts",
|
|
112
|
+
"default": "./dist/framework/cli/index-server.mjs"
|
|
113
|
+
}
|
|
84
114
|
},
|
|
85
115
|
"./package.json": "./package.json"
|
|
86
116
|
},
|
|
@@ -106,7 +136,7 @@
|
|
|
106
136
|
"clean": "rimraf node_modules dist .eslintcache",
|
|
107
137
|
"coverage": "vitest run --coverage",
|
|
108
138
|
"dev": "pnpm run build --watch",
|
|
109
|
-
"lint:eslint": "eslint . --ext js,cjs,mjs,ts,tsx,json,yaml,yml,md,mdx --max-warnings=0 --config .eslintrc.js",
|
|
139
|
+
"lint:eslint": "eslint . --ext js,cjs,mjs,jsx,ts,tsx,json,yaml,yml,md,mdx --max-warnings=0 --config .eslintrc.js",
|
|
110
140
|
"lint:eslint:fix": "pnpm run lint:eslint --fix",
|
|
111
141
|
"lint:prettier": "prettier --config=.prettierrc.js --check .",
|
|
112
142
|
"lint:prettier:fix": "prettier --config=.prettierrc.js --write .",
|
|
@@ -115,90 +145,91 @@
|
|
|
115
145
|
"test:watch": "vitest"
|
|
116
146
|
},
|
|
117
147
|
"dependencies": {
|
|
118
|
-
"@visulima/connect": "
|
|
119
|
-
"@visulima/jsdoc-open-api": "
|
|
148
|
+
"@visulima/connect": "2.0.1",
|
|
149
|
+
"@visulima/jsdoc-open-api": "2.0.1",
|
|
120
150
|
"accepts": "^1.3.8",
|
|
121
151
|
"debug": "^4.3.4",
|
|
122
152
|
"http-errors": "^2.0.0",
|
|
123
153
|
"http-status-codes": "^2.2.0",
|
|
124
|
-
"jstoxml": "^3.2.
|
|
154
|
+
"jstoxml": "^3.2.8",
|
|
125
155
|
"lodash.merge": "^4.6.2",
|
|
126
156
|
"schema-dts": "^1.1.2",
|
|
127
|
-
"ts-japi": "^1.8.
|
|
157
|
+
"ts-japi": "^1.8.1",
|
|
128
158
|
"yaml": "^2.3.1",
|
|
129
|
-
"zod-to-ts": "^1.
|
|
159
|
+
"zod-to-ts": "^1.2.0"
|
|
130
160
|
},
|
|
131
161
|
"devDependencies": {
|
|
132
|
-
"@anolilab/eslint-config": "^11.
|
|
133
|
-
"@anolilab/prettier-config": "^5.0.
|
|
134
|
-
"@anolilab/semantic-release-preset": "^6.0.
|
|
162
|
+
"@anolilab/eslint-config": "^11.3.3",
|
|
163
|
+
"@anolilab/prettier-config": "^5.0.3",
|
|
164
|
+
"@anolilab/semantic-release-preset": "^6.0.4",
|
|
135
165
|
"@arthurgeron/eslint-plugin-react-usememo": "^1.1.4",
|
|
136
166
|
"@hapi/hapi": "^21.3.2",
|
|
137
167
|
"@koa/router": "^12.0.0",
|
|
138
|
-
"@secretlint/secretlint-rule-preset-recommend": "^7.0.
|
|
168
|
+
"@secretlint/secretlint-rule-preset-recommend": "^7.0.7",
|
|
139
169
|
"@testing-library/react": "^14.0.0",
|
|
140
170
|
"@testing-library/react-hooks": "^8.0.1",
|
|
141
|
-
"@total-typescript/ts-reset": "^0.
|
|
171
|
+
"@total-typescript/ts-reset": "^0.5.1",
|
|
142
172
|
"@types/accepts": "^1.3.5",
|
|
143
173
|
"@types/cors": "^2.8.13",
|
|
144
174
|
"@types/debug": "^4.1.8",
|
|
145
175
|
"@types/express": "^4.17.17",
|
|
146
|
-
"@types/express-serve-static-core": "^4.17.
|
|
176
|
+
"@types/express-serve-static-core": "^4.17.36",
|
|
147
177
|
"@types/http-errors": "^2.0.1",
|
|
148
178
|
"@types/jstoxml": "^2.0.2",
|
|
149
179
|
"@types/koa": "^2.13.8",
|
|
150
180
|
"@types/koa__router": "^12.0.0",
|
|
151
181
|
"@types/lodash.merge": "^4.6.7",
|
|
152
182
|
"@types/lodash.set": "^4.3.7",
|
|
153
|
-
"@types/node": "18.
|
|
183
|
+
"@types/node": "18.17.1",
|
|
154
184
|
"@types/qs": "^6.9.7",
|
|
155
|
-
"@types/react": "^18.2.
|
|
185
|
+
"@types/react": "^18.2.21",
|
|
156
186
|
"@types/react-dom": "^18.2.7",
|
|
157
187
|
"@types/swagger-ui-react": "^4.18.0",
|
|
158
|
-
"@types/webpack": "^5.28.
|
|
159
|
-
"@visulima/crud": "
|
|
160
|
-
"@visulima/readdir": "
|
|
161
|
-
"@vitest/coverage-v8": "^0.
|
|
162
|
-
"chalk": "5.
|
|
188
|
+
"@types/webpack": "^5.28.2",
|
|
189
|
+
"@visulima/crud": "2.0.1",
|
|
190
|
+
"@visulima/readdir": "2.0.1",
|
|
191
|
+
"@vitest/coverage-v8": "^0.34.3",
|
|
192
|
+
"chalk": "5.3.0",
|
|
163
193
|
"commander": "^11.0.0",
|
|
164
|
-
"core-js": "^3.32.
|
|
194
|
+
"core-js": "^3.32.1",
|
|
165
195
|
"cors": "^2.8.5",
|
|
166
196
|
"cross-env": "^7.0.3",
|
|
167
|
-
"eslint": "^8.
|
|
197
|
+
"eslint": "^8.48.0",
|
|
168
198
|
"eslint-plugin-etc": "^2.0.3",
|
|
169
199
|
"eslint-plugin-jsx-a11y": "^6.7.1",
|
|
170
|
-
"eslint-plugin-mdx": "^2.
|
|
171
|
-
"eslint-plugin-react": "7.33.
|
|
200
|
+
"eslint-plugin-mdx": "^2.2.0",
|
|
201
|
+
"eslint-plugin-react": "7.33.2",
|
|
172
202
|
"eslint-plugin-react-hooks": "4.6.0",
|
|
173
|
-
"eslint-plugin-testing-library": "^
|
|
203
|
+
"eslint-plugin-testing-library": "^6.0.1",
|
|
174
204
|
"eslint-plugin-vitest": "^0.2.8",
|
|
205
|
+
"eslint-plugin-vitest-globals": "^1.4.0",
|
|
175
206
|
"eslint-plugin-zod": "^1.4.0",
|
|
176
207
|
"express": "^4.18.2",
|
|
177
|
-
"fastify": "^4.
|
|
208
|
+
"fastify": "^4.22.0",
|
|
178
209
|
"koa": "^2.14.2",
|
|
179
210
|
"mobx": "^6.10.0",
|
|
180
|
-
"next": "^13.4.
|
|
211
|
+
"next": "^13.4.12",
|
|
181
212
|
"next-test-api-route-handler": "^4.0.0-canary.1",
|
|
182
|
-
"node-mocks-http": "^1.
|
|
213
|
+
"node-mocks-http": "^1.13.0",
|
|
183
214
|
"openapi-types": "^12.1.3",
|
|
184
|
-
"prettier": "^3.0.
|
|
215
|
+
"prettier": "^3.0.2",
|
|
185
216
|
"rate-limiter-flexible": "^2.4.2",
|
|
186
217
|
"react": "^18.2.0",
|
|
187
218
|
"react-dom": "^18.2.0",
|
|
188
|
-
"redoc": "^2.
|
|
219
|
+
"redoc": "^2.1.1",
|
|
189
220
|
"rimraf": "^5.0.1",
|
|
190
|
-
"secretlint": "7.0.
|
|
191
|
-
"semantic-release": "^21.
|
|
221
|
+
"secretlint": "7.0.7",
|
|
222
|
+
"semantic-release": "^21.1.1",
|
|
192
223
|
"sort-package-json": "^2.5.1",
|
|
193
|
-
"styled-components": "^6.0.
|
|
224
|
+
"styled-components": "^6.0.7",
|
|
194
225
|
"swagger-ui-dist": "^4.19.1",
|
|
195
226
|
"swagger-ui-react": "^4.19.1",
|
|
196
|
-
"tsup": "^7.
|
|
197
|
-
"type-fest": "^4.
|
|
198
|
-
"typescript": "^5.
|
|
199
|
-
"vitest": "^0.
|
|
227
|
+
"tsup": "^7.2.0",
|
|
228
|
+
"type-fest": "^4.3.1",
|
|
229
|
+
"typescript": "^5.2.2",
|
|
230
|
+
"vitest": "^0.34.3",
|
|
200
231
|
"webpack": "^5.88.2",
|
|
201
|
-
"zod": "^3.
|
|
232
|
+
"zod": "^3.22.2"
|
|
202
233
|
},
|
|
203
234
|
"peerDependencies": {
|
|
204
235
|
"react": "^18.2.0",
|
|
@@ -208,23 +239,23 @@
|
|
|
208
239
|
"optionalDependencies": {
|
|
209
240
|
"@hapi/hapi": "^21.3.2",
|
|
210
241
|
"@koa/router": "^12.0.0",
|
|
211
|
-
"@visulima/crud": "
|
|
212
|
-
"@visulima/readdir": "
|
|
213
|
-
"chalk": "5.
|
|
242
|
+
"@visulima/crud": "2.0.1",
|
|
243
|
+
"@visulima/readdir": "2.0.1",
|
|
244
|
+
"chalk": "5.3.0",
|
|
214
245
|
"commander": "^11.0.0",
|
|
215
246
|
"cors": "^2.8.5",
|
|
216
247
|
"express": "^4.18.2",
|
|
217
|
-
"fastify": "^4.
|
|
248
|
+
"fastify": "^4.22.0",
|
|
218
249
|
"koa": "^2.14.2",
|
|
219
|
-
"next": "^13.4.
|
|
250
|
+
"next": "^13.4.12",
|
|
220
251
|
"rate-limiter-flexible": "^2.4.2",
|
|
221
|
-
"redoc": "^2.
|
|
252
|
+
"redoc": "^2.1.1",
|
|
222
253
|
"swagger-ui-dist": "^4.19.1",
|
|
223
254
|
"swagger-ui-react": "^4.19.1",
|
|
224
255
|
"webpack": "^5.88.2"
|
|
225
256
|
},
|
|
226
257
|
"engines": {
|
|
227
|
-
"node": ">=
|
|
258
|
+
"node": ">=18.* <=20.*"
|
|
228
259
|
},
|
|
229
260
|
"publishConfig": {
|
|
230
261
|
"access": "public",
|
package/dist/chunk-3GKT5H3V.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var r = require('debug');
|
|
4
|
-
|
|
5
|
-
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
6
|
-
|
|
7
|
-
var r__default = /*#__PURE__*/_interopDefault(r);
|
|
8
|
-
|
|
9
|
-
var s=r__default.default("visulima:api-platform:swagger:get-static-properties-swagger"),a=t=>async()=>{let e=await(await fetch(t)).json();return s(e),{props:{swaggerData:JSON.parse(JSON.stringify(e)),swaggerUrl:t}}},o=a;
|
|
10
|
-
|
|
11
|
-
exports.a = o;
|
|
12
|
-
//# sourceMappingURL=out.js.map
|
|
13
|
-
//# sourceMappingURL=chunk-3GKT5H3V.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/framework/next/routes/pages/get-static-properties-swagger.ts"],"names":["debug","swaggerDebug","getStaticProps","swaggerUrl","swaggerData","get_static_properties_swagger_default"],"mappings":"AAAA,OAAOA,MAAW,QAIlB,IAAMC,EAAeD,EAAM,6DAA6D,EAElFE,EACDC,GACD,SAKM,CAGF,IAAMC,EAAc,MADH,MAAM,MAAMD,CAAU,GACJ,KAAK,EAExC,OAAAF,EAAaG,CAAW,EAEjB,CACH,MAAO,CACH,YAAa,KAAK,MAAM,KAAK,UAAUA,CAAW,CAAC,EACnD,WAAAD,CACJ,CACJ,CACJ,EAEGE,EAAQH","sourcesContent":["import debug from \"debug\";\nimport type { GetStaticProps } from \"next\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nconst swaggerDebug = debug(\"visulima:api-platform:swagger:get-static-properties-swagger\");\n\nconst getStaticProps: (swaggerUrl: string) => GetStaticProps =\n (swaggerUrl) =>\n async (): Promise<{\n props: {\n swaggerData: OpenAPIV3.Document;\n swaggerUrl: string;\n };\n }> => {\n // eslint-disable-next-line compat/compat\n const response = await fetch(swaggerUrl);\n const swaggerData = await response.json();\n\n swaggerDebug(swaggerData);\n\n return {\n props: {\n swaggerData: JSON.parse(JSON.stringify(swaggerData)) as OpenAPIV3.Document,\n swaggerUrl,\n },\n };\n };\n\nexport default getStaticProps;\n"]}
|
package/dist/chunk-7PP5RUGR.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var child_process = require('child_process');
|
|
4
|
-
var fs = require('fs');
|
|
5
|
-
var path = require('path');
|
|
6
|
-
var d = require('process');
|
|
7
|
-
var u = require('chalk');
|
|
8
|
-
var jsdocOpenApi = require('@visulima/jsdoc-open-api');
|
|
9
|
-
var readdir = require('@visulima/readdir');
|
|
10
|
-
|
|
11
|
-
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
|
-
|
|
13
|
-
var d__default = /*#__PURE__*/_interopDefault(d);
|
|
14
|
-
var u__default = /*#__PURE__*/_interopDefault(u);
|
|
15
|
-
|
|
16
|
-
var Y=(t,r)=>{if(r.length===0)throw new Error("must include at least one key to map");let e=t.toString();return r.forEach(o=>{e=o.optional?e.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):e.replace("(?:([^\\/]+?))",`:${o.name}`);}),e.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/g,"/")},P=Y;var z=(t,r)=>{if(typeof t=="string")return t;if(t.fast_slash)return "";if(t.fast_star)return "*";let e="";r.length>0&&(e=P(t,r));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//.exec(t.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/g,"$1").slice(1):e?e.slice(1):t.toString()},S=z;var Q=(t,r,e)=>{let o=t.route.stack.at(-1),a=r.map(i=>({in:"path",name:i.name,required:!i.optional})),s=t.route.stack.filter(i=>i.handle.metadata);if(s.length>1)throw new Error("Only one metadata middleware is allowed per route");let n=(e+t.route.path).replaceAll(/\/{2,}/g,"/");return s.length===0?{method:o.method,path:n,pathParams:a}:{metadata:s[0].handle.metadata,method:o.method,path:n,pathParams:a}},T=(t,r,e,o)=>{o=[...o,...e.keys],e.name==="router"&&e.handle&&e.handle.stack.forEach(a=>{r=r||"",T(t,`${r}/${S(e.regexp,e.keys)}`,a,o);}),!(!e.route||e.route.stack.length===0)&&t.push(Q(e,o,r));},V=t=>{let r=t._router||t.router,e=[];return r.stack.forEach(o=>{T(e,"",o,[]);}),e},k=V;var Z=t=>{let r=[];return k(t).forEach(e=>{r.push({file:"unknown",method:e.method.toUpperCase(),path:e.path,tags:[]});}),r},D=Z;var $=t=>t.replaceAll(/ \(.*\)/g,"").trim(),j=t=>t.trim().split(" ")[1].slice(1,-1),ee=t=>{let e=t.printRoutes().replaceAll(/[─│└├]/g," ").trimEnd().split(`
|
|
17
|
-
`),o=e.reduce((s,n,i)=>{let p=$(n);if($(e[i-1]??"")===p){let X=s.filter(A=>A.index<i&&A.segment===p),{methods:w}=X.at(-1);return w!==null&&w.push(j(n)),s}let l=n.replaceAll(/ \(.*\)/g,"").match(/ /g);if(l===null)throw new Error("Invalid spaces");let f=l.length/4,m=n.includes("("),y=m?[j(n)]:null;return s.push({depth:f,index:i,isRoute:m,methods:y,segment:p}),s},[]),a=[];return o.filter(s=>s.isRoute).forEach(s=>{let i=[...o.filter(p=>p.index<s.index&&p.depth<s.depth).filter((p,c,l)=>!l.find(f=>f.depth===p.depth&&f.index>p.index)).map(p=>p.segment),s.segment].join("");if(s.methods===null)throw new Error("Invalid methods");s.methods.forEach(p=>{a.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),a},O=ee;var te=t=>{let e=t._core.router.routes,o=[];return [...e.keys()].forEach(a=>{e.get(a).routes.forEach(s=>{o.push({file:"unknown",method:s.route.method.toUpperCase(),path:s.path,tags:[]});});}),o},v=te;var re=t=>{let r=[];return t.middleware.filter(e=>e.router).flatMap(e=>e.router.stack).forEach(e=>{r.push({file:"unknown",method:e.methods.join("|").toUpperCase(),path:e.path,tags:[]});}),r},F=re;var C=/\.(js|ts|mjs|cjs)$/,ae=(t,r,e=!1)=>{let o=[],a=jsdocOpenApi.parseFile(t,jsdocOpenApi.jsDocumentCommentsToOpenApi,e);o=[...o,...a.map(i=>i.spec)];let s=jsdocOpenApi.parseFile(t,jsdocOpenApi.swaggerJsDocumentCommentsToOpenApi,e);o=[...o,...s.map(i=>i.spec)];let n=[];return o.length===0?(fs.readFileSync(t,"utf8").split(/\r?\n/).forEach(p=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/.exec(p);if(c){let[,l]=c;l==="GET"&&(l="GET|HEAD"),n.push({file:t.replace(`${d__default.default.cwd()}${d__default.default.platform==="win32"?"\\":"/"}`,""),method:l,path:t.replace(r,"").replace(C,"").replaceAll("\\","/"),tags:[]});}}),n.length===0&&n.push({file:t.replace(`${d__default.default.cwd()}${d__default.default.platform==="win32"?"\\":"/"}`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:t.replace(r,"").replace(C,"").replaceAll("\\","/"),tags:[]}),n):(o.forEach(i=>{Object.entries(i?.paths??{}).forEach(([c,l])=>{Object.entries(l).forEach(([m,y])=>{n.push({file:t.replace(`${d__default.default.cwd()}${d__default.default.platform==="win32"?"\\":"/"}`,""),method:m.toUpperCase(),path:c.replaceAll("\\","/"),tags:y.tags});});});}),n)},L=ae;var g=[".js",".ts",".mjs",".cjs"],M=t=>{let r=path.parse(t);for(;r.base&&r.root!==r.dir;){if(fs.readdirSync(r.dir).find(a=>a==="package.json"))return r.dir;r=path.parse(r.dir);}return null},I=t=>{let r=`${t}/package.json`,{dependencies:e}=JSON.parse(fs.readFileSync(r).toString());return e?.express?"express":e?.koa&&(e["@koa/router"]||e["koa-router"])?"koa":e?.next?"next":e?.["@hapi/hapi"]?"hapi":e?.fastify?"fastify":null},H=(t,r)=>Object.keys(t).length===0?null:r==="hapi"?typeof t.app.app=="string"?t.app:t:t.app??t;var G=t=>{try{return fs.statSync(t).isDirectory()}catch{return !1}},ue=async(t="",r=!1)=>{let e=path.join(t,"pages/api");return !G(e)&&(e=path.join(t,"src/pages/api"),!G(e))?[]:await readdir.collect(e,{extensions:g,includeDirs:!1,minimatchOptions:{match:{debug:r,matchBase:!0},skip:{debug:r,matchBase:!0}}})},J=ue;var E=async(t,r,e)=>{if(r==="express")return D(t);if(r==="koa")return F(t);if(r==="hapi")return v(t);if(r==="fastify")return O(t);if(r==="next"){let o=await J(t,e);if(o.length===0)throw new Error(`No API routes found, in "${t}".`);return o.flatMap(a=>L(a,t,e))}return null};var fe=(t,r)=>{let e=new Map;return t.forEach(o=>{let a=r(o),s=e.get(a);s?s.push(o):e.set(a,[o]);}),e},_=fe;var me=(t,r)=>{let e={ANY:u__default.default.redBright,DELETE:u__default.default.redBright,GET:u__default.default.blue,HEAD:u__default.default.hex("#6C7280"),OPTIONS:u__default.default.hex("#6C7280"),PATCH:u__default.default.yellow,POST:u__default.default.yellow,PUT:u__default.default.yellow},o;if(t==="GET|HEAD")o=`${u__default.default.blue("GET")}${u__default.default.grey("|HEAD")}`;else {let c=e[t](t);o=t==="GET"?`${c}${u__default.default.grey("|HEAD")}`:c;}let a=t==="GET"?6:14-t.length,s=Array.from({length:a}).fill(" ").join(""),n=process.stdout.columns-16-r.length-4,i=n>0?Array.from({length:n}).fill(".").join(""):"",p=r.split("/").map(c=>[":","["].includes(c[0]??"")?u__default.default.yellowBright(c):c).join("/");return ` ${o}${s}${p}${u__default.default.grey(i)}`},de=(t,r={})=>t.map(e=>{if(!(Array.isArray(r.methods)&&r.methods.includes(e.method)))return e.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(e.method="ANY"),me(e.method,e.path.replace("/pages",""))}).filter(Boolean),x=de;var ye=async(t,r,e={})=>{let o=path.join(d__default.default.cwd(),r);if(!fs.existsSync(o))throw new Error("No such file, invalid path provided.");let a=M(o);if(!a)throw new Error("Please initialize local package.json.");if(t===void 0){let n=I(a);if(!n)throw new Error("Couldn't detect supported back-end framework.");t=n;}let s=null;if(t==="next")s=await E(o,"next",e.verbose??!1);else {if(!fs.statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!g.includes(path.extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let n=`${a}/.env`;fs.existsSync(n)&&(await import(`${a}/node_modules/dotenv/lib/main.js`)).config({path:n});let i=path.extname(o)===".ts",p=path.join(a,"node_modules/.bin/tsc");if(i&&!fs.existsSync(p))throw new Error(`Please install typescript in ${a}`);try{if(i)try{child_process.execSync(`${p} --outDir framework-list >&2`,{cwd:a});}catch(f){console.log(`TSC compilation failed. Please resolve issues in your project.
|
|
18
|
-
`),console.log(f),fs.rmSync(path.join(a,"framework-list"),{recursive:!0});}let c=i?path.join(a,"framework-list",o.replace(a,"").replace(".ts",".js")):o,{default:l}=await import(c);s=await E(["AsyncFunction","Function"].includes(l.constructor.name)?await l():H(l,t),t,e.verbose??!1);}finally{i&&fs.rmSync(path.join(a,"framework-list"),{recursive:!0});}}if(s===null)throw new Error(`Framework "${t}" is not supported.`);if(Array.isArray(e.includePaths)&&e.includePaths.length>0&&(s=e.includePaths.flatMap(n=>s.filter(i=>i.path.startsWith(n)))),Array.isArray(e.excludePaths)&&e.excludePaths.length>0&&(s=e.excludePaths.flatMap(n=>s.filter(i=>!i.path.startsWith(n)))),typeof e.group=="string"&&e.group!==""){console.log();let n=_(s,p=>e.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;n.forEach((p,c)=>{i>0&&console.log();let l=(d__default.default.stdout.columns-16-c.length)/2,f=l>0?Array.from({length:l}).fill(" ").join(""):"";console.log(f+u__default.default.bold.underline(c)),x(p,e).forEach(m=>{console.log(m);}),i+=1;});}else console.log(),x(s,e).forEach(n=>{console.log(n);});console.log(`
|
|
19
|
-
Listed ${u__default.default.greenBright(String(s.length))} HTTP ${s.length===1?"route":"routes"}.
|
|
20
|
-
`);},nt=ye;
|
|
21
|
-
|
|
22
|
-
exports.a = nt;
|
|
23
|
-
//# sourceMappingURL=out.js.map
|
|
24
|
-
//# sourceMappingURL=chunk-7PP5RUGR.js.map
|
package/dist/chunk-FGLO2Y7X.mjs
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { execSync } from 'child_process';
|
|
2
|
-
import { existsSync, statSync, rmSync, readdirSync, readFileSync } from 'fs';
|
|
3
|
-
import { join, extname, parse } from 'path';
|
|
4
|
-
import d from 'process';
|
|
5
|
-
import u from 'chalk';
|
|
6
|
-
import { parseFile, jsDocumentCommentsToOpenApi, swaggerJsDocumentCommentsToOpenApi } from '@visulima/jsdoc-open-api';
|
|
7
|
-
import { collect } from '@visulima/readdir';
|
|
8
|
-
|
|
9
|
-
var Y=(t,r)=>{if(r.length===0)throw new Error("must include at least one key to map");let e=t.toString();return r.forEach(o=>{e=o.optional?e.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):e.replace("(?:([^\\/]+?))",`:${o.name}`);}),e.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/g,"/")},P=Y;var z=(t,r)=>{if(typeof t=="string")return t;if(t.fast_slash)return "";if(t.fast_star)return "*";let e="";r.length>0&&(e=P(t,r));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//.exec(t.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/g,"$1").slice(1):e?e.slice(1):t.toString()},S=z;var Q=(t,r,e)=>{let o=t.route.stack.at(-1),a=r.map(i=>({in:"path",name:i.name,required:!i.optional})),s=t.route.stack.filter(i=>i.handle.metadata);if(s.length>1)throw new Error("Only one metadata middleware is allowed per route");let n=(e+t.route.path).replaceAll(/\/{2,}/g,"/");return s.length===0?{method:o.method,path:n,pathParams:a}:{metadata:s[0].handle.metadata,method:o.method,path:n,pathParams:a}},T=(t,r,e,o)=>{o=[...o,...e.keys],e.name==="router"&&e.handle&&e.handle.stack.forEach(a=>{r=r||"",T(t,`${r}/${S(e.regexp,e.keys)}`,a,o);}),!(!e.route||e.route.stack.length===0)&&t.push(Q(e,o,r));},V=t=>{let r=t._router||t.router,e=[];return r.stack.forEach(o=>{T(e,"",o,[]);}),e},k=V;var Z=t=>{let r=[];return k(t).forEach(e=>{r.push({file:"unknown",method:e.method.toUpperCase(),path:e.path,tags:[]});}),r},D=Z;var $=t=>t.replaceAll(/ \(.*\)/g,"").trim(),j=t=>t.trim().split(" ")[1].slice(1,-1),ee=t=>{let e=t.printRoutes().replaceAll(/[─│└├]/g," ").trimEnd().split(`
|
|
10
|
-
`),o=e.reduce((s,n,i)=>{let p=$(n);if($(e[i-1]??"")===p){let X=s.filter(A=>A.index<i&&A.segment===p),{methods:w}=X.at(-1);return w!==null&&w.push(j(n)),s}let l=n.replaceAll(/ \(.*\)/g,"").match(/ /g);if(l===null)throw new Error("Invalid spaces");let f=l.length/4,m=n.includes("("),y=m?[j(n)]:null;return s.push({depth:f,index:i,isRoute:m,methods:y,segment:p}),s},[]),a=[];return o.filter(s=>s.isRoute).forEach(s=>{let i=[...o.filter(p=>p.index<s.index&&p.depth<s.depth).filter((p,c,l)=>!l.find(f=>f.depth===p.depth&&f.index>p.index)).map(p=>p.segment),s.segment].join("");if(s.methods===null)throw new Error("Invalid methods");s.methods.forEach(p=>{a.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),a},O=ee;var te=t=>{let e=t._core.router.routes,o=[];return [...e.keys()].forEach(a=>{e.get(a).routes.forEach(s=>{o.push({file:"unknown",method:s.route.method.toUpperCase(),path:s.path,tags:[]});});}),o},v=te;var re=t=>{let r=[];return t.middleware.filter(e=>e.router).flatMap(e=>e.router.stack).forEach(e=>{r.push({file:"unknown",method:e.methods.join("|").toUpperCase(),path:e.path,tags:[]});}),r},F=re;var C=/\.(js|ts|mjs|cjs)$/,ae=(t,r,e=!1)=>{let o=[],a=parseFile(t,jsDocumentCommentsToOpenApi,e);o=[...o,...a.map(i=>i.spec)];let s=parseFile(t,swaggerJsDocumentCommentsToOpenApi,e);o=[...o,...s.map(i=>i.spec)];let n=[];return o.length===0?(readFileSync(t,"utf8").split(/\r?\n/).forEach(p=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/.exec(p);if(c){let[,l]=c;l==="GET"&&(l="GET|HEAD"),n.push({file:t.replace(`${d.cwd()}${d.platform==="win32"?"\\":"/"}`,""),method:l,path:t.replace(r,"").replace(C,"").replaceAll("\\","/"),tags:[]});}}),n.length===0&&n.push({file:t.replace(`${d.cwd()}${d.platform==="win32"?"\\":"/"}`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:t.replace(r,"").replace(C,"").replaceAll("\\","/"),tags:[]}),n):(o.forEach(i=>{Object.entries(i?.paths??{}).forEach(([c,l])=>{Object.entries(l).forEach(([m,y])=>{n.push({file:t.replace(`${d.cwd()}${d.platform==="win32"?"\\":"/"}`,""),method:m.toUpperCase(),path:c.replaceAll("\\","/"),tags:y.tags});});});}),n)},L=ae;var g=[".js",".ts",".mjs",".cjs"],M=t=>{let r=parse(t);for(;r.base&&r.root!==r.dir;){if(readdirSync(r.dir).find(a=>a==="package.json"))return r.dir;r=parse(r.dir);}return null},I=t=>{let r=`${t}/package.json`,{dependencies:e}=JSON.parse(readFileSync(r).toString());return e?.express?"express":e?.koa&&(e["@koa/router"]||e["koa-router"])?"koa":e?.next?"next":e?.["@hapi/hapi"]?"hapi":e?.fastify?"fastify":null},H=(t,r)=>Object.keys(t).length===0?null:r==="hapi"?typeof t.app.app=="string"?t.app:t:t.app??t;var G=t=>{try{return statSync(t).isDirectory()}catch{return !1}},ue=async(t="",r=!1)=>{let e=join(t,"pages/api");return !G(e)&&(e=join(t,"src/pages/api"),!G(e))?[]:await collect(e,{extensions:g,includeDirs:!1,minimatchOptions:{match:{debug:r,matchBase:!0},skip:{debug:r,matchBase:!0}}})},J=ue;var E=async(t,r,e)=>{if(r==="express")return D(t);if(r==="koa")return F(t);if(r==="hapi")return v(t);if(r==="fastify")return O(t);if(r==="next"){let o=await J(t,e);if(o.length===0)throw new Error(`No API routes found, in "${t}".`);return o.flatMap(a=>L(a,t,e))}return null};var fe=(t,r)=>{let e=new Map;return t.forEach(o=>{let a=r(o),s=e.get(a);s?s.push(o):e.set(a,[o]);}),e},_=fe;var me=(t,r)=>{let e={ANY:u.redBright,DELETE:u.redBright,GET:u.blue,HEAD:u.hex("#6C7280"),OPTIONS:u.hex("#6C7280"),PATCH:u.yellow,POST:u.yellow,PUT:u.yellow},o;if(t==="GET|HEAD")o=`${u.blue("GET")}${u.grey("|HEAD")}`;else {let c=e[t](t);o=t==="GET"?`${c}${u.grey("|HEAD")}`:c;}let a=t==="GET"?6:14-t.length,s=Array.from({length:a}).fill(" ").join(""),n=process.stdout.columns-16-r.length-4,i=n>0?Array.from({length:n}).fill(".").join(""):"",p=r.split("/").map(c=>[":","["].includes(c[0]??"")?u.yellowBright(c):c).join("/");return ` ${o}${s}${p}${u.grey(i)}`},de=(t,r={})=>t.map(e=>{if(!(Array.isArray(r.methods)&&r.methods.includes(e.method)))return e.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(e.method="ANY"),me(e.method,e.path.replace("/pages",""))}).filter(Boolean),x=de;var ye=async(t,r,e={})=>{let o=join(d.cwd(),r);if(!existsSync(o))throw new Error("No such file, invalid path provided.");let a=M(o);if(!a)throw new Error("Please initialize local package.json.");if(t===void 0){let n=I(a);if(!n)throw new Error("Couldn't detect supported back-end framework.");t=n;}let s=null;if(t==="next")s=await E(o,"next",e.verbose??!1);else {if(!statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!g.includes(extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let n=`${a}/.env`;existsSync(n)&&(await import(`${a}/node_modules/dotenv/lib/main.js`)).config({path:n});let i=extname(o)===".ts",p=join(a,"node_modules/.bin/tsc");if(i&&!existsSync(p))throw new Error(`Please install typescript in ${a}`);try{if(i)try{execSync(`${p} --outDir framework-list >&2`,{cwd:a});}catch(f){console.log(`TSC compilation failed. Please resolve issues in your project.
|
|
11
|
-
`),console.log(f),rmSync(join(a,"framework-list"),{recursive:!0});}let c=i?join(a,"framework-list",o.replace(a,"").replace(".ts",".js")):o,{default:l}=await import(c);s=await E(["AsyncFunction","Function"].includes(l.constructor.name)?await l():H(l,t),t,e.verbose??!1);}finally{i&&rmSync(join(a,"framework-list"),{recursive:!0});}}if(s===null)throw new Error(`Framework "${t}" is not supported.`);if(Array.isArray(e.includePaths)&&e.includePaths.length>0&&(s=e.includePaths.flatMap(n=>s.filter(i=>i.path.startsWith(n)))),Array.isArray(e.excludePaths)&&e.excludePaths.length>0&&(s=e.excludePaths.flatMap(n=>s.filter(i=>!i.path.startsWith(n)))),typeof e.group=="string"&&e.group!==""){console.log();let n=_(s,p=>e.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;n.forEach((p,c)=>{i>0&&console.log();let l=(d.stdout.columns-16-c.length)/2,f=l>0?Array.from({length:l}).fill(" ").join(""):"";console.log(f+u.bold.underline(c)),x(p,e).forEach(m=>{console.log(m);}),i+=1;});}else console.log(),x(s,e).forEach(n=>{console.log(n);});console.log(`
|
|
12
|
-
Listed ${u.greenBright(String(s.length))} HTTP ${s.length===1?"route":"routes"}.
|
|
13
|
-
`);},nt=ye;
|
|
14
|
-
|
|
15
|
-
export { nt as a };
|
|
16
|
-
//# sourceMappingURL=out.js.map
|
|
17
|
-
//# sourceMappingURL=chunk-FGLO2Y7X.mjs.map
|
package/dist/chunk-IGJDNXIE.mjs
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import r from 'debug';
|
|
2
|
-
|
|
3
|
-
var s=r("visulima:api-platform:swagger:get-static-properties-swagger"),a=t=>async()=>{let e=await(await fetch(t)).json();return s(e),{props:{swaggerData:JSON.parse(JSON.stringify(e)),swaggerUrl:t}}},o=a;
|
|
4
|
-
|
|
5
|
-
export { o as a };
|
|
6
|
-
//# sourceMappingURL=out.js.map
|
|
7
|
-
//# sourceMappingURL=chunk-IGJDNXIE.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/framework/next/routes/pages/get-static-properties-swagger.ts"],"names":["debug","swaggerDebug","getStaticProps","swaggerUrl","swaggerData","get_static_properties_swagger_default"],"mappings":"AAAA,OAAOA,MAAW,QAIlB,IAAMC,EAAeD,EAAM,6DAA6D,EAElFE,EACDC,GACD,SAKM,CAGF,IAAMC,EAAc,MADH,MAAM,MAAMD,CAAU,GACJ,KAAK,EAExC,OAAAF,EAAaG,CAAW,EAEjB,CACH,MAAO,CACH,YAAa,KAAK,MAAM,KAAK,UAAUA,CAAW,CAAC,EACnD,WAAAD,CACJ,CACJ,CACJ,EAEGE,EAAQH","sourcesContent":["import debug from \"debug\";\nimport type { GetStaticProps } from \"next\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nconst swaggerDebug = debug(\"visulima:api-platform:swagger:get-static-properties-swagger\");\n\nconst getStaticProps: (swaggerUrl: string) => GetStaticProps =\n (swaggerUrl) =>\n async (): Promise<{\n props: {\n swaggerData: OpenAPIV3.Document;\n swaggerUrl: string;\n };\n }> => {\n // eslint-disable-next-line compat/compat\n const response = await fetch(swaggerUrl);\n const swaggerData = await response.json();\n\n swaggerDebug(swaggerData);\n\n return {\n props: {\n swaggerData: JSON.parse(JSON.stringify(swaggerData)) as OpenAPIV3.Document,\n swaggerUrl,\n },\n };\n };\n\nexport default getStaticProps;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/swagger/api/swagger-handler.ts","../src/swagger/extend-swagger-spec.ts","../src/utils.ts"],"names":["stringify","yamlTransformer","data","yaml_default","existsSync","readFileSync","path","modelsToOpenApi","debug","merge","xml","urlParse","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","pathSpec","swaggerCrudDebug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","fileContents","crudSwagger","modelsOpenApi","error","swagger_handler_default"],"mappings":"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","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n // eslint-disable-next-line no-use-before-define\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}`;\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n xml.toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { parse as urlParse } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): unknown => {\n if (request.query) {\n return request.query;\n }\n\n return urlParse(request.url ?? \"\", true).query;\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/g, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/g, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/g, (c) => c.toUpperCase());\n"]}
|
|
File without changes
|