Home

Description

Netty is a network application framework for development of protocol servers and clients. NoQuicTokenHandler is the tokenHandler used when the application does not set one. Prior to version 4.2.15.Final, its writeToken() returns false (server will not send Retry — acceptable), but validateToken() unconditionally `return 0`. In QuicheQuicServerCodec.handlePacket(), a non-negative return from validateToken() is interpreted as 'token is valid, ODCID starts at offset 0', causing the server to call quiche_accept as if the client's address had been validated by a Retry round-trip. Per RFC 9000 §8.1, a validated address lifts the 3× anti-amplification send limit. Thus any attacker who includes ANY non-empty token bytes in an Initial packet — with a spoofed victim source IP — causes the Netty server to treat the victim as validated and reflect full-size handshake flights (certificates, etc.) toward it without the 3× cap. The correct 'no token handler' semantics would be to return -1 (invalid) so the normal un-validated path and amplification limit apply. Version 4.2.15.Final patches the issue.

PUBLISHED Reserved 2026-05-07 | Published 2026-06-12 | Updated 2026-06-13 | Assigner GitHub_M




HIGH: 7.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N

Problem types

CWE-940: Improper Verification of Source of a Communication Channel

Product status

>= 4.2.0.Final, < 4.2.15.Final
affected

References

github.com/.../netty/security/advisories/GHSA-cmm3-54f8-px4j

github.com/netty/netty/releases/tag/netty-4.2.15.Final

cve.org (CVE-2026-44894)

nvd.nist.gov (CVE-2026-44894)

Download JSON