| 
									
										
										
										
											2018-12-16 02:54:57 -07: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/. */
 | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-16 02:54:57 -07:00
										 |  |  | var Rasha = require('./rasha'); | 
					
						
							| 
									
										
										
										
											2018-12-15 23:16:27 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  | module.exports = function (bitlen, exp) { | 
					
						
							| 
									
										
										
										
											2018-12-15 22:39:14 -07:00
										 |  |  |   var ursa; | 
					
						
							|  |  |  |   try { | 
					
						
							|  |  |  |     ursa = require('ursa'); | 
					
						
							|  |  |  |   } catch(e) { | 
					
						
							|  |  |  |     ursa = require('ursa-optional'); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-12-15 23:16:27 -07:00
										 |  |  |   var keypair = ursa.generatePrivateKey(bitlen, exp); | 
					
						
							|  |  |  |   var result = { | 
					
						
							|  |  |  |     publicKeyPem: keypair.toPublicPem().toString('ascii').trim() | 
					
						
							|  |  |  |   , privateKeyPem: keypair.toPrivatePem().toString('ascii').trim() | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   result.publicKeyJwk = Rasha.importSync({ pem: result.publicKeyPem, public: true }); | 
					
						
							|  |  |  |   result.privateKeyJwk = Rasha.importSync({ pem: result.privateKeyPem }); | 
					
						
							|  |  |  |   return result; | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (require.main === module) { | 
					
						
							| 
									
										
										
										
											2018-12-15 23:16:27 -07:00
										 |  |  |   var keypair = module.exports(2048, 0x10001); | 
					
						
							|  |  |  |   console.info(keypair.privateKeyPem); | 
					
						
							|  |  |  |   console.warn(keypair.publicKeyPem); | 
					
						
							|  |  |  |   //console.info(keypair.privateKeyJwk);
 | 
					
						
							|  |  |  |   //console.warn(keypair.publicKeyJwk);
 | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  | } |