コンテンツにスキップ

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

下記も参照してください。

MITライセンスに基づいてリリースされています。