CVE Vulnerabilities

CVE-2021-23351

Published: Mar 08, 2021 | Modified: Nov 21, 2024
CVSS 3.x
4.9
MEDIUM
Source:
NVD
CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:N/A:H
CVSS 2.x
4 MEDIUM
AV:N/AC:L/Au:S/C:N/I:N/A:P
RedHat/V2
RedHat/V3
Ubuntu
MEDIUM
root.io logo minimus.io logo echo.ai logo

The package github.com/pires/go-proxyproto before 0.5.0 are vulnerable to Denial of Service (DoS) via the parseVersion1() function. The reader in this package is a default bufio.Reader wrapping a net.Conn. It will read from the connection until it finds a newline. Since no limits are implemented in the code, a deliberately malformed V1 header could be used to exhaust memory in a server process using this code - and create a DoS. This can be exploited by sending a stream starting with PROXY and continuing to send data (which does not contain a newline) until the target stops acknowledging. The risk here is small, because only trusted sources should be allowed to send proxy protocol headers.

Affected Software

NameVendorStart VersionEnd Version
Go-proxyprotoGo-proxyproto_project*0.5.0 (excluding)
Golang-github-pires-go-proxyprotoUbuntuesm-apps/jammy*
Golang-github-pires-go-proxyprotoUbuntuhirsute*
Golang-github-pires-go-proxyprotoUbuntuimpish*
Golang-github-pires-go-proxyprotoUbuntujammy*
Golang-github-pires-go-proxyprotoUbuntukinetic*
Golang-github-pires-go-proxyprotoUbuntulunar*
Golang-github-pires-go-proxyprotoUbuntumantic*
Golang-github-pires-go-proxyprotoUbuntutrusty*
Golang-github-pires-go-proxyprotoUbuntuupstream*

References