@mokup/server 1.1.2 → 1.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/dist/connect.cjs +5 -5
  2. package/dist/connect.d.cts +13 -2
  3. package/dist/connect.d.mts +13 -2
  4. package/dist/connect.d.ts +13 -2
  5. package/dist/connect.mjs +1 -1
  6. package/dist/express.cjs +1 -1
  7. package/dist/express.d.cts +13 -2
  8. package/dist/express.d.mts +13 -2
  9. package/dist/express.d.ts +13 -2
  10. package/dist/express.mjs +1 -1
  11. package/dist/fastify.cjs +5 -5
  12. package/dist/fastify.d.cts +13 -2
  13. package/dist/fastify.d.mts +13 -2
  14. package/dist/fastify.d.ts +13 -2
  15. package/dist/fastify.mjs +1 -1
  16. package/dist/fetch-server.cjs +599 -447
  17. package/dist/fetch-server.d.cts +81 -27
  18. package/dist/fetch-server.d.mts +81 -27
  19. package/dist/fetch-server.d.ts +81 -27
  20. package/dist/fetch-server.mjs +601 -449
  21. package/dist/fetch.cjs +5 -5
  22. package/dist/fetch.d.cts +12 -1
  23. package/dist/fetch.d.mts +12 -1
  24. package/dist/fetch.d.ts +12 -1
  25. package/dist/fetch.mjs +1 -1
  26. package/dist/hono.cjs +1 -1
  27. package/dist/hono.d.cts +12 -1
  28. package/dist/hono.d.mts +12 -1
  29. package/dist/hono.d.ts +12 -1
  30. package/dist/hono.mjs +1 -1
  31. package/dist/index.cjs +34 -2
  32. package/dist/index.d.cts +40 -1
  33. package/dist/index.d.mts +40 -1
  34. package/dist/index.d.ts +40 -1
  35. package/dist/index.mjs +36 -1
  36. package/dist/koa.cjs +5 -5
  37. package/dist/koa.d.cts +13 -2
  38. package/dist/koa.d.mts +13 -2
  39. package/dist/koa.d.ts +13 -2
  40. package/dist/koa.mjs +1 -1
  41. package/dist/node.cjs +3 -3
  42. package/dist/node.d.cts +3 -2
  43. package/dist/node.d.mts +3 -2
  44. package/dist/node.d.ts +3 -2
  45. package/dist/node.mjs +3 -3
  46. package/dist/shared/server.CyVIKPsp.d.cts +214 -0
  47. package/dist/shared/server.CyVIKPsp.d.mts +214 -0
  48. package/dist/shared/server.CyVIKPsp.d.ts +214 -0
  49. package/dist/shared/server.D0gAciOr.d.cts +46 -0
  50. package/dist/shared/server.D0gAciOr.d.mts +46 -0
  51. package/dist/shared/server.D0gAciOr.d.ts +46 -0
  52. package/dist/shared/server.DkerfsA-.d.cts +73 -0
  53. package/dist/shared/server.DkerfsA-.d.mts +73 -0
  54. package/dist/shared/server.DkerfsA-.d.ts +73 -0
  55. package/dist/shared/{server.tZ4R8aB2.mjs → server.LbftO9Jh.mjs} +57 -54
  56. package/dist/shared/{server.3GcmR3Ev.cjs → server.aaygIV2Q.cjs} +57 -54
  57. package/dist/worker-node.cjs +1 -1
  58. package/dist/worker-node.d.cts +29 -1
  59. package/dist/worker-node.d.mts +29 -1
  60. package/dist/worker-node.d.ts +29 -1
  61. package/dist/worker-node.mjs +1 -1
  62. package/dist/worker.cjs +1 -1
  63. package/dist/worker.d.cts +23 -1
  64. package/dist/worker.d.mts +23 -1
  65. package/dist/worker.d.ts +23 -1
  66. package/dist/worker.mjs +1 -1
  67. package/package.json +4 -4
  68. package/dist/shared/server.B82hrXoo.d.cts +0 -15
  69. package/dist/shared/server.B82hrXoo.d.mts +0 -15
  70. package/dist/shared/server.B82hrXoo.d.ts +0 -15
  71. package/dist/shared/server.Cb2eiCU2.d.cts +0 -17
  72. package/dist/shared/server.Cb2eiCU2.d.mts +0 -17
  73. package/dist/shared/server.Cb2eiCU2.d.ts +0 -17
@@ -0,0 +1,214 @@
1
+ import { RouteToken } from '@mokup/runtime';
2
+ import { MiddlewareHandler, Context } from '@mokup/shared/hono';
3
+
4
+ /**
5
+ * Supported HTTP methods for server dev routes.
6
+ *
7
+ * @example
8
+ * import type { HttpMethod } from '@mokup/server'
9
+ *
10
+ * const method: HttpMethod = 'GET'
11
+ */
12
+ type HttpMethod = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | 'OPTIONS' | 'HEAD';
13
+ /**
14
+ * Static response payloads supported by route rules.
15
+ *
16
+ * @example
17
+ * import type { RouteStaticResponse } from '@mokup/server'
18
+ *
19
+ * const value: RouteStaticResponse = { ok: true }
20
+ */
21
+ type RouteStaticResponse = string | number | boolean | bigint | symbol | null | undefined | object;
22
+ /**
23
+ * Allowed return value from a route handler.
24
+ *
25
+ * @example
26
+ * import type { RouteHandlerResult } from '@mokup/server'
27
+ *
28
+ * const result: RouteHandlerResult = 'ok'
29
+ */
30
+ type RouteHandlerResult = RouteStaticResponse | Response;
31
+ /**
32
+ * Request handler signature for server dev routes.
33
+ *
34
+ * @example
35
+ * import type { RequestHandler } from '@mokup/server'
36
+ *
37
+ * const handler: RequestHandler = (c) => c.json({ ok: true })
38
+ */
39
+ type RequestHandler = (context: Context) => RouteHandlerResult | Promise<RouteHandlerResult>;
40
+ /**
41
+ * Route response as a static value or handler.
42
+ *
43
+ * @example
44
+ * import type { RouteResponse } from '@mokup/server'
45
+ *
46
+ * const response: RouteResponse = { ok: true }
47
+ */
48
+ type RouteResponse = RouteStaticResponse | RequestHandler;
49
+ /**
50
+ * Rule metadata for a route handler.
51
+ *
52
+ * @example
53
+ * import type { RouteRule } from '@mokup/server'
54
+ *
55
+ * const rule: RouteRule = {
56
+ * handler: () => ({ ok: true }),
57
+ * }
58
+ */
59
+ interface RouteRule {
60
+ /** Handler for the route. */
61
+ handler: RouteResponse;
62
+ /**
63
+ * Enable or disable this rule.
64
+ *
65
+ * @default true
66
+ */
67
+ enabled?: boolean;
68
+ /**
69
+ * Override response status code.
70
+ *
71
+ * @default 200
72
+ */
73
+ status?: number;
74
+ /**
75
+ * Additional response headers.
76
+ *
77
+ * @default {}
78
+ */
79
+ headers?: Record<string, string>;
80
+ /**
81
+ * Delay in milliseconds before responding.
82
+ *
83
+ * @default 0
84
+ */
85
+ delay?: number;
86
+ }
87
+ /**
88
+ * Directory-level config for server dev scanning.
89
+ *
90
+ * @example
91
+ * import type { RouteDirectoryConfig } from '@mokup/server'
92
+ *
93
+ * const config: RouteDirectoryConfig = { headers: { 'x-mokup': 'dir' } }
94
+ */
95
+ interface RouteDirectoryConfig {
96
+ /**
97
+ * Headers applied to routes in this directory.
98
+ *
99
+ * @default {}
100
+ */
101
+ headers?: Record<string, string>;
102
+ /**
103
+ * Default status code override.
104
+ *
105
+ * @default 200
106
+ */
107
+ status?: number;
108
+ /**
109
+ * Default delay in milliseconds.
110
+ *
111
+ * @default 0
112
+ */
113
+ delay?: number;
114
+ /**
115
+ * Enable or disable this directory.
116
+ *
117
+ * @default true
118
+ */
119
+ enabled?: boolean;
120
+ /**
121
+ * Ignore prefixes for files.
122
+ *
123
+ * @default ["."]
124
+ */
125
+ ignorePrefix?: string | string[];
126
+ /**
127
+ * Include filter.
128
+ *
129
+ * @default undefined
130
+ */
131
+ include?: RegExp | RegExp[];
132
+ /**
133
+ * Exclude filter.
134
+ *
135
+ * @default undefined
136
+ */
137
+ exclude?: RegExp | RegExp[];
138
+ /**
139
+ * Middleware for this directory.
140
+ *
141
+ * @default undefined
142
+ */
143
+ middleware?: MiddlewareHandler | MiddlewareHandler[];
144
+ }
145
+ /**
146
+ * Middleware execution position.
147
+ *
148
+ * @example
149
+ * import type { MiddlewarePosition } from '@mokup/server'
150
+ *
151
+ * const position: MiddlewarePosition = 'pre'
152
+ */
153
+ type MiddlewarePosition = 'pre' | 'normal' | 'post';
154
+ /**
155
+ * Middleware registry used by defineConfig.
156
+ *
157
+ * @example
158
+ * import type { MiddlewareRegistry } from '@mokup/server'
159
+ *
160
+ * const registry: MiddlewareRegistry = { use: () => {} }
161
+ */
162
+ interface MiddlewareRegistry {
163
+ use: (...handlers: MiddlewareHandler[]) => void;
164
+ }
165
+ /**
166
+ * Normalized middleware metadata.
167
+ *
168
+ * @example
169
+ * import type { ResolvedMiddleware } from '@mokup/server'
170
+ *
171
+ * const item: ResolvedMiddleware = { handle: () => {}, source: 'index.config.ts', index: 0 }
172
+ */
173
+ interface ResolvedMiddleware {
174
+ handle: MiddlewareHandler;
175
+ source: string;
176
+ index: number;
177
+ /**
178
+ * Position in the middleware chain.
179
+ *
180
+ * @default "normal"
181
+ */
182
+ position: MiddlewarePosition;
183
+ }
184
+ /**
185
+ * Fully resolved route metadata.
186
+ *
187
+ * @example
188
+ * import type { ResolvedRoute } from '@mokup/server'
189
+ *
190
+ * const route: ResolvedRoute = {
191
+ * file: '/mock/ping.get.ts',
192
+ * template: '/ping',
193
+ * method: 'GET',
194
+ * tokens: [{ type: 'static', value: 'ping' }],
195
+ * score: [4],
196
+ * handler: () => ({ ok: true }),
197
+ * }
198
+ */
199
+ interface ResolvedRoute {
200
+ file: string;
201
+ template: string;
202
+ method: HttpMethod;
203
+ tokens: RouteToken[];
204
+ score: number[];
205
+ handler: RouteResponse;
206
+ middlewares?: ResolvedMiddleware[];
207
+ status?: number;
208
+ headers?: Record<string, string>;
209
+ delay?: number;
210
+ ruleIndex?: number;
211
+ }
212
+ type RouteTable = ResolvedRoute[];
213
+
214
+ export type { MiddlewareRegistry as M, RouteDirectoryConfig as R, MiddlewarePosition as a, ResolvedMiddleware as b, RouteRule as c, RouteTable as d };
@@ -0,0 +1,214 @@
1
+ import { RouteToken } from '@mokup/runtime';
2
+ import { MiddlewareHandler, Context } from '@mokup/shared/hono';
3
+
4
+ /**
5
+ * Supported HTTP methods for server dev routes.
6
+ *
7
+ * @example
8
+ * import type { HttpMethod } from '@mokup/server'
9
+ *
10
+ * const method: HttpMethod = 'GET'
11
+ */
12
+ type HttpMethod = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | 'OPTIONS' | 'HEAD';
13
+ /**
14
+ * Static response payloads supported by route rules.
15
+ *
16
+ * @example
17
+ * import type { RouteStaticResponse } from '@mokup/server'
18
+ *
19
+ * const value: RouteStaticResponse = { ok: true }
20
+ */
21
+ type RouteStaticResponse = string | number | boolean | bigint | symbol | null | undefined | object;
22
+ /**
23
+ * Allowed return value from a route handler.
24
+ *
25
+ * @example
26
+ * import type { RouteHandlerResult } from '@mokup/server'
27
+ *
28
+ * const result: RouteHandlerResult = 'ok'
29
+ */
30
+ type RouteHandlerResult = RouteStaticResponse | Response;
31
+ /**
32
+ * Request handler signature for server dev routes.
33
+ *
34
+ * @example
35
+ * import type { RequestHandler } from '@mokup/server'
36
+ *
37
+ * const handler: RequestHandler = (c) => c.json({ ok: true })
38
+ */
39
+ type RequestHandler = (context: Context) => RouteHandlerResult | Promise<RouteHandlerResult>;
40
+ /**
41
+ * Route response as a static value or handler.
42
+ *
43
+ * @example
44
+ * import type { RouteResponse } from '@mokup/server'
45
+ *
46
+ * const response: RouteResponse = { ok: true }
47
+ */
48
+ type RouteResponse = RouteStaticResponse | RequestHandler;
49
+ /**
50
+ * Rule metadata for a route handler.
51
+ *
52
+ * @example
53
+ * import type { RouteRule } from '@mokup/server'
54
+ *
55
+ * const rule: RouteRule = {
56
+ * handler: () => ({ ok: true }),
57
+ * }
58
+ */
59
+ interface RouteRule {
60
+ /** Handler for the route. */
61
+ handler: RouteResponse;
62
+ /**
63
+ * Enable or disable this rule.
64
+ *
65
+ * @default true
66
+ */
67
+ enabled?: boolean;
68
+ /**
69
+ * Override response status code.
70
+ *
71
+ * @default 200
72
+ */
73
+ status?: number;
74
+ /**
75
+ * Additional response headers.
76
+ *
77
+ * @default {}
78
+ */
79
+ headers?: Record<string, string>;
80
+ /**
81
+ * Delay in milliseconds before responding.
82
+ *
83
+ * @default 0
84
+ */
85
+ delay?: number;
86
+ }
87
+ /**
88
+ * Directory-level config for server dev scanning.
89
+ *
90
+ * @example
91
+ * import type { RouteDirectoryConfig } from '@mokup/server'
92
+ *
93
+ * const config: RouteDirectoryConfig = { headers: { 'x-mokup': 'dir' } }
94
+ */
95
+ interface RouteDirectoryConfig {
96
+ /**
97
+ * Headers applied to routes in this directory.
98
+ *
99
+ * @default {}
100
+ */
101
+ headers?: Record<string, string>;
102
+ /**
103
+ * Default status code override.
104
+ *
105
+ * @default 200
106
+ */
107
+ status?: number;
108
+ /**
109
+ * Default delay in milliseconds.
110
+ *
111
+ * @default 0
112
+ */
113
+ delay?: number;
114
+ /**
115
+ * Enable or disable this directory.
116
+ *
117
+ * @default true
118
+ */
119
+ enabled?: boolean;
120
+ /**
121
+ * Ignore prefixes for files.
122
+ *
123
+ * @default ["."]
124
+ */
125
+ ignorePrefix?: string | string[];
126
+ /**
127
+ * Include filter.
128
+ *
129
+ * @default undefined
130
+ */
131
+ include?: RegExp | RegExp[];
132
+ /**
133
+ * Exclude filter.
134
+ *
135
+ * @default undefined
136
+ */
137
+ exclude?: RegExp | RegExp[];
138
+ /**
139
+ * Middleware for this directory.
140
+ *
141
+ * @default undefined
142
+ */
143
+ middleware?: MiddlewareHandler | MiddlewareHandler[];
144
+ }
145
+ /**
146
+ * Middleware execution position.
147
+ *
148
+ * @example
149
+ * import type { MiddlewarePosition } from '@mokup/server'
150
+ *
151
+ * const position: MiddlewarePosition = 'pre'
152
+ */
153
+ type MiddlewarePosition = 'pre' | 'normal' | 'post';
154
+ /**
155
+ * Middleware registry used by defineConfig.
156
+ *
157
+ * @example
158
+ * import type { MiddlewareRegistry } from '@mokup/server'
159
+ *
160
+ * const registry: MiddlewareRegistry = { use: () => {} }
161
+ */
162
+ interface MiddlewareRegistry {
163
+ use: (...handlers: MiddlewareHandler[]) => void;
164
+ }
165
+ /**
166
+ * Normalized middleware metadata.
167
+ *
168
+ * @example
169
+ * import type { ResolvedMiddleware } from '@mokup/server'
170
+ *
171
+ * const item: ResolvedMiddleware = { handle: () => {}, source: 'index.config.ts', index: 0 }
172
+ */
173
+ interface ResolvedMiddleware {
174
+ handle: MiddlewareHandler;
175
+ source: string;
176
+ index: number;
177
+ /**
178
+ * Position in the middleware chain.
179
+ *
180
+ * @default "normal"
181
+ */
182
+ position: MiddlewarePosition;
183
+ }
184
+ /**
185
+ * Fully resolved route metadata.
186
+ *
187
+ * @example
188
+ * import type { ResolvedRoute } from '@mokup/server'
189
+ *
190
+ * const route: ResolvedRoute = {
191
+ * file: '/mock/ping.get.ts',
192
+ * template: '/ping',
193
+ * method: 'GET',
194
+ * tokens: [{ type: 'static', value: 'ping' }],
195
+ * score: [4],
196
+ * handler: () => ({ ok: true }),
197
+ * }
198
+ */
199
+ interface ResolvedRoute {
200
+ file: string;
201
+ template: string;
202
+ method: HttpMethod;
203
+ tokens: RouteToken[];
204
+ score: number[];
205
+ handler: RouteResponse;
206
+ middlewares?: ResolvedMiddleware[];
207
+ status?: number;
208
+ headers?: Record<string, string>;
209
+ delay?: number;
210
+ ruleIndex?: number;
211
+ }
212
+ type RouteTable = ResolvedRoute[];
213
+
214
+ export type { MiddlewareRegistry as M, RouteDirectoryConfig as R, MiddlewarePosition as a, ResolvedMiddleware as b, RouteRule as c, RouteTable as d };
@@ -0,0 +1,214 @@
1
+ import { RouteToken } from '@mokup/runtime';
2
+ import { MiddlewareHandler, Context } from '@mokup/shared/hono';
3
+
4
+ /**
5
+ * Supported HTTP methods for server dev routes.
6
+ *
7
+ * @example
8
+ * import type { HttpMethod } from '@mokup/server'
9
+ *
10
+ * const method: HttpMethod = 'GET'
11
+ */
12
+ type HttpMethod = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | 'OPTIONS' | 'HEAD';
13
+ /**
14
+ * Static response payloads supported by route rules.
15
+ *
16
+ * @example
17
+ * import type { RouteStaticResponse } from '@mokup/server'
18
+ *
19
+ * const value: RouteStaticResponse = { ok: true }
20
+ */
21
+ type RouteStaticResponse = string | number | boolean | bigint | symbol | null | undefined | object;
22
+ /**
23
+ * Allowed return value from a route handler.
24
+ *
25
+ * @example
26
+ * import type { RouteHandlerResult } from '@mokup/server'
27
+ *
28
+ * const result: RouteHandlerResult = 'ok'
29
+ */
30
+ type RouteHandlerResult = RouteStaticResponse | Response;
31
+ /**
32
+ * Request handler signature for server dev routes.
33
+ *
34
+ * @example
35
+ * import type { RequestHandler } from '@mokup/server'
36
+ *
37
+ * const handler: RequestHandler = (c) => c.json({ ok: true })
38
+ */
39
+ type RequestHandler = (context: Context) => RouteHandlerResult | Promise<RouteHandlerResult>;
40
+ /**
41
+ * Route response as a static value or handler.
42
+ *
43
+ * @example
44
+ * import type { RouteResponse } from '@mokup/server'
45
+ *
46
+ * const response: RouteResponse = { ok: true }
47
+ */
48
+ type RouteResponse = RouteStaticResponse | RequestHandler;
49
+ /**
50
+ * Rule metadata for a route handler.
51
+ *
52
+ * @example
53
+ * import type { RouteRule } from '@mokup/server'
54
+ *
55
+ * const rule: RouteRule = {
56
+ * handler: () => ({ ok: true }),
57
+ * }
58
+ */
59
+ interface RouteRule {
60
+ /** Handler for the route. */
61
+ handler: RouteResponse;
62
+ /**
63
+ * Enable or disable this rule.
64
+ *
65
+ * @default true
66
+ */
67
+ enabled?: boolean;
68
+ /**
69
+ * Override response status code.
70
+ *
71
+ * @default 200
72
+ */
73
+ status?: number;
74
+ /**
75
+ * Additional response headers.
76
+ *
77
+ * @default {}
78
+ */
79
+ headers?: Record<string, string>;
80
+ /**
81
+ * Delay in milliseconds before responding.
82
+ *
83
+ * @default 0
84
+ */
85
+ delay?: number;
86
+ }
87
+ /**
88
+ * Directory-level config for server dev scanning.
89
+ *
90
+ * @example
91
+ * import type { RouteDirectoryConfig } from '@mokup/server'
92
+ *
93
+ * const config: RouteDirectoryConfig = { headers: { 'x-mokup': 'dir' } }
94
+ */
95
+ interface RouteDirectoryConfig {
96
+ /**
97
+ * Headers applied to routes in this directory.
98
+ *
99
+ * @default {}
100
+ */
101
+ headers?: Record<string, string>;
102
+ /**
103
+ * Default status code override.
104
+ *
105
+ * @default 200
106
+ */
107
+ status?: number;
108
+ /**
109
+ * Default delay in milliseconds.
110
+ *
111
+ * @default 0
112
+ */
113
+ delay?: number;
114
+ /**
115
+ * Enable or disable this directory.
116
+ *
117
+ * @default true
118
+ */
119
+ enabled?: boolean;
120
+ /**
121
+ * Ignore prefixes for files.
122
+ *
123
+ * @default ["."]
124
+ */
125
+ ignorePrefix?: string | string[];
126
+ /**
127
+ * Include filter.
128
+ *
129
+ * @default undefined
130
+ */
131
+ include?: RegExp | RegExp[];
132
+ /**
133
+ * Exclude filter.
134
+ *
135
+ * @default undefined
136
+ */
137
+ exclude?: RegExp | RegExp[];
138
+ /**
139
+ * Middleware for this directory.
140
+ *
141
+ * @default undefined
142
+ */
143
+ middleware?: MiddlewareHandler | MiddlewareHandler[];
144
+ }
145
+ /**
146
+ * Middleware execution position.
147
+ *
148
+ * @example
149
+ * import type { MiddlewarePosition } from '@mokup/server'
150
+ *
151
+ * const position: MiddlewarePosition = 'pre'
152
+ */
153
+ type MiddlewarePosition = 'pre' | 'normal' | 'post';
154
+ /**
155
+ * Middleware registry used by defineConfig.
156
+ *
157
+ * @example
158
+ * import type { MiddlewareRegistry } from '@mokup/server'
159
+ *
160
+ * const registry: MiddlewareRegistry = { use: () => {} }
161
+ */
162
+ interface MiddlewareRegistry {
163
+ use: (...handlers: MiddlewareHandler[]) => void;
164
+ }
165
+ /**
166
+ * Normalized middleware metadata.
167
+ *
168
+ * @example
169
+ * import type { ResolvedMiddleware } from '@mokup/server'
170
+ *
171
+ * const item: ResolvedMiddleware = { handle: () => {}, source: 'index.config.ts', index: 0 }
172
+ */
173
+ interface ResolvedMiddleware {
174
+ handle: MiddlewareHandler;
175
+ source: string;
176
+ index: number;
177
+ /**
178
+ * Position in the middleware chain.
179
+ *
180
+ * @default "normal"
181
+ */
182
+ position: MiddlewarePosition;
183
+ }
184
+ /**
185
+ * Fully resolved route metadata.
186
+ *
187
+ * @example
188
+ * import type { ResolvedRoute } from '@mokup/server'
189
+ *
190
+ * const route: ResolvedRoute = {
191
+ * file: '/mock/ping.get.ts',
192
+ * template: '/ping',
193
+ * method: 'GET',
194
+ * tokens: [{ type: 'static', value: 'ping' }],
195
+ * score: [4],
196
+ * handler: () => ({ ok: true }),
197
+ * }
198
+ */
199
+ interface ResolvedRoute {
200
+ file: string;
201
+ template: string;
202
+ method: HttpMethod;
203
+ tokens: RouteToken[];
204
+ score: number[];
205
+ handler: RouteResponse;
206
+ middlewares?: ResolvedMiddleware[];
207
+ status?: number;
208
+ headers?: Record<string, string>;
209
+ delay?: number;
210
+ ruleIndex?: number;
211
+ }
212
+ type RouteTable = ResolvedRoute[];
213
+
214
+ export type { MiddlewareRegistry as M, RouteDirectoryConfig as R, MiddlewarePosition as a, ResolvedMiddleware as b, RouteRule as c, RouteTable as d };
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Minimal readable stream shape used by adapters.
3
+ *
4
+ * @example
5
+ * import type { ReadableStreamLike } from '@mokup/server'
6
+ *
7
+ * const stream: ReadableStreamLike = {
8
+ * on: () => {},
9
+ * }
10
+ */
11
+ interface ReadableStreamLike {
12
+ on: (event: string, listener: (...args: unknown[]) => void) => void;
13
+ }
14
+ /**
15
+ * Minimal Node request shape used by adapters.
16
+ *
17
+ * @example
18
+ * import type { NodeRequestLike } from '@mokup/server'
19
+ *
20
+ * const req: NodeRequestLike = { method: 'GET', url: '/api/ping' }
21
+ */
22
+ interface NodeRequestLike extends ReadableStreamLike {
23
+ method?: string;
24
+ url?: string;
25
+ originalUrl?: string;
26
+ headers?: Record<string, string | string[] | undefined>;
27
+ body?: unknown;
28
+ }
29
+ /**
30
+ * Minimal Node response shape used by adapters.
31
+ *
32
+ * @example
33
+ * import type { NodeResponseLike } from '@mokup/server'
34
+ *
35
+ * const res: NodeResponseLike = {
36
+ * setHeader: () => {},
37
+ * end: () => {},
38
+ * }
39
+ */
40
+ interface NodeResponseLike {
41
+ statusCode?: number;
42
+ setHeader: (name: string, value: string) => void;
43
+ end: (data?: string | Uint8Array | ArrayBuffer | null) => void;
44
+ }
45
+
46
+ export type { NodeRequestLike as N, NodeResponseLike as a };