| 
									
										
										
										
											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 23:16:27 -07:00
										 |  |  |   var keypair = require('crypto').generateKeyPairSync( | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  |     'rsa' | 
					
						
							|  |  |  |   , { modulusLength: bitlen | 
					
						
							|  |  |  |     , publicExponent: exp | 
					
						
							|  |  |  |     , privateKeyEncoding: { | 
					
						
							| 
									
										
										
										
											2018-12-16 02:54:57 -07:00
										 |  |  |         type: 'pkcs1' | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  |       , format: 'pem' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     , publicKeyEncoding: { | 
					
						
							| 
									
										
										
										
											2018-12-16 02:54:57 -07:00
										 |  |  |         type: 'pkcs1' | 
					
						
							| 
									
										
										
										
											2018-12-15 22:31:17 -07:00
										 |  |  |       , format: 'pem' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-12-15 23:16:27 -07:00
										 |  |  |   ); | 
					
						
							|  |  |  |   var result = { | 
					
						
							|  |  |  |     publicKeyPem: keypair.publicKey.trim() | 
					
						
							|  |  |  |   , privateKeyPem: keypair.privateKey.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
										 |  |  | } |