@visulima/api-platform 1.2.13 → 1.2.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/bin/index.js +2 -2
  3. package/dist/{chunk-QTZRF77U.js → chunk-7PP5RUGR.js} +3 -3
  4. package/dist/chunk-7PP5RUGR.js.map +1 -0
  5. package/dist/{chunk-CQXODW6L.mjs → chunk-CFLRDDCI.mjs} +5 -5
  6. package/dist/chunk-CFLRDDCI.mjs.map +1 -0
  7. package/dist/{chunk-J3RIDYN3.mjs → chunk-FGLO2Y7X.mjs} +2 -2
  8. package/dist/chunk-FGLO2Y7X.mjs.map +1 -0
  9. package/dist/{chunk-PEE2NOLZ.js → chunk-JBHGHBWN.js} +7 -7
  10. package/dist/chunk-JBHGHBWN.js.map +1 -0
  11. package/dist/framework/cli/commander/index.js +2 -2
  12. package/dist/framework/cli/commander/index.js.map +1 -1
  13. package/dist/framework/cli/commander/index.mjs +1 -1
  14. package/dist/framework/cli/commander/index.mjs.map +1 -1
  15. package/dist/framework/cli/index.js +2 -2
  16. package/dist/framework/cli/index.mjs +1 -1
  17. package/dist/framework/next/index-server.d.mts +2 -2
  18. package/dist/framework/next/index-server.d.ts +2 -2
  19. package/dist/framework/next/index-server.js +5 -5
  20. package/dist/framework/next/index-server.js.map +1 -1
  21. package/dist/framework/next/index-server.mjs +4 -4
  22. package/dist/framework/next/index-server.mjs.map +1 -1
  23. package/dist/index-server.d.mts +2 -2
  24. package/dist/index-server.d.ts +2 -2
  25. package/dist/index-server.js +4 -4
  26. package/dist/index-server.js.map +1 -1
  27. package/dist/index-server.mjs +2 -2
  28. package/dist/index-server.mjs.map +1 -1
  29. package/package.json +17 -17
  30. package/dist/chunk-CQXODW6L.mjs.map +0 -1
  31. package/dist/chunk-J3RIDYN3.mjs.map +0 -1
  32. package/dist/chunk-PEE2NOLZ.js.map +0 -1
  33. package/dist/chunk-QTZRF77U.js.map +0 -1
  34. package/dist/{swagger-handler-47360cd1.d.ts → swagger-handler-1f05481b.d.ts} +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["exit","listCommand","program","commandName","description","options","list_command_default","error"],"mappings":"6EACA,OAAS,QAAAA,MAAY,UAIrB,IAAMC,EAAc,CAChBC,EACAC,EAAc,OACdC,EAAc,iGACP,CACPF,EACK,QAAQC,CAAW,EACnB,YAAYC,CAAW,EACvB,OAAO,0BAA2B,oEAAoE,EACtG,OAAO,oBAAqB,KAAK,EACjC,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,wBAAyB,oFAAqF,CAAC,CAAC,EACvH,OAAO,wBAAyB,+EAAgF,CAAC,CAAC,EAClH,OAAO,gBAAiB,kBAAmB,EAAK,EAChD,OAAO,MAAOC,GAAY,CACvB,GAAI,CACA,MAAMC,EAAQD,EAAQ,UAA8DA,EAAQ,KAAgB,CACxG,aAAcA,EAAQ,aACtB,MAAOA,EAAQ,MACf,aAAcA,EAAQ,YACtB,QAASA,EAAQ,OACrB,CAAC,CACL,OAASE,EAAY,CACjB,QAAQ,IAAI,EACZ,QAAQ,MAAMA,CAAK,EACnBP,EAAK,CAAC,CACV,CACJ,CAAC,CACT,EAEOM,EAAQL","sourcesContent":["import type { Command } from \"commander\";\nimport { exit } from \"node:process\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(async (options) => {\n try {\n await command(options.framework as \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\", options.path as string, {\n excludePaths: options.excludePaths as string[] | undefined,\n group: options.group as string | undefined,\n includePaths: options.includePath as string[] | undefined,\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n console.log();\n console.error(error);\n exit(1);\n }\n });\n};\n\nexport default listCommand;\n"]}
1
+ {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["exit","listCommand","program","commandName","description","options","list_command_default","error"],"mappings":"6EAAA,OAAS,QAAAA,MAAY,UAKrB,IAAMC,EAAc,CAChBC,EACAC,EAAc,OACdC,EAAc,iGACP,CACPF,EACK,QAAQC,CAAW,EACnB,YAAYC,CAAW,EACvB,OAAO,0BAA2B,oEAAoE,EACtG,OAAO,oBAAqB,KAAK,EACjC,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,wBAAyB,oFAAqF,CAAC,CAAC,EACvH,OAAO,wBAAyB,+EAAgF,CAAC,CAAC,EAClH,OAAO,gBAAiB,kBAAmB,EAAK,EAChD,OAAO,MAAOC,GAAY,CACvB,GAAI,CACA,MAAMC,EAAQD,EAAQ,UAA8DA,EAAQ,KAAgB,CACxG,aAAcA,EAAQ,aACtB,MAAOA,EAAQ,MACf,aAAcA,EAAQ,YACtB,QAASA,EAAQ,OACrB,CAAC,CACL,OAASE,EAAY,CAEjB,QAAQ,IAAI,EAEZ,QAAQ,MAAMA,CAAK,EACnBP,EAAK,CAAC,CACV,CACJ,CAAC,CACT,EAEOM,EAAQL","sourcesContent":["import { exit } from \"node:process\";\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(async (options) => {\n try {\n await command(options.framework as \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\", options.path as string, {\n excludePaths: options.excludePaths as string[] | undefined,\n group: options.group as string | undefined,\n includePaths: options.includePath as string[] | undefined,\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n });\n};\n\nexport default listCommand;\n"]}
@@ -1,4 +1,4 @@
1
- import { a } from '../../../chunk-J3RIDYN3.mjs';
1
+ import { a } from '../../../chunk-FGLO2Y7X.mjs';
2
2
  import '../../../chunk-XIJ2ZQRX.mjs';
3
3
  import { exit } from 'process';
4
4
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["exit","listCommand","program","commandName","description","options","list_command_default","error"],"mappings":"+EACA,OAAS,QAAAA,MAAY,UAIrB,IAAMC,EAAc,CAChBC,EACAC,EAAc,OACdC,EAAc,iGACP,CACPF,EACK,QAAQC,CAAW,EACnB,YAAYC,CAAW,EACvB,OAAO,0BAA2B,oEAAoE,EACtG,OAAO,oBAAqB,KAAK,EACjC,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,wBAAyB,oFAAqF,CAAC,CAAC,EACvH,OAAO,wBAAyB,+EAAgF,CAAC,CAAC,EAClH,OAAO,gBAAiB,kBAAmB,EAAK,EAChD,OAAO,MAAOC,GAAY,CACvB,GAAI,CACA,MAAMC,EAAQD,EAAQ,UAA8DA,EAAQ,KAAgB,CACxG,aAAcA,EAAQ,aACtB,MAAOA,EAAQ,MACf,aAAcA,EAAQ,YACtB,QAASA,EAAQ,OACrB,CAAC,CACL,OAASE,EAAY,CACjB,QAAQ,IAAI,EACZ,QAAQ,MAAMA,CAAK,EACnBP,EAAK,CAAC,CACV,CACJ,CAAC,CACT,EAEOM,EAAQL","sourcesContent":["import type { Command } from \"commander\";\nimport { exit } from \"node:process\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(async (options) => {\n try {\n await command(options.framework as \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\", options.path as string, {\n excludePaths: options.excludePaths as string[] | undefined,\n group: options.group as string | undefined,\n includePaths: options.includePath as string[] | undefined,\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n console.log();\n console.error(error);\n exit(1);\n }\n });\n};\n\nexport default listCommand;\n"]}
1
+ {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["exit","listCommand","program","commandName","description","options","list_command_default","error"],"mappings":"+EAAA,OAAS,QAAAA,MAAY,UAKrB,IAAMC,EAAc,CAChBC,EACAC,EAAc,OACdC,EAAc,iGACP,CACPF,EACK,QAAQC,CAAW,EACnB,YAAYC,CAAW,EACvB,OAAO,0BAA2B,oEAAoE,EACtG,OAAO,oBAAqB,KAAK,EACjC,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,wBAAyB,oFAAqF,CAAC,CAAC,EACvH,OAAO,wBAAyB,+EAAgF,CAAC,CAAC,EAClH,OAAO,gBAAiB,kBAAmB,EAAK,EAChD,OAAO,MAAOC,GAAY,CACvB,GAAI,CACA,MAAMC,EAAQD,EAAQ,UAA8DA,EAAQ,KAAgB,CACxG,aAAcA,EAAQ,aACtB,MAAOA,EAAQ,MACf,aAAcA,EAAQ,YACtB,QAASA,EAAQ,OACrB,CAAC,CACL,OAASE,EAAY,CAEjB,QAAQ,IAAI,EAEZ,QAAQ,MAAMA,CAAK,EACnBP,EAAK,CAAC,CACV,CACJ,CAAC,CACT,EAEOM,EAAQL","sourcesContent":["import { exit } from \"node:process\";\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(async (options) => {\n try {\n await command(options.framework as \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\", options.path as string, {\n excludePaths: options.excludePaths as string[] | undefined,\n group: options.group as string | undefined,\n includePaths: options.includePath as string[] | undefined,\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n });\n};\n\nexport default listCommand;\n"]}
@@ -1,13 +1,13 @@
1
1
  'use strict';
2
2
 
3
- var chunkQTZRF77U_js = require('../../chunk-QTZRF77U.js');
3
+ var chunk7PP5RUGR_js = require('../../chunk-7PP5RUGR.js');
4
4
  require('../../chunk-4D6JZ4TL.js');
5
5
 
6
6
 
7
7
 
8
8
  Object.defineProperty(exports, 'listCommand', {
9
9
  enumerable: true,
10
- get: function () { return chunkQTZRF77U_js.a; }
10
+ get: function () { return chunk7PP5RUGR_js.a; }
11
11
  });
12
12
  //# sourceMappingURL=out.js.map
13
13
  //# sourceMappingURL=index.js.map
@@ -1,4 +1,4 @@
1
- export { a as listCommand } from '../../chunk-J3RIDYN3.mjs';
1
+ export { a as listCommand } from '../../chunk-FGLO2Y7X.mjs';
2
2
  import '../../chunk-XIJ2ZQRX.mjs';
3
3
  //# sourceMappingURL=out.js.map
4
4
  //# sourceMappingURL=index.mjs.map
@@ -1,9 +1,9 @@
1
1
  export { getSwaggerStaticProps } from './index-browser.mjs';
2
- import { S as SwaggerHandlerOptions } from '../../swagger-handler-47360cd1.js';
2
+ import { S as SwaggerHandlerOptions } from '../../swagger-handler-1f05481b.js';
3
3
  import { BaseDefinition } from '@visulima/jsdoc-open-api';
4
4
  import { NextConfig } from 'next';
5
- import '@visulima/crud';
6
5
  import 'node:http';
6
+ import '@visulima/crud';
7
7
  import 'openapi-types';
8
8
 
9
9
  declare const swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void;
@@ -1,9 +1,9 @@
1
1
  export { getSwaggerStaticProps } from './index-browser.js';
2
- import { S as SwaggerHandlerOptions } from '../../swagger-handler-47360cd1.js';
2
+ import { S as SwaggerHandlerOptions } from '../../swagger-handler-1f05481b.js';
3
3
  import { BaseDefinition } from '@visulima/jsdoc-open-api';
4
4
  import { NextConfig } from 'next';
5
- import '@visulima/crud';
6
5
  import 'node:http';
6
+ import '@visulima/crud';
7
7
  import 'openapi-types';
8
8
 
9
9
  declare const swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void;
@@ -1,18 +1,18 @@
1
1
  'use strict';
2
2
 
3
- var chunkPEE2NOLZ_js = require('../../chunk-PEE2NOLZ.js');
3
+ var chunkJBHGHBWN_js = require('../../chunk-JBHGHBWN.js');
4
4
  var chunk3GKT5H3V_js = require('../../chunk-3GKT5H3V.js');
5
5
  require('../../chunk-4D6JZ4TL.js');
6
+ var l = require('fs');
7
+ var d = require('path');
6
8
  var jsdocOpenApi = require('@visulima/jsdoc-open-api');
7
- var d = require('fs');
8
- var w = require('path');
9
9
 
10
10
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
11
11
 
12
+ var l__default = /*#__PURE__*/_interopDefault(l);
12
13
  var d__default = /*#__PURE__*/_interopDefault(d);
13
- var w__default = /*#__PURE__*/_interopDefault(w);
14
14
 
15
- var f=(t={})=>chunkPEE2NOLZ_js.c(t),m=f;var u=({definition:t,output:r="swagger/swagger.json",sources:s,verbose:p})=>o=>({...o,webpack:(e,i)=>{if(!i.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new jsdocOpenApi.SwaggerCompilerPlugin(`${i.dir}/${r}`,s.map(g=>{let a=w__default.default.join(i.dir,g.replace("./",""));return d__default.default.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...t},{verbose:p})]},typeof o.webpack=="function"?o.webpack(e,i):e}}),c=u;
15
+ var f=(t={})=>chunkJBHGHBWN_js.c(t),m=f;var u=({definition:t,output:r="swagger/swagger.json",sources:s,verbose:p})=>o=>({...o,webpack:(e,i)=>{if(!i.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new jsdocOpenApi.SwaggerCompilerPlugin(`${i.dir}/${r}`,s.map(g=>{let a=d__default.default.join(i.dir,g.replace("./",""));return l__default.default.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...t},{verbose:p})]},typeof o.webpack=="function"?o.webpack(e,i):e}}),c=u;
16
16
 
17
17
  Object.defineProperty(exports, 'getSwaggerStaticProps', {
18
18
  enumerable: true,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/framework/next/routes/api/swagger.ts","../../../src/framework/next/webpack/with-open-api.ts"],"names":["swaggerApiRoute","options","swagger_handler_default","swagger_default","SwaggerCompilerPlugin","fs","path","withOpenApi","definition","output","sources","verbose","nextConfig","config","source","combinedPath","with_open_api_default"],"mappings":"wHAOA,IAAMA,EAAsH,CAACC,EAAU,CAAC,IACpIC,EAAeD,CAAO,EAGnBE,EAAQH,ECVf,OAAS,yBAAAI,MAA6B,2BAGtC,OAAOC,MAAQ,KACf,OAAOC,MAAU,OAGjB,IAAMC,EACF,CAAC,CACG,WAAAC,EACA,OAAAC,EAAS,uBACT,QAAAC,EACA,QAAAC,CACJ,IAMCC,IACI,CACG,GAAGA,EACH,QAAS,CAACC,EAAuBZ,IAAiB,CAC9C,GAAI,CAACA,EAAQ,SACT,OAAOY,EAQX,GALIJ,EAAO,WAAW,GAAG,IAErBA,EAASA,EAAO,MAAM,CAAC,GAGvB,CAACA,EAAO,SAAS,OAAO,EACxB,MAAM,IAAI,MAAM,qCAAqC,EA6BzD,OAzBAI,EAAS,CACL,GAAGA,EACH,QAAS,CAEL,GAAGA,EAAO,QACV,IAAIT,EACA,GAAGH,EAAQ,GAAG,IAAIQ,CAAM,GACxBC,EAAQ,IAAKI,GAAW,CACpB,IAAMC,EAAeT,EAAK,KAAKL,EAAQ,IAAea,EAAO,QAAQ,KAAM,EAAE,CAAC,EAG9E,OAAAT,EAAG,UAAUU,CAAY,EAAE,YAAY,EAEhCA,CACX,CAAC,EACD,CAEI,QAAS,QACT,GAAGP,CACP,EACA,CAAE,QAAAG,CAAQ,CACd,CACJ,CACJ,EAEI,OAAOC,EAAW,SAAY,WACvBA,EAAW,QAAQC,EAAQZ,CAAO,EAGtCY,CACX,CACJ,GAEDG,EAAQT","sourcesContent":["import type { SwaggerHandlerOptions } from \"../../../../swagger/api/swagger-handler\";\nimport swaggerHandler from \"../../../../swagger/api/swagger-handler\";\n\n/**\n * @deprecated Use `import { swaggerHandler } from \"@visulima/api-platform\"` instead.\n */\n\nconst swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void = (options = {}) =>\n swaggerHandler(options);\n\n// eslint-disable-next-line etc/no-deprecated\nexport default swaggerApiRoute;\n","import type { BaseDefinition } from \"@visulima/jsdoc-open-api\";\nimport { SwaggerCompilerPlugin } from \"@visulima/jsdoc-open-api\";\nimport type { NextConfig } from \"next\";\nimport type { NextJsWebpackConfig } from \"next/dist/server/config-shared\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport type { Configuration } from \"webpack\";\n\nconst withOpenApi =\n ({\n definition,\n output = \"swagger/swagger.json\",\n sources,\n verbose,\n }: {\n definition: Exclude<BaseDefinition, \"openapi\"> & { openapi?: string };\n output: string;\n sources: string[];\n verbose?: boolean;\n }) =>\n (nextConfig: NextConfig): NextConfig =>\n ({\n ...nextConfig,\n webpack: (config: Configuration, options: any) => {\n if (!options.isServer) {\n return config;\n }\n\n if (output.startsWith(\"/\")) {\n // eslint-disable-next-line no-param-reassign\n output = output.slice(1);\n }\n\n if (!output.endsWith(\".json\")) {\n throw new Error(\"The output path must end with .json\");\n }\n\n // eslint-disable-next-line no-param-reassign\n config = {\n ...config,\n plugins: [\n // @ts-expect-error: ignore\n ...config.plugins,\n new SwaggerCompilerPlugin(\n `${options.dir}/${output}`,\n sources.map((source) => {\n const combinedPath = path.join(options.dir as string, source.replace(\"./\", \"\"));\n\n // Check if the path is a directory\n fs.lstatSync(combinedPath).isDirectory();\n\n return combinedPath;\n }),\n {\n // @ts-expect-error: This property should be overwritten\n openapi: \"3.0.0\",\n ...definition,\n },\n { verbose },\n ),\n ],\n };\n\n if (typeof nextConfig.webpack === \"function\") {\n return nextConfig.webpack(config, options) as NextJsWebpackConfig;\n }\n\n return config as NextJsWebpackConfig;\n },\n }) as NextConfig;\n\nexport default withOpenApi;\n"]}
1
+ {"version":3,"sources":["../../../src/framework/next/routes/api/swagger.ts","../../../src/framework/next/webpack/with-open-api.ts"],"names":["swaggerApiRoute","options","swagger_handler_default","swagger_default","fs","path","SwaggerCompilerPlugin","withOpenApi","definition","output","sources","verbose","nextConfig","config","source","combinedPath","with_open_api_default"],"mappings":"wHAOA,IAAMA,EAAsH,CAACC,EAAU,CAAC,IACpIC,EAAeD,CAAO,EAGnBE,EAAQH,ECXf,OAAOI,MAAQ,KACf,OAAOC,MAAU,OAEjB,OAAS,yBAAAC,MAA6B,2BAKtC,IAAMC,EACF,CAAC,CACG,WAAAC,EACA,OAAAC,EAAS,uBACT,QAAAC,EACA,QAAAC,CACJ,IAMCC,IACI,CACG,GAAGA,EACH,QAAS,CAACC,EAAuBZ,IAAiB,CAC9C,GAAI,CAACA,EAAQ,SACT,OAAOY,EAQX,GALIJ,EAAO,WAAW,GAAG,IAErBA,EAASA,EAAO,MAAM,CAAC,GAGvB,CAACA,EAAO,SAAS,OAAO,EACxB,MAAM,IAAI,MAAM,qCAAqC,EA6BzD,OAzBAI,EAAS,CACL,GAAGA,EACH,QAAS,CAEL,GAAGA,EAAO,QACV,IAAIP,EACA,GAAGL,EAAQ,GAAG,IAAIQ,CAAM,GACxBC,EAAQ,IAAKI,GAAW,CACpB,IAAMC,EAAeV,EAAK,KAAKJ,EAAQ,IAAea,EAAO,QAAQ,KAAM,EAAE,CAAC,EAG9E,OAAAV,EAAG,UAAUW,CAAY,EAAE,YAAY,EAEhCA,CACX,CAAC,EACD,CAEI,QAAS,QACT,GAAGP,CACP,EACA,CAAE,QAAAG,CAAQ,CACd,CACJ,CACJ,EAEI,OAAOC,EAAW,SAAY,WACvBA,EAAW,QAAQC,EAAQZ,CAAO,EAGtCY,CACX,CACJ,GAEDG,EAAQT","sourcesContent":["import type { SwaggerHandlerOptions } from \"../../../../swagger/api/swagger-handler\";\nimport swaggerHandler from \"../../../../swagger/api/swagger-handler\";\n\n/**\n * @deprecated Use `import { swaggerHandler } from \"@visulima/api-platform\"` instead.\n */\n\nconst swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void = (options = {}) =>\n swaggerHandler(options);\n\n// eslint-disable-next-line etc/no-deprecated\nexport default swaggerApiRoute;\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport type { BaseDefinition } from \"@visulima/jsdoc-open-api\";\nimport { SwaggerCompilerPlugin } from \"@visulima/jsdoc-open-api\";\nimport type { NextConfig } from \"next\";\nimport type { NextJsWebpackConfig } from \"next/dist/server/config-shared\";\nimport type { Configuration } from \"webpack\";\n\nconst withOpenApi =\n ({\n definition,\n output = \"swagger/swagger.json\",\n sources,\n verbose,\n }: {\n definition: Exclude<BaseDefinition, \"openapi\"> & { openapi?: string };\n output: string;\n sources: string[];\n verbose?: boolean;\n }) =>\n (nextConfig: NextConfig): NextConfig =>\n ({\n ...nextConfig,\n webpack: (config: Configuration, options: any) => {\n if (!options.isServer) {\n return config;\n }\n\n if (output.startsWith(\"/\")) {\n // eslint-disable-next-line no-param-reassign\n output = output.slice(1);\n }\n\n if (!output.endsWith(\".json\")) {\n throw new Error(\"The output path must end with .json\");\n }\n\n // eslint-disable-next-line no-param-reassign\n config = {\n ...config,\n plugins: [\n // @ts-expect-error: ignore\n ...config.plugins,\n new SwaggerCompilerPlugin(\n `${options.dir}/${output}`,\n sources.map((source) => {\n const combinedPath = path.join(options.dir as string, source.replace(\"./\", \"\"));\n\n // Check if the path is a directory\n fs.lstatSync(combinedPath).isDirectory();\n\n return combinedPath;\n }),\n {\n // @ts-expect-error: This property should be overwritten\n openapi: \"3.0.0\",\n ...definition,\n },\n { verbose },\n ),\n ],\n };\n\n if (typeof nextConfig.webpack === \"function\") {\n return nextConfig.webpack(config, options) as NextJsWebpackConfig;\n }\n\n return config as NextJsWebpackConfig;\n },\n }) as NextConfig;\n\nexport default withOpenApi;\n"]}
@@ -1,11 +1,11 @@
1
- import { c as c$1 } from '../../chunk-CQXODW6L.mjs';
1
+ import { c as c$1 } from '../../chunk-CFLRDDCI.mjs';
2
2
  export { a as getSwaggerStaticProps } from '../../chunk-IGJDNXIE.mjs';
3
3
  import '../../chunk-XIJ2ZQRX.mjs';
4
+ import l from 'fs';
5
+ import d from 'path';
4
6
  import { SwaggerCompilerPlugin } from '@visulima/jsdoc-open-api';
5
- import d from 'fs';
6
- import w from 'path';
7
7
 
8
- var f=(t={})=>c$1(t),m=f;var u=({definition:t,output:r="swagger/swagger.json",sources:s,verbose:p})=>o=>({...o,webpack:(e,i)=>{if(!i.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new SwaggerCompilerPlugin(`${i.dir}/${r}`,s.map(g=>{let a=w.join(i.dir,g.replace("./",""));return d.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...t},{verbose:p})]},typeof o.webpack=="function"?o.webpack(e,i):e}}),c=u;
8
+ var f=(t={})=>c$1(t),m=f;var u=({definition:t,output:r="swagger/swagger.json",sources:s,verbose:p})=>o=>({...o,webpack:(e,i)=>{if(!i.isServer)return e;if(r.startsWith("/")&&(r=r.slice(1)),!r.endsWith(".json"))throw new Error("The output path must end with .json");return e={...e,plugins:[...e.plugins,new SwaggerCompilerPlugin(`${i.dir}/${r}`,s.map(g=>{let a=d.join(i.dir,g.replace("./",""));return l.lstatSync(a).isDirectory(),a}),{openapi:"3.0.0",...t},{verbose:p})]},typeof o.webpack=="function"?o.webpack(e,i):e}}),c=u;
9
9
 
10
10
  export { m as swaggerApiRoute, c as withOpenApi };
11
11
  //# sourceMappingURL=out.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/framework/next/routes/api/swagger.ts","../../../src/framework/next/webpack/with-open-api.ts"],"names":["swaggerApiRoute","options","swagger_handler_default","swagger_default","SwaggerCompilerPlugin","fs","path","withOpenApi","definition","output","sources","verbose","nextConfig","config","source","combinedPath","with_open_api_default"],"mappings":"2HAOA,IAAMA,EAAsH,CAACC,EAAU,CAAC,IACpIC,EAAeD,CAAO,EAGnBE,EAAQH,ECVf,OAAS,yBAAAI,MAA6B,2BAGtC,OAAOC,MAAQ,KACf,OAAOC,MAAU,OAGjB,IAAMC,EACF,CAAC,CACG,WAAAC,EACA,OAAAC,EAAS,uBACT,QAAAC,EACA,QAAAC,CACJ,IAMCC,IACI,CACG,GAAGA,EACH,QAAS,CAACC,EAAuBZ,IAAiB,CAC9C,GAAI,CAACA,EAAQ,SACT,OAAOY,EAQX,GALIJ,EAAO,WAAW,GAAG,IAErBA,EAASA,EAAO,MAAM,CAAC,GAGvB,CAACA,EAAO,SAAS,OAAO,EACxB,MAAM,IAAI,MAAM,qCAAqC,EA6BzD,OAzBAI,EAAS,CACL,GAAGA,EACH,QAAS,CAEL,GAAGA,EAAO,QACV,IAAIT,EACA,GAAGH,EAAQ,GAAG,IAAIQ,CAAM,GACxBC,EAAQ,IAAKI,GAAW,CACpB,IAAMC,EAAeT,EAAK,KAAKL,EAAQ,IAAea,EAAO,QAAQ,KAAM,EAAE,CAAC,EAG9E,OAAAT,EAAG,UAAUU,CAAY,EAAE,YAAY,EAEhCA,CACX,CAAC,EACD,CAEI,QAAS,QACT,GAAGP,CACP,EACA,CAAE,QAAAG,CAAQ,CACd,CACJ,CACJ,EAEI,OAAOC,EAAW,SAAY,WACvBA,EAAW,QAAQC,EAAQZ,CAAO,EAGtCY,CACX,CACJ,GAEDG,EAAQT","sourcesContent":["import type { SwaggerHandlerOptions } from \"../../../../swagger/api/swagger-handler\";\nimport swaggerHandler from \"../../../../swagger/api/swagger-handler\";\n\n/**\n * @deprecated Use `import { swaggerHandler } from \"@visulima/api-platform\"` instead.\n */\n\nconst swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void = (options = {}) =>\n swaggerHandler(options);\n\n// eslint-disable-next-line etc/no-deprecated\nexport default swaggerApiRoute;\n","import type { BaseDefinition } from \"@visulima/jsdoc-open-api\";\nimport { SwaggerCompilerPlugin } from \"@visulima/jsdoc-open-api\";\nimport type { NextConfig } from \"next\";\nimport type { NextJsWebpackConfig } from \"next/dist/server/config-shared\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport type { Configuration } from \"webpack\";\n\nconst withOpenApi =\n ({\n definition,\n output = \"swagger/swagger.json\",\n sources,\n verbose,\n }: {\n definition: Exclude<BaseDefinition, \"openapi\"> & { openapi?: string };\n output: string;\n sources: string[];\n verbose?: boolean;\n }) =>\n (nextConfig: NextConfig): NextConfig =>\n ({\n ...nextConfig,\n webpack: (config: Configuration, options: any) => {\n if (!options.isServer) {\n return config;\n }\n\n if (output.startsWith(\"/\")) {\n // eslint-disable-next-line no-param-reassign\n output = output.slice(1);\n }\n\n if (!output.endsWith(\".json\")) {\n throw new Error(\"The output path must end with .json\");\n }\n\n // eslint-disable-next-line no-param-reassign\n config = {\n ...config,\n plugins: [\n // @ts-expect-error: ignore\n ...config.plugins,\n new SwaggerCompilerPlugin(\n `${options.dir}/${output}`,\n sources.map((source) => {\n const combinedPath = path.join(options.dir as string, source.replace(\"./\", \"\"));\n\n // Check if the path is a directory\n fs.lstatSync(combinedPath).isDirectory();\n\n return combinedPath;\n }),\n {\n // @ts-expect-error: This property should be overwritten\n openapi: \"3.0.0\",\n ...definition,\n },\n { verbose },\n ),\n ],\n };\n\n if (typeof nextConfig.webpack === \"function\") {\n return nextConfig.webpack(config, options) as NextJsWebpackConfig;\n }\n\n return config as NextJsWebpackConfig;\n },\n }) as NextConfig;\n\nexport default withOpenApi;\n"]}
1
+ {"version":3,"sources":["../../../src/framework/next/routes/api/swagger.ts","../../../src/framework/next/webpack/with-open-api.ts"],"names":["swaggerApiRoute","options","swagger_handler_default","swagger_default","fs","path","SwaggerCompilerPlugin","withOpenApi","definition","output","sources","verbose","nextConfig","config","source","combinedPath","with_open_api_default"],"mappings":"2HAOA,IAAMA,EAAsH,CAACC,EAAU,CAAC,IACpIC,EAAeD,CAAO,EAGnBE,EAAQH,ECXf,OAAOI,MAAQ,KACf,OAAOC,MAAU,OAEjB,OAAS,yBAAAC,MAA6B,2BAKtC,IAAMC,EACF,CAAC,CACG,WAAAC,EACA,OAAAC,EAAS,uBACT,QAAAC,EACA,QAAAC,CACJ,IAMCC,IACI,CACG,GAAGA,EACH,QAAS,CAACC,EAAuBZ,IAAiB,CAC9C,GAAI,CAACA,EAAQ,SACT,OAAOY,EAQX,GALIJ,EAAO,WAAW,GAAG,IAErBA,EAASA,EAAO,MAAM,CAAC,GAGvB,CAACA,EAAO,SAAS,OAAO,EACxB,MAAM,IAAI,MAAM,qCAAqC,EA6BzD,OAzBAI,EAAS,CACL,GAAGA,EACH,QAAS,CAEL,GAAGA,EAAO,QACV,IAAIP,EACA,GAAGL,EAAQ,GAAG,IAAIQ,CAAM,GACxBC,EAAQ,IAAKI,GAAW,CACpB,IAAMC,EAAeV,EAAK,KAAKJ,EAAQ,IAAea,EAAO,QAAQ,KAAM,EAAE,CAAC,EAG9E,OAAAV,EAAG,UAAUW,CAAY,EAAE,YAAY,EAEhCA,CACX,CAAC,EACD,CAEI,QAAS,QACT,GAAGP,CACP,EACA,CAAE,QAAAG,CAAQ,CACd,CACJ,CACJ,EAEI,OAAOC,EAAW,SAAY,WACvBA,EAAW,QAAQC,EAAQZ,CAAO,EAGtCY,CACX,CACJ,GAEDG,EAAQT","sourcesContent":["import type { SwaggerHandlerOptions } from \"../../../../swagger/api/swagger-handler\";\nimport swaggerHandler from \"../../../../swagger/api/swagger-handler\";\n\n/**\n * @deprecated Use `import { swaggerHandler } from \"@visulima/api-platform\"` instead.\n */\n\nconst swaggerApiRoute: <M extends string, PrismaClient>(options: Partial<SwaggerHandlerOptions<M, PrismaClient>>) => void = (options = {}) =>\n swaggerHandler(options);\n\n// eslint-disable-next-line etc/no-deprecated\nexport default swaggerApiRoute;\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport type { BaseDefinition } from \"@visulima/jsdoc-open-api\";\nimport { SwaggerCompilerPlugin } from \"@visulima/jsdoc-open-api\";\nimport type { NextConfig } from \"next\";\nimport type { NextJsWebpackConfig } from \"next/dist/server/config-shared\";\nimport type { Configuration } from \"webpack\";\n\nconst withOpenApi =\n ({\n definition,\n output = \"swagger/swagger.json\",\n sources,\n verbose,\n }: {\n definition: Exclude<BaseDefinition, \"openapi\"> & { openapi?: string };\n output: string;\n sources: string[];\n verbose?: boolean;\n }) =>\n (nextConfig: NextConfig): NextConfig =>\n ({\n ...nextConfig,\n webpack: (config: Configuration, options: any) => {\n if (!options.isServer) {\n return config;\n }\n\n if (output.startsWith(\"/\")) {\n // eslint-disable-next-line no-param-reassign\n output = output.slice(1);\n }\n\n if (!output.endsWith(\".json\")) {\n throw new Error(\"The output path must end with .json\");\n }\n\n // eslint-disable-next-line no-param-reassign\n config = {\n ...config,\n plugins: [\n // @ts-expect-error: ignore\n ...config.plugins,\n new SwaggerCompilerPlugin(\n `${options.dir}/${output}`,\n sources.map((source) => {\n const combinedPath = path.join(options.dir as string, source.replace(\"./\", \"\"));\n\n // Check if the path is a directory\n fs.lstatSync(combinedPath).isDirectory();\n\n return combinedPath;\n }),\n {\n // @ts-expect-error: This property should be overwritten\n openapi: \"3.0.0\",\n ...definition,\n },\n { verbose },\n ),\n ],\n };\n\n if (typeof nextConfig.webpack === \"function\") {\n return nextConfig.webpack(config, options) as NextJsWebpackConfig;\n }\n\n return config as NextJsWebpackConfig;\n },\n }) as NextConfig;\n\nexport default withOpenApi;\n"]}
@@ -1,14 +1,14 @@
1
1
  export { d as dateIn, a as dateOut, i as zod } from './index-browser-48644724.js';
2
2
  import * as zod from 'zod';
3
3
  import { AnyZodObject, ZodObject } from 'zod';
4
+ import { IncomingMessage, ServerResponse } from 'node:http';
4
5
  import * as _visulima_connect from '@visulima/connect';
5
6
  import { NodeRouter, Route, Nextable, FunctionLike, ValueOrPromise, NextHandler } from '@visulima/connect';
6
7
  export { EdgeRequestHandler, EdgeRouter, ExpressRequestHandler, FindResult, FunctionLike, HandlerOptions, HttpMethod, NextHandler, Nextable, NodeRequestHandler, NodeRouter, Route, RouteShortcutMethod, Router, ValueOrPromise, createEdgeRouter, expressWrapper, sendJson, withZod } from '@visulima/connect';
7
- import { IncomingMessage, ServerResponse } from 'node:http';
8
8
  import { CorsOptions, CorsOptionsDelegate } from 'cors';
9
9
  import { NextApiResponse } from 'next';
10
10
  import { RateLimiterAbstract, RateLimiterRes } from 'rate-limiter-flexible';
11
- export { s as swaggerHandler } from './swagger-handler-47360cd1.js';
11
+ export { s as swaggerHandler } from './swagger-handler-1f05481b.js';
12
12
  export { BadGateway, BadRequest, BandwidthLimitExceeded, Conflict, ExpectationFailed, FailedDependency, Forbidden, GatewayTimeout, Gone, HTTPVersionNotSupported, ImATeapot, InsufficientStorage, InternalServerError, LengthRequired, Locked, LoopDetected, MethodNotAllowed, MisdirectedRequest, NetworkAuthenticationRequire, NotAcceptable, NotExtended, NotFound, NotImplemented, PayloadTooLarge, PaymentRequired, PreconditionFailed, PreconditionRequired, ProxyAuthenticationRequired, RangeNotSatisfiable, RequestHeaderFieldsTooLarge, RequestTimeout, ServiceUnavailable, TooManyRequests, URITooLong, Unauthorized, UnavailableForLegalReasons, UnprocessableEntity, UnsupportedMediaType, UpgradeRequired, VariantAlsoNegotiates, default as createHttpError } from 'http-errors';
13
13
  import '@visulima/crud';
14
14
  import 'openapi-types';
@@ -1,14 +1,14 @@
1
1
  export { d as dateIn, a as dateOut, i as zod } from './index-browser-48644724.js';
2
2
  import * as zod from 'zod';
3
3
  import { AnyZodObject, ZodObject } from 'zod';
4
+ import { IncomingMessage, ServerResponse } from 'node:http';
4
5
  import * as _visulima_connect from '@visulima/connect';
5
6
  import { NodeRouter, Route, Nextable, FunctionLike, ValueOrPromise, NextHandler } from '@visulima/connect';
6
7
  export { EdgeRequestHandler, EdgeRouter, ExpressRequestHandler, FindResult, FunctionLike, HandlerOptions, HttpMethod, NextHandler, Nextable, NodeRequestHandler, NodeRouter, Route, RouteShortcutMethod, Router, ValueOrPromise, createEdgeRouter, expressWrapper, sendJson, withZod } from '@visulima/connect';
7
- import { IncomingMessage, ServerResponse } from 'node:http';
8
8
  import { CorsOptions, CorsOptionsDelegate } from 'cors';
9
9
  import { NextApiResponse } from 'next';
10
10
  import { RateLimiterAbstract, RateLimiterRes } from 'rate-limiter-flexible';
11
- export { s as swaggerHandler } from './swagger-handler-47360cd1.js';
11
+ export { s as swaggerHandler } from './swagger-handler-1f05481b.js';
12
12
  export { BadGateway, BadRequest, BandwidthLimitExceeded, Conflict, ExpectationFailed, FailedDependency, Forbidden, GatewayTimeout, Gone, HTTPVersionNotSupported, ImATeapot, InsufficientStorage, InternalServerError, LengthRequired, Locked, LoopDetected, MethodNotAllowed, MisdirectedRequest, NetworkAuthenticationRequire, NotAcceptable, NotExtended, NotFound, NotImplemented, PayloadTooLarge, PaymentRequired, PreconditionFailed, PreconditionRequired, ProxyAuthenticationRequired, RangeNotSatisfiable, RequestHeaderFieldsTooLarge, RequestTimeout, ServiceUnavailable, TooManyRequests, URITooLong, Unauthorized, UnavailableForLegalReasons, UnprocessableEntity, UnsupportedMediaType, UpgradeRequired, VariantAlsoNegotiates, default as createHttpError } from 'http-errors';
13
13
  import '@visulima/crud';
14
14
  import 'openapi-types';
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkWYXGSYH5_js = require('./chunk-WYXGSYH5.js');
4
- var chunkPEE2NOLZ_js = require('./chunk-PEE2NOLZ.js');
4
+ var chunkJBHGHBWN_js = require('./chunk-JBHGHBWN.js');
5
5
  require('./chunk-4D6JZ4TL.js');
6
6
  var connect = require('@visulima/connect');
7
7
  var O = require('http-errors');
@@ -21,7 +21,7 @@ var $__default = /*#__PURE__*/_interopDefault($);
21
21
  var G__default = /*#__PURE__*/_interopDefault(G);
22
22
  var ae__default = /*#__PURE__*/_interopDefault(ae);
23
23
 
24
- var f=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},p=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},u=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=httpStatusCodes.StatusCodes.INTERNAL_SERVER_ERROR);};var v="An error occurred",J=(e,o,t)=>{if(u(t,e),f(t,e),e instanceof y__default.default.JapiError||y__default.default.JapiError.isLikeJapiError(e)){let r=new y__default.default.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof O.HttpError){let{message:r,statusCode:n,title:a}=e;p(t,{errors:[{code:n,title:a||httpStatusCodes.getReasonPhrase(n)||v,detail:r}]});}else {let{message:r}=e;p(t,{errors:[{code:"500",title:httpStatusCodes.getReasonPhrase(t.statusCode)||v,detail:r}]});}},z=J;var A="https://tools.ietf.org/html/rfc2616#section-10",M="An error occurred",W=(e,o,t)=>{let{message:r,stack:n}=e;if(e instanceof O.HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,f(t,e),p(t,{type:d||A,title:i||httpStatusCodes.getReasonPhrase(s)||M,details:r,...a?{trace:n}:{}});}else u(t,e),p(t,{type:A,title:httpStatusCodes.getReasonPhrase(t.statusCode)||M,details:r,...e.expose?{trace:n}:{}});},C=W;var x=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=C;a==="application/vnd.api+json"&&(s=z);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},h=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,O__default.default(405,`No route with [${e.method}] method found.`)};var I={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},X=(e,o)=>{let t=e.toLowerCase();return o?I[t]?I[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},K={canonical:!1,normalizeHeaderKey:X},Z=e=>{let o={...K,...e};return async(t,r,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},H=Z;var B=e=>{if(typeof e!="string")return !1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch{return !1}},S=B;var _=e=>G__default.default.toXML(e,{header:!0,indent:" "}),R=_;var g="Content-Type",Q=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...$__default.default(o).types(),n.defaultContentType],d=r,w=!1;return i.forEach(l=>{e.forEach(({regex:q,serializer:P})=>{q.test(l)&&(t.setHeader(g,l),d=P(d),w=!0);}),w||(/yaml|yml/.test(l)?(t.setHeader(g,l),d=chunkPEE2NOLZ_js.b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(g,l),d=R({[chunkPEE2NOLZ_js.a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},c=Q;var ee=Y__default.default("api-platform:connect:serializers-middleware"),te=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=c(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")ee("response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.");else {let a=r.end;r.end=(s,...i)=>(r.end=a,s=c(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},E=te;var oe=(e={})=>new connect.NodeRouter({onError:x(e.errorHandlers??[],e.showTrace??!1),onNoMatch:h}).use(H(e.middlewares?.["http-header-normalizer"]??{})).use(E(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),se=oe;var ie=e=>connect.expressWrapper(ae__default.default(e)),de=ie;var pe=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,le=(e,o)=>async(t,r,n)=>{let a=pe(t);if(a===void 0)throw O__default.default(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw O__default.default(429,"Too Many Requests")}},ce=le;
24
+ var f=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},p=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},u=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=httpStatusCodes.StatusCodes.INTERNAL_SERVER_ERROR);};var v="An error occurred",J=(e,o,t)=>{if(u(t,e),f(t,e),e instanceof y__default.default.JapiError||y__default.default.JapiError.isLikeJapiError(e)){let r=new y__default.default.ErrorSerializer;p(t,r.serialize(e));}else if(e instanceof O.HttpError){let{message:r,statusCode:n,title:a}=e;p(t,{errors:[{code:n,title:a||httpStatusCodes.getReasonPhrase(n)||v,detail:r}]});}else {let{message:r}=e;p(t,{errors:[{code:"500",title:httpStatusCodes.getReasonPhrase(t.statusCode)||v,detail:r}]});}},z=J;var A="https://tools.ietf.org/html/rfc2616#section-10",M="An error occurred",W=(e,o,t)=>{let{message:r,stack:n}=e;if(e instanceof O.HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,f(t,e),p(t,{type:d||A,title:i||httpStatusCodes.getReasonPhrase(s)||M,details:r,...a?{trace:n}:{}});}else u(t,e),p(t,{type:A,title:httpStatusCodes.getReasonPhrase(t.statusCode)||M,details:r,...e.expose?{trace:n}:{}});},C=W;var x=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=C;a==="application/vnd.api+json"&&(s=z);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},h=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,O__default.default(405,`No route with [${e.method}] method found.`)};var I={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},X=(e,o)=>{let t=e.toLowerCase();return o?I[t]?I[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},K={canonical:!1,normalizeHeaderKey:X},Z=e=>{let o={...K,...e};return async(t,r,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},H=Z;var B=e=>{if(typeof e!="string")return !1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch{return !1}},S=B;var _=e=>G__default.default.toXML(e,{header:!0,indent:" "}),R=_;var g="Content-Type",Q=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...$__default.default(o).types(),n.defaultContentType],d=r,w=!1;return i.forEach(l=>{e.forEach(({regex:q,serializer:P})=>{q.test(l)&&(t.setHeader(g,l),d=P(d),w=!0);}),w||(/yaml|yml/.test(l)?(t.setHeader(g,l),d=chunkJBHGHBWN_js.b(S(r)?JSON.parse(r):r)):l.includes("xml")&&(t.setHeader(g,l),d=R({[chunkJBHGHBWN_js.a(`${o.url?.replace("/api/","")}`.trim())]:S(r)?JSON.parse(r):r})));}),d},c=Q;var ee=Y__default.default("api-platform:connect:serializers-middleware"),te=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=c(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")ee("response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.");else {let a=r.end;r.end=(s,...i)=>(r.end=a,s=c(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},E=te;var oe=(e={})=>new connect.NodeRouter({onError:x(e.errorHandlers??[],e.showTrace??!1),onNoMatch:h}).use(H(e.middlewares?.["http-header-normalizer"]??{})).use(E(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),se=oe;var ie=e=>connect.expressWrapper(ae__default.default(e)),de=ie;var pe=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,le=(e,o)=>async(t,r,n)=>{let a=pe(t);if(a===void 0)throw O__default.default(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw O__default.default(429,"Too Many Requests")}},ce=le;
25
25
 
26
26
  Object.defineProperty(exports, 'dateIn', {
27
27
  enumerable: true,
@@ -37,11 +37,11 @@ Object.defineProperty(exports, 'zod', {
37
37
  });
38
38
  Object.defineProperty(exports, 'swaggerHandler', {
39
39
  enumerable: true,
40
- get: function () { return chunkPEE2NOLZ_js.c; }
40
+ get: function () { return chunkJBHGHBWN_js.c; }
41
41
  });
42
42
  Object.defineProperty(exports, 'yamlTransformer', {
43
43
  enumerable: true,
44
- get: function () { return chunkPEE2NOLZ_js.b; }
44
+ get: function () { return chunkJBHGHBWN_js.b; }
45
45
  });
46
46
  Object.defineProperty(exports, 'EdgeRouter', {
47
47
  enumerable: true,
@@ -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 { NodeRouter } from \"@visulima/connect\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport type { ErrorHandlers } from \"../error-handler/types\";\nimport type { Serializers } from \"../serializers\";\nimport { onError, onNoMatch } from \"./handler\";\nimport httpHeaderNormalizerMiddleware from \"./middleware/http-header-normalizer\";\nimport serializersMiddleware from \"./middleware/serializers-middleware\";\n\nconst createNodeRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: {\n errorHandlers?: ErrorHandlers;\n middlewares?: {\n \"http-header-normalizer\"?: { canonical?: boolean; normalizeHeaderKey?: (key: string, canonical: boolean) => string };\n serializers?: {\n defaultContentType?: string;\n serializers?: Serializers;\n };\n };\n showTrace?: boolean;\n } = {},\n): NodeRouter<Request, Response, Schema> => {\n const router = new NodeRouter<Request, Response, Schema>({\n onError: onError(options.errorHandlers ?? [], options.showTrace ?? false),\n onNoMatch,\n });\n\n return router\n .use(httpHeaderNormalizerMiddleware(options.middlewares?.[\"http-header-normalizer\"] ?? {}))\n .use(\n serializersMiddleware(\n options.middlewares?.serializers?.serializers ?? [],\n options.middlewares?.serializers?.defaultContentType ?? \"application/json; charset=utf-8\",\n ),\n );\n};\n\nexport default createNodeRouter;\n","import type { FunctionLike, Nextable, Route, ValueOrPromise } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport JsonapiErrorHandler from \"../error-handler/jsonapi-error-handler\";\nimport ProblemErrorHandler from \"../error-handler/problem-error-handler\";\nimport type { ErrorHandler, ErrorHandlers } from \"../error-handler/types\";\n\nexport const onError =\n <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) =>\n async (error: unknown, request: Request, response: Response): Promise<void> => {\n const apiFormat: string = request.headers.accept as string;\n\n let errorHandler: ErrorHandler = ProblemErrorHandler;\n\n if (apiFormat === \"application/vnd.api+json\") {\n errorHandler = JsonapiErrorHandler;\n }\n\n // eslint-disable-next-line no-restricted-syntax\n for (const { handler, regex } of errorHandlers) {\n if (regex.test(apiFormat)) {\n errorHandler = handler;\n break;\n }\n }\n\n // eslint-disable-next-line no-param-reassign\n (error as Error & { expose: boolean }).expose = showTrace;\n\n errorHandler(error, request, response);\n };\n\nexport const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: Response,\n routes: Route<Nextable<FunctionLike>>[],\n) => ValueOrPromise<void> = async (request, response, routes) => {\n const uniqueMethods = [...new Set(routes.map((route) => route.method))].join(\", \");\n\n response.setHeader(\"Allow\", uniqueMethods);\n response.statusCode = 405;\n\n throw createHttpError(405, `No route with [${request.method}] method found.`);\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\nimport tsJapi from \"ts-japi\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultTitle = \"An error occurred\";\n\nconst jsonapiErrorHandler: ErrorHandler = (error: Error | HttpError | tsJapi.JapiError, _request, response) => {\n addStatusCodeToResponse(response, error);\n\n setErrorHeaders(response, error);\n\n if (error instanceof tsJapi.JapiError || tsJapi.JapiError.isLikeJapiError(error)) {\n const serializer = new tsJapi.ErrorSerializer();\n\n sendJson(response, serializer.serialize(error));\n } else if (error instanceof HttpError) {\n const { message, statusCode, title } = error;\n\n sendJson(response, {\n errors: [\n {\n code: statusCode,\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n } else {\n const { message } = error;\n\n sendJson(response, {\n errors: [\n {\n code: \"500\",\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n detail: message,\n },\n ],\n });\n }\n};\n\nexport default jsonapiErrorHandler;\n","import type { HttpError } from \"http-errors\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { ServerResponse } from \"node:http\";\n\nexport const setErrorHeaders = (response: ServerResponse, error: unknown): void => {\n const headers: Record<string, ReadonlyArray<string> | number | string> = (error as HttpError).headers ?? {};\n\n Object.keys(headers).forEach((header: string) => {\n response.setHeader(header, headers[header] as ReadonlyArray<string> | number | string);\n });\n};\n\n/**\n * Send `JSON` object\n * @param response response object\n * @param jsonBody of data\n */\nexport const sendJson = (response: ServerResponse, jsonBody: unknown): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.end(JSON.stringify(jsonBody));\n};\n\nexport const addStatusCodeToResponse = (response: ServerResponse, error: unknown): void => {\n // respect err.statusCode\n\n if ((error as HttpError).statusCode !== undefined) {\n response.statusCode = (error as HttpError).statusCode;\n }\n\n // respect err.status\n\n if ((error as HttpError).status !== undefined) {\n response.statusCode = (error as HttpError).status;\n }\n\n // default status code to 500\n if (response.statusCode < 400) {\n response.statusCode = StatusCodes.INTERNAL_SERVER_ERROR;\n }\n};\n","import { HttpError } from \"http-errors\";\nimport { getReasonPhrase } from \"http-status-codes\";\n\nimport type { ErrorHandler } from \"./types\";\nimport { addStatusCodeToResponse, sendJson, setErrorHeaders } from \"./utils\";\n\nconst defaultType = \"https://tools.ietf.org/html/rfc2616#section-10\";\nconst defaultTitle = \"An error occurred\";\n/**\n * Normalizes errors according to the API Problem spec (RFC 7807).\n *\n * @see https://tools.ietf.org/html/rfc7807\n */\nconst problemErrorHandler: ErrorHandler = (error: Error | HttpError, _request, response) => {\n const { message, stack } = error;\n\n if (error instanceof HttpError) {\n const { expose, statusCode, title, type } = error;\n\n response.statusCode = statusCode;\n\n setErrorHeaders(response, error);\n\n sendJson(response, {\n type: type || defaultType,\n // eslint-disable-next-line perfectionist/sort-objects\n title: title || getReasonPhrase(statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n details: message,\n ...(expose ? { trace: stack } : {}),\n });\n } else {\n addStatusCodeToResponse(response, error);\n\n sendJson(response, {\n type: defaultType,\n // eslint-disable-next-line perfectionist/sort-objects\n title: getReasonPhrase(response.statusCode) || defaultTitle,\n // eslint-disable-next-line perfectionist/sort-objects\n details: message,\n ...((error as Error & { expose: boolean }).expose ? { trace: stack } : {}),\n });\n }\n};\n\nexport default problemErrorHandler;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport type { IncomingHttpHeaders, IncomingMessage, ServerResponse } from \"node:http\";\n\nconst exceptions = {\n alpn: \"ALPN\",\n \"c-pep\": \"C-PEP\",\n \"c-pep-info\": \"C-PEP-Info\",\n \"caldav-timezones\": \"CalDAV-Timezones\",\n \"content-id\": \"Content-ID\",\n \"content-md5\": \"Content-MD5\",\n dasl: \"DASL\",\n dav: \"DAV\",\n dnt: \"DNT\",\n etag: \"ETag\",\n getprofile: \"GetProfile\",\n \"http2-settings\": \"HTTP2-Settings\",\n \"last-event-id\": \"Last-Event-ID\",\n \"mime-version\": \"MIME-Version\",\n \"optional-www-authenticate\": \"Optional-WWW-Authenticate\",\n \"sec-webSocket-key\": \"Sec-WebSocket-Key\",\n \"sec-webSocket-protocol\": \"Sec-WebSocket-Protocol\",\n \"sec-webSocket-version\": \"Sec-WebSocket-Version\",\n \"sec-websocket-accept\": \"Sec-WebSocket-Accept\",\n \"sec-websocket-extensions\": \"Sec-WebSocket-Extensions\",\n slug: \"SLUG\",\n tcn: \"TCN\",\n te: \"TE\",\n ttl: \"TTL\",\n \"www-authenticate\": \"WWW-Authenticate\",\n \"x-att-deviceid\": \"X-ATT-DeviceId\",\n \"x-dnsprefetch-control\": \"X-DNSPrefetch-Control\",\n \"x-uidh\": \"X-UIDH\",\n};\n\nconst normalizeHeaderKey = (key: string, canonical: boolean) => {\n const lowerCaseKey = key.toLowerCase();\n\n if (!canonical) {\n return lowerCaseKey;\n }\n\n if (exceptions[lowerCaseKey as keyof typeof exceptions]) {\n return exceptions[lowerCaseKey as keyof typeof exceptions];\n }\n\n return lowerCaseKey\n .split(\"-\")\n\n .map((text) => text[0]?.toUpperCase() + text.slice(1))\n .join(\"-\");\n};\n\nconst defaults = {\n canonical: false,\n normalizeHeaderKey,\n};\n\n/**\n * HTTP headers are case-insensitive.\n * That's why NodeJS makes them lower case by default.\n * While sensible, sometimes, for example for compatibility reasons, you might need them in their more common form.\n */\nconst httpHeaderNormalizerMiddleware = (options_?: {\n canonical?: boolean;\n normalizeHeaderKey?: (key: string, canonical: boolean) => string;\n}): ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>) => {\n const options = { ...defaults, ...options_ };\n\n return async <Request extends IncomingMessage>(request: Request, _: any, next: NextHandler) => {\n const rawHeaders: IncomingHttpHeaders = {};\n const headers: IncomingHttpHeaders = {};\n\n Object.keys(request.headers).forEach((key) => {\n rawHeaders[key] = request.headers[key];\n\n const normalizedKey = options.normalizeHeaderKey(key, options.canonical);\n\n if (normalizedKey) {\n headers[normalizedKey] = request.headers[key];\n }\n });\n\n request.headers = headers;\n // @TODO at type `request.rawHeaders` to global scope\n // @ts-expect-error - `rawHeaders` is not a property of `Request`\n request.rawHeaders = rawHeaders;\n\n return next();\n };\n};\n\nexport default httpHeaderNormalizerMiddleware;\n","import type { NextHandler, ValueOrPromise } from \"@visulima/connect\";\nimport debug from \"debug\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { Serializers } from \"../../serializers\";\nimport { serialize } from \"../../serializers\";\n\nconst log = debug(\"api-platform:connect:serializers-middleware\");\n\nconst serializersMiddleware =\n (serializers: Serializers = [], defaultContentType = \"application/json; charset=utf-8\") =>\n async <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n ): Promise<ValueOrPromise<void>> => {\n if (typeof (response as NextApiResponse).send === \"function\") {\n const oldSend = (response as NextApiResponse).send;\n\n (response as NextApiResponse).send = (data) => {\n (response as NextApiResponse).send = oldSend;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n (response as NextApiResponse).send(data);\n };\n } else if (typeof (response as NextApiResponse).json === \"function\") {\n log(\"response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.\");\n } else {\n const oldEnd = response.end;\n\n // @ts-expect-error TS2322: Type\n (response as Response).end = (data, ...arguments_) => {\n response.end = oldEnd;\n\n // eslint-disable-next-line no-param-reassign\n data = serialize<Request, NextApiResponse | Response>(serializers, request, response, data, { defaultContentType });\n\n // @ts-expect-error TS2345: Argument of type 'unknown' is not assignable to parameter of type 'BufferEncoding'.\n return response.end(data, ...arguments_);\n };\n }\n\n return next();\n };\n\nexport default serializersMiddleware;\n","import accepts from \"accepts\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport { toHeaderCase } from \"../utils\";\nimport hasJsonStructure from \"./has-json-structure\";\nimport xmlTransformer from \"./transformer/xml\";\nimport yamlTransformer from \"./transformer/yaml\";\nimport type { Serializers } from \"./types\";\n\nconst contentTypeKey = \"Content-Type\";\n\nconst serialize = <Request extends IncomingMessage, Response extends ServerResponse>(\n serializers: Serializers,\n request: Request,\n response: Response,\n data: unknown,\n options: {\n defaultContentType: string;\n },\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Buffer | Uint8Array | string => {\n const contentType = response.getHeader(contentTypeKey) as string | undefined;\n\n // skip serialization when Content-Type is already set\n if (typeof contentType === \"string\") {\n return data as string;\n }\n\n const accept = accepts(request);\n const types: string[] = [...(accept.types() as string[]), options.defaultContentType];\n\n let serializedData = data;\n let breakTypes = false;\n\n types.forEach((type) => {\n serializers.forEach(({ regex, serializer }) => {\n if (regex.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = serializer(serializedData);\n breakTypes = true;\n }\n });\n\n if (!breakTypes) {\n if (/yaml|yml/.test(type)) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = yamlTransformer(hasJsonStructure(data) ? JSON.parse(data as string) : data);\n } else if (type.includes(\"xml\")) {\n response.setHeader(contentTypeKey, type);\n\n serializedData = xmlTransformer({\n [toHeaderCase(`${request.url?.replace(\"/api/\", \"\")}`.trim())]: hasJsonStructure(data) ? JSON.parse(data as string) : data,\n });\n }\n }\n });\n\n return serializedData as Buffer | Uint8Array | string;\n};\n\nexport default serialize;\n","const hasJsonStructure = (data: unknown): boolean => {\n if (typeof data !== \"string\") {\n return false;\n }\n\n try {\n const result = JSON.parse(data);\n const type = Object.prototype.toString.call(result);\n\n return type === \"[object Object]\" || type === \"[object Array]\";\n } catch {\n return false;\n }\n};\n\nexport default hasJsonStructure;\n","import type { XmlElement } from \"jstoxml\";\nimport xml from \"jstoxml\";\n\nimport type { Serializer } from \"../types\";\n\nconst xmlTransformer: Serializer = (data?: XmlElement | XmlElement[]) =>\n xml.toXML(data, {\n header: true,\n indent: \" \",\n });\n\nexport default xmlTransformer;\n","import { expressWrapper } from \"@visulima/connect\";\nimport type { CorsOptions, CorsOptionsDelegate } from \"cors\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport cors from \"cors\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nconst corsMiddleware = <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) =>\n expressWrapper<Request, Response>(cors(options));\n\nexport default corsMiddleware;\n","import type { NextHandler } from \"@visulima/connect\";\nimport createHttpError from \"http-errors\";\nimport type { NextApiResponse } from \"next\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { RateLimiterAbstract, RateLimiterRes } from \"rate-limiter-flexible\";\n\nconst getIP: (request: IncomingMessage & { ip?: string }) => string | undefined = (request) =>\n request.ip ??\n (request.headers[\"x-forwarded-for\"] as string | undefined) ??\n (request.headers[\"x-real-ip\"] as string | undefined) ??\n request.socket.remoteAddress;\n\ntype HeaderValue = ReadonlyArray<string> | number | string;\n\nconst rateLimiterMiddleware =\n (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) =>\n async <Request extends IncomingMessage, Response extends ServerResponse>(\n request: Request,\n response: NextApiResponse | Response,\n next: NextHandler,\n ): Promise<void> => {\n const ip = getIP(request);\n\n if (ip === undefined) {\n throw createHttpError(400, \"Missing IP\");\n }\n\n try {\n const limiter = await rateLimiter.consume(ip);\n\n const mergedHeaders: Record<string, HeaderValue> = {\n \"Retry-After\": Math.round(limiter.msBeforeNext / 1000) || 1,\n \"X-RateLimit-Remaining\": limiter.remainingPoints,\n \"X-RateLimit-Reset\": new Date(Date.now() + limiter.msBeforeNext).toISOString(),\n ...headers,\n };\n\n Object.keys(mergedHeaders).forEach((key) => {\n response.setHeader(key, mergedHeaders[key] as HeaderValue);\n });\n\n await next();\n } catch {\n throw createHttpError(429, \"Too Many Requests\");\n }\n };\n\nexport default rateLimiterMiddleware;\n","export * from \"./index-browser\";\n\nexport { default as createNodeRouter } from \"./connect/create-node-router\";\n\nexport { onError, onNoMatch } from \"./connect/handler\";\nexport { default as corsMiddleware } from \"./connect/middleware/cors-middleware\";\nexport { default as httpHeaderNormalizerMiddleware } from \"./connect/middleware/http-header-normalizer\";\nexport { default as rateLimiterMiddleware } from \"./connect/middleware/rate-limiter-middleware\";\n\nexport { default as serializersMiddleware } from \"./connect/middleware/serializers-middleware\";\nexport { serialize, xmlTransformer, yamlTransformer } from \"./serializers\";\n\nexport type { Serializer, Serializers } from \"./serializers\";\nexport { default as swaggerHandler } from \"./swagger/api/swagger-handler\";\nexport { dateIn, dateOut } from \"./zod\";\nexport { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from \"@visulima/connect\";\n\nexport type {\n EdgeRequestHandler,\n ExpressRequestHandler,\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n NextHandler,\n Nextable,\n NodeRequestHandler,\n Route,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"@visulima/connect\";\n\nexport {\n BadGateway,\n BadRequest,\n BandwidthLimitExceeded,\n Conflict,\n ExpectationFailed,\n FailedDependency,\n Forbidden,\n GatewayTimeout,\n Gone,\n HTTPVersionNotSupported,\n ImATeapot,\n InsufficientStorage,\n InternalServerError,\n LengthRequired,\n Locked,\n LoopDetected,\n MethodNotAllowed,\n MisdirectedRequest,\n NetworkAuthenticationRequire,\n NotAcceptable,\n NotExtended,\n NotFound,\n NotImplemented,\n PayloadTooLarge,\n PaymentRequired,\n PreconditionFailed,\n PreconditionRequired,\n ProxyAuthenticationRequired,\n RangeNotSatisfiable,\n RequestHeaderFieldsTooLarge,\n RequestTimeout,\n ServiceUnavailable,\n TooManyRequests,\n URITooLong,\n Unauthorized,\n UnavailableForLegalReasons,\n UnprocessableEntity,\n UnsupportedMediaType,\n UpgradeRequired,\n VariantAlsoNegotiates,\n default as createHttpError,\n} from \"http-errors\";\n"]}
1
+ {"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,6 +1,6 @@
1
1
  export { a as dateIn, b as dateOut, c as zod } from './chunk-AB7BFRZY.mjs';
2
- import { b, a } from './chunk-CQXODW6L.mjs';
3
- export { c as swaggerHandler, b as yamlTransformer } from './chunk-CQXODW6L.mjs';
2
+ import { b, a } from './chunk-CFLRDDCI.mjs';
3
+ export { c as swaggerHandler, b as yamlTransformer } from './chunk-CFLRDDCI.mjs';
4
4
  import './chunk-XIJ2ZQRX.mjs';
5
5
  import { NodeRouter, expressWrapper } from '@visulima/connect';
6
6
  export { EdgeRouter, NodeRouter, Router, createEdgeRouter, expressWrapper, sendJson, withZod } from '@visulima/connect';