libcurl offers "OCSP stapling" via the CURLOPT_SSL_VERIFYSTATUS
option. When
set, libcurl verifies the OCSP response that a server responds with as part of
the TLS handshake. It then aborts the TLS negotiation if something is wrong
with the response. The same feature can be enabled with --cert-status
using
the curl tool.
As part of the OCSP response verification, a client should verify that the response is indeed set out for the correct certificate. This step was not performed by libcurl when built or told to use OpenSSL as TLS backend.
This flaw would allow an attacker, who perhaps could have breached a TLS server, to provide a fraudulent OCSP response that would appear fine, instead of the real one. Like if the original certificate actually has been revoked.
{ "CWE": { "id": "CWE-299", "desc": "Improper Check for Certificate Revocation" }, "award": { "amount": "900", "currency": "USD" }, "URL": "https://curl.se/docs/CVE-2020-8286.json", "package": "curl", "severity": "Medium", "issue": "https://hackerone.com/reports/1048457", "www": "https://curl.se/docs/CVE-2020-8286.html", "last_affected": "7.73.0" }