-
Notifications
You must be signed in to change notification settings - Fork 53
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
NullPointerException when trying to decrypt non-encrypted data (v2.3.0) #58
Comments
Thanks for the very detailed error report! This seems to be a bug. I'll try to get into that during the weekend (or ideally review a PR ;-) ) |
Same here. Spent a couple of hours trying to understand what critical part is missing or I'm doing something completely wrong way. Until I searched "validateMDC" in this repo and get came upon this issue. Changed the version to 2.2.0 and it's working as expected. I'm not sure about PR in which cases MDCValidatingInputStream needs to be bypassed. |
It seems to be linked to my changes related to MDC verification @neuhalje |
@neuhalje / @Sauhardstark , can this be fixed asap?. we cannot downgrade to 2.2.0 as we had #56 issue in that release. Could you please check and let us know when can this be fixed. Thanks! |
Hi, I'll raise a PR for this immediately |
- Added a null check in MDC validation stream for signed but unencrypted streams - Fixes bug - neuhalje#58
- Added a null check in MDC validation stream for signed but unencrypted streams - Fixes bug - neuhalje#58
@SandeepLakka / @neuhalje - I've raised a PR for this. Please take a look |
It works for me |
Describe the bug
When we call the method
decryptAndVerifyStream
with an input stream that contains data that is not encrypted (for example only signed), there is a NullPointerException when reading the returned InputStream later thrown byname.neuhalfen.projects.crypto.bouncycastle.openpgp.decrypting.MDCValidatingInputStream.validateMDC
, where the local variablepbe
is null.In v2.2.0, there was no exception, trying to decrypt a non-encrypted stream just returned the original stream.
The same thing happens when trying to read an input stream obtained after trying to decrypt an input stream that was (incorrectly) encrypted twice (which is a unit test we are running).
The issue seems to be introduced by the following commit:
986d436#diff-f7bfd613f0ac7d22e02bd9c1727a319dad532f787e9de5ae702da71b252580b4
Here the new
MDCValidatingInputStream
class is introduced, and we see that the value ofpbe
comes fromDecryptionStreamFactory
, where it is initialized only if the methodnextDecryptedStream
finds an instance ofPGPEncryptedDataList
, otherwise it stays null and is passed to theMDCValidatingInputStream
where there is no null check.To Reproduce
In v2.3.0, execute a decryption with:
where
in
is an input stream containing not encrypted, but signed data.Expected behavior
No
NullPointerException
thrown.** System (please complete the following information):**
The text was updated successfully, but these errors were encountered: