honojs-middleware/packages/ajv-validator
Yusuke Wada e678c36193
chore: update the lock file (#1019)
2025-03-17 23:43:15 +09:00
..
src chore: use the latest eslint and `@hono/eslint-config` (#904) 2024-12-25 18:08:43 +09:00
test chore: Migrate workspaces that use `jest` to `vitest` (#998) 2025-03-04 22:00:28 +09:00
CHANGELOG.md Version Packages (#829) 2024-11-15 17:36:35 +09:00
README.md feat(ajv-validator): Add Ajv validator middleware (#794) 2024-11-15 05:17:22 +09:00
package.json chore: update the lock file (#1019) 2025-03-17 23:43:15 +09:00
tsconfig.json feat(ajv-validator): Add Ajv validator middleware (#794) 2024-11-15 05:17:22 +09:00
vitest.config.ts test(workspace): upgrade to vitest v3 (#1009) 2025-03-12 12:52:15 +09:00

README.md

Ajv validator middleware for Hono

Validator middleware using Ajv for Hono applications. Define your schema with Ajv and validate incoming requests.

Usage

No Hook:

import { type JSONSchemaType } from 'ajv';
import { ajvValidator } from '@hono/ajv-validator';
 
const schema: JSONSchemaType<{ name: string; age: number }> = {
  type: 'object',
  properties: {
    name: { type: 'string' },
    age: { type: 'number' },
  },
  required: ['name', 'age'],
  additionalProperties: false,
} as const;

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

Hook:

import { type JSONSchemaType } from 'ajv';
import { ajvValidator } from '@hono/ajv-validator';

const schema: JSONSchemaType<{ name: string; age: number }> = {
  type: 'object',
  properties: {
    name: { type: 'string' },
    age: { type: 'number' },
  },
  required: ['name', 'age'],
  additionalProperties: false,
};

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

Author

Illia Khvost https://github.com/ikhvost

License

MIT