Skip to content

Releases: honojs/hono

v4.12.23

25 May 02:00

Choose a tag to compare

What's Changed

  • fix(serve-static): normalize all backslashes in file paths, not just the first in #4962
  • feat(context): export the Context class publicly by @BlankParticle in #4543
  • docs(contribution): add AI Usage Policy by @yusukebe in #4970
  • feat(compress): add contentTypeFilter option and COMPRESSIBLE_CONTENT_TYPE_REGEX re-export by @na-trium-144 in #4961
  • fix(utils/ipaddr): do not compress a single 0 group to :: by @yusukebe in #4971

Full Changelog: v4.12.22...v4.12.23

v4.12.22

22 May 09:16

Choose a tag to compare

What's Changed

  • chore: update vitest to v4 and cleanups by @BlankParticle in #4952
  • fix(mime): specify charset parameter per MIME type instead of mechanical detection by @renatograsso10 in #4912
  • fix(compress): respect Accept-Encoding when encoding option is set by @LeSingh1 in #4951
  • fix(deno): echo negotiated WebSocket subprotocol in upgrade response by @ATOM00blue in #4955
  • feat: add msgpack as a compressible content type by @na-trium-144 in #4957

New Contributors

Full Changelog: v4.12.21...v4.12.22

v4.12.21

19 May 11:40

Choose a tag to compare

Security fixes

This release includes fixes for the following security issues:

app.mount() strips mount prefix using undecoded path, causing incorrect routing for percent-encoded paths

Affects: app.mount(). Fixes prefix stripping using the raw URL pathname instead of the decoded path, where percent-encoded characters in the mount prefix or path could cause the prefix to be removed at the wrong position, resulting in the sub-application receiving an incorrect path. GHSA-2gcr-mfcq-wcc3

IP Restriction bypasses static deny rules for non-canonical IPv6

Affects: hono/ip-restriction. Fixes IP address comparison using string equality, where non-canonical IPv6 representations of a denied address β€” such as compressed forms or hex-notation IPv4-mapped addresses β€” could bypass static deny rules. GHSA-xrhx-7g5j-rcj5

Cookie helper does not sanitize sameSite and priority, allowing Set-Cookie injection

Affects: hono/cookie. Fixes missing validation of sameSite and priority options against injection characters (;, \r, \n), where user-controlled input passed to either option could inject additional attributes into the Set-Cookie response header. GHSA-3hrh-pfw6-9m5x

JWT middleware accepts any Authorization scheme, not only Bearer

Affects: hono/jwt, hono/jwk. Fixes missing scheme validation in the Authorization header, where any two-part header value was accepted regardless of the scheme name, allowing non-Bearer schemes to pass JWT authentication. GHSA-f577-qrjj-4474


Users who use app.mount(), hono/ip-restriction, hono/cookie, or hono/jwt/hono/jwk are encouraged to upgrade to this version.

v4.12.20

19 May 10:41

Choose a tag to compare

What's Changed

  • fix(route): preserve the base path of the mounted route() app by @usualoma in #4942
  • fix(jsx): widen jsx and jsxFn children to Child[] by @ashunar0 in #4947

New Contributors

Full Changelog: v4.12.19...v4.12.20

v4.12.19

16 May 10:17

Choose a tag to compare

What's Changed

  • ci: pin GitHub Actions to SHAs by @yusukebe in #4932
  • fix(serveStatic): make options parameter optional in all adapters by @mixelburg in #4934
  • fix(cookie): return the first cookie when there are multiple cookies with the same name by @usualoma in #4922
  • feat(bearer-auth): make bearerAuth generic for typed context in verifyToken by @justinnais in #4913
  • feat(cache): key cache entries by configured vary headers by @usualoma in #4915
  • feat(request): add bytes() by @yusukebe in #4921
  • fix(stream): upgrade @hono/node-server to v2 and fix abort handling by @yusukebe in #4940

New Contributors

Full Changelog: v4.12.18...v4.12.19

v4.12.18

06 May 11:39

Choose a tag to compare

Security fixes

This release includes fixes for the following security issues:

Cache Middleware ignores Vary: Authorization / Vary: Cookie leading to cross-user cache leakage

Affects: Cache Middleware. Fixes missing cache-skip handling for Vary: Authorization and Vary: Cookie, where a response cached for one authenticated user could be served to other users. GHSA-p77w-8qqv-26rm

CSS Declaration Injection via Style Object Values in JSX SSR

Affects: hono/jsx. Fixes a missing CSS-context escape for style object values and property names, where untrusted input could inject additional CSS declarations. The impact is limited to CSS and does not allow JavaScript execution. GHSA-qp7p-654g-cw7p

Improper validation of NumericDate claims (exp, nbf, iat) in JWT verify()

Affects: hono/utils/jwt. Fixes improper validation of exp, nbf, and iat claims, where falsy, non-finite, or non-numeric values could silently bypass time-based checks instead of being rejected per RFC 7519. GHSA-hm8q-7f3q-5f36


Users who use the JWT helper, hono/jsx, or the Cache middleware are strongly encouraged to upgrade to this version.

v4.12.17

05 May 09:31

Choose a tag to compare

What's Changed

  • fix(jsx): normalize SVG attributes on the root element by @kfly8 in #4893
  • fix(ssg): add atom+xml and rss+xml to defaultExtensionMap by @yuintei in #4899
  • fix(cors): make origin optional in CORSOptions by @truffle-dev in #4905
  • fix(types): propagate middleware response types to app.on overloads by @T4ko0522 in #4906

New Contributors

Full Changelog: v4.12.16...v4.12.17

v4.12.16

30 Apr 09:16

Choose a tag to compare

Security fixes

This release includes fixes for the following security issues:

Unvalidated JSX Tag Names in hono/jsx May Allow HTML Injection

Affects: hono/jsx. Fixes missing validation of JSX tag names when using jsx() or createElement(), which could allow HTML injection if untrusted input is used as the tag name. GHSA-69xw-7hcm-h432

bodyLimit() can be bypassed for chunked / unknown-length requests

Affects: Body Limit Middleware. Fixes late enforcement for request bodies without a reliable Content-Length (e.g. chunked requests), where oversized requests could reach handlers and return successful responses before being rejected. GHSA-9vqf-7f2p-gf9v

v4.12.15

24 Apr 06:51

Choose a tag to compare

What's Changed

  • fix(jwt): support single-line PEM keys by @hiendv in #4889

New Contributors

Full Changelog: v4.12.14...v4.12.15

v4.12.14

15 Apr 06:15

Choose a tag to compare

Security fixes

This release includes fixes for the following security issues:

Improper handling of JSX attribute names in hono/jsx SSR

Affects: hono/jsx. Fixes missing validation of JSX attribute names during server-side rendering, which could allow malformed attribute keys to corrupt the generated HTML output and inject unintended attributes or elements. GHSA-458j-xx4x-4375

Other changes

  • fix(aws-lambda): handle invalid header names in request processing (#4883) fa2c74f