honojs-middleware/packages/zod-validator
Yusuke Wada 88e54c1b9d
chore(tsyringe): add a build command (#834)
* chore(tsyringe): add a build command

* add changeset
2024-11-18 11:05:17 +09:00
..
src feat(zod-validator): support enum types for `query` (#763) 2024-10-06 13:24:53 +09:00
test feat(zod-validator): support enum types for `query` (#763) 2024-10-06 13:24:53 +09:00
CHANGELOG.md Version Packages (#767) 2024-10-06 14:16:02 +09:00
README.md feat(typebox-validator): Add TypeBox Validator middleware (#55) 2023-02-24 18:22:02 +09:00
package.cjs.json fix(zod-validator): fix export for esm module (#431) 2024-03-26 09:03:48 +09:00
package.json chore(tsyringe): add a build command (#834) 2024-11-18 11:05:17 +09:00
tsconfig.cjs.json feat: introduce zod-validator (#16) 2023-01-02 00:03:44 +09:00
tsconfig.esm.json feat: introduce zod-validator (#16) 2023-01-02 00:03:44 +09:00
tsconfig.json feat: introduce zod-validator (#16) 2023-01-02 00:03:44 +09:00
vitest.config.ts fix(zod-validator): fix export for esm module (#431) 2024-03-26 09:03:48 +09:00

README.md

Zod validator middleware for Hono

The validator middleware using Zod for Hono applications. You can write a schema with Zod and validate the incoming values.

Usage

import { z } from 'zod'
import { zValidator } from '@hono/zod-validator'

const schema = z.object({
  name: z.string(),
  age: z.number(),
})

app.post('/author', zValidator('json', schema), (c) => {
  const data = c.req.valid('json')
  return c.json({
    success: true,
    message: `${data.name} is ${data.age}`,
  })
})

Hook:

app.post(
  '/post',
  zValidator('json', schema, (result, c) => {
    if (!result.success) {
      return c.text('Invalid!', 400)
    }
  })
  //...
)

Author

Yusuke Wada https://github.com/yusukebe

License

MIT