@kerebron/extension-server-hono 0.4.26 → 0.4.27

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 (59) hide show
  1. package/package.json +2 -1
  2. package/esm/HonoYjsMemAdapter.d.ts +0 -41
  3. package/esm/HonoYjsMemAdapter.d.ts.map +0 -1
  4. package/esm/HonoYjsMemAdapter.js +0 -203
  5. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/compose.d.ts +0 -15
  6. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/compose.d.ts.map +0 -1
  7. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/compose.js +0 -64
  8. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/context.d.ts +0 -452
  9. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/context.d.ts.map +0 -1
  10. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/context.js +0 -410
  11. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/helper/websocket/index.d.ts +0 -70
  12. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/helper/websocket/index.d.ts.map +0 -1
  13. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/helper/websocket/index.js +0 -62
  14. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/hono-base.d.ts +0 -221
  15. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/hono-base.d.ts.map +0 -1
  16. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/hono-base.js +0 -391
  17. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/http-exception.d.ts +0 -60
  18. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/http-exception.d.ts.map +0 -1
  19. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/http-exception.js +0 -61
  20. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request/constants.d.ts +0 -2
  21. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request/constants.d.ts.map +0 -1
  22. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request/constants.js +0 -1
  23. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request.d.ts +0 -314
  24. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request.d.ts.map +0 -1
  25. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/request.js +0 -327
  26. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/router.d.ts +0 -98
  27. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/router.d.ts.map +0 -1
  28. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/router.js +0 -25
  29. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/types.d.ts +0 -574
  30. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/types.d.ts.map +0 -1
  31. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/types.js +0 -11
  32. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/body.d.ts +0 -80
  33. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/body.d.ts.map +0 -1
  34. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/body.js +0 -111
  35. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/constants.d.ts +0 -5
  36. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/constants.d.ts.map +0 -1
  37. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/constants.js +0 -4
  38. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/headers.d.ts +0 -9
  39. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/headers.d.ts.map +0 -1
  40. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/headers.js +0 -5
  41. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/html.d.ts +0 -45
  42. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/html.d.ts.map +0 -1
  43. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/html.js +0 -122
  44. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/http-status.d.ts +0 -33
  45. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/http-status.d.ts.map +0 -1
  46. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/http-status.js +0 -5
  47. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/mime.d.ts +0 -71
  48. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/mime.d.ts.map +0 -1
  49. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/mime.js +0 -83
  50. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/types.d.ts +0 -75
  51. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/types.d.ts.map +0 -1
  52. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/types.js +0 -5
  53. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/url.d.ts +0 -30
  54. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/url.d.ts.map +0 -1
  55. package/esm/deps/jsr.io/@hono/hono/4.11.1/src/utils/url.js +0 -255
  56. package/esm/mod.d.ts +0 -5
  57. package/esm/mod.d.ts.map +0 -1
  58. package/esm/mod.js +0 -1
  59. package/esm/package.json +0 -3
@@ -1,61 +0,0 @@
1
- /**
2
- * @module
3
- * This module provides the `HTTPException` class.
4
- */
5
- /**
6
- * `HTTPException` must be used when a fatal error such as authentication failure occurs.
7
- *
8
- * @see {@link https://hono.dev/docs/api/exception}
9
- *
10
- * @param {StatusCode} status - status code of HTTPException
11
- * @param {HTTPExceptionOptions} options - options of HTTPException
12
- * @param {HTTPExceptionOptions["res"]} options.res - response of options of HTTPException
13
- * @param {HTTPExceptionOptions["message"]} options.message - message of options of HTTPException
14
- * @param {HTTPExceptionOptions["cause"]} options.cause - cause of options of HTTPException
15
- *
16
- * @example
17
- * ```ts
18
- * import { HTTPException } from 'hono/http-exception'
19
- *
20
- * // ...
21
- *
22
- * app.post('/auth', async (c, next) => {
23
- * // authentication
24
- * if (authorized === false) {
25
- * throw new HTTPException(401, { message: 'Custom error message' })
26
- * }
27
- * await next()
28
- * })
29
- * ```
30
- */
31
- export class HTTPException extends Error {
32
- res;
33
- status;
34
- /**
35
- * Creates an instance of `HTTPException`.
36
- * @param status - HTTP status code for the exception. Defaults to 500.
37
- * @param options - Additional options for the exception.
38
- */
39
- constructor(status = 500, options) {
40
- super(options?.message, { cause: options?.cause });
41
- this.res = options?.res;
42
- this.status = status;
43
- }
44
- /**
45
- * Returns the response object associated with the exception.
46
- * If a response object is not provided, a new response is created with the error message and status code.
47
- * @returns The response object.
48
- */
49
- getResponse() {
50
- if (this.res) {
51
- const newResponse = new Response(this.res.body, {
52
- status: this.status,
53
- headers: this.res.headers,
54
- });
55
- return newResponse;
56
- }
57
- return new Response(this.message, {
58
- status: this.status,
59
- });
60
- }
61
- }
@@ -1,2 +0,0 @@
1
- export declare const GET_MATCH_RESULT: symbol;
2
- //# sourceMappingURL=constants.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../../../../../../src/deps/jsr.io/@hono/hono/4.11.1/src/request/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,EAAE,MAAiB,CAAA"}
@@ -1 +0,0 @@
1
- export const GET_MATCH_RESULT = Symbol();
@@ -1,314 +0,0 @@
1
- import { GET_MATCH_RESULT } from './request/constants.js';
2
- import type { Result } from './router.js';
3
- import type { Input, InputToDataByTarget, ParamKeyToRecord, ParamKeys, RemoveQuestion, RouterRoute, ValidationTargets } from './types.js';
4
- import type { BodyData, ParseBodyOptions } from './utils/body.js';
5
- import type { CustomHeader, RequestHeader } from './utils/headers.js';
6
- import type { Simplify, UnionToIntersection } from './utils/types.js';
7
- type Body = {
8
- json: any;
9
- text: string;
10
- arrayBuffer: ArrayBuffer;
11
- blob: Blob;
12
- formData: FormData;
13
- };
14
- type BodyCache = Partial<Body & {
15
- parsedBody: BodyData;
16
- }>;
17
- export declare class HonoRequest<P extends string = '/', I extends Input['out'] = {}> {
18
- #private;
19
- [GET_MATCH_RESULT]: Result<[unknown, RouterRoute]>;
20
- /**
21
- * `.raw` can get the raw Request object.
22
- *
23
- * @see {@link https://hono.dev/docs/api/request#raw}
24
- *
25
- * @example
26
- * ```ts
27
- * // For Cloudflare Workers
28
- * app.post('/', async (c) => {
29
- * const metadata = c.req.raw.cf?.hostMetadata?
30
- * ...
31
- * })
32
- * ```
33
- */
34
- raw: Request;
35
- routeIndex: number;
36
- /**
37
- * `.path` can get the pathname of the request.
38
- *
39
- * @see {@link https://hono.dev/docs/api/request#path}
40
- *
41
- * @example
42
- * ```ts
43
- * app.get('/about/me', (c) => {
44
- * const pathname = c.req.path // `/about/me`
45
- * })
46
- * ```
47
- */
48
- path: string;
49
- bodyCache: BodyCache;
50
- constructor(request: Request, path?: string, matchResult?: Result<[unknown, RouterRoute]>);
51
- /**
52
- * `.req.param()` gets the path parameters.
53
- *
54
- * @see {@link https://hono.dev/docs/api/routing#path-parameter}
55
- *
56
- * @example
57
- * ```ts
58
- * const name = c.req.param('name')
59
- * // or all parameters at once
60
- * const { id, comment_id } = c.req.param()
61
- * ```
62
- */
63
- param<P2 extends ParamKeys<P> = ParamKeys<P>>(key: P2 extends `${infer _}?` ? never : P2): string;
64
- param<P2 extends RemoveQuestion<ParamKeys<P>> = RemoveQuestion<ParamKeys<P>>>(key: P2): string | undefined;
65
- param(key: string): string | undefined;
66
- param<P2 extends string = P>(): Simplify<UnionToIntersection<ParamKeyToRecord<ParamKeys<P2>>>>;
67
- /**
68
- * `.query()` can get querystring parameters.
69
- *
70
- * @see {@link https://hono.dev/docs/api/request#query}
71
- *
72
- * @example
73
- * ```ts
74
- * // Query params
75
- * app.get('/search', (c) => {
76
- * const query = c.req.query('q')
77
- * })
78
- *
79
- * // Get all params at once
80
- * app.get('/search', (c) => {
81
- * const { q, limit, offset } = c.req.query()
82
- * })
83
- * ```
84
- */
85
- query(key: string): string | undefined;
86
- query(): Record<string, string>;
87
- /**
88
- * `.queries()` can get multiple querystring parameter values, e.g. /search?tags=A&tags=B
89
- *
90
- * @see {@link https://hono.dev/docs/api/request#queries}
91
- *
92
- * @example
93
- * ```ts
94
- * app.get('/search', (c) => {
95
- * // tags will be string[]
96
- * const tags = c.req.queries('tags')
97
- * })
98
- * ```
99
- */
100
- queries(key: string): string[] | undefined;
101
- queries(): Record<string, string[]>;
102
- /**
103
- * `.header()` can get the request header value.
104
- *
105
- * @see {@link https://hono.dev/docs/api/request#header}
106
- *
107
- * @example
108
- * ```ts
109
- * app.get('/', (c) => {
110
- * const userAgent = c.req.header('User-Agent')
111
- * })
112
- * ```
113
- */
114
- header(name: RequestHeader): string | undefined;
115
- header(name: string): string | undefined;
116
- header(): Record<RequestHeader | (string & CustomHeader), string>;
117
- /**
118
- * `.parseBody()` can parse Request body of type `multipart/form-data` or `application/x-www-form-urlencoded`
119
- *
120
- * @see {@link https://hono.dev/docs/api/request#parsebody}
121
- *
122
- * @example
123
- * ```ts
124
- * app.post('/entry', async (c) => {
125
- * const body = await c.req.parseBody()
126
- * })
127
- * ```
128
- */
129
- parseBody<Options extends Partial<ParseBodyOptions>, T extends BodyData<Options>>(options?: Options): Promise<T>;
130
- parseBody<T extends BodyData>(options?: Partial<ParseBodyOptions>): Promise<T>;
131
- /**
132
- * `.json()` can parse Request body of type `application/json`
133
- *
134
- * @see {@link https://hono.dev/docs/api/request#json}
135
- *
136
- * @example
137
- * ```ts
138
- * app.post('/entry', async (c) => {
139
- * const body = await c.req.json()
140
- * })
141
- * ```
142
- */
143
- json<T = any>(): Promise<T>;
144
- /**
145
- * `.text()` can parse Request body of type `text/plain`
146
- *
147
- * @see {@link https://hono.dev/docs/api/request#text}
148
- *
149
- * @example
150
- * ```ts
151
- * app.post('/entry', async (c) => {
152
- * const body = await c.req.text()
153
- * })
154
- * ```
155
- */
156
- text(): Promise<string>;
157
- /**
158
- * `.arrayBuffer()` parse Request body as an `ArrayBuffer`
159
- *
160
- * @see {@link https://hono.dev/docs/api/request#arraybuffer}
161
- *
162
- * @example
163
- * ```ts
164
- * app.post('/entry', async (c) => {
165
- * const body = await c.req.arrayBuffer()
166
- * })
167
- * ```
168
- */
169
- arrayBuffer(): Promise<ArrayBuffer>;
170
- /**
171
- * Parses the request body as a `Blob`.
172
- * @example
173
- * ```ts
174
- * app.post('/entry', async (c) => {
175
- * const body = await c.req.blob();
176
- * });
177
- * ```
178
- * @see https://hono.dev/docs/api/request#blob
179
- */
180
- blob(): Promise<Blob>;
181
- /**
182
- * Parses the request body as `FormData`.
183
- * @example
184
- * ```ts
185
- * app.post('/entry', async (c) => {
186
- * const body = await c.req.formData();
187
- * });
188
- * ```
189
- * @see https://hono.dev/docs/api/request#formdata
190
- */
191
- formData(): Promise<FormData>;
192
- /**
193
- * Adds validated data to the request.
194
- *
195
- * @param target - The target of the validation.
196
- * @param data - The validated data to add.
197
- */
198
- addValidatedData(target: keyof ValidationTargets, data: {}): void;
199
- /**
200
- * Gets validated data from the request.
201
- *
202
- * @param target - The target of the validation.
203
- * @returns The validated data.
204
- *
205
- * @see https://hono.dev/docs/api/request#valid
206
- */
207
- valid<T extends keyof I & keyof ValidationTargets>(target: T): InputToDataByTarget<I, T>;
208
- /**
209
- * `.url()` can get the request url strings.
210
- *
211
- * @see {@link https://hono.dev/docs/api/request#url}
212
- *
213
- * @example
214
- * ```ts
215
- * app.get('/about/me', (c) => {
216
- * const url = c.req.url // `http://localhost:8787/about/me`
217
- * ...
218
- * })
219
- * ```
220
- */
221
- get url(): string;
222
- /**
223
- * `.method()` can get the method name of the request.
224
- *
225
- * @see {@link https://hono.dev/docs/api/request#method}
226
- *
227
- * @example
228
- * ```ts
229
- * app.get('/about/me', (c) => {
230
- * const method = c.req.method // `GET`
231
- * })
232
- * ```
233
- */
234
- get method(): string;
235
- /**
236
- * `.matchedRoutes()` can return a matched route in the handler
237
- *
238
- * @deprecated
239
- *
240
- * Use matchedRoutes helper defined in "hono/route" instead.
241
- *
242
- * @see {@link https://hono.dev/docs/api/request#matchedroutes}
243
- *
244
- * @example
245
- * ```ts
246
- * app.use('*', async function logger(c, next) {
247
- * await next()
248
- * c.req.matchedRoutes.forEach(({ handler, method, path }, i) => {
249
- * const name = handler.name || (handler.length < 2 ? '[handler]' : '[middleware]')
250
- * console.log(
251
- * method,
252
- * ' ',
253
- * path,
254
- * ' '.repeat(Math.max(10 - path.length, 0)),
255
- * name,
256
- * i === c.req.routeIndex ? '<- respond from here' : ''
257
- * )
258
- * })
259
- * })
260
- * ```
261
- */
262
- get matchedRoutes(): RouterRoute[];
263
- /**
264
- * `routePath()` can retrieve the path registered within the handler
265
- *
266
- * @deprecated
267
- *
268
- * Use routePath helper defined in "hono/route" instead.
269
- *
270
- * @see {@link https://hono.dev/docs/api/request#routepath}
271
- *
272
- * @example
273
- * ```ts
274
- * app.get('/posts/:id', (c) => {
275
- * return c.json({ path: c.req.routePath })
276
- * })
277
- * ```
278
- */
279
- get routePath(): string;
280
- }
281
- /**
282
- * Clones a HonoRequest's underlying raw Request object.
283
- *
284
- * This utility handles both consumed and unconsumed request bodies:
285
- * - If the request body hasn't been consumed, it uses the native `clone()` method
286
- * - If the request body has been consumed, it reconstructs a new Request using cached body data
287
- *
288
- * This is particularly useful when you need to:
289
- * - Process the same request body multiple times
290
- * - Pass requests to external services after validation
291
- *
292
- * @param req - The HonoRequest object to clone
293
- * @returns A Promise that resolves to a new Request object with the same properties
294
- * @throws {HTTPException} If the request body was consumed directly via `req.raw`
295
- * without using HonoRequest methods (e.g., `req.json()`, `req.text()`), making it
296
- * impossible to reconstruct the body from cache
297
- *
298
- * @example
299
- * ```ts
300
- * // Clone after consuming the body (e.g., after validation)
301
- * app.post('/forward',
302
- * validator('json', (data) => data),
303
- * async (c) => {
304
- * const validated = c.req.valid('json')
305
- * // Body has been consumed, but cloneRawRequest still works
306
- * const clonedReq = await cloneRawRequest(c.req)
307
- * return fetch('http://backend-service.com', clonedReq)
308
- * }
309
- * )
310
- * ```
311
- */
312
- export declare const cloneRawRequest: (req: HonoRequest) => Promise<Request>;
313
- export {};
314
- //# sourceMappingURL=request.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"request.d.ts","sourceRoot":"","sources":["../../../../../../../src/deps/jsr.io/@hono/hono/4.11.1/src/request.ts"],"names":[],"mappings":"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"}