@visulima/connect 1.3.6 → 1.3.7

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 CHANGED
@@ -1,3 +1,11 @@
1
+ ## @visulima/connect [1.3.7](https://github.com/visulima/visulima/compare/@visulima/connect@1.3.6...@visulima/connect@1.3.7) (2023-07-26)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * Add secretlintignore and modify router.test.ts for better readability ([81cba4e](https://github.com/visulima/visulima/commit/81cba4ea8236461cd2d3a2ef421699e86bab0763))
7
+ * Update eslint-config version to 10.0.6 across multiple packages ([391238a](https://github.com/visulima/visulima/commit/391238ab4d00335e4ad47d7b705960d0af9a5412))
8
+
1
9
  ## @visulima/connect [1.3.6](https://github.com/visulima/visulima/compare/@visulima/connect@1.3.5...@visulima/connect@1.3.6) (2023-06-06)
2
10
 
3
11
 
@@ -0,0 +1,142 @@
1
+ import { IncomingMessage, ServerResponse } from 'node:http';
2
+ import * as zod from 'zod';
3
+ import { AnyZodObject, ZodObject } from 'zod';
4
+
5
+ type HttpMethod = "DELETE" | "GET" | "HEAD" | "PATCH" | "POST" | "PUT";
6
+
7
+ type FunctionLike = (...arguments_: any[]) => any;
8
+
9
+ type RouteMatch = RegExp | string;
10
+
11
+ type ValueOrPromise<T> = Promise<T> | T;
12
+
13
+ type NextHandler = () => ValueOrPromise<any>;
14
+
15
+ type Nextable<H extends FunctionLike> = (...arguments_: [...Parameters<H>, NextHandler]) => ValueOrPromise<any>;
16
+
17
+ interface FindResult<H extends FunctionLike> {
18
+ fns: Nextable<H>[];
19
+ middleOnly: boolean;
20
+ params: Record<string, string>;
21
+ }
22
+
23
+ type RoutesExtendedRequestHandler<Request extends object, Context, RResponse, Routes> = (
24
+ request: Request,
25
+ response: Context,
26
+ routes: Routes,
27
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
28
+ ) => ValueOrPromise<RResponse | void>;
29
+
30
+ interface HandlerOptions<Handler extends FunctionLike> {
31
+ onError?: (error: unknown, ...arguments_: Parameters<Handler>) => ReturnType<Handler>;
32
+ onNoMatch?: Handler;
33
+ }
34
+
35
+ type RouteShortcutMethod<This, Schema extends AnyZodObject, H extends FunctionLike> = (
36
+ route: Nextable<H> | RouteMatch,
37
+ zodSchemaOrRouteOrFns?: Nextable<H> | RouteMatch | Schema | string,
38
+ ...fns: Nextable<H>[]
39
+ ) => This;
40
+
41
+ type Route<H> = {
42
+ fns: (H | Router<H extends FunctionLike ? H : never>)[];
43
+ isMiddleware: boolean;
44
+ method: HttpMethod | "";
45
+ } & ({
46
+ keys: string[] | false;
47
+ pattern: RegExp;
48
+ } | {
49
+ matchAll: true;
50
+ });
51
+ declare class Router<H extends FunctionLike> {
52
+ base: string;
53
+ routes: Route<Nextable<H>>[];
54
+ constructor(base?: string, routes?: Route<Nextable<H>>[]);
55
+ static exec<FL extends FunctionLike>(fns: Nextable<FL>[], ...arguments_: Parameters<FL>): Promise<any>;
56
+ add(method: HttpMethod | "", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this;
57
+ clone(base?: string): Router<H>;
58
+ find(method: HttpMethod, pathname: string): FindResult<H>;
59
+ use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this;
60
+ }
61
+
62
+ type RequestHandler$1<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;
63
+ declare class NodeRouter<Request extends IncomingMessage = IncomingMessage, Response extends ServerResponse = ServerResponse, Schema extends AnyZodObject = ZodObject<never>> {
64
+ private readonly onError;
65
+ private readonly onNoMatch;
66
+ private router;
67
+ all: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
68
+ delete: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
69
+ get: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
70
+ head: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
71
+ patch: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
72
+ post: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
73
+ put: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
74
+ constructor(options?: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>);
75
+ private add;
76
+ private prepareRequest;
77
+ clone(): NodeRouter<Request, Response, Schema>;
78
+ handler(): (request: Request, response: Response) => Promise<void>;
79
+ run(request: Request, response: Response): Promise<unknown>;
80
+ use(base: Nextable<RequestHandler$1<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch, ...fns: (Nextable<RequestHandler$1<Request, Response>> | NodeRouter<Request, Response, Schema>)[]): this;
81
+ }
82
+ declare const createRouter: <Request_1 extends IncomingMessage, Response_1 extends ServerResponse<IncomingMessage>, Schema extends AnyZodObject = ZodObject<{
83
+ body?: AnyZodObject | undefined;
84
+ headers?: AnyZodObject | undefined;
85
+ query?: AnyZodObject | undefined;
86
+ }, zod.UnknownKeysParam, zod.ZodTypeAny, {
87
+ body?: unknown;
88
+ headers?: unknown;
89
+ query?: unknown;
90
+ }, {
91
+ body?: unknown;
92
+ headers?: unknown;
93
+ query?: unknown;
94
+ }>>(options?: HandlerOptions<RoutesExtendedRequestHandler<Request_1, Response_1, Response_1, Route<Nextable<FunctionLike>>[]>>) => NodeRouter<Request_1, Response_1, Schema>;
95
+
96
+ type NextFunction = (error?: any) => void;
97
+ declare const expressWrapper: <Request_1 extends IncomingMessage, Response_1 extends ServerResponse<IncomingMessage>>(function_: ExpressRequestHandler<Request_1, Response_1>) => Nextable<RequestHandler$1<Request_1, Response_1>>;
98
+ type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;
99
+
100
+ declare const withZod: <Request_1, Response_1, Handler extends Nextable<any>, Schema extends ZodObject<{
101
+ body?: AnyZodObject | undefined;
102
+ headers?: AnyZodObject | undefined;
103
+ query?: AnyZodObject | undefined;
104
+ }, zod.UnknownKeysParam, zod.ZodTypeAny, {
105
+ body?: unknown;
106
+ headers?: unknown;
107
+ query?: unknown;
108
+ }, {
109
+ body?: unknown;
110
+ headers?: unknown;
111
+ query?: unknown;
112
+ }>>(schema: Schema, handler: Handler) => (request: Request_1, response: Response_1, next: NextHandler) => Promise<Response_1>;
113
+
114
+ type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;
115
+ declare class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {
116
+ private readonly onError;
117
+ private readonly onNoMatch;
118
+ private router;
119
+ all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
120
+ delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
121
+ get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
122
+ head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
123
+ patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
124
+ post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
125
+ put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
126
+ constructor(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);
127
+ private add;
128
+ private prepareRequest;
129
+ clone(): EdgeRouter<R, Context, RResponse, Schema>;
130
+ handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse>;
131
+ run(request: R, context_: Context): Promise<unknown>;
132
+ use(base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch, ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]): this;
133
+ }
134
+ declare const createEdgeRouter: <R extends Request, Context>(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>>) => EdgeRouter<R, Context, Response, ZodObject<any, zod.UnknownKeysParam, zod.ZodTypeAny, {
135
+ [x: string]: any;
136
+ }, {
137
+ [x: string]: any;
138
+ }>>;
139
+
140
+ declare const sendJson: (response: ServerResponse, statusCode: number, jsonBody: unknown) => void;
141
+
142
+ export { RequestHandler as EdgeRequestHandler, EdgeRouter, ExpressRequestHandler, FindResult, FunctionLike, HandlerOptions, HttpMethod, NextHandler, Nextable, RequestHandler$1 as NodeRequestHandler, NodeRouter, Route, RouteShortcutMethod, Router, ValueOrPromise, createEdgeRouter, createRouter as createNodeRouter, createRouter, expressWrapper, sendJson, withZod };
package/dist/index.d.ts CHANGED
@@ -1,22 +1,24 @@
1
+ import { IncomingMessage, ServerResponse } from 'node:http';
1
2
  import * as zod from 'zod';
2
3
  import { AnyZodObject, ZodObject } from 'zod';
3
- import { IncomingMessage, ServerResponse } from 'node:http';
4
4
 
5
5
  type HttpMethod = "DELETE" | "GET" | "HEAD" | "PATCH" | "POST" | "PUT";
6
6
 
7
- type FunctionLike = (...arguments_: any[]) => unknown;
7
+ type FunctionLike = (...arguments_: any[]) => any;
8
8
 
9
9
  type RouteMatch = RegExp | string;
10
10
 
11
+ type ValueOrPromise<T> = Promise<T> | T;
12
+
11
13
  type NextHandler = () => ValueOrPromise<any>;
12
14
 
13
15
  type Nextable<H extends FunctionLike> = (...arguments_: [...Parameters<H>, NextHandler]) => ValueOrPromise<any>;
14
16
 
15
- type FindResult<H extends FunctionLike> = {
17
+ interface FindResult<H extends FunctionLike> {
16
18
  fns: Nextable<H>[];
17
- params: Record<string, string>;
18
19
  middleOnly: boolean;
19
- };
20
+ params: Record<string, string>;
21
+ }
20
22
 
21
23
  type RoutesExtendedRequestHandler<Request extends object, Context, RResponse, Routes> = (
22
24
  request: Request,
@@ -26,12 +28,10 @@ type RoutesExtendedRequestHandler<Request extends object, Context, RResponse, Ro
26
28
  ) => ValueOrPromise<RResponse | void>;
27
29
 
28
30
  interface HandlerOptions<Handler extends FunctionLike> {
29
- onNoMatch?: Handler;
30
31
  onError?: (error: unknown, ...arguments_: Parameters<Handler>) => ReturnType<Handler>;
32
+ onNoMatch?: Handler;
31
33
  }
32
34
 
33
- type ValueOrPromise<T> = Promise<T> | T;
34
-
35
35
  type RouteShortcutMethod<This, Schema extends AnyZodObject, H extends FunctionLike> = (
36
36
  route: Nextable<H> | RouteMatch,
37
37
  zodSchemaOrRouteOrFns?: Nextable<H> | RouteMatch | Schema | string,
@@ -39,9 +39,9 @@ type RouteShortcutMethod<This, Schema extends AnyZodObject, H extends FunctionLi
39
39
  ) => This;
40
40
 
41
41
  type Route<H> = {
42
- method: HttpMethod | "";
43
42
  fns: (H | Router<H extends FunctionLike ? H : never>)[];
44
43
  isMiddleware: boolean;
44
+ method: HttpMethod | "";
45
45
  } & ({
46
46
  keys: string[] | false;
47
47
  pattern: RegExp;
@@ -52,54 +52,32 @@ declare class Router<H extends FunctionLike> {
52
52
  base: string;
53
53
  routes: Route<Nextable<H>>[];
54
54
  constructor(base?: string, routes?: Route<Nextable<H>>[]);
55
+ static exec<FL extends FunctionLike>(fns: Nextable<FL>[], ...arguments_: Parameters<FL>): Promise<any>;
55
56
  add(method: HttpMethod | "", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this;
56
- use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this;
57
57
  clone(base?: string): Router<H>;
58
- static exec<H extends FunctionLike>(fns: Nextable<H>[], ...arguments_: Parameters<H>): Promise<unknown>;
59
58
  find(method: HttpMethod, pathname: string): FindResult<H>;
59
+ use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this;
60
60
  }
61
61
 
62
- type RequestHandler$1<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;
63
- declare class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {
64
- private router;
65
- private readonly onNoMatch;
62
+ type RequestHandler$1<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;
63
+ declare class NodeRouter<Request extends IncomingMessage = IncomingMessage, Response extends ServerResponse = ServerResponse, Schema extends AnyZodObject = ZodObject<never>> {
66
64
  private readonly onError;
67
- constructor(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);
68
- private add;
69
- all: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
70
- get: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
71
- head: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
72
- post: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
73
- put: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
74
- patch: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
75
- delete: RouteShortcutMethod<this, Schema, RequestHandler$1<R, Context>>;
76
- use(base: EdgeRouter<R, Context> | Nextable<RequestHandler$1<R, Context>> | RouteMatch, ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler$1<R, Context>>)[]): this;
77
- private prepareRequest;
78
- clone(): EdgeRouter<R, Context, RResponse, Schema>;
79
- run(request: R, context_: Context): Promise<unknown>;
80
- handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse>;
81
- }
82
- declare function createEdgeRouter<R extends Request, Context>(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>>): EdgeRouter<R, Context>;
83
-
84
- type RequestHandler<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;
85
- declare class NodeRouter<Request extends IncomingMessage = IncomingMessage, Response extends ServerResponse = ServerResponse, Schema extends AnyZodObject = ZodObject<any>> {
86
- private router;
87
65
  private readonly onNoMatch;
88
- private readonly onError;
66
+ private router;
67
+ all: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
68
+ delete: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
69
+ get: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
70
+ head: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
71
+ patch: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
72
+ post: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
73
+ put: RouteShortcutMethod<this, Schema, RequestHandler$1<Request, Response>>;
89
74
  constructor(options?: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>);
90
75
  private add;
91
- all: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
92
- get: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
93
- head: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
94
- post: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
95
- put: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
96
- patch: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
97
- delete: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>>;
98
- use(base: Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch, ...fns: (Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema>)[]): this;
99
76
  private prepareRequest;
100
77
  clone(): NodeRouter<Request, Response, Schema>;
101
- run(request: Request, response: Response): Promise<unknown>;
102
78
  handler(): (request: Request, response: Response) => Promise<void>;
79
+ run(request: Request, response: Response): Promise<unknown>;
80
+ use(base: Nextable<RequestHandler$1<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch, ...fns: (Nextable<RequestHandler$1<Request, Response>> | NodeRouter<Request, Response, Schema>)[]): this;
103
81
  }
104
82
  declare const createRouter: <Request_1 extends IncomingMessage, Response_1 extends ServerResponse<IncomingMessage>, Schema extends AnyZodObject = ZodObject<{
105
83
  body?: AnyZodObject | undefined;
@@ -116,7 +94,7 @@ declare const createRouter: <Request_1 extends IncomingMessage, Response_1 exten
116
94
  }>>(options?: HandlerOptions<RoutesExtendedRequestHandler<Request_1, Response_1, Response_1, Route<Nextable<FunctionLike>>[]>>) => NodeRouter<Request_1, Response_1, Schema>;
117
95
 
118
96
  type NextFunction = (error?: any) => void;
119
- declare const expressWrapper: <Request_1 extends IncomingMessage, Response_1 extends ServerResponse<IncomingMessage>>(function_: ExpressRequestHandler<Request_1, Response_1>) => Nextable<RequestHandler<Request_1, Response_1>>;
97
+ declare const expressWrapper: <Request_1 extends IncomingMessage, Response_1 extends ServerResponse<IncomingMessage>>(function_: ExpressRequestHandler<Request_1, Response_1>) => Nextable<RequestHandler$1<Request_1, Response_1>>;
120
98
  type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;
121
99
 
122
100
  declare const withZod: <Request_1, Response_1, Handler extends Nextable<any>, Schema extends ZodObject<{
@@ -133,6 +111,32 @@ declare const withZod: <Request_1, Response_1, Handler extends Nextable<any>, Sc
133
111
  query?: unknown;
134
112
  }>>(schema: Schema, handler: Handler) => (request: Request_1, response: Response_1, next: NextHandler) => Promise<Response_1>;
135
113
 
114
+ type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;
115
+ declare class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {
116
+ private readonly onError;
117
+ private readonly onNoMatch;
118
+ private router;
119
+ all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
120
+ delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
121
+ get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
122
+ head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
123
+ patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
124
+ post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
125
+ put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>>;
126
+ constructor(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);
127
+ private add;
128
+ private prepareRequest;
129
+ clone(): EdgeRouter<R, Context, RResponse, Schema>;
130
+ handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse>;
131
+ run(request: R, context_: Context): Promise<unknown>;
132
+ use(base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch, ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]): this;
133
+ }
134
+ declare const createEdgeRouter: <R extends Request, Context>(options?: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>>) => EdgeRouter<R, Context, Response, ZodObject<any, zod.UnknownKeysParam, zod.ZodTypeAny, {
135
+ [x: string]: any;
136
+ }, {
137
+ [x: string]: any;
138
+ }>>;
139
+
136
140
  declare const sendJson: (response: ServerResponse, statusCode: number, jsonBody: unknown) => void;
137
141
 
138
- export { RequestHandler$1 as EdgeRequestHandler, EdgeRouter, ExpressRequestHandler, FindResult, FunctionLike, HandlerOptions, HttpMethod, NextHandler, Nextable, RequestHandler as NodeRequestHandler, NodeRouter, Route, RouteShortcutMethod, Router, ValueOrPromise, createEdgeRouter, createRouter as createNodeRouter, createRouter, expressWrapper, sendJson, withZod };
142
+ export { RequestHandler as EdgeRequestHandler, EdgeRouter, ExpressRequestHandler, FindResult, FunctionLike, HandlerOptions, HttpMethod, NextHandler, Nextable, RequestHandler$1 as NodeRequestHandler, NodeRouter, Route, RouteShortcutMethod, Router, ValueOrPromise, createEdgeRouter, createRouter as createNodeRouter, createRouter, expressWrapper, sendJson, withZod };
package/dist/index.js CHANGED
@@ -1,23 +1,23 @@
1
1
  'use strict';
2
2
 
3
- var q = require('http-errors');
3
+ var S = require('http-errors');
4
4
  var zod = require('zod');
5
5
  var regexparam = require('regexparam');
6
6
 
7
7
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
8
8
 
9
- var q__default = /*#__PURE__*/_interopDefault(q);
9
+ var S__default = /*#__PURE__*/_interopDefault(S);
10
10
 
11
- var S=(o,e)=>async(t,s,n)=>{let r=t;try{r=await o.parseAsync(t);}catch(R){let{message:a}=R;throw R instanceof zod.ZodError&&typeof R.format=="function"&&(a=R.issues.map(d=>`${d.path.join("/")} - ${d.message}`).join("/n")),q__default.default(422,a)}return e(r,s,n)},h=S;var u=class{constructor(e="/",t=[]){this.base=e;this.routes=t;}add(e,t,...s){if(typeof t=="function"&&(s.unshift(t),t=""),t==="")this.routes.push({matchAll:!0,method:e,fns:s,isMiddleware:!1});else {let{keys:n,pattern:r}=regexparam.parse(t);this.routes.push({keys:n,pattern:r,method:e,fns:s,isMiddleware:!1});}return this}use(e,...t){(typeof e=="function"||e instanceof u)&&(t.unshift(e),e="/"),t=t.map(r=>{if(r instanceof u){if(typeof e=="string")return r.clone(e);throw new Error("Mounting a router to RegExp base is not supported")}return r});let{keys:s,pattern:n}=regexparam.parse(e,!0);return this.routes.push({keys:s,pattern:n,method:"",fns:t,isMiddleware:!0}),this}clone(e){return new u(e,[...this.routes])}static async exec(e,...t){let s=0,n=()=>e[++s](...t,n);return e[s](...t,n)}find(e,t){let s=!0,n=[],r={},R=e==="HEAD";return Object.values(this.routes).forEach(a=>{if(a.method!==e&&a.method!==""&&!(R&&a.method==="GET"))return;let d=!1;if("matchAll"in a)d=!0;else if(a.keys===!1){let i=a.pattern.exec(t);if(i===null)return;i.groups!==void 0&&Object.keys(i.groups).forEach(p=>{r[p]=i.groups[p];}),d=!0;}else if(a.keys.length>0){let i=a.pattern.exec(t);if(i===null)return;for(let p=0;p<a.keys.length;){let x=a.keys[p];r[x]=i[++p];}d=!0;}else a.pattern.test(t)&&(d=!0);d&&(n.push(...a.fns.flatMap(i=>{if(i instanceof u){let{base:p}=i,x=t.slice(p.length);x.startsWith("/")||(x=`/${x}`);let m=i.find(e,x);return m.middleOnly||(s=!1),Object.assign(r,m.params),m.fns}return i})),a.isMiddleware||(s=!1));}),{fns:n,params:r,middleOnly:s}}};var N=async o=>new Response(o.method==="HEAD"?null:`Route ${o.method} ${o.url} not found`,{status:404}),g=async o=>(console.error(o),new Response("Internal Server Error",{status:500}));function H(o){return (o.nextUrl??new URL(o.url)).pathname}var l=class{constructor(e={}){this.router=new u;this.all=this.add.bind(this,"");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.patch=this.add.bind(this,"PATCH");this.delete=this.add.bind(this,"DELETE");this.onNoMatch=e.onNoMatch??N,this.onError=e.onError??g;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[h(s,t)]:n=n.map(r=>h(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}use(e,...t){return (typeof e=="function"||e instanceof l)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof l?s.router:s)),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new l({onNoMatch:this.onNoMatch,onError:this.onError});return e.router=this.router.clone(),e}async run(e,t){let s=this.router.find(e.method,H(e));if(s.fns.length!==0)return this.prepareRequest(e,s),u.exec(s.fns,e,t)}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,H(t));this.prepareRequest(t,n);try{return await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):u.exec(n.fns,t,s))}catch(r){return this.onError(r,t,s,e)}}}};function E(o={}){return new l(o)}var k=o=>(e,t,s)=>new Promise((n,r)=>{o(e,t,R=>R?r(R):n());}).then(s),C=k;var w=async(o,e)=>{e.statusCode=404,e.end(o.method==="HEAD"?void 0:`Route ${o.method} ${o.url} not found`);},v=async(o,e,t)=>{t.statusCode=500,console.error(o),t.end("Internal Server Error");};function y(o){let e=o.indexOf("?");return e===-1?o:o.slice(0,Math.max(0,e))}var c=class{constructor(e={}){this.router=new u;this.all=this.add.bind(this,"");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.patch=this.add.bind(this,"PATCH");this.delete=this.add.bind(this,"DELETE");this.onNoMatch=e.onNoMatch??w,this.onError=e.onError??v;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[h(s,t)]:n=n.map(r=>h(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}use(e,...t){return (typeof e=="function"||e instanceof c)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof c?s.router:s)),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new c({onNoMatch:this.onNoMatch,onError:this.onError});return e.router=this.router.clone(),e}async run(e,t){let s=this.router.find(e.method,y(e.url));if(s.fns.length!==0)return this.prepareRequest(e,s),u.exec(s.fns,e,t)}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,y(t.url));this.prepareRequest(t,n);try{await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):u.exec(n.fns,t,s));}catch(r){await this.onError(r,t,s,e);}}}},b=(o={})=>new c(o);var L=(o,e,t)=>{o.setHeader("content-type","application/json; charset=utf-8"),o.statusCode=e,o.end(JSON.stringify(t,null,2));},j=L;
11
+ var q=o=>async(e,t,s)=>await new Promise((n,r)=>{o(e,t,R=>R?r(R):n());}).then(s),M=q;var g=(o,e)=>async(t,s,n)=>{let r=t;try{r=await o.parseAsync(t);}catch(R){let{message:a}=R;throw R instanceof zod.ZodError&&typeof R.format=="function"&&(a=R.issues.map(d=>`${d.path.join("/")} - ${d.message}`).join("/n")),S__default.default(422,a)}return e(r,s,n)},l=g;var i=class o{constructor(e="/",t=[]){this.base=e;this.routes=t;}static async exec(e,...t){let s=0,n=()=>e[++s](...t,n);return e[s](...t,n)}add(e,t,...s){if(typeof t=="function"&&(s.unshift(t),t=""),t==="")this.routes.push({fns:s,isMiddleware:!1,matchAll:!0,method:e});else {let{keys:n,pattern:r}=regexparam.parse(t);this.routes.push({fns:s,isMiddleware:!1,keys:n,method:e,pattern:r});}return this}clone(e){return new o(e,[...this.routes])}find(e,t){let s=!0,n=[],r={},R=e==="HEAD";return Object.values(this.routes).forEach(a=>{if(a.method!==e&&a.method!==""&&!(R&&a.method==="GET"))return;let d=!1;if("matchAll"in a)d=!0;else if(a.keys===!1){let u=a.pattern.exec(t);if(u===null)return;u.groups!==void 0&&Object.keys(u.groups).forEach(p=>{r[p]=u.groups[p];}),d=!0;}else if(a.keys.length>0){let u=a.pattern.exec(t);if(u===null)return;for(let p=0;p<a.keys.length;){let c=a.keys[p];r[c]=u[++p];}d=!0;}else a.pattern.test(t)&&(d=!0);d&&(n.push(...a.fns.flatMap(u=>{if(u instanceof o){let{base:p}=u,c=t.slice(p.length);c.startsWith("/")||(c=`/${c}`);let m=u.find(e,c);return m.middleOnly||(s=!1),Object.assign(r,m.params),m.fns}return u})),a.isMiddleware||(s=!1));}),{fns:n,middleOnly:s,params:r}}use(e,...t){(typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),t=t.map(r=>{if(r instanceof o){if(typeof e=="string")return r.clone(e);throw new Error("Mounting a router to RegExp base is not supported")}return r});let{keys:s,pattern:n}=regexparam.parse(e,!0);return this.routes.push({fns:t,isMiddleware:!0,keys:s,method:"",pattern:n}),this}};var E=async o=>new Response(o.method==="HEAD"?null:`Route ${o.method} ${o.url} not found`,{status:404}),k=async o=>(console.error(o),new Response("Internal Server Error",{status:500})),H=o=>(o.nextUrl??new URL(o.url)).pathname,h=class o{constructor(e={}){this.router=new i;this.all=this.add.bind(this,"");this.delete=this.add.bind(this,"DELETE");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.patch=this.add.bind(this,"PATCH");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.onNoMatch=e.onNoMatch??E,this.onError=e.onError??k;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[l(s,t)]:n=n.map(r=>l(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new o({onError:this.onError,onNoMatch:this.onNoMatch});return e.router=this.router.clone(),e}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,H(t));this.prepareRequest(t,n);try{return await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):i.exec(n.fns,t,s))}catch(r){return await this.onError(r,t,s,e)}}}async run(e,t){let s=this.router.find(e.method,H(e));if(s.fns.length!==0)return this.prepareRequest(e,s),await i.exec(s.fns,e,t)}use(e,...t){return (typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof o?s.router:s)),this}},C=(o={})=>new h(o);var w=async(o,e)=>{e.statusCode=404,e.end(o.method==="HEAD"?void 0:`Route ${o.method} ${o.url} not found`);},v=async(o,e,t)=>{t.statusCode=500,console.error(o),t.end("Internal Server Error");},y=o=>{let e=o.indexOf("?");return e===-1?o:o.slice(0,Math.max(0,e))},x=class o{constructor(e={}){this.router=new i;this.all=this.add.bind(this,"");this.delete=this.add.bind(this,"DELETE");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.patch=this.add.bind(this,"PATCH");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.onNoMatch=e.onNoMatch??w,this.onError=e.onError??v;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[l(s,t)]:n=n.map(r=>l(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new o({onError:this.onError,onNoMatch:this.onNoMatch});return e.router=this.router.clone(),e}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,y(t.url));this.prepareRequest(t,n);try{await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):i.exec(n.fns,t,s));}catch(r){await this.onError(r,t,s,e);}}}async run(e,t){let s=this.router.find(e.method,y(e.url));if(s.fns.length!==0)return this.prepareRequest(e,s),await i.exec(s.fns,e,t)}use(e,...t){return (typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof o?s.router:s)),this}},b=(o={})=>new x(o);var L=(o,e,t)=>{o.setHeader("content-type","application/json; charset=utf-8"),o.statusCode=e,o.end(JSON.stringify(t,null,2));},j=L;
12
12
 
13
- exports.EdgeRouter = l;
14
- exports.NodeRouter = c;
15
- exports.Router = u;
16
- exports.createEdgeRouter = E;
13
+ exports.EdgeRouter = h;
14
+ exports.NodeRouter = x;
15
+ exports.Router = i;
16
+ exports.createEdgeRouter = C;
17
17
  exports.createNodeRouter = b;
18
18
  exports.createRouter = b;
19
- exports.expressWrapper = C;
19
+ exports.expressWrapper = M;
20
20
  exports.sendJson = j;
21
- exports.withZod = h;
21
+ exports.withZod = l;
22
22
  //# sourceMappingURL=out.js.map
23
23
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/adapter/with-zod.ts","../src/router.ts","../src/edge.ts","../src/adapter/express.ts","../src/node.ts","../src/utils/send-json.ts"],"names":["createHttpError","ZodError","withZod","schema","handler","request","response","next","transformedRequest","error","message","issue","with_zod_default","parse","Router","base","routes","method","route","fns","keys","pattern","function_","arguments_","index","pathname","middleOnly","parameters","isHead","matched","matches","key","parameterKey","stripPathname","result","onNoMatch","onError","getPathname","EdgeRouter","options","routeOrFunction","zodOrRouteOrFunction","findResult","r","context_","createEdgeRouter","expressWrapper","resolve","reject","express_default","_request","url","queryIndex","NodeRouter","createRouter","sendJson","statusCode","jsonBody","send_json_default"],"mappings":"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","sourcesContent":["import createHttpError from \"http-errors\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\nimport { ZodError } from \"zod\";\n\nimport type { Nextable, NextHandler } from \"../types\";\n\n// eslint-disable-next-line max-len\nconst withZod = <Request, Response, Handler extends Nextable<any>, Schema extends ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>>(\n schema: Schema,\n handler: Handler,\n): ((request: Request, response: Response, next: NextHandler) => Promise<Response>) => async (request: Request, response: Response, next) => {\n let transformedRequest: Request = request;\n\n try {\n transformedRequest = (await schema.parseAsync(request)) as Request;\n } catch (error: any) {\n let { message } = error;\n\n // eslint-disable-next-line unicorn/consistent-destructuring\n if (error instanceof ZodError && typeof error.format === \"function\") {\n // eslint-disable-next-line unicorn/consistent-destructuring\n message = error.issues.map((issue) => `${issue.path.join(\"/\")} - ${issue.message}`).join(\"/n\");\n }\n\n throw createHttpError(422, message);\n }\n\n return handler(transformedRequest, response, next);\n };\n\nexport default withZod;\n","/**\n * Agnostic router class\n * Adapted from lukeed/trouter library:\n * https://github.com/lukeed/trouter/blob/master/index.mjs\n */\nimport { parse } from \"regexparam\";\n\nimport type {\n FindResult, FunctionLike, HttpMethod, Nextable, RouteMatch,\n} from \"./types\";\n\nexport type Route<H> = {\n method: HttpMethod | \"\";\n fns: (H | Router<H extends FunctionLike ? H : never>)[];\n isMiddleware: boolean;\n} & (\n | {\n keys: string[] | false;\n pattern: RegExp;\n }\n | { matchAll: true }\n);\n\nexport class Router<H extends FunctionLike> {\n public constructor(public base: string = \"/\", public routes: Route<Nextable<H>>[] = []) {}\n\n public add(method: HttpMethod | \"\", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this {\n if (typeof route === \"function\") {\n fns.unshift(route);\n // eslint-disable-next-line no-param-reassign\n route = \"\";\n }\n\n if (route === \"\") {\n this.routes.push({\n matchAll: true,\n method,\n fns,\n isMiddleware: false,\n });\n } else {\n const { keys, pattern } = parse(route);\n\n this.routes.push({\n keys,\n pattern,\n method,\n fns,\n isMiddleware: false,\n });\n }\n\n return this;\n }\n\n public use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this {\n if (typeof base === \"function\" || base instanceof Router) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n // mount subrouter\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => {\n if (function_ instanceof Router) {\n if (typeof base === \"string\") return function_.clone(base);\n throw new Error(\"Mounting a router to RegExp base is not supported\");\n }\n return function_;\n });\n\n const { keys, pattern } = parse(base, true);\n\n this.routes.push({\n keys,\n pattern,\n method: \"\",\n fns,\n isMiddleware: true,\n });\n\n return this;\n }\n\n public clone(base?: string): Router<H> {\n return new Router<H>(base, [...this.routes]);\n }\n\n public static async exec<H extends FunctionLike>(fns: Nextable<H>[], ...arguments_: Parameters<H>): Promise<unknown> {\n let index = 0;\n\n // eslint-disable-next-line no-plusplus\n const next = () => (fns[++index] as FunctionLike)(...arguments_, next);\n\n return (fns[index] as FunctionLike)(...arguments_, next);\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n public find(method: HttpMethod, pathname: string): FindResult<H> {\n let middleOnly = true;\n\n const fns: Nextable<H>[] = [];\n const parameters: Record<string, string> = {};\n const isHead = method === \"HEAD\";\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.values(this.routes).forEach((route) => {\n if (\n route.method !== method\n // matches any method\n && route.method !== \"\"\n // The HEAD method requests that the target resource transfer a representation of its state, as for a GET request...\n && !(isHead && route.method === \"GET\")\n ) {\n return;\n }\n\n let matched = false;\n\n if (\"matchAll\" in route) {\n matched = true;\n } else if (route.keys === false) {\n // routes.key is RegExp: https://github.com/lukeed/regexparam/blob/master/src/index.js#L2\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n // eslint-disable-next-line no-void\n if (matches.groups !== void 0) {\n Object.keys(matches.groups).forEach((key) => {\n // @ts-expect-error @TODO: fix this\n parameters[key] = matches.groups[key] as string;\n });\n }\n\n matched = true;\n } else if (route.keys.length > 0) {\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n for (let index = 0; index < route.keys.length;) {\n const parameterKey = route.keys[index];\n\n // @ts-expect-error @TODO: fix this\n // eslint-disable-next-line no-plusplus\n parameters[parameterKey] = matches[++index];\n }\n\n matched = true;\n } else if (route.pattern.test(pathname)) {\n matched = true;\n } // else not a match\n\n if (matched) {\n fns.push(\n ...route.fns.flatMap((function_) => {\n if (function_ instanceof Router) {\n const { base } = function_;\n\n let stripPathname = pathname.slice(base.length);\n\n // fix stripped pathname, not sure why this happens\n // eslint-disable-next-line eqeqeq\n if (!stripPathname.startsWith(\"/\")) {\n stripPathname = `/${stripPathname}`;\n }\n\n // eslint-disable-next-line unicorn/no-array-callback-reference, unicorn/no-array-method-this-argument\n const result = function_.find(method, stripPathname);\n\n if (!result.middleOnly) {\n middleOnly = false;\n }\n\n // merge params\n Object.assign(parameters, result.params);\n\n return result.fns;\n }\n\n return function_;\n }),\n );\n if (!route.isMiddleware) middleOnly = false;\n }\n });\n\n return { fns, params: parameters, middleOnly };\n }\n}\n","import type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RoutesExtendedRequestHandler,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"./types\";\n\n// eslint-disable-next-line max-len\nconst onNoMatch = async (request: Request) => new Response(request.method === \"HEAD\" ? null : `Route ${request.method} ${request.url} not found`, { status: 404 });\n\nconst onError = async (error: unknown) => {\n // eslint-disable-next-line no-console\n console.error(error);\n return new Response(\"Internal Server Error\", { status: 500 });\n};\n\nexport function getPathname(request: Request & { nextUrl?: URL }): string {\n // eslint-disable-next-line compat/compat\n return (request.nextUrl ?? new URL(request.url)).pathname;\n}\n\n// eslint-disable-next-line max-len,@typescript-eslint/no-invalid-void-type\nexport type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;\n\nexport class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {\n private router = new Router<RequestHandler<R, Context>>();\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>;\n\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>;\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? (onNoMatch as unknown as RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>);\n this.onError = options.onError\n ?? (onError as unknown as (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<R, Context>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<R, Context>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<R, Context>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign,max-len\n fns = fns.map((function_) => withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"HEAD\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PUT\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PATCH\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"DELETE\");\n\n public use(\n base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch,\n ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof EdgeRouter) {\n fns.unshift(base as EdgeRouter<R, Context>);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n\n this.router.use(base, ...fns.map((function_) => (function_ instanceof EdgeRouter ? function_.router : function_)));\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: R & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<R, Context>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): EdgeRouter<R, Context, RResponse, Schema> {\n const r = new EdgeRouter<R, Context, RResponse, Schema>({ onNoMatch: this.onNoMatch, onError: this.onError });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public async run(request: R, context_: Context): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return Router.exec(result.fns, request, context_);\n }\n\n public handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: R, context_: Context): Promise<any> => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n this.prepareRequest(request, result);\n\n try {\n return await (result.fns.length === 0 || result.middleOnly\n ? this.onNoMatch(request, context_, routes)\n : Router.exec(result.fns, request, context_));\n } catch (error) {\n return this.onError(error, request, context_, routes);\n }\n };\n }\n}\n\nexport function createEdgeRouter<R extends Request, Context>(\n options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): EdgeRouter<R, Context> {\n return new EdgeRouter<R, Context, Response>(options);\n}\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { RequestHandler } from \"../node\";\nimport type { Nextable } from \"../types\";\n\ntype NextFunction = (error?: any) => void;\n\nconst expressWrapper = <Request extends IncomingMessage, Response extends ServerResponse>(\n function_: ExpressRequestHandler<Request, Response>,\n // eslint-disable-next-line compat/compat\n): Nextable<RequestHandler<Request, Response>> => (request, response, next) => new Promise<void>((resolve, reject) => {\n function_(request, response, (error) => (error ? reject(error) : resolve()));\n // eslint-disable-next-line promise/no-callback-in-promise\n }).then(next);\n\nexport type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;\n\nexport default expressWrapper;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RoutesExtendedRequestHandler,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 404;\n response.end(request.method === \"HEAD\" ? undefined : `Route ${request.method} ${request.url} not found`);\n};\n\nconst onError = async (error: unknown, _request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 500;\n // eslint-disable-next-line no-console\n console.error(error);\n\n response.end(\"Internal Server Error\");\n};\n\nexport function getPathname(url: string): string {\n const queryIndex = url.indexOf(\"?\");\n\n return queryIndex === -1 ? url : url.slice(0, Math.max(0, queryIndex));\n}\n\nexport type RequestHandler<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;\n\nexport class NodeRouter<\n Request extends IncomingMessage = IncomingMessage,\n Response extends ServerResponse = ServerResponse,\n Schema extends AnyZodObject = ZodObject<any>,\n> {\n private router = new Router<RequestHandler<Request, Response>>();\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>;\n\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>;\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? onNoMatch;\n this.onError = options.onError ?? onError;\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<Request, Response>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<Request, Response>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<Request, Response>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign,max-len\n fns = fns.map((function_) => withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"HEAD\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PUT\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PATCH\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"DELETE\");\n\n public use(\n base: Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch,\n ...fns: (Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof NodeRouter) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n this.router.use(base, ...fns.map((function_) => (function_ instanceof NodeRouter ? function_.router : function_)));\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: Request & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<Request, Response>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): NodeRouter<Request, Response, Schema> {\n const r = new NodeRouter<Request, Response, Schema>({ onNoMatch: this.onNoMatch, onError: this.onError });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public async run(request: Request, response: Response): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return Router.exec(result.fns, request, response);\n }\n\n public handler(): (request: Request, response: Response) => Promise<void> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: Request, response: Response) => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n this.prepareRequest(request, result);\n\n try {\n await (result.fns.length === 0 || result.middleOnly ? this.onNoMatch(request, response, routes) : Router.exec(result.fns, request, response));\n } catch (error) {\n await this.onError(error, request, response, routes);\n }\n };\n }\n}\n\nexport const createRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {},\n ): NodeRouter<Request, Response, Schema> => new NodeRouter<Request, Response, Schema>(options);\n","import type { ServerResponse } from \"node:http\";\n\n/**\n * Send `JSON` object\n * @param {ServerResponse} response response object\n * @param {number} statusCode\n * @param {any} jsonBody of data\n */\nconst sendJson = (response: ServerResponse, statusCode: number, jsonBody: unknown): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.statusCode = statusCode;\n response.end(JSON.stringify(jsonBody, null, 2));\n};\n\nexport default sendJson;\n"]}
1
+ {"version":3,"sources":["../src/adapter/express.ts","../src/adapter/with-zod.ts","../src/router.ts","../src/edge.ts","../src/node.ts","../src/utils/send-json.ts"],"names":["expressWrapper","function_","request","response","next","resolve","reject","error","express_default","createHttpError","ZodError","withZod","schema","handler","transformedRequest","message","issue","with_zod_default","parse","Router","_Router","base","routes","fns","arguments_","index","method","route","keys","pattern","pathname","middleOnly","parameters","isHead","matched","matches","key","parameterKey","stripPathname","result","onNoMatch","onError","getPathname","EdgeRouter","_EdgeRouter","options","routeOrFunction","zodOrRouteOrFunction","findResult","r","context_","createEdgeRouter","_request","url","queryIndex","NodeRouter","_NodeRouter","createRouter","sendJson","statusCode","jsonBody","send_json_default"],"mappings":"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","sourcesContent":["import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { RequestHandler } from \"../node\";\nimport type { Nextable } from \"../types\";\n\ntype NextFunction = (error?: any) => void;\n\nconst expressWrapper =\n <Request extends IncomingMessage, Response extends ServerResponse>(\n // eslint-disable-next-line no-use-before-define\n function_: ExpressRequestHandler<Request, Response>,\n ): Nextable<RequestHandler<Request, Response>> =>\n async (request, response, next) =>\n // eslint-disable-next-line compat/compat\n await new Promise<void>((resolve, reject): void => {\n function_(request, response, (error) => (error ? reject(error) : resolve()));\n // eslint-disable-next-line promise/no-callback-in-promise\n }).then<Nextable<RequestHandler<Request, Response>>>(next);\n\nexport type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;\n\nexport default expressWrapper;\n","import createHttpError from \"http-errors\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\nimport { ZodError } from \"zod\";\n\nimport type { NextHandler, Nextable } from \"../types\";\n\nconst withZod =\n <Request, Response, Handler extends Nextable<any>, Schema extends ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>>(\n schema: Schema,\n handler: Handler,\n ): ((request: Request, response: Response, next: NextHandler) => Promise<Response>) =>\n async (request: Request, response: Response, next) => {\n let transformedRequest: Request = request;\n\n try {\n transformedRequest = (await schema.parseAsync(request)) as Request;\n } catch (error: any) {\n let { message } = error as Error;\n\n if (error instanceof ZodError && typeof error.format === \"function\") {\n message = error.issues.map((issue) => `${issue.path.join(\"/\")} - ${issue.message}`).join(\"/n\");\n }\n\n throw createHttpError(422, message);\n }\n\n return handler(transformedRequest, response, next);\n };\n\nexport default withZod;\n","/**\n * Agnostic router class\n * Adapted from lukeed/trouter library:\n * https://github.com/lukeed/trouter/blob/master/index.mjs\n */\nimport { parse } from \"regexparam\";\n\nimport type { FindResult, FunctionLike, HttpMethod, Nextable, RouteMatch } from \"./types\";\n\nexport type Route<H> = {\n // eslint-disable-next-line no-use-before-define\n fns: (H | Router<H extends FunctionLike ? H : never>)[];\n isMiddleware: boolean;\n method: HttpMethod | \"\";\n} & (\n | {\n keys: string[] | false;\n pattern: RegExp;\n }\n | { matchAll: true }\n);\n\nexport class Router<H extends FunctionLike> {\n public constructor(\n public base: string = \"/\",\n public routes: Route<Nextable<H>>[] = [],\n ) {}\n\n public static async exec<FL extends FunctionLike>(fns: Nextable<FL>[], ...arguments_: Parameters<FL>): Promise<any> {\n let index = 0;\n\n // eslint-disable-next-line no-plusplus\n const next = () => (fns[++index] as FunctionLike)(...arguments_, next);\n\n return (fns[index] as FunctionLike)(...arguments_, next);\n }\n\n public add(method: HttpMethod | \"\", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this {\n if (typeof route === \"function\") {\n fns.unshift(route);\n // eslint-disable-next-line no-param-reassign\n route = \"\";\n }\n\n if (route === \"\") {\n this.routes.push({\n fns,\n isMiddleware: false,\n matchAll: true,\n method,\n });\n } else {\n const { keys, pattern } = parse(route);\n\n this.routes.push({\n fns,\n isMiddleware: false,\n keys,\n method,\n pattern,\n });\n }\n\n return this;\n }\n\n public clone(base?: string): Router<H> {\n return new Router<H>(base, [...this.routes]);\n }\n\n public find(method: HttpMethod, pathname: string): FindResult<H> {\n let middleOnly = true;\n\n const fns: Nextable<H>[] = [];\n const parameters: Record<string, string> = {};\n const isHead = method === \"HEAD\";\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.values(this.routes).forEach((route) => {\n if (\n route.method !== method &&\n // matches any method\n route.method !== \"\" &&\n // The HEAD method requests that the target resource transfer a representation of its state, as for a GET request...\n !(isHead && route.method === \"GET\")\n ) {\n return;\n }\n\n let matched = false;\n\n if (\"matchAll\" in route) {\n matched = true;\n } else if (route.keys === false) {\n // routes.key is RegExp: https://github.com/lukeed/regexparam/blob/master/src/index.js#L2\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n // eslint-disable-next-line no-void\n if (matches.groups !== void 0) {\n Object.keys(matches.groups).forEach((key) => {\n // @ts-expect-error @TODO: fix this\n parameters[key] = matches.groups[key] as string;\n });\n }\n\n matched = true;\n } else if (route.keys.length > 0) {\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n for (let index = 0; index < route.keys.length; ) {\n const parameterKey = route.keys[index];\n\n // @ts-expect-error @TODO: fix this\n // eslint-disable-next-line no-plusplus\n parameters[parameterKey] = matches[++index];\n }\n\n matched = true;\n } else if (route.pattern.test(pathname)) {\n matched = true;\n } // else not a match\n\n if (matched) {\n fns.push(\n ...route.fns.flatMap((function_) => {\n if (function_ instanceof Router) {\n const { base } = function_;\n\n let stripPathname = pathname.slice(base.length);\n\n // fix stripped pathname, not sure why this happens\n\n if (!stripPathname.startsWith(\"/\")) {\n stripPathname = `/${stripPathname}`;\n }\n\n // eslint-disable-next-line unicorn/no-array-callback-reference, unicorn/no-array-method-this-argument\n const result = function_.find(method, stripPathname);\n\n if (!result.middleOnly) {\n middleOnly = false;\n }\n\n // merge params\n Object.assign(parameters, result.params);\n\n return result.fns;\n }\n\n return function_;\n }),\n );\n if (!route.isMiddleware) {\n middleOnly = false;\n }\n }\n });\n\n return { fns, middleOnly, params: parameters };\n }\n\n public use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this {\n if (typeof base === \"function\" || base instanceof Router) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n // mount subrouter\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => {\n if (function_ instanceof Router) {\n if (typeof base === \"string\") {\n return function_.clone(base);\n }\n\n throw new Error(\"Mounting a router to RegExp base is not supported\");\n }\n return function_;\n });\n\n const { keys, pattern } = parse(base, true);\n\n this.routes.push({\n fns,\n isMiddleware: true,\n keys,\n method: \"\",\n pattern,\n });\n\n return this;\n }\n}\n","import type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RouteShortcutMethod,\n RoutesExtendedRequestHandler,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: Request) =>\n new Response(request.method === \"HEAD\" ? null : `Route ${request.method} ${request.url} not found`, { status: 404 });\n\nconst onError = async (error: unknown) => {\n console.error(error);\n return new Response(\"Internal Server Error\", { status: 500 });\n};\n\nexport const getPathname = (request: Request & { nextUrl?: URL }): string =>\n // eslint-disable-next-line compat/compat\n (request.nextUrl ?? new URL(request.url)).pathname;\n\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type\nexport type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;\n\nexport class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>;\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>;\n\n private router = new Router<RequestHandler<R, Context>>();\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"DELETE\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"HEAD\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PATCH\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PUT\");\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? (onNoMatch as unknown as RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>);\n this.onError =\n options.onError ??\n (onError as unknown as (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<R, Context>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<R, Context>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<R, Context>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: R & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<R, Context>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): EdgeRouter<R, Context, RResponse, Schema> {\n const r = new EdgeRouter<R, Context, RResponse, Schema>({ onError: this.onError, onNoMatch: this.onNoMatch });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n public handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: R, context_: Context): Promise<any> => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n this.prepareRequest(request, result);\n\n try {\n return await (result.fns.length === 0 || result.middleOnly\n ? this.onNoMatch(request, context_, routes)\n : Router.exec(result.fns, request, context_));\n } catch (error) {\n return await this.onError(error, request, context_, routes);\n }\n };\n }\n\n public async run(request: R, context_: Context): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return await Router.exec(result.fns, request, context_);\n }\n\n public use(\n base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch,\n ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof EdgeRouter) {\n fns.unshift(base as EdgeRouter<R, Context>);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n\n this.router.use(base, ...fns.map((function_) => (function_ instanceof EdgeRouter ? function_.router : function_)));\n\n return this;\n }\n}\n\nexport const createEdgeRouter = <R extends Request, Context>(\n options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): EdgeRouter<R, Context> => new EdgeRouter<R, Context, Response>(options);\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RouteShortcutMethod,\n RoutesExtendedRequestHandler,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 404;\n response.end(request.method === \"HEAD\" ? undefined : `Route ${request.method} ${request.url} not found`);\n};\n\nconst onError = async (error: unknown, _request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 500;\n\n console.error(error);\n\n response.end(\"Internal Server Error\");\n};\n\nexport const getPathname = (url: string): string => {\n const queryIndex = url.indexOf(\"?\");\n\n return queryIndex === -1 ? url : url.slice(0, Math.max(0, queryIndex));\n};\n\nexport type RequestHandler<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;\n\nexport class NodeRouter<\n Request extends IncomingMessage = IncomingMessage,\n Response extends ServerResponse = ServerResponse,\n Schema extends AnyZodObject = ZodObject<never>,\n> {\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>;\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>;\n\n private router = new Router<RequestHandler<Request, Response>>();\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"DELETE\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"HEAD\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PATCH\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PUT\");\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? onNoMatch;\n this.onError = options.onError ?? onError;\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<Request, Response>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<Request, Response>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<Request, Response>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) =>\n withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, function_),\n );\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: Request & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<Request, Response>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): NodeRouter<Request, Response, Schema> {\n const r = new NodeRouter<Request, Response, Schema>({ onError: this.onError, onNoMatch: this.onNoMatch });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public handler(): (request: Request, response: Response) => Promise<void> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: Request, response: Response) => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n this.prepareRequest(request, result);\n\n try {\n await (result.fns.length === 0 || result.middleOnly ? this.onNoMatch(request, response, routes) : Router.exec(result.fns, request, response));\n } catch (error) {\n await this.onError(error, request, response, routes);\n }\n };\n }\n\n public async run(request: Request, response: Response): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return await Router.exec(result.fns, request, response);\n }\n\n public use(\n base: Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch,\n ...fns: (Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof NodeRouter) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n this.router.use(base, ...fns.map((function_) => (function_ instanceof NodeRouter ? function_.router : function_)));\n\n return this;\n }\n}\n\nexport const createRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): NodeRouter<Request, Response, Schema> => new NodeRouter<Request, Response, Schema>(options);\n","import type { ServerResponse } from \"node:http\";\n\n/**\n * Send `JSON` object\n * @param {ServerResponse} response response object\n * @param {number} statusCode\n * @param {any} jsonBody of data\n */\nconst sendJson = (response: ServerResponse, statusCode: number, jsonBody: unknown): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.statusCode = statusCode;\n response.end(JSON.stringify(jsonBody, null, 2));\n};\n\nexport default sendJson;\n"]}
package/dist/index.mjs CHANGED
@@ -1,9 +1,9 @@
1
- import q from 'http-errors';
1
+ import S from 'http-errors';
2
2
  import { ZodError } from 'zod';
3
3
  import { parse } from 'regexparam';
4
4
 
5
- var S=(o,e)=>async(t,s,n)=>{let r=t;try{r=await o.parseAsync(t);}catch(R){let{message:a}=R;throw R instanceof ZodError&&typeof R.format=="function"&&(a=R.issues.map(d=>`${d.path.join("/")} - ${d.message}`).join("/n")),q(422,a)}return e(r,s,n)},h=S;var u=class{constructor(e="/",t=[]){this.base=e;this.routes=t;}add(e,t,...s){if(typeof t=="function"&&(s.unshift(t),t=""),t==="")this.routes.push({matchAll:!0,method:e,fns:s,isMiddleware:!1});else {let{keys:n,pattern:r}=parse(t);this.routes.push({keys:n,pattern:r,method:e,fns:s,isMiddleware:!1});}return this}use(e,...t){(typeof e=="function"||e instanceof u)&&(t.unshift(e),e="/"),t=t.map(r=>{if(r instanceof u){if(typeof e=="string")return r.clone(e);throw new Error("Mounting a router to RegExp base is not supported")}return r});let{keys:s,pattern:n}=parse(e,!0);return this.routes.push({keys:s,pattern:n,method:"",fns:t,isMiddleware:!0}),this}clone(e){return new u(e,[...this.routes])}static async exec(e,...t){let s=0,n=()=>e[++s](...t,n);return e[s](...t,n)}find(e,t){let s=!0,n=[],r={},R=e==="HEAD";return Object.values(this.routes).forEach(a=>{if(a.method!==e&&a.method!==""&&!(R&&a.method==="GET"))return;let d=!1;if("matchAll"in a)d=!0;else if(a.keys===!1){let i=a.pattern.exec(t);if(i===null)return;i.groups!==void 0&&Object.keys(i.groups).forEach(p=>{r[p]=i.groups[p];}),d=!0;}else if(a.keys.length>0){let i=a.pattern.exec(t);if(i===null)return;for(let p=0;p<a.keys.length;){let x=a.keys[p];r[x]=i[++p];}d=!0;}else a.pattern.test(t)&&(d=!0);d&&(n.push(...a.fns.flatMap(i=>{if(i instanceof u){let{base:p}=i,x=t.slice(p.length);x.startsWith("/")||(x=`/${x}`);let m=i.find(e,x);return m.middleOnly||(s=!1),Object.assign(r,m.params),m.fns}return i})),a.isMiddleware||(s=!1));}),{fns:n,params:r,middleOnly:s}}};var N=async o=>new Response(o.method==="HEAD"?null:`Route ${o.method} ${o.url} not found`,{status:404}),g=async o=>(console.error(o),new Response("Internal Server Error",{status:500}));function H(o){return (o.nextUrl??new URL(o.url)).pathname}var l=class{constructor(e={}){this.router=new u;this.all=this.add.bind(this,"");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.patch=this.add.bind(this,"PATCH");this.delete=this.add.bind(this,"DELETE");this.onNoMatch=e.onNoMatch??N,this.onError=e.onError??g;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[h(s,t)]:n=n.map(r=>h(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}use(e,...t){return (typeof e=="function"||e instanceof l)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof l?s.router:s)),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new l({onNoMatch:this.onNoMatch,onError:this.onError});return e.router=this.router.clone(),e}async run(e,t){let s=this.router.find(e.method,H(e));if(s.fns.length!==0)return this.prepareRequest(e,s),u.exec(s.fns,e,t)}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,H(t));this.prepareRequest(t,n);try{return await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):u.exec(n.fns,t,s))}catch(r){return this.onError(r,t,s,e)}}}};function E(o={}){return new l(o)}var k=o=>(e,t,s)=>new Promise((n,r)=>{o(e,t,R=>R?r(R):n());}).then(s),C=k;var w=async(o,e)=>{e.statusCode=404,e.end(o.method==="HEAD"?void 0:`Route ${o.method} ${o.url} not found`);},v=async(o,e,t)=>{t.statusCode=500,console.error(o),t.end("Internal Server Error");};function y(o){let e=o.indexOf("?");return e===-1?o:o.slice(0,Math.max(0,e))}var c=class{constructor(e={}){this.router=new u;this.all=this.add.bind(this,"");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.patch=this.add.bind(this,"PATCH");this.delete=this.add.bind(this,"DELETE");this.onNoMatch=e.onNoMatch??w,this.onError=e.onError??v;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[h(s,t)]:n=n.map(r=>h(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}use(e,...t){return (typeof e=="function"||e instanceof c)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof c?s.router:s)),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new c({onNoMatch:this.onNoMatch,onError:this.onError});return e.router=this.router.clone(),e}async run(e,t){let s=this.router.find(e.method,y(e.url));if(s.fns.length!==0)return this.prepareRequest(e,s),u.exec(s.fns,e,t)}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,y(t.url));this.prepareRequest(t,n);try{await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):u.exec(n.fns,t,s));}catch(r){await this.onError(r,t,s,e);}}}},b=(o={})=>new c(o);var L=(o,e,t)=>{o.setHeader("content-type","application/json; charset=utf-8"),o.statusCode=e,o.end(JSON.stringify(t,null,2));},j=L;
5
+ var q=o=>async(e,t,s)=>await new Promise((n,r)=>{o(e,t,R=>R?r(R):n());}).then(s),M=q;var g=(o,e)=>async(t,s,n)=>{let r=t;try{r=await o.parseAsync(t);}catch(R){let{message:a}=R;throw R instanceof ZodError&&typeof R.format=="function"&&(a=R.issues.map(d=>`${d.path.join("/")} - ${d.message}`).join("/n")),S(422,a)}return e(r,s,n)},l=g;var i=class o{constructor(e="/",t=[]){this.base=e;this.routes=t;}static async exec(e,...t){let s=0,n=()=>e[++s](...t,n);return e[s](...t,n)}add(e,t,...s){if(typeof t=="function"&&(s.unshift(t),t=""),t==="")this.routes.push({fns:s,isMiddleware:!1,matchAll:!0,method:e});else {let{keys:n,pattern:r}=parse(t);this.routes.push({fns:s,isMiddleware:!1,keys:n,method:e,pattern:r});}return this}clone(e){return new o(e,[...this.routes])}find(e,t){let s=!0,n=[],r={},R=e==="HEAD";return Object.values(this.routes).forEach(a=>{if(a.method!==e&&a.method!==""&&!(R&&a.method==="GET"))return;let d=!1;if("matchAll"in a)d=!0;else if(a.keys===!1){let u=a.pattern.exec(t);if(u===null)return;u.groups!==void 0&&Object.keys(u.groups).forEach(p=>{r[p]=u.groups[p];}),d=!0;}else if(a.keys.length>0){let u=a.pattern.exec(t);if(u===null)return;for(let p=0;p<a.keys.length;){let c=a.keys[p];r[c]=u[++p];}d=!0;}else a.pattern.test(t)&&(d=!0);d&&(n.push(...a.fns.flatMap(u=>{if(u instanceof o){let{base:p}=u,c=t.slice(p.length);c.startsWith("/")||(c=`/${c}`);let m=u.find(e,c);return m.middleOnly||(s=!1),Object.assign(r,m.params),m.fns}return u})),a.isMiddleware||(s=!1));}),{fns:n,middleOnly:s,params:r}}use(e,...t){(typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),t=t.map(r=>{if(r instanceof o){if(typeof e=="string")return r.clone(e);throw new Error("Mounting a router to RegExp base is not supported")}return r});let{keys:s,pattern:n}=parse(e,!0);return this.routes.push({fns:t,isMiddleware:!0,keys:s,method:"",pattern:n}),this}};var E=async o=>new Response(o.method==="HEAD"?null:`Route ${o.method} ${o.url} not found`,{status:404}),k=async o=>(console.error(o),new Response("Internal Server Error",{status:500})),H=o=>(o.nextUrl??new URL(o.url)).pathname,h=class o{constructor(e={}){this.router=new i;this.all=this.add.bind(this,"");this.delete=this.add.bind(this,"DELETE");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.patch=this.add.bind(this,"PATCH");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.onNoMatch=e.onNoMatch??E,this.onError=e.onError??k;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[l(s,t)]:n=n.map(r=>l(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new o({onError:this.onError,onNoMatch:this.onNoMatch});return e.router=this.router.clone(),e}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,H(t));this.prepareRequest(t,n);try{return await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):i.exec(n.fns,t,s))}catch(r){return await this.onError(r,t,s,e)}}}async run(e,t){let s=this.router.find(e.method,H(e));if(s.fns.length!==0)return this.prepareRequest(e,s),await i.exec(s.fns,e,t)}use(e,...t){return (typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof o?s.router:s)),this}},C=(o={})=>new h(o);var w=async(o,e)=>{e.statusCode=404,e.end(o.method==="HEAD"?void 0:`Route ${o.method} ${o.url} not found`);},v=async(o,e,t)=>{t.statusCode=500,console.error(o),t.end("Internal Server Error");},y=o=>{let e=o.indexOf("?");return e===-1?o:o.slice(0,Math.max(0,e))},x=class o{constructor(e={}){this.router=new i;this.all=this.add.bind(this,"");this.delete=this.add.bind(this,"DELETE");this.get=this.add.bind(this,"GET");this.head=this.add.bind(this,"HEAD");this.patch=this.add.bind(this,"PATCH");this.post=this.add.bind(this,"POST");this.put=this.add.bind(this,"PUT");this.onNoMatch=e.onNoMatch??w,this.onError=e.onError??v;}add(e,t,s,...n){return typeof t=="string"&&typeof s=="function"?n=[s]:typeof s=="object"?typeof t=="function"?n=[l(s,t)]:n=n.map(r=>l(s,r)):typeof s=="function"&&(n=[s]),this.router.add(e,t,...n),this}prepareRequest(e,t){e.params={...t.params,...e.params};}clone(){let e=new o({onError:this.onError,onNoMatch:this.onNoMatch});return e.router=this.router.clone(),e}handler(){let{routes:e}=this.router;return async(t,s)=>{let n=this.router.find(t.method,y(t.url));this.prepareRequest(t,n);try{await(n.fns.length===0||n.middleOnly?this.onNoMatch(t,s,e):i.exec(n.fns,t,s));}catch(r){await this.onError(r,t,s,e);}}}async run(e,t){let s=this.router.find(e.method,y(e.url));if(s.fns.length!==0)return this.prepareRequest(e,s),await i.exec(s.fns,e,t)}use(e,...t){return (typeof e=="function"||e instanceof o)&&(t.unshift(e),e="/"),this.router.use(e,...t.map(s=>s instanceof o?s.router:s)),this}},b=(o={})=>new x(o);var L=(o,e,t)=>{o.setHeader("content-type","application/json; charset=utf-8"),o.statusCode=e,o.end(JSON.stringify(t,null,2));},j=L;
6
6
 
7
- export { l as EdgeRouter, c as NodeRouter, u as Router, E as createEdgeRouter, b as createNodeRouter, b as createRouter, C as expressWrapper, j as sendJson, h as withZod };
7
+ export { h as EdgeRouter, x as NodeRouter, i as Router, C as createEdgeRouter, b as createNodeRouter, b as createRouter, M as expressWrapper, j as sendJson, l as withZod };
8
8
  //# sourceMappingURL=out.js.map
9
9
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/adapter/with-zod.ts","../src/router.ts","../src/edge.ts","../src/adapter/express.ts","../src/node.ts","../src/utils/send-json.ts"],"names":["createHttpError","ZodError","withZod","schema","handler","request","response","next","transformedRequest","error","message","issue","with_zod_default","parse","Router","base","routes","method","route","fns","keys","pattern","function_","arguments_","index","pathname","middleOnly","parameters","isHead","matched","matches","key","parameterKey","stripPathname","result","onNoMatch","onError","getPathname","EdgeRouter","options","routeOrFunction","zodOrRouteOrFunction","findResult","r","context_","createEdgeRouter","expressWrapper","resolve","reject","express_default","_request","url","queryIndex","NodeRouter","createRouter","sendJson","statusCode","jsonBody","send_json_default"],"mappings":"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","sourcesContent":["import createHttpError from \"http-errors\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\nimport { ZodError } from \"zod\";\n\nimport type { Nextable, NextHandler } from \"../types\";\n\n// eslint-disable-next-line max-len\nconst withZod = <Request, Response, Handler extends Nextable<any>, Schema extends ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>>(\n schema: Schema,\n handler: Handler,\n): ((request: Request, response: Response, next: NextHandler) => Promise<Response>) => async (request: Request, response: Response, next) => {\n let transformedRequest: Request = request;\n\n try {\n transformedRequest = (await schema.parseAsync(request)) as Request;\n } catch (error: any) {\n let { message } = error;\n\n // eslint-disable-next-line unicorn/consistent-destructuring\n if (error instanceof ZodError && typeof error.format === \"function\") {\n // eslint-disable-next-line unicorn/consistent-destructuring\n message = error.issues.map((issue) => `${issue.path.join(\"/\")} - ${issue.message}`).join(\"/n\");\n }\n\n throw createHttpError(422, message);\n }\n\n return handler(transformedRequest, response, next);\n };\n\nexport default withZod;\n","/**\n * Agnostic router class\n * Adapted from lukeed/trouter library:\n * https://github.com/lukeed/trouter/blob/master/index.mjs\n */\nimport { parse } from \"regexparam\";\n\nimport type {\n FindResult, FunctionLike, HttpMethod, Nextable, RouteMatch,\n} from \"./types\";\n\nexport type Route<H> = {\n method: HttpMethod | \"\";\n fns: (H | Router<H extends FunctionLike ? H : never>)[];\n isMiddleware: boolean;\n} & (\n | {\n keys: string[] | false;\n pattern: RegExp;\n }\n | { matchAll: true }\n);\n\nexport class Router<H extends FunctionLike> {\n public constructor(public base: string = \"/\", public routes: Route<Nextable<H>>[] = []) {}\n\n public add(method: HttpMethod | \"\", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this {\n if (typeof route === \"function\") {\n fns.unshift(route);\n // eslint-disable-next-line no-param-reassign\n route = \"\";\n }\n\n if (route === \"\") {\n this.routes.push({\n matchAll: true,\n method,\n fns,\n isMiddleware: false,\n });\n } else {\n const { keys, pattern } = parse(route);\n\n this.routes.push({\n keys,\n pattern,\n method,\n fns,\n isMiddleware: false,\n });\n }\n\n return this;\n }\n\n public use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this {\n if (typeof base === \"function\" || base instanceof Router) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n // mount subrouter\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => {\n if (function_ instanceof Router) {\n if (typeof base === \"string\") return function_.clone(base);\n throw new Error(\"Mounting a router to RegExp base is not supported\");\n }\n return function_;\n });\n\n const { keys, pattern } = parse(base, true);\n\n this.routes.push({\n keys,\n pattern,\n method: \"\",\n fns,\n isMiddleware: true,\n });\n\n return this;\n }\n\n public clone(base?: string): Router<H> {\n return new Router<H>(base, [...this.routes]);\n }\n\n public static async exec<H extends FunctionLike>(fns: Nextable<H>[], ...arguments_: Parameters<H>): Promise<unknown> {\n let index = 0;\n\n // eslint-disable-next-line no-plusplus\n const next = () => (fns[++index] as FunctionLike)(...arguments_, next);\n\n return (fns[index] as FunctionLike)(...arguments_, next);\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n public find(method: HttpMethod, pathname: string): FindResult<H> {\n let middleOnly = true;\n\n const fns: Nextable<H>[] = [];\n const parameters: Record<string, string> = {};\n const isHead = method === \"HEAD\";\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.values(this.routes).forEach((route) => {\n if (\n route.method !== method\n // matches any method\n && route.method !== \"\"\n // The HEAD method requests that the target resource transfer a representation of its state, as for a GET request...\n && !(isHead && route.method === \"GET\")\n ) {\n return;\n }\n\n let matched = false;\n\n if (\"matchAll\" in route) {\n matched = true;\n } else if (route.keys === false) {\n // routes.key is RegExp: https://github.com/lukeed/regexparam/blob/master/src/index.js#L2\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n // eslint-disable-next-line no-void\n if (matches.groups !== void 0) {\n Object.keys(matches.groups).forEach((key) => {\n // @ts-expect-error @TODO: fix this\n parameters[key] = matches.groups[key] as string;\n });\n }\n\n matched = true;\n } else if (route.keys.length > 0) {\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n for (let index = 0; index < route.keys.length;) {\n const parameterKey = route.keys[index];\n\n // @ts-expect-error @TODO: fix this\n // eslint-disable-next-line no-plusplus\n parameters[parameterKey] = matches[++index];\n }\n\n matched = true;\n } else if (route.pattern.test(pathname)) {\n matched = true;\n } // else not a match\n\n if (matched) {\n fns.push(\n ...route.fns.flatMap((function_) => {\n if (function_ instanceof Router) {\n const { base } = function_;\n\n let stripPathname = pathname.slice(base.length);\n\n // fix stripped pathname, not sure why this happens\n // eslint-disable-next-line eqeqeq\n if (!stripPathname.startsWith(\"/\")) {\n stripPathname = `/${stripPathname}`;\n }\n\n // eslint-disable-next-line unicorn/no-array-callback-reference, unicorn/no-array-method-this-argument\n const result = function_.find(method, stripPathname);\n\n if (!result.middleOnly) {\n middleOnly = false;\n }\n\n // merge params\n Object.assign(parameters, result.params);\n\n return result.fns;\n }\n\n return function_;\n }),\n );\n if (!route.isMiddleware) middleOnly = false;\n }\n });\n\n return { fns, params: parameters, middleOnly };\n }\n}\n","import type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RoutesExtendedRequestHandler,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"./types\";\n\n// eslint-disable-next-line max-len\nconst onNoMatch = async (request: Request) => new Response(request.method === \"HEAD\" ? null : `Route ${request.method} ${request.url} not found`, { status: 404 });\n\nconst onError = async (error: unknown) => {\n // eslint-disable-next-line no-console\n console.error(error);\n return new Response(\"Internal Server Error\", { status: 500 });\n};\n\nexport function getPathname(request: Request & { nextUrl?: URL }): string {\n // eslint-disable-next-line compat/compat\n return (request.nextUrl ?? new URL(request.url)).pathname;\n}\n\n// eslint-disable-next-line max-len,@typescript-eslint/no-invalid-void-type\nexport type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;\n\nexport class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {\n private router = new Router<RequestHandler<R, Context>>();\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>;\n\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>;\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? (onNoMatch as unknown as RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>);\n this.onError = options.onError\n ?? (onError as unknown as (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<R, Context>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<R, Context>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<R, Context>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign,max-len\n fns = fns.map((function_) => withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"HEAD\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PUT\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PATCH\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"DELETE\");\n\n public use(\n base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch,\n ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof EdgeRouter) {\n fns.unshift(base as EdgeRouter<R, Context>);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n\n this.router.use(base, ...fns.map((function_) => (function_ instanceof EdgeRouter ? function_.router : function_)));\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: R & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<R, Context>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): EdgeRouter<R, Context, RResponse, Schema> {\n const r = new EdgeRouter<R, Context, RResponse, Schema>({ onNoMatch: this.onNoMatch, onError: this.onError });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public async run(request: R, context_: Context): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return Router.exec(result.fns, request, context_);\n }\n\n public handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: R, context_: Context): Promise<any> => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n this.prepareRequest(request, result);\n\n try {\n return await (result.fns.length === 0 || result.middleOnly\n ? this.onNoMatch(request, context_, routes)\n : Router.exec(result.fns, request, context_));\n } catch (error) {\n return this.onError(error, request, context_, routes);\n }\n };\n }\n}\n\nexport function createEdgeRouter<R extends Request, Context>(\n options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): EdgeRouter<R, Context> {\n return new EdgeRouter<R, Context, Response>(options);\n}\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { RequestHandler } from \"../node\";\nimport type { Nextable } from \"../types\";\n\ntype NextFunction = (error?: any) => void;\n\nconst expressWrapper = <Request extends IncomingMessage, Response extends ServerResponse>(\n function_: ExpressRequestHandler<Request, Response>,\n // eslint-disable-next-line compat/compat\n): Nextable<RequestHandler<Request, Response>> => (request, response, next) => new Promise<void>((resolve, reject) => {\n function_(request, response, (error) => (error ? reject(error) : resolve()));\n // eslint-disable-next-line promise/no-callback-in-promise\n }).then(next);\n\nexport type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;\n\nexport default expressWrapper;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RoutesExtendedRequestHandler,\n RouteShortcutMethod,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 404;\n response.end(request.method === \"HEAD\" ? undefined : `Route ${request.method} ${request.url} not found`);\n};\n\nconst onError = async (error: unknown, _request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 500;\n // eslint-disable-next-line no-console\n console.error(error);\n\n response.end(\"Internal Server Error\");\n};\n\nexport function getPathname(url: string): string {\n const queryIndex = url.indexOf(\"?\");\n\n return queryIndex === -1 ? url : url.slice(0, Math.max(0, queryIndex));\n}\n\nexport type RequestHandler<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;\n\nexport class NodeRouter<\n Request extends IncomingMessage = IncomingMessage,\n Response extends ServerResponse = ServerResponse,\n Schema extends AnyZodObject = ZodObject<any>,\n> {\n private router = new Router<RequestHandler<Request, Response>>();\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>;\n\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>;\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? onNoMatch;\n this.onError = options.onError ?? onError;\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<Request, Response>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<Request, Response>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<Request, Response>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign,max-len\n fns = fns.map((function_) => withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"HEAD\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PUT\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PATCH\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"DELETE\");\n\n public use(\n base: Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch,\n ...fns: (Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof NodeRouter) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n this.router.use(base, ...fns.map((function_) => (function_ instanceof NodeRouter ? function_.router : function_)));\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: Request & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<Request, Response>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): NodeRouter<Request, Response, Schema> {\n const r = new NodeRouter<Request, Response, Schema>({ onNoMatch: this.onNoMatch, onError: this.onError });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public async run(request: Request, response: Response): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return Router.exec(result.fns, request, response);\n }\n\n public handler(): (request: Request, response: Response) => Promise<void> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: Request, response: Response) => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n this.prepareRequest(request, result);\n\n try {\n await (result.fns.length === 0 || result.middleOnly ? this.onNoMatch(request, response, routes) : Router.exec(result.fns, request, response));\n } catch (error) {\n await this.onError(error, request, response, routes);\n }\n };\n }\n}\n\nexport const createRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {},\n ): NodeRouter<Request, Response, Schema> => new NodeRouter<Request, Response, Schema>(options);\n","import type { ServerResponse } from \"node:http\";\n\n/**\n * Send `JSON` object\n * @param {ServerResponse} response response object\n * @param {number} statusCode\n * @param {any} jsonBody of data\n */\nconst sendJson = (response: ServerResponse, statusCode: number, jsonBody: unknown): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.statusCode = statusCode;\n response.end(JSON.stringify(jsonBody, null, 2));\n};\n\nexport default sendJson;\n"]}
1
+ {"version":3,"sources":["../src/adapter/express.ts","../src/adapter/with-zod.ts","../src/router.ts","../src/edge.ts","../src/node.ts","../src/utils/send-json.ts"],"names":["expressWrapper","function_","request","response","next","resolve","reject","error","express_default","createHttpError","ZodError","withZod","schema","handler","transformedRequest","message","issue","with_zod_default","parse","Router","_Router","base","routes","fns","arguments_","index","method","route","keys","pattern","pathname","middleOnly","parameters","isHead","matched","matches","key","parameterKey","stripPathname","result","onNoMatch","onError","getPathname","EdgeRouter","_EdgeRouter","options","routeOrFunction","zodOrRouteOrFunction","findResult","r","context_","createEdgeRouter","_request","url","queryIndex","NodeRouter","_NodeRouter","createRouter","sendJson","statusCode","jsonBody","send_json_default"],"mappings":"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","sourcesContent":["import type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { RequestHandler } from \"../node\";\nimport type { Nextable } from \"../types\";\n\ntype NextFunction = (error?: any) => void;\n\nconst expressWrapper =\n <Request extends IncomingMessage, Response extends ServerResponse>(\n // eslint-disable-next-line no-use-before-define\n function_: ExpressRequestHandler<Request, Response>,\n ): Nextable<RequestHandler<Request, Response>> =>\n async (request, response, next) =>\n // eslint-disable-next-line compat/compat\n await new Promise<void>((resolve, reject): void => {\n function_(request, response, (error) => (error ? reject(error) : resolve()));\n // eslint-disable-next-line promise/no-callback-in-promise\n }).then<Nextable<RequestHandler<Request, Response>>>(next);\n\nexport type ExpressRequestHandler<Request, Response> = (request: Request, response: Response, next: NextFunction) => void;\n\nexport default expressWrapper;\n","import createHttpError from \"http-errors\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\nimport { ZodError } from \"zod\";\n\nimport type { NextHandler, Nextable } from \"../types\";\n\nconst withZod =\n <Request, Response, Handler extends Nextable<any>, Schema extends ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>>(\n schema: Schema,\n handler: Handler,\n ): ((request: Request, response: Response, next: NextHandler) => Promise<Response>) =>\n async (request: Request, response: Response, next) => {\n let transformedRequest: Request = request;\n\n try {\n transformedRequest = (await schema.parseAsync(request)) as Request;\n } catch (error: any) {\n let { message } = error as Error;\n\n if (error instanceof ZodError && typeof error.format === \"function\") {\n message = error.issues.map((issue) => `${issue.path.join(\"/\")} - ${issue.message}`).join(\"/n\");\n }\n\n throw createHttpError(422, message);\n }\n\n return handler(transformedRequest, response, next);\n };\n\nexport default withZod;\n","/**\n * Agnostic router class\n * Adapted from lukeed/trouter library:\n * https://github.com/lukeed/trouter/blob/master/index.mjs\n */\nimport { parse } from \"regexparam\";\n\nimport type { FindResult, FunctionLike, HttpMethod, Nextable, RouteMatch } from \"./types\";\n\nexport type Route<H> = {\n // eslint-disable-next-line no-use-before-define\n fns: (H | Router<H extends FunctionLike ? H : never>)[];\n isMiddleware: boolean;\n method: HttpMethod | \"\";\n} & (\n | {\n keys: string[] | false;\n pattern: RegExp;\n }\n | { matchAll: true }\n);\n\nexport class Router<H extends FunctionLike> {\n public constructor(\n public base: string = \"/\",\n public routes: Route<Nextable<H>>[] = [],\n ) {}\n\n public static async exec<FL extends FunctionLike>(fns: Nextable<FL>[], ...arguments_: Parameters<FL>): Promise<any> {\n let index = 0;\n\n // eslint-disable-next-line no-plusplus\n const next = () => (fns[++index] as FunctionLike)(...arguments_, next);\n\n return (fns[index] as FunctionLike)(...arguments_, next);\n }\n\n public add(method: HttpMethod | \"\", route: Nextable<H> | RouteMatch, ...fns: Nextable<H>[]): this {\n if (typeof route === \"function\") {\n fns.unshift(route);\n // eslint-disable-next-line no-param-reassign\n route = \"\";\n }\n\n if (route === \"\") {\n this.routes.push({\n fns,\n isMiddleware: false,\n matchAll: true,\n method,\n });\n } else {\n const { keys, pattern } = parse(route);\n\n this.routes.push({\n fns,\n isMiddleware: false,\n keys,\n method,\n pattern,\n });\n }\n\n return this;\n }\n\n public clone(base?: string): Router<H> {\n return new Router<H>(base, [...this.routes]);\n }\n\n public find(method: HttpMethod, pathname: string): FindResult<H> {\n let middleOnly = true;\n\n const fns: Nextable<H>[] = [];\n const parameters: Record<string, string> = {};\n const isHead = method === \"HEAD\";\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.values(this.routes).forEach((route) => {\n if (\n route.method !== method &&\n // matches any method\n route.method !== \"\" &&\n // The HEAD method requests that the target resource transfer a representation of its state, as for a GET request...\n !(isHead && route.method === \"GET\")\n ) {\n return;\n }\n\n let matched = false;\n\n if (\"matchAll\" in route) {\n matched = true;\n } else if (route.keys === false) {\n // routes.key is RegExp: https://github.com/lukeed/regexparam/blob/master/src/index.js#L2\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n // eslint-disable-next-line no-void\n if (matches.groups !== void 0) {\n Object.keys(matches.groups).forEach((key) => {\n // @ts-expect-error @TODO: fix this\n parameters[key] = matches.groups[key] as string;\n });\n }\n\n matched = true;\n } else if (route.keys.length > 0) {\n const matches = route.pattern.exec(pathname);\n\n if (matches === null) {\n return;\n }\n\n for (let index = 0; index < route.keys.length; ) {\n const parameterKey = route.keys[index];\n\n // @ts-expect-error @TODO: fix this\n // eslint-disable-next-line no-plusplus\n parameters[parameterKey] = matches[++index];\n }\n\n matched = true;\n } else if (route.pattern.test(pathname)) {\n matched = true;\n } // else not a match\n\n if (matched) {\n fns.push(\n ...route.fns.flatMap((function_) => {\n if (function_ instanceof Router) {\n const { base } = function_;\n\n let stripPathname = pathname.slice(base.length);\n\n // fix stripped pathname, not sure why this happens\n\n if (!stripPathname.startsWith(\"/\")) {\n stripPathname = `/${stripPathname}`;\n }\n\n // eslint-disable-next-line unicorn/no-array-callback-reference, unicorn/no-array-method-this-argument\n const result = function_.find(method, stripPathname);\n\n if (!result.middleOnly) {\n middleOnly = false;\n }\n\n // merge params\n Object.assign(parameters, result.params);\n\n return result.fns;\n }\n\n return function_;\n }),\n );\n if (!route.isMiddleware) {\n middleOnly = false;\n }\n }\n });\n\n return { fns, middleOnly, params: parameters };\n }\n\n public use(base: Nextable<H> | RouteMatch | Router<H>, ...fns: (Nextable<H> | Router<H>)[]): this {\n if (typeof base === \"function\" || base instanceof Router) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n // mount subrouter\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => {\n if (function_ instanceof Router) {\n if (typeof base === \"string\") {\n return function_.clone(base);\n }\n\n throw new Error(\"Mounting a router to RegExp base is not supported\");\n }\n return function_;\n });\n\n const { keys, pattern } = parse(base, true);\n\n this.routes.push({\n fns,\n isMiddleware: true,\n keys,\n method: \"\",\n pattern,\n });\n\n return this;\n }\n}\n","import type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RouteShortcutMethod,\n RoutesExtendedRequestHandler,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: Request) =>\n new Response(request.method === \"HEAD\" ? null : `Route ${request.method} ${request.url} not found`, { status: 404 });\n\nconst onError = async (error: unknown) => {\n console.error(error);\n return new Response(\"Internal Server Error\", { status: 500 });\n};\n\nexport const getPathname = (request: Request & { nextUrl?: URL }): string =>\n // eslint-disable-next-line compat/compat\n (request.nextUrl ?? new URL(request.url)).pathname;\n\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type\nexport type RequestHandler<R extends Request, Context> = (request: R, context_: Context) => ValueOrPromise<Response | void>;\n\nexport class EdgeRouter<R extends Request = Request, Context = unknown, RResponse extends Response = Response, Schema extends AnyZodObject = ZodObject<any>> {\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>;\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>;\n\n private router = new Router<RequestHandler<R, Context>>();\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"DELETE\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"HEAD\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PATCH\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<R, Context>> = this.add.bind(this, \"PUT\");\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? (onNoMatch as unknown as RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>);\n this.onError =\n options.onError ??\n (onError as unknown as (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<R, Context, RResponse, Route<Nextable<FunctionLike>>[]>>);\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<R, Context>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<R, Context>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<R, Context>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n // eslint-disable-next-line unicorn/prefer-ternary\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) => withZod<R, Context, Nextable<RequestHandler<R, Context>>, Schema>(zodOrRouteOrFunction as Schema, function_));\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: R & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<R, Context>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): EdgeRouter<R, Context, RResponse, Schema> {\n const r = new EdgeRouter<R, Context, RResponse, Schema>({ onError: this.onError, onNoMatch: this.onNoMatch });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n public handler(): (request: R, context_: Context) => Promise<any> | ReturnType<FunctionLike> | ValueOrPromise<RResponse> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: R, context_: Context): Promise<any> => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n this.prepareRequest(request, result);\n\n try {\n return await (result.fns.length === 0 || result.middleOnly\n ? this.onNoMatch(request, context_, routes)\n : Router.exec(result.fns, request, context_));\n } catch (error) {\n return await this.onError(error, request, context_, routes);\n }\n };\n }\n\n public async run(request: R, context_: Context): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return await Router.exec(result.fns, request, context_);\n }\n\n public use(\n base: EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>> | RouteMatch,\n ...fns: (EdgeRouter<R, Context> | Nextable<RequestHandler<R, Context>>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof EdgeRouter) {\n fns.unshift(base as EdgeRouter<R, Context>);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n\n this.router.use(base, ...fns.map((function_) => (function_ instanceof EdgeRouter ? function_.router : function_)));\n\n return this;\n }\n}\n\nexport const createEdgeRouter = <R extends Request, Context>(\n options: HandlerOptions<RoutesExtendedRequestHandler<R, Context, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): EdgeRouter<R, Context> => new EdgeRouter<R, Context, Response>(options);\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport type { AnyZodObject, ZodObject } from \"zod\";\n\nimport withZod from \"./adapter/with-zod\";\nimport type { Route } from \"./router\";\nimport { Router } from \"./router\";\nimport type {\n FindResult,\n FunctionLike,\n HandlerOptions,\n HttpMethod,\n Nextable,\n RouteMatch,\n RouteShortcutMethod,\n RoutesExtendedRequestHandler,\n ValueOrPromise,\n} from \"./types\";\n\nconst onNoMatch = async (request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 404;\n response.end(request.method === \"HEAD\" ? undefined : `Route ${request.method} ${request.url} not found`);\n};\n\nconst onError = async (error: unknown, _request: IncomingMessage, response: ServerResponse) => {\n response.statusCode = 500;\n\n console.error(error);\n\n response.end(\"Internal Server Error\");\n};\n\nexport const getPathname = (url: string): string => {\n const queryIndex = url.indexOf(\"?\");\n\n return queryIndex === -1 ? url : url.slice(0, Math.max(0, queryIndex));\n};\n\nexport type RequestHandler<Request extends IncomingMessage, Response extends ServerResponse> = (request: Request, response: Response) => ValueOrPromise<void>;\n\nexport class NodeRouter<\n Request extends IncomingMessage = IncomingMessage,\n Response extends ServerResponse = ServerResponse,\n Schema extends AnyZodObject = ZodObject<never>,\n> {\n private readonly onError: (\n error: unknown,\n ...arguments_: Parameters<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>\n ) => ReturnType<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>>;\n\n private readonly onNoMatch: RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>;\n\n private router = new Router<RequestHandler<Request, Response>>();\n\n public all: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"\");\n\n public delete: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"DELETE\");\n\n public get: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"GET\");\n\n public head: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"HEAD\");\n\n public patch: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PATCH\");\n\n public post: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"POST\");\n\n public put: RouteShortcutMethod<this, Schema, RequestHandler<Request, Response>> = this.add.bind(this, \"PUT\");\n\n public constructor(options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {}) {\n this.onNoMatch = options.onNoMatch ?? onNoMatch;\n this.onError = options.onError ?? onError;\n }\n\n private add(\n method: HttpMethod | \"\",\n routeOrFunction: Nextable<RequestHandler<Request, Response>> | RouteMatch,\n zodOrRouteOrFunction?: Nextable<RequestHandler<Request, Response>> | RouteMatch | Schema,\n ...fns: Nextable<RequestHandler<Request, Response>>[]\n ) {\n if (typeof routeOrFunction === \"string\" && typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n } else if (typeof zodOrRouteOrFunction === \"object\") {\n if (typeof routeOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, routeOrFunction)];\n } else {\n // eslint-disable-next-line no-param-reassign\n fns = fns.map((function_) =>\n withZod<Request, Response, Nextable<RequestHandler<Request, Response>>, Schema>(zodOrRouteOrFunction as Schema, function_),\n );\n }\n } else if (typeof zodOrRouteOrFunction === \"function\") {\n // eslint-disable-next-line no-param-reassign\n fns = [zodOrRouteOrFunction];\n }\n\n this.router.add(method, routeOrFunction, ...fns);\n\n return this;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private prepareRequest(request: Request & { params?: Record<string, unknown> }, findResult: FindResult<RequestHandler<Request, Response>>) {\n request.params = {\n ...findResult.params,\n ...request.params, // original params will take precedence\n };\n }\n\n public clone(): NodeRouter<Request, Response, Schema> {\n const r = new NodeRouter<Request, Response, Schema>({ onError: this.onError, onNoMatch: this.onNoMatch });\n\n r.router = this.router.clone();\n\n return r;\n }\n\n public handler(): (request: Request, response: Response) => Promise<void> {\n const { routes } = this.router as Router<FunctionLike>;\n\n return async (request: Request, response: Response) => {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n this.prepareRequest(request, result);\n\n try {\n await (result.fns.length === 0 || result.middleOnly ? this.onNoMatch(request, response, routes) : Router.exec(result.fns, request, response));\n } catch (error) {\n await this.onError(error, request, response, routes);\n }\n };\n }\n\n public async run(request: Request, response: Response): Promise<unknown> {\n // eslint-disable-next-line unicorn/no-array-callback-reference,unicorn/no-array-method-this-argument\n const result = this.router.find(request.method as HttpMethod, getPathname(request.url as string));\n\n if (result.fns.length === 0) {\n return;\n }\n\n this.prepareRequest(request, result);\n\n // eslint-disable-next-line consistent-return\n return await Router.exec(result.fns, request, response);\n }\n\n public use(\n base: Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema> | RouteMatch,\n ...fns: (Nextable<RequestHandler<Request, Response>> | NodeRouter<Request, Response, Schema>)[]\n ): this {\n if (typeof base === \"function\" || base instanceof NodeRouter) {\n fns.unshift(base);\n // eslint-disable-next-line no-param-reassign\n base = \"/\";\n }\n this.router.use(base, ...fns.map((function_) => (function_ instanceof NodeRouter ? function_.router : function_)));\n\n return this;\n }\n}\n\nexport const createRouter = <\n Request extends IncomingMessage,\n Response extends ServerResponse,\n Schema extends AnyZodObject = ZodObject<{ body?: AnyZodObject; headers?: AnyZodObject; query?: AnyZodObject }>,\n>(\n options: HandlerOptions<RoutesExtendedRequestHandler<Request, Response, Response, Route<Nextable<FunctionLike>>[]>> = {},\n): NodeRouter<Request, Response, Schema> => new NodeRouter<Request, Response, Schema>(options);\n","import type { ServerResponse } from \"node:http\";\n\n/**\n * Send `JSON` object\n * @param {ServerResponse} response response object\n * @param {number} statusCode\n * @param {any} jsonBody of data\n */\nconst sendJson = (response: ServerResponse, statusCode: number, jsonBody: unknown): void => {\n // Set header to application/json\n response.setHeader(\"content-type\", \"application/json; charset=utf-8\");\n\n response.statusCode = statusCode;\n response.end(JSON.stringify(jsonBody, null, 2));\n};\n\nexport default sendJson;\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/connect",
3
- "version": "1.3.6",
3
+ "version": "1.3.7",
4
4
  "description": "The minimal router and middleware layer for Next.js, Micro, Vercel, or Node.js http/http2 with support for zod validation.",
5
5
  "keywords": [
6
6
  "javascript",
@@ -63,8 +63,11 @@
63
63
  "clean": "rimraf node_modules dist .eslintcache",
64
64
  "coverage": "vitest run --coverage",
65
65
  "dev": "pnpm run build --watch",
66
- "lint:eslint": "cross-env NO_LOGS=true eslint . --ext js,jsx,ts,tsx --max-warnings=0 --config .eslintrc.cjs --cache --cache-strategy content .",
66
+ "lint:eslint": "eslint . --ext js,cjs,mjs,ts,tsx,json,yaml,yml,md,mdx --max-warnings=0 --config .eslintrc.js",
67
67
  "lint:eslint:fix": "pnpm run lint:eslint --fix",
68
+ "lint:prettier": "prettier --config=.prettierrc.js --check .",
69
+ "lint:prettier:fix": "prettier --config=.prettierrc.js --write .",
70
+ "lint:types": "tsc --noEmit",
68
71
  "test": "vitest run",
69
72
  "test:watch": "vitest"
70
73
  },
@@ -73,45 +76,30 @@
73
76
  "regexparam": "^2.0.1"
74
77
  },
75
78
  "devDependencies": {
76
- "@anolilab/eslint-config": "^5.0.5",
77
- "@anolilab/semantic-release-preset": "^2.2.1",
79
+ "@anolilab/eslint-config": "^10.0.6",
80
+ "@anolilab/prettier-config": "^5.0.1",
81
+ "@anolilab/semantic-release-preset": "^6.0.2",
78
82
  "@rushstack/eslint-plugin-security": "^0.6.0",
79
83
  "@types/http-errors": "^2.0.1",
80
- "@types/node": "18.16.16",
81
- "@typescript-eslint/eslint-plugin": "^5.59.8",
82
- "@typescript-eslint/parser": "^5.59.8",
83
- "@vitest/coverage-c8": "^0.31.1",
84
- "c8": "^7.14.0",
84
+ "@types/node": "18.16.18",
85
+ "@vitest/coverage-v8": "^0.33.0",
86
+ "c8": "^8.0.1",
85
87
  "cross-env": "^7.0.3",
86
- "eslint": "^8.41.0",
87
- "eslint-plugin-compat": "^4.1.4",
88
- "eslint-plugin-eslint-comments": "^3.2.0",
89
- "eslint-plugin-import": "^2.27.5",
90
- "eslint-plugin-json": "^3.1.0",
91
- "eslint-plugin-jsonc": "^2.8.0",
92
- "eslint-plugin-jsx-a11y": "^6.7.1",
93
- "eslint-plugin-markdown": "^3.0.0",
94
- "eslint-plugin-material-ui": "^1.0.1",
95
- "eslint-plugin-no-loops": "^0.3.0",
96
- "eslint-plugin-no-secrets": "^0.8.9",
97
- "eslint-plugin-node": "^11.1.0",
98
- "eslint-plugin-optimize-regex": "^1.2.1",
99
- "eslint-plugin-promise": "^6.1.1",
100
- "eslint-plugin-simple-import-sort": "^10.0.0",
101
- "eslint-plugin-sort-keys-fix": "^1.1.2",
102
- "eslint-plugin-testing-library": "^5.11.0",
103
- "eslint-plugin-unicorn": "^47.0.0",
104
- "eslint-plugin-you-dont-need-lodash-underscore": "^6.12.0",
105
- "eslint-plugin-you-dont-need-momentjs": "^1.6.0",
88
+ "eslint": "^8.45.0",
89
+ "eslint-plugin-etc": "^2.0.3",
90
+ "eslint-plugin-mdx": "^2.1.0",
91
+ "eslint-plugin-vitest": "^0.2.6",
92
+ "eslint-plugin-zod": "^1.4.0",
106
93
  "express": "^4.18.2",
107
- "fastify": "^4.17.0",
94
+ "fastify": "^4.20.0",
108
95
  "isomorphic-fetch": "^3.0.0",
109
- "prettier": "^2.8.8",
96
+ "prettier": "^3.0.0",
110
97
  "rimraf": "^5.0.1",
111
- "semantic-release": "^21.0.2",
112
- "tsup": "^6.7.0",
113
- "typescript": "^5.0.4",
114
- "vitest": "^0.31.1",
98
+ "semantic-release": "^21.0.7",
99
+ "sort-package-json": "^2.5.1",
100
+ "tsup": "^7.1.0",
101
+ "typescript": "^5.1.6",
102
+ "vitest": "^0.33.0",
115
103
  "zod": "^3.21.4"
116
104
  },
117
105
  "peerDependencies": {
@@ -123,5 +111,16 @@
123
111
  "publishConfig": {
124
112
  "access": "public",
125
113
  "provenance": true
114
+ },
115
+ "anolilab": {
116
+ "eslint-config": {
117
+ "plugin": {
118
+ "tsdoc": false
119
+ },
120
+ "warn_on_unsupported_typescript_version": false,
121
+ "info_on_disabling_jsx_react_rule": false,
122
+ "info_on_disabling_prettier_conflict_rule": false,
123
+ "info_on_disabling_jsonc_sort_keys_rule": false
124
+ }
126
125
  }
127
126
  }