HTTP: cURL and libcurl SOCKS5 Hostname Handling Heap Buffer Overflow

This signature detects attempts to exploit a known vulnerability against cURL. A successful attack can lead to a buffer overflow and arbitrary remote code execution within the context of the target user.

Extended Description

This flaw makes curl overflow a heap based buffer in the SOCKS5 proxy handshake. When curl is asked to pass along the host name to the SOCKS5 proxy to allow that to resolve the address instead of it getting done by curl itself, the maximum length that host name can be is 255 bytes. If the host name is detected to be longer, curl switches to local name resolving and instead passes on the resolved address only. Due to this bug, the local variable that means "let the host resolve the name" could get the wrong value during a slow SOCKS5 handshake, and contrary to the intention, copy the too long host name to the target buffer instead of copying just the resolved address there. The target buffer being a heap based buffer, and the host name coming from the URL that curl has been told to operate with.

Affected Products

Microsoft windows_11_21h2

References

CVE: CVE-2023-38545

Short Name
HTTP:OVERFLOW:CURL-SOCKS5-HSTNM
Severity
Critical
Recommended
True
Recommended Action
None
Category
HTTP
Keywords
Buffer CVE-2023-38545 Handling Heap Hostname Overflow SOCKS5 and cURL libcurl
Release Date
11/06/2023
Supported Platforms

srx-branch-19.3

vsrx3bsd-19.2

srx-19.4

vsrx3bsd-19.4

srx-branch-19.4

vsrx-19.4

vsrx-19.2

srx-19.3

Sigpack Version
3783
False Positive
Unknown
Vendors

Fedoraproject

Netapp

Haxx

Microsoft

Found a potential security threat?