CVE-2026-55568 PUBLISHED

Guzzle: Silent HTTPS-Proxy Downgrade to Cleartext

Assigner: GitHub_M
Reserved: 16.06.2026 Published: 23.06.2026 Updated: 23.06.2026

Guzzle is an extensible PHP HTTP client. Prior to 7.12.1, in certain configurations, traffic expected to be protected by TLS on the hop to the proxy is transmitted in cleartext. Proxy authentication credentials (the Proxy-Authorization header, proxy userinfo in the proxy URL, or CURLOPT_PROXYUSERPWD) are sent without encryption, and the CONNECT target host and port for tunneled HTTPS requests are exposed. The built-in cURL handlers (GuzzleHttp\Handler\CurlHandler and GuzzleHttp\Handler\CurlMultiHandler, used by default whenever the PHP cURL extension is available) accept an https:// proxy. libcurl older than 7.50.2 silently treats an https:// proxy as a plaintext http:// proxy. The TLS connection to the proxy is never established, and the proxy leg is cleartext with no error or warning. An application is affected when it sends requests through one of the built-in cURL handlers, configures an https:// proxy expecting the proxy connection itself to be encrypted, and runs with libcurl older than 7.50.2. This vulnerability is fixed in 7.12.1.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:N/A:N
CVSS Score: 5.9

Product Status

Vendor guzzle
Product guzzle
Versions
  • Version < 7.12.1 is affected

References

Problem Types

  • CWE-311: Missing Encryption of Sensitive Data CWE
  • CWE-319: Cleartext Transmission of Sensitive Information CWE
  • CWE-636: Not Failing Securely ('Failing Open') CWE