diff --git a/doc/api/crypto.md b/doc/api/crypto.md index b7bf532d2f71e5..0af7bea90edece 100644 --- a/doc/api/crypto.md +++ b/doc/api/crypto.md @@ -1673,6 +1673,116 @@ Use [`crypto.getHashes()`][] to obtain an array of names of the available signing algorithms. Optional `options` argument controls the `stream.Writable` behavior. +### crypto.generateKeyPair(type, options, callback) + +* `type`: {string} Must be `'rsa'`, `'dsa'` or `'ec'`. +* `options`: {Object} + - `modulusLength`: {number} Key size in bits (RSA, DSA). + - `publicExponent`: {number} Public exponent (RSA). **Default:** `0x10001`. + - `divisorLength`: {number} Size of `q` in bits (DSA). + - `namedCurve`: {string} Name of the curve to use (EC). + - `publicKeyEncoding`: {Object} + - `type`: {string} Must be one of `'pkcs1'` (RSA only) or `'spki'`. + - `format`: {string} Must be `'pem'` or `'der'`. + - `privateKeyEncoding`: {Object} + - `type`: {string} Must be one of `'pkcs1'` (RSA only), `'pkcs8'` or + `'sec1'` (EC only). + - `format`: {string} Must be `'pem'` or `'der'`. + - `cipher`: {string} If specified, the private key will be encrypted with + the given `cipher` and `passphrase` using PKCS#5 v2.0 password based + encryption. + - `passphrase`: {string} The passphrase to use for encryption, see `cipher`. +* `callback`: {Function} + - `err`: {Error} + - `publicKey`: {string|Buffer} + - `privateKey`: {string|Buffer} + +Generates a new asymmetric key pair of the given `type`. Only RSA, DSA and EC +are currently supported. + +It is recommended to encode public keys as `'spki'` and private keys as +`'pkcs8'` with encryption: + +```js +const { generateKeyPair } = require('crypto'); +generateKeyPair('rsa', { + modulusLength: 4096, + publicKeyEncoding: { + type: 'spki', + format: 'pem' + }, + privateKeyEncoding: { + type: 'pkcs8', + format: 'pem', + cipher: 'aes-256-cbc', + passphrase: 'top secret' + } +}, (err, publicKey, privateKey) => { + // Handle errors and use the generated key pair. +}); +``` + +On completion, `callback` will be called with `err` set to `undefined` and +`publicKey` / `privateKey` representing the generated key pair. When PEM +encoding was selected, the result will be a string, otherwise it will be a +buffer containing the data encoded as DER. Note that Node.js itself does not +accept DER, it is supported for interoperability with other libraries such as +WebCrypto only. + +### crypto.generateKeyPairSync(type, options) + +* `type`: {string} Must be `'rsa'`, `'dsa'` or `'ec'`. +* `options`: {Object} + - `modulusLength`: {number} Key size in bits (RSA, DSA). + - `publicExponent`: {number} Public exponent (RSA). **Default:** `0x10001`. + - `divisorLength`: {number} Size of `q` in bits (DSA). + - `namedCurve`: {string} Name of the curve to use (EC). + - `publicKeyEncoding`: {Object} + - `type`: {string} Must be one of `'pkcs1'` (RSA only) or `'spki'`. + - `format`: {string} Must be `'pem'` or `'der'`. + - `privateKeyEncoding`: {Object} + - `type`: {string} Must be one of `'pkcs1'` (RSA only), `'pkcs8'` or + `'sec1'` (EC only). + - `format`: {string} Must be `'pem'` or `'der'`. + - `cipher`: {string} If specified, the private key will be encrypted with + the given `cipher` and `passphrase` using PKCS#5 v2.0 password based + encryption. + - `passphrase`: {string} The passphrase to use for encryption, see `cipher`. +* Returns: {Object} + - `publicKey`: {string|Buffer} + - `privateKey`: {string|Buffer} + +Generates a new asymmetric key pair of the given `type`. Only RSA, DSA and EC +are currently supported. + +It is recommended to encode public keys as `'spki'` and private keys as +`'pkcs8'` with encryption: + +```js +const { generateKeyPairSync } = require('crypto'); +const { publicKey, privateKey } = generateKeyPairSync('rsa', { + modulusLength: 4096, + publicKeyEncoding: { + type: 'spki', + format: 'pem' + }, + privateKeyEncoding: { + type: 'pkcs8', + format: 'pem', + cipher: 'aes-256-cbc', + passphrase: 'top secret' + } +}); +``` + +The return value `{ publicKey, privateKey }` represents the generated key pair. +When PEM encoding was selected, the respective key will be a string, otherwise +it will be a buffer containing the data encoded as DER. + ### crypto.getCiphers()