-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsodium.js
66 lines (54 loc) · 1.44 KB
/
sodium.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
62
63
64
65
66
/* eslint-disable camelcase */
const javascript = require('sodium-javascript')
const universal = require('sodium-universal')
const browser = require('sodium-browserify')
const nacl = {
// eslint-disable-next-line global-require
auth: require('tweetnacl-auth')
}
const polyfill = {
// auth
crypto_auth_KEYBYTES: 32,
crypto_auth_BYTES: 32,
crypto_auth_verify,
crypto_auth,
// box
crypto_box_PUBLICKEYBYTES: 32,
crypto_box_SECRETKEYBYTES: 32,
crypto_box_SEALBYTES: 32,
// secretbox
crypto_secretbox_NONCEBYTES: 24,
crypto_secretbox_KEYBYTES: 32,
crypto_secretbox_MACBYTES: 16,
// curve25519
crypto_sign_PUBLICKEYBYTES: 32,
crypto_sign_SECRETKEYBYTES: 64,
crypto_sign_SEEDBYTES: 32,
crypto_sign_BYTES: 64,
// scalarmult
crypto_scalarmult_SCALARBYTES: 32,
crypto_scalarmult_BYTES: 32,
// kx
crypto_kx_SESSIONKEYBYTES: 32,
crypto_kx_PUBLICKEYBYTES: 32,
crypto_kx_SECRETKEYBYTES: 32,
crypto_kx_SEEDBYTES: 32,
// shorthash
crypto_shorthash_KEYBYTES: 16,
crypto_shorthash_BYTES: 8,
}
const sodium = {
...browser,
...javascript,
...polyfill,
...universal
}
module.exports = sodium
function crypto_auth(out, message, key) {
return Buffer.from(nacl.auth(message, key)).copy(out)
}
function crypto_auth_verify(mac, message, key) {
const expected = Buffer.allocUnsafe(sodium.crypto_auth_BYTES)
crypto_auth(expected, message, key)
return 0 === Buffer.compare(expected, mac.slice(0, expected.length))
}