← Back to Skills Marketplace
yuexiaoliang

hono

by 岳晓亮 · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ Security Clean
104
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install hono
Description
Hono web framework skill for building APIs across all JS runtimes (Cloudflare Workers, Deno, Bun, Node.js, etc.). Covers routing, middleware, JSX, RPC client...
README (SKILL.md)

Hono

Hono (Japanese for "flame" 🔥) is a small, fast web framework built on Web Standards. Works on all JS runtimes.

Core API

import { Hono } from 'hono'
const app = new Hono()

app.get('/', (c) => c.text('Hello!'))
app.post('/api', async (c) => c.json({ ok: true }, 201))

export default app

Context Core Methods

// Responses
c.text(str, status?)       // plain text
c.json(obj, status?)        // JSON
c.html(str)                 // HTML string
c.body(stream, headers?)    // raw body

// Requests
c.req.param('id')          // path params (type-inferred)
c.req.query('name')         // query params
c.req.valid('json')         // validated data (with validator)
c.req.header('x-token')     // request headers
c.req.cookie('session')     // cookies

// Variables/state
c.set('key', value)         // set variable (shared via middleware)
c.get('key')                // get variable
c.var.foo                   // access middleware-set variable

// Other
c.notFound()                // 404 (avoid in RPC)
c.redirect('/path', 302)    // redirect

Routing

// Basic routes
app.get('/users/:id', (c) => c.json({ id: c.req.param('id') }))

// Regex routes
app.get('/posts/:id{.+}', (c) => { /* matches /posts/a/b/c */ })

// Route grouping
const api = new Hono()
api.get('/posts', ...)
api.get('/users', ...)
app.route('/api', api)

// HTTP methods
app.get|post|put|patch|delete|options|head

// Multiple paths
app.get(['/home', '/'], (c) => c.text('Home'))

Project Creation

# npm
npm create hono@latest my-app -- --template cloudflare-workers --pm npm --install

# bun
bun create hono@latest my-app

# Common templates: cloudflare-workers, bun, deno, vercel, aws-lambda, nodejs

npm create arg passing: npm requires --, others optional. --template selects template, --pm specifies package manager, --install auto-installs deps.

Large Application Structure

Recommended: Use app.route() for modular apps, not RoR-style Controllers (type inference breaks).

// authors.ts - separate Hono instance per module
const app = new Hono()
  .get('/', (c) => c.json('list'))
  .post('/', (c) => c.json('create', 201))
  .get('/:id', (c) => c.json(c.req.param('id')))

export default app
export type AppType = typeof app
// index.ts - compose
import authors from './authors'
const app = new Hono()
app.route('/authors', authors)
export default app

RPC: Chain methods to export types:

const route = app.get('/', (c) => c.json({ ok: true }))
export type AppType = typeof route  // or typeof app

Middleware

// Built-in
import { cors, logger, etag } from 'hono/middleware'
app.use('*', cors(), logger(), etag())

// Custom
app.use('*', async (c, next) => {
  c.set('requestId', crypto.randomUUID())
  await next()
})

// Path-specific
app.use('/api/*', authenticate())

// Error handling
app.onError((err, c) => {
  return c.json({ error: err.message }, 500)
})

Common built-in middleware: cors, jwt, bearer-auth, basic-auth, logger, etag, secure-headers, cache, compress, body-limit, pretty-json, timing, request-id, ip-restriction

Validators

import { zValidator } from '@hono/zod-validator'
import { z } from 'zod'

app.post('/posts',
  zValidator('json', z.object({ title: z.string(), body: z.string() })),
  (c) => {
    const { title, body } = c.req.valid('json')
    return c.json({ ok: true }, 201)
  }
)

export type AppType = typeof app  // export for client

Validation targets: json, form, query, param, header, cookie

RPC Client

import { hc } from 'hono/client'
import type { AppType } from './server'

const client = hc\x3CAppType>('http://localhost:8787/')

// Request
const res = await client.posts.$post({
  json: { title: 'Hello', body: 'Hono!' }
})

// Response
if (res.ok) {
  const data = await res.json()
}

Don't use c.notFound() in RPC mode — use c.json(..., 404) instead, or type inference breaks.

Path params use param, queries use query, forms use form, JSON use json.

JSX

import { Hono } from 'hono'
import type { FC } from 'hono/jsx'

const app = new Hono()

const Layout: FC = (props) => (
  \x3Chtml>\x3Cbody>{props.children}\x3C/body>\x3C/html>
)

app.get('/', (c) => c.html(\x3CLayout>\x3Ch1>Hello!\x3C/h1>\x3C/Layout>))

tsconfig.json needs:

{
  "compilerOptions": {
    "jsx": "react-jsx",
    "jsxImportSource": "hono/jsx"
  }
}

Helpers

Helper Purpose
html Template literal HTML
cookie Cookie read/write
jwt JWT encode/decode
ssg Static site generation
streaming Streaming responses
accepts Content negotiation
factory Reusable handlers (preserves type inference)

Context Extensions (Variable Types)

// Define types
type Env = { Variables: { user: User } }

// Use
const app = new Hono\x3C{ Variables: { user: User } }>()

app.use('*', async (c, next) => {
  c.set('user', { id: 1, name: 'Alice' })
  await next()
})

app.get('/me', (c) => c.json(c.var.user))

Testing

// Method 1: app.request()
const res = await app.request('/api/posts?page=1', {
  method: 'POST',
  body: JSON.stringify({ title: 'Hello' }),
  headers: { 'Content-Type': 'application/json' }
})

// Method 2: fetch style
const res = await fetch('/api/posts', {
  method: 'POST',
  body: JSON.stringify({ title: 'Hello' })
})
const data = await res.json()

Reference Docs

Detailed docs loaded on demand:

Usage Guidance
This bundle is documentation/examples for the Hono framework and appears coherent and low-risk as provided. Before using it in a project: install Hono packages from the official source (npm/github) and verify package integrity; replace example secrets (signingKey, API_KEY) with appropriately scoped credentials; and review any third‑party middleware you add (e.g., jwt, proxy, fetch calls) to ensure they don't send sensitive data to unknown endpoints.
Capability Analysis
Type: OpenClaw Skill Name: hono Version: 1.0.0 The skill bundle contains comprehensive documentation and code examples for the Hono web framework. The content in SKILL.md and the reference files (context.md, helpers.md, middleware.md, routing.md, rpc.md) consists of standard API usage, project initialization commands (npm/bun create), and architectural best practices. No evidence of malicious intent, data exfiltration, or prompt injection was found.
Capability Tags
crypto
Capability Assessment
Purpose & Capability
Name/description match the included documentation: routing, middleware, JSX, RPC client, validators, and context examples. The skill does not request unrelated binaries, credentials, or config paths.
Instruction Scope
SKILL.md and reference files are documentation and code examples for using Hono. They reference runtime constructs (c.env, crypto, fetch, service bindings, JWT secrets) as expected for framework examples — but they do not instruct the agent to read host files, exfiltrate data, or access environment variables beyond illustrative usage.
Install Mechanism
No install spec or downloads are present (instruction-only). Nothing will be written to disk or executed by an installer when the skill is installed.
Credentials
The skill declares no required environment variables or credentials. Examples show using secrets (JWT signingKey, API_KEY) but these are illustrative and not requested by the skill itself.
Persistence & Privilege
always is false; the skill is user-invocable and can be called autonomously (platform default) but it does not request elevated persistence or modify other skills/configuration.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install hono
  3. After installation, invoke the skill by name or use /hono
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
- Initial release of the hono skill (v1.0.0). - Provides concise documentation for the Hono web framework, covering core API usage, routing, middleware, validation, RPC client, JSX support, helpers, context extensions, and testing. - Supports usage across all major JavaScript runtimes (Cloudflare Workers, Deno, Bun, Node.js, and more). - Offers quick start examples and project setup instructions. - Includes references to detailed subtopics for advanced usage.
Metadata
Slug hono
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is hono?

Hono web framework skill for building APIs across all JS runtimes (Cloudflare Workers, Deno, Bun, Node.js, etc.). Covers routing, middleware, JSX, RPC client... It is an AI Agent Skill for Claude Code / OpenClaw, with 104 downloads so far.

How do I install hono?

Run "/install hono" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is hono free?

Yes, hono is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does hono support?

hono is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created hono?

It is built and maintained by 岳晓亮 (@yuexiaoliang); the current version is v1.0.0.

💬 Comments