refactor(zod-validator): pass the path to `Context` for the hook (#74)
* refactor(zod-validator): pass the path to `Context` for the hook * add changesetpull/73/head
parent
9ce42c23dd
commit
7d84e06943
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'@hono/zod-validator': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
refactor: pass the path to Context for the hook
|
|
@ -3,9 +3,9 @@ import { validator } from 'hono/validator'
|
||||||
import type { z } from 'zod'
|
import type { z } from 'zod'
|
||||||
import type { ZodSchema, ZodError } from 'zod'
|
import type { ZodSchema, ZodError } from 'zod'
|
||||||
|
|
||||||
type Hook<T, E extends Env> = (
|
type Hook<T, E extends Env, P extends string> = (
|
||||||
result: { success: true; data: T } | { success: false; error: ZodError },
|
result: { success: true; data: T } | { success: false; error: ZodError },
|
||||||
c: Context<E>
|
c: Context<E, P>
|
||||||
) => Response | Promise<Response> | void
|
) => Response | Promise<Response> | void
|
||||||
|
|
||||||
export const zValidator = <
|
export const zValidator = <
|
||||||
|
@ -23,7 +23,7 @@ export const zValidator = <
|
||||||
>(
|
>(
|
||||||
target: Target,
|
target: Target,
|
||||||
schema: T,
|
schema: T,
|
||||||
hook?: Hook<z.infer<T>, E>
|
hook?: Hook<z.infer<T>, E, P>
|
||||||
): MiddlewareHandler<E, P, V> =>
|
): MiddlewareHandler<E, P, V> =>
|
||||||
validator(target, (value, c) => {
|
validator(target, (value, c) => {
|
||||||
const result = schema.safeParse(value)
|
const result = schema.safeParse(value)
|
||||||
|
|
Loading…
Reference in New Issue