-
-
Notifications
You must be signed in to change notification settings - Fork 35.4k
Expand file tree
/
Copy pathargon2.js
More file actions
71 lines (62 loc) · 1.75 KB
/
argon2.js
File metadata and controls
71 lines (62 loc) · 1.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
function define_tests() {
var subtle = self.crypto.subtle;
var testData = getTestData();
var testVectors = testData.testVectors;
return setUpBaseKeys().then(function (allKeys) {
var baseKeys = allKeys.baseKeys;
testVectors.forEach(function (vector) {
var algorithmName = vector.algorithm;
var params = vector.params;
var expected = vector.expected;
var testName = algorithmName + ' deriveBits';
// Test deriveBits
subsetTest(
promise_test,
function (test) {
var algorithm = Object.assign({ name: algorithmName }, params);
return subtle
.deriveBits(algorithm, baseKeys[algorithmName], 256)
.then(
function (derivation) {
assert_true(
equalBuffers(derivation, expected),
'Derived correct key'
);
},
function (err) {
assert_unreached(
'deriveBits failed with error ' +
err.name +
': ' +
err.message
);
}
);
},
testName
);
});
});
function setUpBaseKeys() {
var promises = [];
var baseKeys = {};
testVectors.forEach(function (vector) {
var algorithmName = vector.algorithm;
var password = vector.password;
promises.push(
subtle
.importKey('raw-secret', password, algorithmName, false, [
'deriveBits',
])
.then(function (key) {
baseKeys[algorithmName] = key;
})
);
});
return Promise.all(promises).then(function () {
return {
baseKeys: baseKeys,
};
});
}
}