Zod OpenAPI
Zod OpenAPI Honoは、OpenAPIをサポートする拡張Honoクラスです。これにより、Zodを使用して値やタイプを検証し、OpenAPI Swaggerのドキュメントを生成できます。このWebサイトでは、基本的な使い方のみを示します。
最初に、Zodでスキーマを定義します。z
オブジェクトは@hono/zod-openapi
からインポートする必要があります。
ts
import { z } from '@hono/zod-openapi'
const ParamsSchema = z.object({
id: z
.string()
.min(3)
.openapi({
param: {
name: 'id',
in: 'path',
},
example: '1212121',
}),
})
const UserSchema = z
.object({
id: z.string().openapi({
example: '123',
}),
name: z.string().openapi({
example: 'John Doe',
}),
age: z.number().openapi({
example: 42,
}),
})
.openapi('User')
次に、ルートを作成します。
ts
import { createRoute } from '@hono/zod-openapi'
const route = createRoute({
method: 'get',
path: '/users/{id}',
request: {
params: ParamsSchema,
},
responses: {
200: {
content: {
'application/json': {
schema: UserSchema,
},
},
description: 'Retrieve the user',
},
},
})
最後に、アプリを設定します。
ts
import { OpenAPIHono } from '@hono/zod-openapi'
const app = new OpenAPIHono()
app.openapi(route, (c) => {
const { id } = c.req.valid('param')
return c.json({
id,
age: 20,
name: 'Ultra-man',
})
})
// The OpenAPI documentation will be available at /doc
app.doc('/doc', {
openapi: '3.0.0',
info: {
version: '1.0.0',
title: 'My API',
},
})
アプリは、Honoの場合と同じように開始できます。Cloudflare WorkersとBunの場合、このエントリポイントを使用します。
ts
export default app