Fix unhandled promise rejection when decrypting non-MDC message
This commit is contained in:
parent
13c29b1fc9
commit
11fd2313a7
|
@ -78,7 +78,8 @@ SymmetricallyEncrypted.prototype.write = function () {
|
|||
* @async
|
||||
*/
|
||||
SymmetricallyEncrypted.prototype.decrypt = async function (sessionKeyAlgorithm, key) {
|
||||
const decrypted = crypto.cfb.decrypt(sessionKeyAlgorithm, key, await stream.readToEnd(this.encrypted), true);
|
||||
this.encrypted = await stream.readToEnd(this.encrypted);
|
||||
const decrypted = crypto.cfb.decrypt(sessionKeyAlgorithm, key, this.encrypted, true);
|
||||
// If MDC errors are not being ignored, all missing MDC packets in symmetrically encrypted data should throw an error
|
||||
if (!this.ignore_mdc_error) {
|
||||
throw new Error('Decryption failed due to missing MDC.');
|
||||
|
|
|
@ -77,12 +77,12 @@ describe("Packet", function() {
|
|||
|
||||
await enc.encrypt(algo, key);
|
||||
|
||||
const msg2 = new openpgp.packet.List();
|
||||
await msg2.read(message.write());
|
||||
msg2[0].ignore_mdc_error = true;
|
||||
await msg2[0].decrypt(algo, key);
|
||||
const msg2 = new openpgp.message.Message();
|
||||
await msg2.packets.read(message.write());
|
||||
msg2.packets[0].ignore_mdc_error = true;
|
||||
const dec = await msg2.decrypt(null, null, [{ algorithm: algo, data: key }]);
|
||||
|
||||
expect(await stringify(msg2[0].packets[0].data)).to.equal(stringify(literal.data));
|
||||
expect(await stringify(dec.packets[0].data)).to.equal(stringify(literal.data));
|
||||
});
|
||||
|
||||
it('Symmetrically encrypted packet - MDC error for modern cipher', async function() {
|
||||
|
|
Loading…
Reference in New Issue
Block a user