2018-12-16 09:54:57 +00: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-16 05:31:17 +00:00
|
|
|
'use strict';
|
|
|
|
|
2019-03-14 17:59:31 +00:00
|
|
|
var Keypairs = require('keypairs');
|
2018-12-16 06:16:27 +00:00
|
|
|
|
2018-12-16 05:31:17 +00:00
|
|
|
module.exports = function (bitlen, exp) {
|
2018-12-16 05:39:14 +00:00
|
|
|
var ursa;
|
|
|
|
try {
|
|
|
|
ursa = require('ursa');
|
|
|
|
} catch(e) {
|
|
|
|
ursa = require('ursa-optional');
|
|
|
|
}
|
2018-12-16 06:16:27 +00:00
|
|
|
var keypair = ursa.generatePrivateKey(bitlen, exp);
|
|
|
|
var result = {
|
|
|
|
publicKeyPem: keypair.toPublicPem().toString('ascii').trim()
|
|
|
|
, privateKeyPem: keypair.toPrivatePem().toString('ascii').trim()
|
|
|
|
};
|
2019-03-14 17:59:31 +00:00
|
|
|
result.publicKeyJwk = Keypairs._importSync({ pem: result.publicKeyPem, public: true });
|
|
|
|
result.privateKeyJwk = Keypairs._importSync({ pem: result.privateKeyPem });
|
2018-12-16 06:16:27 +00:00
|
|
|
return result;
|
2018-12-16 05:31:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (require.main === module) {
|
2018-12-16 06:16:27 +00: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-16 05:31:17 +00:00
|
|
|
}
|