hono-open-api-starter

A starter template for building fully documented type-safe JSON APIs with Hono and Open API

MIT License

Stars
154

Hono Open API Starter

A starter template for building fully documented type-safe JSON APIs with Hono and Open API.

For a cloudflare specific template, see the cloudflare branch on this repo

For other deployment examples see the hono-node-deployment-examples repo

Included

Setup

Clone this template without git history

npx degit w3cj/hono-open-api-starter my-api
cd my-api

Create .env file

cp .env.sample .env

Create sqlite db / push schema

pnpm drizzle-kit push

Install dependencies

pnpm install

Run

pnpm dev

Lint

pnpm lint

Test

pnpm test

Code Tour

Base hono app exported from app.ts. Local development uses @hono/node-server defined in index.ts - update this file or create a new entry point to use your preferred runtime.

Typesafe env defined in env.ts - add any other required environment variables here. The application will not start if any required environment variables are missing

See src/routes/tasks for an example Open API group. Copy this folder / use as an example for your route groups.

All app routes are grouped together and exported into single type as AppType in app.ts for use in RPC / hono/client.

Endpoints

Path Description
GET /doc Open API Specification
GET /reference Scalar API Documentation
GET /tasks List all tasks
POST /tasks Create a task
GET /tasks/{id} Get one task by id
PATCH /tasks/{id} Patch one task by id
DELETE /tasks/{id} Delete one task by id

References