Bug 2438762 (CVE-2026-26007)

Summary: CVE-2026-26007 cryptography: cryptography Subgroup Attack Due to Missing Subgroup Validation for SECT Curves
Product: [Other] Security Response Reporter: OSIDB Bzimport <bzimport>
Component: vulnerabilityAssignee: Product Security DevOps Team <prodsec-dev>
Status: NEW --- QA Contact:
Severity: high Docs Contact:
Priority: high    
Version: unspecifiedCC: adudiak, alcohan, anpicker, anthomas, aprice, bdettelb, bparees, brasmith, caswilli, cmyers, cochase, crizzo, derez, dfreiber, dnakabaa, doconnor, dranck, drow, dschmidt, ebourniv, ehelms, erezende, ggainey, gparvin, hasun, jbalunas, jburrell, jdobes, jfula, jkoehler, jmitchel, jowilson, jsamir, juwatts, jwong, kaycoth, kgaikwad, kshier, lball, lcouzens, lgallett, ljawale, lphiri, luizcosta, mattdavi, mhulan, ngough, nmoumoul, nweather, nyancey, oezr, omaciel, ometelka, orabin, osousa, pahickey, pakotvan, pbohmill, pcreech, ptisnovs, rbobbitt, rchan, rhaigner, sbunciak, smallamp, smcdonal, stcannon, sthirugn, syedriko, teagle, tmalecek, ttakamiy, veshanka, vkumar, xdharmai, yguenane
Target Milestone: ---Keywords: Security
Target Release: ---   
Hardware: All   
OS: Linux   
Whiteboard:
Fixed In Version: Doc Type: ---
Doc Text:
A validation flaw has been discovered in the python cryptography package. This missing validation allows an attacker to provide a public key point P from a small-order subgroup. This can lead to security issues in various situations, such as the most commonly used signature verification (ECDSA) and shared key negotiation (ECDH). When the victim computes the shared secret as S = [victim_private_key]P via ECDH, this leaks information about victim_private_key mod (small_subgroup_order). For curves with cofactor > 1, this reveals the least significant bits of the private key. When these weak public keys are used in ECDSA , it's easy to forge signatures on the small subgroup. Only SECT curves are impacted by this.
Story Points: ---
Clone Of: Environment:
Last Closed: Type: ---
Regression: --- Mount Type: ---
Documentation: --- CRM:
Verified Versions: Category: ---
oVirt Team: --- RHEL 7.3 requirements from Atomic Host:
Cloudforms Team: --- Target Upstream Version:
Embargoed:
Bug Depends On: 2438777, 2438778, 2438779, 2438780, 2438781, 2438782    
Bug Blocks:    

Description OSIDB Bzimport 2026-02-10 22:01:23 UTC
cryptography is a package designed to expose cryptographic primitives and recipes to Python developers. Prior to 46.0.5, the public_key_from_numbers (or EllipticCurvePublicNumbers.public_key()), EllipticCurvePublicNumbers.public_key(), load_der_public_key() and load_pem_public_key() functions do not verify that the point belongs to the expected prime-order subgroup of the curve. This missing validation allows an attacker to provide a public key point P from a small-order subgroup. This can lead to security issues in various situations, such as the most commonly used signature verification (ECDSA) and shared key negotiation (ECDH). When the victim computes the shared secret as S = [victim_private_key]P via ECDH, this leaks information about victim_private_key mod (small_subgroup_order). For curves with cofactor > 1, this reveals the least significant bits of the private key. When these weak public keys are used in ECDSA , it's easy to forge signatures on the small subgroup. Only SECT curves are impacted by this. This vulnerability is fixed in 46.0.5.