5.9 Medium
CVSS3
Attack Vector
NETWORK
Attack Complexity
HIGH
Privileges Required
NONE
User Interaction
NONE
Scope
UNCHANGED
Confidentiality Impact
NONE
Integrity Impact
HIGH
Availability Impact
NONE
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:H/A:N
2.6 Low
CVSS2
Access Vector
NETWORK
Access Complexity
HIGH
Authentication
NONE
Confidentiality Impact
NONE
Integrity Impact
PARTIAL
Availability Impact
NONE
AV:N/AC:H/Au:N/C:N/I:P/A:N
0.184 Low
EPSS
Percentile
96.1%
Netty is an open-source, asynchronous event-driven network application
framework for rapid development of maintainable high performance protocol
servers & clients. In Netty (io.netty:netty-codec-http2) before version
4.1.60.Final there is a vulnerability that enables request smuggling. If a
Content-Length header is present in the original HTTP/2 request, the field
is not validated by Http2MultiplexHandler
as it is propagated up. This is
fine as long as the request is not proxied through as HTTP/1.1. If the
request comes in as an HTTP/2 stream, gets converted into the HTTP/1.1
domain objects (HttpRequest
, HttpContent
, etc.) via
Http2StreamFrameToHttpObjectCodec
and then sent up to the child channel’s
pipeline and proxied through a remote peer as HTTP/1.1 this may result in
request smuggling. In a proxy case, users may assume the content-length is
validated somehow, which is not the case. If the request is forwarded to a
backend channel that is a HTTP/1.1 connection, the Content-Length now has
meaning and needs to be checked. An attacker can smuggle requests inside
the body as it gets downgraded from HTTP/2 to HTTP/1.1. For an example
attack refer to the linked GitHub Advisory. Users are only affected if all
of this is true: HTTP2MultiplexCodec
or Http2FrameCodec
is used,
Http2StreamFrameToHttpObjectCodec
is used to convert to HTTP/1.1 objects,
and these HTTP/1.1 objects are forwarded to another remote peer. This has
been patched in 4.1.60.Final As a workaround, the user can do the
validation by themselves by implementing a custom ChannelInboundHandler
that is put in the ChannelPipeline
behind
Http2StreamFrameToHttpObjectCodec
.
OS | Version | Architecture | Package | Version | Filename |
---|---|---|---|---|---|
ubuntu | 18.04 | noarch | netty | < 1:4.1.7-4ubuntu0.1+esm2 | UNKNOWN |
ubuntu | 20.04 | noarch | netty | < 1:4.1.45-1ubuntu0.1~esm1 | UNKNOWN |
ubuntu | 22.04 | noarch | netty | < 1:4.1.48-4+deb11u1build0.22.04.1 | UNKNOWN |
ubuntu | 22.10 | noarch | netty | < 1:4.1.48-5ubuntu0.1 | UNKNOWN |
ubuntu | 23.10 | noarch | netty | < any | UNKNOWN |
ubuntu | 14.04 | noarch | netty | < any | UNKNOWN |
ubuntu | 16.04 | noarch | netty | < 1:4.0.34-1ubuntu0.1~esm1 | UNKNOWN |
github.com/Netflix/zuul/pull/980
github.com/netty/netty/commit/89c241e3b1795ff257af4ad6eadc616cb2fb3dc4
github.com/netty/netty/security/advisories/GHSA-wm47-8v5p-wjpj
launchpad.net/bugs/cve/CVE-2021-21295
nvd.nist.gov/vuln/detail/CVE-2021-21295
security-tracker.debian.org/tracker/CVE-2021-21295
ubuntu.com/security/notices/USN-6049-1
www.cve.org/CVERecord?id=CVE-2021-21295
5.9 Medium
CVSS3
Attack Vector
NETWORK
Attack Complexity
HIGH
Privileges Required
NONE
User Interaction
NONE
Scope
UNCHANGED
Confidentiality Impact
NONE
Integrity Impact
HIGH
Availability Impact
NONE
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:H/A:N
2.6 Low
CVSS2
Access Vector
NETWORK
Access Complexity
HIGH
Authentication
NONE
Confidentiality Impact
NONE
Integrity Impact
PARTIAL
Availability Impact
NONE
AV:N/AC:H/Au:N/C:N/I:P/A:N
0.184 Low
EPSS
Percentile
96.1%