GHSA-55xh-53m6-936r

Suggest an improvement
Source
https://github.com/advisories/GHSA-55xh-53m6-936r
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2021/06/GHSA-55xh-53m6-936r/GHSA-55xh-53m6-936r.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-55xh-53m6-936r
Aliases
Published
2021-06-01T21:17:36Z
Modified
2024-12-02T05:55:18.043355Z
Summary
Improper Verification of Cryptographic Signature in aws-encryption-sdk-java
Details

Impact

This advisory addresses several LOW severity issues with streaming signed messages and restricting processing of certain types of invalid messages.

This update addresses an issue where certain invalid ECDSA signatures incorrectly passed validation. These signatures provide defense in depth and there is no impact on the integrity of decrypted plaintext.

This ESDK supports a streaming mode where callers may stream the plaintext of signed messages before the ECDSA signature is validated. In addition to these signatures, the ESDK uses AES-GCM encryption and all plaintext is verified before being released to a caller. There is no impact on the integrity of the ciphertext or decrypted plaintext, however some callers may rely on the the ECDSA signature for non-repudiation. Without validating the ECDSA signature, an actor with trusted KMS permissions to decrypt a message may also be able to encrypt messages. This update introduces a new API for callers who wish to stream only unsigned messages.

For customers who process ESDK messages from untrusted sources, this update also introduces a new configuration to limit the number of Encrypted Data Keys (EDKs) that the ESDK will attempt to process per message. This configuration provides customers with a way to limit the number of AWS KMS Decrypt API calls that the ESDK will make per message. This setting will reject messages with more EDKs than the configured limit.

Finally, this update adds early rejection of invalid messages with certain invalid combinations of algorithm suite and header data.

Patches

Fixed in versions 1.9 and 2.2. We recommend that all users upgrade to address these issues.

Customers leveraging the ESDK’s streaming features have several options to protect signature validation. One is to ensure that client code reads to the end of the stream before using released plaintext. With this release, using the new API for streaming and falling back to the non-streaming decrypt API for signed messages prevents using any plaintext from signed data before the signature is validated. See https://docs.aws.amazon.com/encryption-sdk/latest/developer-guide/about-versions.html#version2.2.x

Users processing ESDK messages from untrusted sources should use the new maximum encrypted data keys parameter. See https://docs.aws.amazon.com/encryption-sdk/latest/developer-guide/about-versions.html#version2.2.x

Workarounds

None

For more information

https://docs.aws.amazon.com/encryption-sdk/latest/developer-guide/concepts.html#digital-sigs

https://docs.aws.amazon.com/encryption-sdk/latest/developer-guide/about-versions.html#version2.2.x

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [
        "CWE-347"
    ],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2021-06-01T19:14:06Z"
}
References

Affected packages

Maven / com.amazonaws:aws-encryption-sdk-java

Package

Name
com.amazonaws:aws-encryption-sdk-java
View open source insights on deps.dev
Purl
pkg:maven/com.amazonaws/aws-encryption-sdk-java

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.9.0

Affected versions

0.*

0.0.1

1.*

1.3.0
1.3.1
1.3.1-STAGING
1.3.2
1.3.3
1.3.4
1.3.5
1.3.6
1.4.0
1.4.1
1.5.0
1.6.0
1.6.1
1.6.2
1.7.0

Maven / com.amazonaws:aws-encryption-sdk-java

Package

Name
com.amazonaws:aws-encryption-sdk-java
View open source insights on deps.dev
Purl
pkg:maven/com.amazonaws/aws-encryption-sdk-java

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.0.0
Fixed
2.2.0

Affected versions

2.*

2.0.0