CVE-2021-3450
Vulnerability Summary
Timeline
Description
The X509_V_FLAG_X509_STRICT flag enables additional security checks of the certificates present in a certificate chain. It is not set by default. Starting from OpenSSL version 1.1.1h a check to disallow certificates in the chain that have explicitly encoded elliptic curve parameters was added as an additional strict check. An error in the implementation of this check meant that the result of a previous check to confirm that certificates in the chain are valid CA certificates was overwritten. This effectively bypasses the check that non-CA certificates must not be able to issue other certificates. If a "purpose" has been configured then there is a subsequent opportunity for checks that the certificate is a valid CA. All of the named "purpose" values implemented in libcrypto perform this check. Therefore, where a purpose is set the certificate chain will still be rejected even when the strict flag has been used. A purpose is set by default in libssl client and server certificate verification routines, but it can be overridden or removed by an application. In order to be affected, an application must explicitly set the X509_V_FLAG_X509_STRICT verification flag and either not set a purpose for the certificate verification or, in the case of TLS client or server applications, override the default purpose. OpenSSL versions 1.1.1h and newer are affected by this issue. Users of these versions should upgrade to OpenSSL 1.1.1k. OpenSSL 1.0.2 is not impacted by this issue. Fixed in OpenSSL 1.1.1k (Affected 1.1.1h-1.1.1j).
CVSS Metrics
- v3.1•HIGH•Score: 7.4CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N
- v2.0•MEDIUM•Score: 5.8AV:N/AC:M/Au:N/C:P/I:P/A:N
EPSS Trends
Current EPSS score: 0.50%• Percentile: 67%
Techniques & Countermeasures
- CWE-295•Improper Certificate Validation
The product does not validate, or incorrectly validates, a certificate.
Affected Systems
- Crates.Io•openssl-src
≥ 111.11.0, < 111.15.0
- fedoraproject•fedora
34
- freebsd•freebsd
12.2 | 12.2:p1 | 12.2:p2
- mcafee•web_gateway
8.2.19 | 9.2.10 | 10.1.1
- mcafee•web_gateway_cloud_service
8.2.19 | 9.2.10 | 10.1.1
- netapp•cloud_volumes_ontap_mediator
na
- netapp•oncommand_workflow_automation
na
- netapp•ontap_select_deploy_administration_utility
na
- netapp•santricity_smi-s_provider
na
- netapp•storagegrid
na
- nodejs•node.js
≥ 10.0.0, < 10.24.1 | ≥ 12.0.0, < 12.22.1 | ≥ 14.0.0, < 14.16.1 | ≥ 15.0.0, < 15.14.0
- Unknown•OpenSSL
≥ 1.1.1h, < 1.1.1k | Fixed in OpenSSL 1.1.1k (Affected 1.1.1h-1.1.1j)
- oracle•commerce_guided_search
11.3.2
- oracle•enterprise_manager_for_storage_management
13.4.0.0
- oracle•graalvm
19.3.5 | 20.3.1.2 | 21.0.0.2
- oracle•jd_edwards_enterpriseone_tools
< 9.2.6.0
- oracle•jd_edwards_world_security
a9.4
- oracle•mysql_connectors
≤ 8.0.23
- oracle•mysql_enterprise_monitor
≤ 8.0.23
- oracle•mysql_server
≤ 5.7.33 | ≥ 8.0.15, ≤ 8.0.23
- oracle•mysql_workbench
≤ 8.0.23
- oracle•peoplesoft_enterprise_peopletools
≥ 8.57, ≤ 8.59
- oracle•secure_backup
< 18.1.0.1.0
- oracle•secure_global_desktop
5.6
- Unknown•WebLogic Server
12.2.1.4.0 | 14.1.1.0.0
- sonicwall•capture_client
< 3.6.24
- sonicwall•email_security
< 10.0.11
- Unknown•SMA100
< 10.2.1.0-17sv
- Unknown•SonicOS
≤ 7.0.1-r1456
- tenable•nessus
≤ 8.13.1
- tenable•nessus_agent
≥ 8.2.1, ≤ 8.2.3
- tenable•nessus_network_monitor
5.11.0 | 5.11.1 | 5.12.0 | 5.12.1 | 5.13.0
- windriver•linux
na | 17.0 | 18.0 | 19.0
References (31)
- https://www.openssl.org/news/secadv/20210325.txt
- https://git.openssl.org/gitweb/?p=openssl.git%3Ba=commitdiff%3Bh=2a40b7bc7b94dd7de897a74571e7024f0cf0d63b
- https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-openssl-2021-GHY28dJd
- http://www.openwall.com/lists/oss-security/2021/03/27/1
- http://www.openwall.com/lists/oss-security/2021/03/27/2
- http://www.openwall.com/lists/oss-security/2021/03/28/3
- http://www.openwall.com/lists/oss-security/2021/03/28/4
- https://security.gentoo.org/glsa/202103-03
- https://lists.fedoraproject.org/archives/list/package-announce%40lists.fedoraproject.org/message/CCBFLLVQVILIVGZMBJL3IXZGKWQISYNP/
- https://www.oracle.com/security-alerts/cpuApr2021.html
- https://www.tenable.com/security/tns-2021-09
- https://security.netapp.com/advisory/ntap-20210326-0006/
- https://security.FreeBSD.org/advisories/FreeBSD-SA-21:07.openssl.asc
- https://www.tenable.com/security/tns-2021-05
- https://kc.mcafee.com/corporate/index?page=content&id=SB10356
- https://www.tenable.com/security/tns-2021-08
- https://mta.openssl.org/pipermail/openssl-announce/2021-March/000198.html
- https://www.oracle.com//security-alerts/cpujul2021.html
- https://kb.pulsesecure.net/articles/Pulse_Security_Advisories/SA44845
- https://psirt.global.sonicwall.com/vuln-detail/SNWLID-2021-0013
- https://www.oracle.com/security-alerts/cpuoct2021.html
- https://www.oracle.com/security-alerts/cpuapr2022.html
- https://cert-portal.siemens.com/productcert/pdf/ssa-389290.pdf
- https://www.oracle.com/security-alerts/cpujul2022.html
- https://nvd.nist.gov/vuln/detail/CVE-2021-3450
- https://security.netapp.com/advisory/ntap-20210326-0006
- https://rustsec.org/advisories/RUSTSEC-2021-0056.html
- https://lists.fedoraproject.org/archives/list/package-announce@lists.fedoraproject.org/message/CCBFLLVQVILIVGZMBJL3IXZGKWQISYNP
- https://github.com/alexcrichton/openssl-src-rs
- https://git.openssl.org/gitweb/?p=openssl.git;a=commitdiff;h=2a40b7bc7b94dd7de897a74571e7024f0cf0d63b
- https://crates.io/crates/openssl-src