diff options
author | Florian Dold <florian.dold@gmail.com> | 2017-05-24 15:10:37 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2017-05-24 15:11:17 +0200 |
commit | 7a3df06eb573d36142bd1a8e03c5ce8752d300b3 (patch) | |
tree | 70bfaea8884c374876f607774850a3a51c0cb381 /node_modules/pbkdf2/lib/sync.js | |
parent | aca1143cb9eed16cf37f04e475e4257418dd18ac (diff) |
fix build issues and add typedoc
Diffstat (limited to 'node_modules/pbkdf2/lib/sync.js')
-rw-r--r-- | node_modules/pbkdf2/lib/sync.js | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/node_modules/pbkdf2/lib/sync.js b/node_modules/pbkdf2/lib/sync.js new file mode 100644 index 000000000..762e2f4e4 --- /dev/null +++ b/node_modules/pbkdf2/lib/sync.js @@ -0,0 +1,53 @@ +var sizes = { + md5: 16, + sha1: 20, + sha224: 28, + sha256: 32, + sha384: 48, + sha512: 64, + rmd160: 20, + ripemd160: 20 +} + +var createHmac = require('create-hmac') +var checkParameters = require('../lib/precondition') +var defaultEncoding = require('../lib/default-encoding') +var Buffer = require('safe-buffer').Buffer +module.exports = pbkdf2 +function pbkdf2 (password, salt, iterations, keylen, digest) { + if (!Buffer.isBuffer(password)) password = Buffer.from(password, defaultEncoding) + if (!Buffer.isBuffer(salt)) salt = Buffer.from(salt, defaultEncoding) + + checkParameters(iterations, keylen) + + digest = digest || 'sha1' + + var DK = Buffer.allocUnsafe(keylen) + var block1 = Buffer.allocUnsafe(salt.length + 4) + salt.copy(block1, 0, 0, salt.length) + + var U, j, destPos, len + + var hLen = sizes[digest] + var T = Buffer.allocUnsafe(hLen) + var l = Math.ceil(keylen / hLen) + var r = keylen - (l - 1) * hLen + + for (var i = 1; i <= l; i++) { + block1.writeUInt32BE(i, salt.length) + U = createHmac(digest, password).update(block1).digest() + + U.copy(T, 0, 0, hLen) + + for (j = 1; j < iterations; j++) { + U = createHmac(digest, password).update(U).digest() + for (var k = 0; k < hLen; k++) T[k] ^= U[k] + } + + destPos = (i - 1) * hLen + len = (i === l ? r : hLen) + T.copy(DK, destPos, 0, len) + } + + return DK +} |