| 
									
										
										
										
											2019-10-04 17:35:59 -06:00
										 |  |  | // Copyright 2016-2018 AJ ONeal. All rights reserved
 | 
					
						
							|  |  |  | /* This Source Code Form is subject to the terms of the Mozilla Public | 
					
						
							|  |  |  |  * License, v. 2.0. If a copy of the MPL was not distributed with this | 
					
						
							|  |  |  |  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | 
					
						
							|  |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var oldver = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-08 13:02:43 -06:00
										 |  |  | module.exports = function(bitlen, exp) { | 
					
						
							|  |  |  | 	bitlen = parseInt(bitlen, 10) || 2048; | 
					
						
							|  |  |  | 	exp = parseInt(exp, 10) || 65537; | 
					
						
							| 
									
										
										
										
											2019-10-04 17:35:59 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-08 13:02:43 -06:00
										 |  |  | 	try { | 
					
						
							|  |  |  | 		return require('./generate-privkey-node.js')(bitlen, exp); | 
					
						
							|  |  |  | 	} catch (e) { | 
					
						
							|  |  |  | 		if (!/generateKeyPairSync is not a function/.test(e.message)) { | 
					
						
							|  |  |  | 			throw e; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		try { | 
					
						
							|  |  |  | 			return require('./generate-privkey-ursa.js')(bitlen, exp); | 
					
						
							|  |  |  | 		} catch (e) { | 
					
						
							|  |  |  | 			if (e.code !== 'MODULE_NOT_FOUND') { | 
					
						
							|  |  |  | 				console.error( | 
					
						
							|  |  |  | 					"[rsa-compat] Unexpected error when using 'ursa':" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				console.error(e); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if (!oldver) { | 
					
						
							|  |  |  | 				oldver = true; | 
					
						
							|  |  |  | 				console.warn( | 
					
						
							|  |  |  | 					'[WARN] rsa-compat: Your version of node does not have crypto.generateKeyPair()' | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				console.warn( | 
					
						
							|  |  |  | 					"[WARN] rsa-compat: Please update to node >= v10.12 or 'npm install --save ursa node-forge'" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				console.warn( | 
					
						
							|  |  |  | 					'[WARN] rsa-compat: Using node-forge as a fallback may be unacceptably slow.' | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				if (/arm|mips/i.test(require('os').arch)) { | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'================================================================' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn('                         WARNING'); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'================================================================' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn(''); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'WARNING: You are generating an RSA key using pure JavaScript on' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'         a VERY SLOW cpu. This could take DOZENS of minutes!' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn(''); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						"         We recommend installing node >= v10.12, or 'gcc' and 'ursa'" | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn(''); | 
					
						
							|  |  |  | 					console.warn('EXAMPLE:'); | 
					
						
							|  |  |  | 					console.warn(''); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'        sudo apt-get install build-essential && npm install ursa' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 					console.warn(''); | 
					
						
							|  |  |  | 					console.warn( | 
					
						
							|  |  |  | 						'================================================================' | 
					
						
							|  |  |  | 					); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			try { | 
					
						
							|  |  |  | 				return require('./generate-privkey-forge.js')(bitlen, exp); | 
					
						
							|  |  |  | 			} catch (e) { | 
					
						
							|  |  |  | 				if (e.code !== 'MODULE_NOT_FOUND') { | 
					
						
							|  |  |  | 					throw e; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				console.error( | 
					
						
							|  |  |  | 					'[ERROR] rsa-compat: could not generate a private key.' | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				console.error( | 
					
						
							|  |  |  | 					'None of crypto.generateKeyPair, ursa, nor node-forge are present' | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-10-04 17:35:59 -06:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (require.main === module) { | 
					
						
							| 
									
										
										
										
											2019-10-08 13:02:43 -06:00
										 |  |  | 	var keypair = module.exports(2048, 0x10001); | 
					
						
							|  |  |  | 	console.info(keypair.privateKeyPem); | 
					
						
							| 
									
										
										
										
											2019-10-04 17:35:59 -06:00
										 |  |  | } |