forked from bcoin-org/bcrypto
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkmac128.js
61 lines (47 loc) · 1.1 KB
/
kmac128.js
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
/*!
* kmac128.js - KMAC128 implementation for bcrypto
* Copyright (c) 2017-2019, Christopher Jeffrey (MIT License).
* https://github.com/bcoin-org/bcrypto
*/
'use strict';
const KMAC = require('./kmac');
/**
* KMAC128
*/
class KMAC128 extends KMAC {
constructor() {
super();
}
init(key, pers) {
return super.init(128, key, pers);
}
static hash() {
return new KMAC128();
}
static hmac(key, pers, len) {
return super.hmac(128, key, pers, len);
}
static digest(data, key, pers, len) {
return super.digest(data, 128, key, pers, len);
}
static root(left, right, key, pers, len) {
return super.root(left, right, 128, key, pers, len);
}
static multi(x, y, z, key, pers, len) {
return super.multi(x, y, z, 128, key, pers, len);
}
static mac(data, salt, key, pers, len) {
return super.mac(data, salt, 128, key, pers, len);
}
}
KMAC128.native = KMAC.native;
KMAC128.id = 'KMAC128';
KMAC128.size = 16;
KMAC128.bits = 128;
KMAC128.blockSize = 168;
KMAC128.zero = Buffer.alloc(16, 0x00);
KMAC128.ctx = new KMAC128();
/*
* Expose
*/
module.exports = KMAC128;