mirror of
https://github.com/nodejs/node.git
synced 2024-11-30 15:30:56 +01:00
eb05d68815
This is just a refactoring to reduce code and computational overhead. PR-URL: https://github.com/nodejs/node/pull/29683 Reviewed-By: James M Snell <jasnell@gmail.com>
87 lines
2.7 KiB
JavaScript
87 lines
2.7 KiB
JavaScript
'use strict';
|
|
|
|
const { AsyncWrap, Providers } = internalBinding('async_wrap');
|
|
const { Buffer } = require('buffer');
|
|
const { pbkdf2: _pbkdf2 } = internalBinding('crypto');
|
|
const { validateUint32 } = require('internal/validators');
|
|
const { deprecate } = require('internal/util');
|
|
const {
|
|
ERR_CRYPTO_INVALID_DIGEST,
|
|
ERR_CRYPTO_PBKDF2_ERROR,
|
|
ERR_INVALID_ARG_TYPE,
|
|
ERR_INVALID_CALLBACK,
|
|
} = require('internal/errors').codes;
|
|
const {
|
|
getDefaultEncoding,
|
|
getArrayBufferView,
|
|
} = require('internal/crypto/util');
|
|
|
|
function pbkdf2(password, salt, iterations, keylen, digest, callback) {
|
|
if (typeof digest === 'function') {
|
|
callback = digest;
|
|
digest = undefined;
|
|
}
|
|
|
|
({ password, salt, iterations, keylen, digest } =
|
|
check(password, salt, iterations, keylen, digest));
|
|
|
|
if (typeof callback !== 'function')
|
|
throw new ERR_INVALID_CALLBACK(callback);
|
|
|
|
const encoding = getDefaultEncoding();
|
|
const keybuf = Buffer.alloc(keylen);
|
|
|
|
const wrap = new AsyncWrap(Providers.PBKDF2REQUEST);
|
|
wrap.ondone = (ok) => { // Retains keybuf while request is in flight.
|
|
if (!ok) return callback.call(wrap, new ERR_CRYPTO_PBKDF2_ERROR());
|
|
if (encoding === 'buffer') return callback.call(wrap, null, keybuf);
|
|
callback.call(wrap, null, keybuf.toString(encoding));
|
|
};
|
|
|
|
handleError(_pbkdf2(keybuf, password, salt, iterations, digest, wrap),
|
|
digest);
|
|
}
|
|
|
|
function pbkdf2Sync(password, salt, iterations, keylen, digest) {
|
|
({ password, salt, iterations, keylen, digest } =
|
|
check(password, salt, iterations, keylen, digest));
|
|
const keybuf = Buffer.alloc(keylen);
|
|
handleError(_pbkdf2(keybuf, password, salt, iterations, digest), digest);
|
|
const encoding = getDefaultEncoding();
|
|
if (encoding === 'buffer') return keybuf;
|
|
return keybuf.toString(encoding);
|
|
}
|
|
|
|
const defaultDigest = deprecate(() => 'sha1',
|
|
'Calling pbkdf2 or pbkdf2Sync with "digest" ' +
|
|
'set to null is deprecated.',
|
|
'DEP0009');
|
|
|
|
function check(password, salt, iterations, keylen, digest) {
|
|
if (typeof digest !== 'string') {
|
|
if (digest !== null)
|
|
throw new ERR_INVALID_ARG_TYPE('digest', ['string', 'null'], digest);
|
|
digest = defaultDigest();
|
|
}
|
|
|
|
password = getArrayBufferView(password, 'password');
|
|
salt = getArrayBufferView(salt, 'salt');
|
|
validateUint32(iterations, 'iterations', 0);
|
|
validateUint32(keylen, 'keylen', 0);
|
|
|
|
return { password, salt, iterations, keylen, digest };
|
|
}
|
|
|
|
function handleError(rc, digest) {
|
|
if (rc === -1)
|
|
throw new ERR_CRYPTO_INVALID_DIGEST(digest);
|
|
|
|
if (rc === false)
|
|
throw new ERR_CRYPTO_PBKDF2_ERROR();
|
|
}
|
|
|
|
module.exports = {
|
|
pbkdf2,
|
|
pbkdf2Sync
|
|
};
|