rsa-compat.js/lib/generate-privkey-node.js

40 lines
1.2 KiB
JavaScript
Raw Permalink Normal View History

// 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 05:31:17 +00:00
module.exports = function (bitlen, exp) {
var keypair = require('crypto').generateKeyPairSync(
2018-12-16 05:31:17 +00:00
'rsa'
, { modulusLength: bitlen
, publicExponent: exp
, privateKeyEncoding: {
type: 'pkcs1'
2018-12-16 05:31:17 +00:00
, format: 'pem'
}
, publicKeyEncoding: {
type: 'pkcs1'
2018-12-16 05:31:17 +00:00
, format: 'pem'
}
}
);
var result = {
publicKeyPem: keypair.publicKey.trim()
, privateKeyPem: keypair.privateKey.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 });
return result;
2018-12-16 05:31:17 +00:00
};
if (require.main === module) {
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
}