0
0
mirror of https://github.com/honojs/hono.git synced 2024-11-29 17:46:30 +01:00
hono/deno_dist
Sor4chi 31f0605209 feat: Add c.stream() (#1437)
* feat: implement stream api utility-class

* test: write the test of StreamApi

* feat: implement `c.stream` to context

* test: write the test of `c.stream()`

* chore: denoify

* fix: extend for bytes, remove buffer system, add pipe and log interface

* test: update test about log, pipe, etc... for streaming API

* feat: extend textStream interface, remove utf-8 content-type

* test: add test about `c.textStream`

* refactor: update some args name

* chore: denoify

* fix: for deno, removed the optional parameter of `write` and `writeln`

* chore: denoify

* feat: add charset for textStream content-type header

* fix: rename textStream to streamText

* fix: reuse stream in streamText for bundle size

* feat: add `stream.wait()` api

* chore: denoify

* fix: rename `stream.wait` to `stream.sleep`

* test: use `stream.sleep` for waiting

* refactor: remove `stream.log`

* fix: remove preHeader from `c.stream()` and use `transfer-encoding` only `c.streamText()`

* chore: denoify

* refactoring: remove preHeader initialize

* test: reduce sleep duration

* chore: denoify

Co-authored-by: Glen Maddern <glenmaddern@gmail.com>
2023-09-17 00:57:26 +09:00
..
adapter fix(netlify): fix import paths (#1304) 2023-08-08 09:35:05 +09:00
client feat: allow the type of app.request (#1444) 2023-09-13 08:04:04 +09:00
helper fix(types): middleware with different env types (#1466) 2023-09-16 20:32:54 +09:00
jsx feat(jsx): export FC (#1420) 2023-09-09 17:12:21 +09:00
middleware feat(req): deprecate c.req.headers (not c.req.header) and others (#1410) 2023-09-05 22:08:43 +09:00
preset fix(types): remove type-errors for routes (#1371) 2023-08-24 15:36:49 +09:00
router fix(trie-router-router): For "Named param with trailing wildcard" (#1246) 2023-07-20 16:48:38 +09:00
utils feat: Add c.stream() (#1437) 2023-09-17 00:57:26 +09:00
validator fix(validator): cache arrayBuffer to use after validation (#1393) 2023-09-03 14:43:01 +09:00
compose.ts
context.ts feat: Add c.stream() (#1437) 2023-09-17 00:57:26 +09:00
helper.ts feat: introduce "Helpers" (#1353) 2023-08-21 15:22:37 +09:00
hono-base.ts fix(types): fix the type error in MiddlewareHandlerInterface (#1449) 2023-09-13 08:57:52 +09:00
hono.ts fix(types): remove type-errors for routes (#1371) 2023-08-24 15:36:49 +09:00
http-exception.ts fix(HttpException): error message should not be the HTTP reason phrase (#1161) 2023-06-07 21:17:52 +09:00
LICENSE
middleware.ts fix(middleware.ts): export secure-headers for Deno (#1361) 2023-08-21 15:38:35 +09:00
mod.ts feat(context): introduce c.render() (#1397) 2023-09-05 16:01:58 +09:00
README.md chore(benchmark): update the handle-event benchmark (#1297) 2023-08-05 23:37:41 +09:00
request.ts feat(req): deprecate c.req.headers (not c.req.header) and others (#1410) 2023-09-05 22:08:43 +09:00
router.ts feat: handle HEAD method (#1142) 2023-06-03 09:07:33 +09:00
types.ts fix(types): support infering path types for multiple handlers (#1473) 2023-09-16 22:47:47 +09:00


Documentation 👉 hono.dev
v3 has been released! Migration guide


GitHub Workflow Status GitHub npm npm Bundle Size Bundle Size npm type definitions GitHub commit activity GitHub last commit Deno badge Discord badge

Hono - [炎] means flame🔥 in Japanese - is a small, simple, and ultrafast web framework for the Edges. It works on any JavaScript runtime: Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, Vercel, Lagon, AWS Lambda, Lambda@Edge, and Node.js.

Fast, but not only fast.

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

app.get('/', (c) => c.text('Hono!'))

export default app

Quick Start

npm create hono@latest my-app

Features

  • Ultrafast 🚀 - The router RegExpRouter is really fast. Not using linear loops. Fast.
  • Lightweight 🪶 - The hono/tiny preset is under 12kB. Hono has zero dependencies and uses only the Web Standard API.
  • Multi-runtime 🌍 - Works on Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, Lagon, AWS Lambda, Lambda@Edge, or Node.js. The same code runs on all platforms.
  • Batteries Included 🔋 - Hono has built-in middleware, custom middleware, and third-party middleware. Batteries included.
  • Delightful DX 🛠️ - Super clean APIs. First-class TypeScript support. Now, we've got "Types".

Benchmarks

Hono is the fastest, compared to other routers for Cloudflare Workers.

Hono x 510,171 ops/sec ±4.61% (82 runs sampled)
itty-router x 285,810 ops/sec ±4.13% (85 runs sampled)
sunder x 345,272 ops/sec ±4.46% (87 runs sampled)
worktop x 203,468 ops/sec ±3.03% (91 runs sampled)
Fastest is Hono
✨  Done in 28.68s.

Documentation

The documentation is available on hono.dev.

Migration

The migration guide is available on docs/MIGRATION.md.

Communication

Twitter and Discord channel are available.

Contributing

Contributions Welcome! You can contribute in the following ways.

  • Create an Issue - Propose a new feature. Report a bug.
  • Pull Request - Fix a bug and typo. Refactor the code.
  • Create third-party middleware - Instruct below.
  • Share - Share your thoughts on the Blog, Twitter, and others.
  • Make your application - Please try to use Hono.

For more details, see docs/CONTRIBUTING.md.

Contributors

Thanks to all contributors!

Authors

Yusuke Wada https://github.com/yusukebe

RegExpRouter, SmartRouter, LinearRouter, and PatternRouter are created by Taku Amano https://github.com/usualoma

License

Distributed under the MIT License. See LICENSE for more information.