Skip to main content

Improper Check for Unusual or Exceptional Conditions

CVE-2023-5678

Severity Medium
Score 5.3/10

Summary

Generating excessively long X9.42 DH keys or checking excessively long X9.42 DH keys or parameters may be very slow. Applications that use the functions "DH_generate_key()" to generate an X9.42 DH key may experience long delays. Likewise, applications that use "DH_check_pub_key()", "DH_check_pub_key_ex()" or "EVP_PKEY_public_check()" to check an X9.42 DH key or X9.42 DH parameters may experience long delays. Where the key or parameters that are being checked have been obtained from an untrusted source this may lead to a Denial of Service. While "DH_check()" performs all the necessary checks (as of CVE-2023-3817), "DH_check_pub_key()" doesn't make any of these checks, and is therefore vulnerable for excessively large P and Q parameters. Likewise, while "DH_generate_key()" performs a check for an excessively large P, it doesn't check for an excessively large Q. An application that calls "DH_generate_key()" or "DH_check_pub_key()" and supplies a key or parameters obtained from an untrusted source could be vulnerable to a Denial of Service attack. "DH_generate_key()" and "DH_check_pub_key()" are also called by a number of other OpenSSL functions. An application calling any of those other functions may similarly be affected. The other functions affected by this are "DH_check_pub_key_ex()", "EVP_PKEY_public_check()", and "EVP_PKEY_generate()". Also vulnerable are the OpenSSL pkey command line application when using the "-pubcheck" option, as well as the OpenSSL genpkey command line application. The OpenSSL SSL/TLS implementation is not affected by this issue. The OpenSSL 3.0 and 3.1 FIPS providers are not affected by this issue. This issue affects the openssl versions 1.0.2 through 1.0.2u, 1.1.1 through 1.1.1w, 3.0.0-alpha1 through 3.0.12, 3.1.0-alpha1 through 3.1.4, and openssl-3.2.0-alpha1 through openssl-3.2.0-beta1.

  • LOW
  • NETWORK
  • NONE
  • UNCHANGED
  • NONE
  • NONE
  • NONE
  • LOW

CWE-754 - Improper Check for Unusual or Exceptional Conditions

The software does not check or incorrectly checks for unusual or exceptional conditions that are not expected to occur frequently during day to day operation of the software.

Advisory Timeline

  • Published