GHSA-v638-38fc-rhfv

Suggest an improvement
Source
https://github.com/advisories/GHSA-v638-38fc-rhfv
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-v638-38fc-rhfv/GHSA-v638-38fc-rhfv.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-v638-38fc-rhfv
Aliases
  • CVE-2026-6550
Published
2026-04-24T15:59:17Z
Modified
2026-04-24T16:16:32.746296Z
Severity
  • 4.7 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:N/I:H/A:N CVSS Calculator
  • 5.7 (Medium) CVSS_V4 - CVSS:4.0/AV:L/AC:H/AT:P/PR:L/UI:N/VC:N/VI:H/VA:N/SC:N/SI:N/SA:N CVSS Calculator
Summary
AWS Encryption SDK for Python: Key commitment policy bypass via shared key cache
Details

Summary

AWS Encryption SDK (ESDK) for Python is a client-side encryption library. An issue exists where, under certain circumstances, a specific cryptographic algorithm downgrade in the caching layer might allow an authenticated local threat actor to bypass key commitment policy enforcement via a shared key cache, resulting in ciphertext that can be decrypted to multiple different plaintexts.

Impact

This issue requires all of the following conditions to be true: (1) Two ESDK for Python clients with different commitment policies share a single CachingCryptoMaterialsManager instance within the same process. (2) The client with the weaker commitment policy encrypts first, warming the cache. (3) Both clients use matching encryption contexts. (4) Both clients use the pre-configured default algorithm suite.

These conditions may occur during a migration from ESDK for Python v1 to newer versions, as v1 did not support key commitment.

When the weaker-policy client encrypts first, the cache stores encryption materials that do not enforce key commitment. Subsequent callers — including those configured to require key commitment — are served these cached materials instead of generating new ones that satisfy their policy. This results in encryption without key commitment, meaning the same ciphertext can be validly decrypted to different plaintexts under different keys (the "Invisible Salamanders" issue; see https://github.com/google/security-research/security/advisories/GHSA-wqgp-vphw-hphf). A threat actor who controls ciphertext can cause a recipient to decrypt a message different from what the sender encrypted, breaking message integrity.

Impacted versions

  • From 2.0 to 2.5.1
  • From 3.0 to 3.3.0
  • From 4.0 to 4.0.4

Patches

This issue has been addressed in ESDK for Python versions 3.3.1 and 4.0.5. We recommend upgrading to the latest version and ensuring any forked or derivative code is patched to incorporate the new fixes.

Workarounds

If a customer requires operating multiple instances of the Python ESDK each with differently configured key commitment policies, they must not share a key cache.

References If there are any questions or comments about this advisory, contact AWS Security through the vulnerability reporting page or directly via email to aws-security@amazon.com. Please do not create a public GitHub issue.

Acknowledgement

Thanks to 1seal.org for collaborating on this issue through the coordinated vulnerability disclosure process.

Database specific
{
    "github_reviewed_at": "2026-04-24T15:59:17Z",
    "github_reviewed": true,
    "severity": "MODERATE",
    "nvd_published_at": "2026-04-20T20:16:49Z",
    "cwe_ids": [
        "CWE-757"
    ]
}
References

Affected packages

PyPI / aws-encryption-sdk

Package

Name
aws-encryption-sdk
View open source insights on deps.dev
Purl
pkg:pypi/aws-encryption-sdk

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.0.0
Fixed
3.3.1

Affected versions

2.*
2.0.0
2.1.0
2.2.0
2.3.0
2.4.0
2.5.0
2.5.1
3.*
3.0.0
3.1.0
3.1.1
3.2.0
3.3.0

Database specific

last_known_affected_version_range
"< 3.3.0"
source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-v638-38fc-rhfv/GHSA-v638-38fc-rhfv.json"

PyPI / aws-encryption-sdk

Package

Name
aws-encryption-sdk
View open source insights on deps.dev
Purl
pkg:pypi/aws-encryption-sdk

Affected ranges

Type
ECOSYSTEM
Events
Introduced
4.0.0
Fixed
4.0.5

Affected versions

4.*
4.0.0
4.0.1
4.0.2
4.0.3
4.0.4

Database specific

last_known_affected_version_range
"< 4.0.4"
source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-v638-38fc-rhfv/GHSA-v638-38fc-rhfv.json"