-
Notifications
You must be signed in to change notification settings - Fork 796
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
**SECURITY**: Three RSA PKCS#1 v1.5 signature verification issues were reported by Moosa Yahyazadeh ([email protected]): - Leniency in checking `digestAlgorithm` structure can lead to signature forgery. - The code is lenient in checking the digest algorithm structure. This can allow a crafted structure that steals padding bytes and uses unchecked portion of the PKCS#1 encoded message to forge a signature when a low public exponent is being used. - Failing to check tailing garbage bytes can lead to signature forgery. - The code does not check for tailing garbage bytes after decoding a `DigestInfo` ASN.1 structure. This can allow padding bytes to be removed and garbage data added to forge a signature when a low public exponent is being used. - Leniency in checking type octet. - `DigestInfo` is not properly checked for proper ASN.1 structure. This can lead to successful verification with signatures that contain invalid structures but a valid digest. For more information, please see "Bleichenbacher's RSA signature forgery based on implementation error" by Hal Finney: https://mailarchive.ietf.org/arch/msg/openpgp/5rnE9ZRN1AokBVj3VqblGlP63QE/ Fixed with the following: - [asn1] `fromDer` is now more strict and will default to ensuring all input bytes are parsed or throw an error. A new option `parseAllBytes` can disable this behavior. - **NOTE**: The previous behavior is being changed since it can lead to security issues with crafted inputs. It is possible that code doing custom DER parsing may need to adapt to this new behavior and optional flag. - [rsa] Add and use a validator to check for proper structure of parsed ASN.1 `RSASSA-PKCS-v1_5` `DigestInfo` data. Additionally check that the hash algorithm identifier is a known value. An invalid `DigestInfo` or algorithm identifier will now cause an error to be thrown. - [oid] Added `1.2.840.113549.2.2` / `md2` for hash algorithm checking. - [tests] Tests were added for all of the reported issues. A private verify option was added to assist in checking multiple possible failures in the test data.
- Loading branch information
Showing
5 changed files
with
284 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,8 +3,46 @@ Forge ChangeLog | |
|
||
## 1.3.0 - 2022-XXX | ||
|
||
### Security | ||
- **SECURITY**: Three RSA PKCS#1 v1.5 signature verification issues were | ||
reported by Moosa Yahyazadeh ([email protected]). | ||
- Leniency in checking `digestAlgorithm` structure can lead to signature | ||
forgery. | ||
- The code is lenient in checking the digest algorithm structure. This can | ||
allow a crafted structure that steals padding bytes and uses unchecked | ||
portion of the PKCS#1 encoded message to forge a signature when a low | ||
public exponent is being used. For more information, please see | ||
["Bleichenbacher's RSA signature forgery based on implementation | ||
error"](https://mailarchive.ietf.org/arch/msg/openpgp/5rnE9ZRN1AokBVj3VqblGlP63QE/) | ||
by Hal Finney. | ||
- Failing to check tailing garbage bytes can lead to signature forgery. | ||
- The code does not check for tailing garbage bytes after decoding a | ||
`DigestInfo` ASN.1 structure. This can allow padding bytes to be removed | ||
and garbage data added to forge a signature when a low public exponent is | ||
being used. For more information, please see ["Bleichenbacher's RSA | ||
signature forgery based on implementation | ||
error"](https://mailarchive.ietf.org/arch/msg/openpgp/5rnE9ZRN1AokBVj3VqblGlP63QE/) | ||
by Hal Finney. | ||
- Leniency in checking type octet. | ||
- `DigestInfo` is not properly checked for proper ASN.1 structure. This can | ||
lead to successful verification with signatures that contain invalid | ||
structures but a valid digest. | ||
|
||
### Fixed | ||
- [asn1] Add fallback to pretty print invalid UTF8 data. | ||
- [asn1] `fromDer` is now more strict and will default to ensuring all input | ||
bytes are parsed or throw an error. A new option `parseAllBytes` can disable | ||
this behavior. | ||
- **NOTE**: The previous behavior is being changed since it can lead to | ||
security issues with crafted inputs. It is possible that code doing custom | ||
DER parsing may need to adapt to this new behavior and optional flag. | ||
- [rsa] Add and use a validator to check for proper structure of parsed ASN.1 | ||
`RSASSA-PKCS-v1_5` `DigestInfo` data. Additionally check that the hash | ||
algorithm identifier is a known value. An invalid `DigestInfo` or algorithm | ||
identifier will now cause an error to be thrown. | ||
|
||
### Added | ||
- [oid] Added `1.2.840.113549.2.2` / `md2` for hash algorithm checking. | ||
|
||
## 1.2.1 - 2022-01-11 | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.