---
name: cloudflare-hono
description: Wire Cloudflare Workers Env typings into Hono apps. Use when working in Cloudflare Workers + Hono, when the user mentions wrangler types, worker-configuration.d.ts, or typing Bindings/Env in Hono.
---

# Cloudflare Hono Env Typing

## Quick start

Use the Env type generated by `wrangler types` from `apps/api/worker-configuration.d.ts`, then pass it into Hono's generics.

```
import type { Env } from "../worker-configuration";
import { Hono } from "hono";

export const domainWorkersRouter = new Hono<{ Bindings: Env }>();
```

## Workflow

1. Generate or update typings:
   - Run `wrangler types` in `apps/api` (this creates/updates `apps/api/worker-configuration.d.ts`).
2. Import the Env type from `apps/api/worker-configuration.d.ts`:
   - `import type { Env } from "../worker-configuration";`
3. Thread Env into Hono:
   - `new Hono<{ Bindings: Env }>()`
4. Use typed bindings via `c.env`:
   - `const db = c.env.ZEROSPIN_DATABASE`

## Notes

- Keep the Env import as a type-only import.
- The `worker-configuration.d.ts` file is generated; do not hand-edit it.
- If the file path changes, update the import path in routes/modules accordingly.

## Example route snippet

```
import type { Env } from "../worker-configuration";
import { Hono } from "hono";

export const domainWorkersRouter = new Hono<{ Bindings: Env }>();

domainWorkersRouter.get("/", (c) => {
  const db = c.env.ZEROSPIN_DATABASE;
  return c.json({ ok: true, hasDb: Boolean(db) });
});
```
