56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // 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';
 | |
| 
 | |
| module.exports = function(bitlen, exp) {
 | |
| 	var k = require('node-forge').pki.rsa.generateKeyPair({
 | |
| 		bits: bitlen || 2048,
 | |
| 		e: exp || 0x10001
 | |
| 	}).privateKey;
 | |
| 	var jwk = {
 | |
| 		kty: 'RSA',
 | |
| 		n: _toUrlBase64(k.n),
 | |
| 		e: _toUrlBase64(k.e),
 | |
| 		d: _toUrlBase64(k.d),
 | |
| 		p: _toUrlBase64(k.p),
 | |
| 		q: _toUrlBase64(k.q),
 | |
| 		dp: _toUrlBase64(k.dP),
 | |
| 		dq: _toUrlBase64(k.dQ),
 | |
| 		qi: _toUrlBase64(k.qInv)
 | |
| 	};
 | |
| 	return {
 | |
| 		private: jwk,
 | |
| 		public: {
 | |
| 			kty: jwk.kty,
 | |
| 			n: jwk.n,
 | |
| 			e: jwk.e
 | |
| 		}
 | |
| 	};
 | |
| };
 | |
| 
 | |
| function _toUrlBase64(fbn) {
 | |
| 	var hex = fbn.toRadix(16);
 | |
| 	if (hex.length % 2) {
 | |
| 		// Invalid hex string
 | |
| 		hex = '0' + hex;
 | |
| 	}
 | |
| 	while ('00' === hex.slice(0, 2)) {
 | |
| 		hex = hex.slice(2);
 | |
| 	}
 | |
| 	return Buffer.from(hex, 'hex')
 | |
| 		.toString('base64')
 | |
| 		.replace(/\+/g, '-')
 | |
| 		.replace(/\//g, '_')
 | |
| 		.replace(/=/g, '');
 | |
| }
 | |
| 
 | |
| if (require.main === module) {
 | |
| 	var keypair = module.exports(2048, 0x10001);
 | |
| 	console.info(keypair.private);
 | |
| 	console.warn(keypair.public);
 | |
| 	//console.info(keypair.privateKeyJwk);
 | |
| 	//console.warn(keypair.publicKeyJwk);
 | |
| }
 |