Vulnerability Description
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.
CVSS Score
MEDIUM
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Go-Proxyproto Project | Go-Proxyproto | < 0.5.0 |
| Fedoraproject | Fedora | 33 |
References
- https://github.com/pires/go-proxyproto/commit/7f48261db810703d173f27f3309a808cc2PatchThird Party Advisory
- https://github.com/pires/go-proxyproto/issues/69Third Party Advisory
- https://github.com/pires/go-proxyproto/pull/71PatchThird Party Advisory
- https://lists.fedoraproject.org/archives/list/package-announce%40lists.fedorapro
- https://lists.fedoraproject.org/archives/list/package-announce%40lists.fedorapro
- https://snyk.io/vuln/SNYK-GOLANG-GITHUBCOMPIRESGOPROXYPROTO-1081577Third Party Advisory
- https://github.com/pires/go-proxyproto/commit/7f48261db810703d173f27f3309a808cc2PatchThird Party Advisory
- https://github.com/pires/go-proxyproto/issues/69Third Party Advisory
- https://github.com/pires/go-proxyproto/pull/71PatchThird Party Advisory
- https://lists.fedoraproject.org/archives/list/package-announce%40lists.fedorapro
- https://lists.fedoraproject.org/archives/list/package-announce%40lists.fedorapro
- https://snyk.io/vuln/SNYK-GOLANG-GITHUBCOMPIRESGOPROXYPROTO-1081577Third Party Advisory
FAQ
What is CVE-2021-23351?
CVE-2021-23351 is a vulnerability with a CVSS score of 4.4 (MEDIUM). 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....
How severe is CVE-2021-23351?
CVE-2021-23351 has been rated MEDIUM with a CVSS base score of 4.4/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2021-23351?
Check the references section above for vendor advisories and patch information. Affected products include: Go-Proxyproto Project Go-Proxyproto, Fedoraproject Fedora.