Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Download
80540 views
1
var createHmac = require('create-hmac')
2
var MAX_ALLOC = Math.pow(2, 30) - 1 // default in iojs
3
4
exports.pbkdf2 = pbkdf2
5
function pbkdf2 (password, salt, iterations, keylen, digest, callback) {
6
if (typeof digest === 'function') {
7
callback = digest
8
digest = undefined
9
}
10
11
if (typeof callback !== 'function') {
12
throw new Error('No callback provided to pbkdf2')
13
}
14
15
var result = pbkdf2Sync(password, salt, iterations, keylen, digest)
16
setTimeout(function () {
17
callback(undefined, result)
18
})
19
}
20
21
exports.pbkdf2Sync = pbkdf2Sync
22
function pbkdf2Sync (password, salt, iterations, keylen, digest) {
23
if (typeof iterations !== 'number') {
24
throw new TypeError('Iterations not a number')
25
}
26
27
if (iterations < 0) {
28
throw new TypeError('Bad iterations')
29
}
30
31
if (typeof keylen !== 'number') {
32
throw new TypeError('Key length not a number')
33
}
34
35
if (keylen < 0 || keylen > MAX_ALLOC) {
36
throw new TypeError('Bad key length')
37
}
38
39
digest = digest || 'sha1'
40
41
if (!Buffer.isBuffer(password)) password = new Buffer(password, 'binary')
42
if (!Buffer.isBuffer(salt)) salt = new Buffer(salt, 'binary')
43
44
var hLen
45
var l = 1
46
var DK = new Buffer(keylen)
47
var block1 = new Buffer(salt.length + 4)
48
salt.copy(block1, 0, 0, salt.length)
49
50
var r
51
var T
52
53
for (var i = 1; i <= l; i++) {
54
block1.writeUInt32BE(i, salt.length)
55
var U = createHmac(digest, password).update(block1).digest()
56
57
if (!hLen) {
58
hLen = U.length
59
T = new Buffer(hLen)
60
l = Math.ceil(keylen / hLen)
61
r = keylen - (l - 1) * hLen
62
}
63
64
U.copy(T, 0, 0, hLen)
65
66
for (var j = 1; j < iterations; j++) {
67
U = createHmac(digest, password).update(U).digest()
68
69
for (var k = 0; k < hLen; k++) {
70
T[k] ^= U[k]
71
}
72
}
73
74
var destPos = (i - 1) * hLen
75
var len = (i === l ? r : hLen)
76
T.copy(DK, destPos, 0, len)
77
}
78
79
return DK
80
}
81
82