mirror of
				https://github.com/openpgpjs/openpgpjs.git
				synced 2025-10-14 00:59:29 +00:00 
			
		
		
		
	Use JS fallback code for RSA message decryption in Node if PKCS#1 is not supported (#1728)
Necessary as Node v18.19.1, 20.11.1 and 21.6.2 have disabled support for PKCS#1 decryption.
This commit is contained in:
		
							parent
							
								
									7a6b41fbd4
								
							
						
					
					
						commit
						a4e2c56c49
					
				| @ -140,8 +140,15 @@ export async function encrypt(data, n, e) { | |||||||
|  * @async |  * @async | ||||||
|  */ |  */ | ||||||
| export async function decrypt(data, n, e, d, p, q, u, randomPayload) { | export async function decrypt(data, n, e, d, p, q, u, randomPayload) { | ||||||
|   if (util.getNodeCrypto()) { |   // Node v18.19.1, 20.11.1 and 21.6.2 have disabled support for PKCS#1 decryption,
 | ||||||
|     return nodeDecrypt(data, n, e, d, p, q, u, randomPayload); |   // and we want to avoid checking the error type to decide if the random payload
 | ||||||
|  |   // should indeed be returned.
 | ||||||
|  |   if (util.getNodeCrypto() && !randomPayload) { | ||||||
|  |     try { | ||||||
|  |       return await nodeDecrypt(data, n, e, d, p, q, u); | ||||||
|  |     } catch (err) { | ||||||
|  |       util.printDebugError(err); | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|   return bnDecrypt(data, n, e, d, p, q, u, randomPayload); |   return bnDecrypt(data, n, e, d, p, q, u, randomPayload); | ||||||
| } | } | ||||||
| @ -443,7 +450,7 @@ async function bnEncrypt(data, n, e) { | |||||||
|   return data.modExp(e, n).toUint8Array('be', n.byteLength()); |   return data.modExp(e, n).toUint8Array('be', n.byteLength()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function nodeDecrypt(data, n, e, d, p, q, u, randomPayload) { | async function nodeDecrypt(data, n, e, d, p, q, u) { | ||||||
|   const { default: BN } = await import('bn.js'); |   const { default: BN } = await import('bn.js'); | ||||||
| 
 | 
 | ||||||
|   const pBNum = new BN(p); |   const pBNum = new BN(p); | ||||||
| @ -477,9 +484,6 @@ async function nodeDecrypt(data, n, e, d, p, q, u, randomPayload) { | |||||||
|   try { |   try { | ||||||
|     return new Uint8Array(nodeCrypto.privateDecrypt(key, data)); |     return new Uint8Array(nodeCrypto.privateDecrypt(key, data)); | ||||||
|   } catch (err) { |   } catch (err) { | ||||||
|     if (randomPayload) { |  | ||||||
|       return randomPayload; |  | ||||||
|     } |  | ||||||
|     throw new Error('Decryption error'); |     throw new Error('Decryption error'); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1188,7 +1188,7 @@ Fk7EflUZzngwY4lBzYAfnNBjEjc30xD/ddo+rwE= | |||||||
|       ], |       ], | ||||||
|       config |       config | ||||||
|     }); |     }); | ||||||
|     expect(openpgp.decrypt({ |     await expect(openpgp.decrypt({ | ||||||
|       message: await openpgp.readMessage({ armoredMessage: message_with_notation }), |       message: await openpgp.readMessage({ armoredMessage: message_with_notation }), | ||||||
|       decryptionKeys: privKey, |       decryptionKeys: privKey, | ||||||
|       verificationKeys: privKey, |       verificationKeys: privKey, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 larabr
						larabr