@byline/admin 2.4.0 → 2.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/abilities.js +5 -24
- package/dist/index.js +8 -30
- package/dist/lib/assert-admin-actor.js +13 -74
- package/dist/lib/create-command.js +6 -16
- package/dist/modules/admin-account/commands.js +35 -24
- package/dist/modules/admin-account/components/change-password.d.ts +8 -0
- package/dist/modules/admin-account/components/change-password.js +192 -0
- package/dist/modules/admin-account/components/change-password.module.js +8 -0
- package/dist/modules/admin-account/components/change-password_module.css +27 -0
- package/dist/modules/admin-account/components/container.d.ts +29 -0
- package/dist/modules/admin-account/components/container.js +298 -0
- package/dist/modules/admin-account/components/container.module.js +28 -0
- package/dist/modules/admin-account/components/container_module.css +106 -0
- package/dist/modules/admin-account/components/update.d.ts +8 -0
- package/dist/modules/admin-account/components/update.js +207 -0
- package/dist/modules/admin-account/components/update.module.js +8 -0
- package/dist/modules/admin-account/components/update_module.css +27 -0
- package/dist/modules/admin-account/errors.js +14 -45
- package/dist/modules/admin-account/index.js +4 -34
- package/dist/modules/admin-account/schemas.js +25 -59
- package/dist/modules/admin-account/service.js +56 -61
- package/dist/modules/admin-permissions/abilities.js +6 -24
- package/dist/modules/admin-permissions/commands.js +42 -28
- package/dist/modules/admin-permissions/components/inspector.d.ts +4 -0
- package/dist/modules/admin-permissions/components/inspector.js +284 -0
- package/dist/modules/admin-permissions/components/inspector.module.js +56 -0
- package/dist/modules/admin-permissions/components/inspector_module.css +238 -0
- package/dist/modules/admin-permissions/dto.js +3 -16
- package/dist/modules/admin-permissions/errors.js +14 -27
- package/dist/modules/admin-permissions/index.js +6 -26
- package/dist/modules/admin-permissions/repository.js +1 -8
- package/dist/modules/admin-permissions/schemas.js +33 -70
- package/dist/modules/admin-permissions/service.js +88 -92
- package/dist/modules/admin-roles/abilities.js +8 -30
- package/dist/modules/admin-roles/commands.js +89 -55
- package/dist/modules/admin-roles/components/create.d.ts +7 -0
- package/dist/modules/admin-roles/components/create.js +177 -0
- package/dist/modules/admin-roles/components/create.module.js +8 -0
- package/dist/modules/admin-roles/components/create_module.css +27 -0
- package/dist/modules/admin-roles/components/permissions.d.ts +10 -0
- package/dist/modules/admin-roles/components/permissions.js +303 -0
- package/dist/modules/admin-roles/components/permissions.module.js +44 -0
- package/dist/modules/admin-roles/components/permissions_module.css +192 -0
- package/dist/modules/admin-roles/components/update.d.ts +8 -0
- package/dist/modules/admin-roles/components/update.js +166 -0
- package/dist/modules/admin-roles/components/update.module.js +8 -0
- package/dist/modules/admin-roles/components/update_module.css +27 -0
- package/dist/modules/admin-roles/dto.js +3 -16
- package/dist/modules/admin-roles/errors.js +16 -40
- package/dist/modules/admin-roles/index.js +6 -26
- package/dist/modules/admin-roles/repository.js +1 -8
- package/dist/modules/admin-roles/schemas.js +41 -71
- package/dist/modules/admin-roles/service.js +79 -82
- package/dist/modules/admin-users/abilities.js +9 -38
- package/dist/modules/admin-users/commands.js +92 -50
- package/dist/modules/admin-users/components/create.d.ts +8 -0
- package/dist/modules/admin-users/components/create.js +268 -0
- package/dist/modules/admin-users/components/create.module.js +10 -0
- package/dist/modules/admin-users/components/create_module.css +45 -0
- package/dist/modules/admin-users/components/roles.d.ts +11 -0
- package/dist/modules/admin-users/components/roles.js +148 -0
- package/dist/modules/admin-users/components/roles.module.js +18 -0
- package/dist/modules/admin-users/components/roles_module.css +75 -0
- package/dist/modules/admin-users/components/set-password.d.ts +8 -0
- package/dist/modules/admin-users/components/set-password.js +170 -0
- package/dist/modules/admin-users/components/set-password.module.js +9 -0
- package/dist/modules/admin-users/components/set-password_module.css +31 -0
- package/dist/modules/admin-users/components/update.d.ts +8 -0
- package/dist/modules/admin-users/components/update.js +254 -0
- package/dist/modules/admin-users/components/update.module.js +9 -0
- package/dist/modules/admin-users/components/update_module.css +34 -0
- package/dist/modules/admin-users/dto.js +3 -18
- package/dist/modules/admin-users/errors.js +17 -43
- package/dist/modules/admin-users/index.js +7 -27
- package/dist/modules/admin-users/repository.js +1 -8
- package/dist/modules/admin-users/schemas.js +44 -75
- package/dist/modules/admin-users/seed-super-admin.js +9 -34
- package/dist/modules/admin-users/service.js +76 -91
- package/dist/modules/auth/components/sign-in-form.d.ts +12 -0
- package/dist/modules/auth/components/sign-in-form.js +115 -0
- package/dist/modules/auth/components/sign-in-form.module.js +12 -0
- package/dist/modules/auth/components/sign-in-form_module.css +41 -0
- package/dist/modules/auth/index.js +3 -24
- package/dist/modules/auth/jwt-session-provider.js +179 -149
- package/dist/modules/auth/password.js +11 -53
- package/dist/modules/auth/phc.js +21 -54
- package/dist/modules/auth/refresh-tokens-repository.js +1 -8
- package/dist/modules/auth/resolve-actor.js +6 -28
- package/dist/services/admin-services-context.d.ts +16 -0
- package/dist/services/admin-services-context.js +13 -0
- package/dist/services/admin-services-types.d.ts +129 -0
- package/dist/services/admin-services-types.js +1 -0
- package/dist/store.js +1 -8
- package/dist/vendor/noble-argon2/_blake.js +277 -45
- package/dist/vendor/noble-argon2/_md.js +81 -136
- package/dist/vendor/noble-argon2/_u64.js +65 -67
- package/dist/vendor/noble-argon2/argon2.js +181 -342
- package/dist/vendor/noble-argon2/blake2.js +252 -327
- package/dist/vendor/noble-argon2/utils.js +110 -490
- package/dist/vendor/noble-argon2/utils.js.LICENSE.txt +1 -0
- package/package.json +89 -10
- package/src/abilities.ts +32 -0
- package/src/declarations.d.ts +4 -0
- package/src/index.ts +39 -0
- package/src/lib/assert-admin-actor.ts +90 -0
- package/src/lib/create-command.ts +109 -0
- package/src/modules/admin-account/commands.ts +76 -0
- package/src/modules/admin-account/components/change-password.module.css +40 -0
- package/src/modules/admin-account/components/change-password.tsx +232 -0
- package/src/modules/admin-account/components/container.module.css +158 -0
- package/src/modules/admin-account/components/container.tsx +229 -0
- package/src/modules/admin-account/components/update.module.css +40 -0
- package/src/modules/admin-account/components/update.tsx +263 -0
- package/src/modules/admin-account/errors.ts +75 -0
- package/src/modules/admin-account/index.ts +60 -0
- package/src/modules/admin-account/schemas.ts +84 -0
- package/src/modules/admin-account/service.ts +92 -0
- package/src/modules/admin-permissions/abilities.ts +46 -0
- package/src/modules/admin-permissions/commands.ts +103 -0
- package/src/modules/admin-permissions/components/inspector.module.css +326 -0
- package/src/modules/admin-permissions/components/inspector.tsx +298 -0
- package/src/modules/admin-permissions/dto.ts +28 -0
- package/src/modules/admin-permissions/errors.ts +57 -0
- package/src/modules/admin-permissions/index.ts +72 -0
- package/src/modules/admin-permissions/repository.ts +49 -0
- package/src/modules/admin-permissions/schemas.ts +128 -0
- package/src/modules/admin-permissions/service.ts +137 -0
- package/src/modules/admin-roles/abilities.ts +62 -0
- package/src/modules/admin-roles/commands.ts +161 -0
- package/src/modules/admin-roles/components/create.module.css +40 -0
- package/src/modules/admin-roles/components/create.tsx +218 -0
- package/src/modules/admin-roles/components/permissions.module.css +279 -0
- package/src/modules/admin-roles/components/permissions.tsx +396 -0
- package/src/modules/admin-roles/components/update.module.css +40 -0
- package/src/modules/admin-roles/components/update.tsx +218 -0
- package/src/modules/admin-roles/dto.ts +30 -0
- package/src/modules/admin-roles/errors.ts +76 -0
- package/src/modules/admin-roles/index.ts +81 -0
- package/src/modules/admin-roles/repository.ts +96 -0
- package/src/modules/admin-roles/schemas.ts +139 -0
- package/src/modules/admin-roles/service.ts +136 -0
- package/src/modules/admin-users/abilities.ts +76 -0
- package/src/modules/admin-users/commands.ts +157 -0
- package/src/modules/admin-users/components/create.module.css +63 -0
- package/src/modules/admin-users/components/create.tsx +323 -0
- package/src/modules/admin-users/components/roles.module.css +119 -0
- package/src/modules/admin-users/components/roles.tsx +172 -0
- package/src/modules/admin-users/components/set-password.module.css +46 -0
- package/src/modules/admin-users/components/set-password.tsx +199 -0
- package/src/modules/admin-users/components/update.module.css +49 -0
- package/src/modules/admin-users/components/update.tsx +328 -0
- package/src/modules/admin-users/dto.ts +39 -0
- package/src/modules/admin-users/errors.ts +84 -0
- package/src/modules/admin-users/index.ts +91 -0
- package/src/modules/admin-users/repository.ts +161 -0
- package/src/modules/admin-users/schemas.ts +168 -0
- package/src/modules/admin-users/seed-super-admin.ts +102 -0
- package/src/modules/admin-users/service.ts +166 -0
- package/src/modules/auth/components/sign-in-form.module.css +62 -0
- package/src/modules/auth/components/sign-in-form.tsx +132 -0
- package/src/modules/auth/index.ts +31 -0
- package/src/modules/auth/jwt-session-provider.ts +301 -0
- package/src/modules/auth/password.ts +94 -0
- package/src/modules/auth/phc.ts +121 -0
- package/src/modules/auth/refresh-tokens-repository.ts +74 -0
- package/src/modules/auth/resolve-actor.ts +42 -0
- package/src/services/admin-services-context.tsx +52 -0
- package/src/services/admin-services-types.ts +177 -0
- package/src/store.ts +32 -0
- package/src/vendor/noble-argon2/LICENSE +21 -0
- package/src/vendor/noble-argon2/README.md +87 -0
- package/src/vendor/noble-argon2/_blake.ts +58 -0
- package/src/vendor/noble-argon2/_md.ts +223 -0
- package/src/vendor/noble-argon2/_u64.ts +118 -0
- package/src/vendor/noble-argon2/argon2.ts +668 -0
- package/src/vendor/noble-argon2/blake2.ts +583 -0
- package/src/vendor/noble-argon2/utils.ts +849 -0
|
@@ -0,0 +1,583 @@
|
|
|
1
|
+
// @ts-nocheck — vendored from noble-hashes; see ./README.md
|
|
2
|
+
/**
|
|
3
|
+
* blake2b (64-bit) & blake2s (8 to 32-bit) hash functions.
|
|
4
|
+
* b could have been faster, but there is no fast u64 in js, so s is 1.5x faster.
|
|
5
|
+
* @module
|
|
6
|
+
*/
|
|
7
|
+
import { BSIGMA, G1s, G2s } from './_blake.js';
|
|
8
|
+
import { SHA256_IV } from './_md.js';
|
|
9
|
+
import * as u64 from './_u64.js';
|
|
10
|
+
// prettier-ignore
|
|
11
|
+
import {
|
|
12
|
+
abytes, aexists, anumber, aoutput,
|
|
13
|
+
clean, createHasher,
|
|
14
|
+
swap32IfBE, swap8IfBE,
|
|
15
|
+
u32,
|
|
16
|
+
type CHash,
|
|
17
|
+
type Hash,
|
|
18
|
+
type TArg,
|
|
19
|
+
type TRet
|
|
20
|
+
} from './utils.js';
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Blake hash options.
|
|
24
|
+
* `dkLen` is output length. `key` is used in MAC mode. `salt` is used in
|
|
25
|
+
* KDF mode.
|
|
26
|
+
*/
|
|
27
|
+
export type Blake2Opts = {
|
|
28
|
+
/** Desired digest length in bytes. RFC 7693 uses 1..64 for blake2b and 1..32 for blake2s. */
|
|
29
|
+
dkLen?: number;
|
|
30
|
+
/** Optional MAC key. */
|
|
31
|
+
key?: Uint8Array;
|
|
32
|
+
/** Optional salt mixed into initialization. */
|
|
33
|
+
salt?: Uint8Array;
|
|
34
|
+
/** Optional personalization bytes. */
|
|
35
|
+
personalization?: Uint8Array;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// Same IV words as `SHA512_IV`, but endian-swapped into LE u32 low/high halves
|
|
39
|
+
// for the BLAKE2b u64 helpers below.
|
|
40
|
+
const B2B_IV = /* @__PURE__ */ Uint32Array.from([
|
|
41
|
+
0xf3bcc908, 0x6a09e667, 0x84caa73b, 0xbb67ae85, 0xfe94f82b, 0x3c6ef372, 0x5f1d36f1, 0xa54ff53a,
|
|
42
|
+
0xade682d1, 0x510e527f, 0x2b3e6c1f, 0x9b05688c, 0xfb41bd6b, 0x1f83d9ab, 0x137e2179, 0x5be0cd19,
|
|
43
|
+
]);
|
|
44
|
+
// Shared synchronous BLAKE2b work vector as LE u32 low/high halves.
|
|
45
|
+
const BBUF = /* @__PURE__ */ new Uint32Array(32);
|
|
46
|
+
|
|
47
|
+
// BLAKE2b G mix split into two half-rounds over LE u32 low/high limbs.
|
|
48
|
+
function G1b(a: number, b: number, c: number, d: number, msg: TArg<Uint32Array>, x: number) {
|
|
49
|
+
// NOTE: V is LE here
|
|
50
|
+
const Xl = msg[x], Xh = msg[x + 1]; // prettier-ignore
|
|
51
|
+
let Al = BBUF[2 * a], Ah = BBUF[2 * a + 1]; // prettier-ignore
|
|
52
|
+
let Bl = BBUF[2 * b], Bh = BBUF[2 * b + 1]; // prettier-ignore
|
|
53
|
+
let Cl = BBUF[2 * c], Ch = BBUF[2 * c + 1]; // prettier-ignore
|
|
54
|
+
let Dl = BBUF[2 * d], Dh = BBUF[2 * d + 1]; // prettier-ignore
|
|
55
|
+
// v[a] = (v[a] + v[b] + x) | 0;
|
|
56
|
+
let ll = u64.add3L(Al, Bl, Xl);
|
|
57
|
+
Ah = u64.add3H(ll, Ah, Bh, Xh);
|
|
58
|
+
Al = ll | 0;
|
|
59
|
+
// v[d] = rotr(v[d] ^ v[a], 32)
|
|
60
|
+
({ Dh, Dl } = { Dh: Dh ^ Ah, Dl: Dl ^ Al });
|
|
61
|
+
({ Dh, Dl } = { Dh: u64.rotr32H(Dh, Dl), Dl: u64.rotr32L(Dh, Dl) });
|
|
62
|
+
// v[c] = (v[c] + v[d]) | 0;
|
|
63
|
+
({ h: Ch, l: Cl } = u64.add(Ch, Cl, Dh, Dl));
|
|
64
|
+
// v[b] = rotr(v[b] ^ v[c], 24)
|
|
65
|
+
({ Bh, Bl } = { Bh: Bh ^ Ch, Bl: Bl ^ Cl });
|
|
66
|
+
({ Bh, Bl } = { Bh: u64.rotrSH(Bh, Bl, 24), Bl: u64.rotrSL(Bh, Bl, 24) });
|
|
67
|
+
((BBUF[2 * a] = Al), (BBUF[2 * a + 1] = Ah));
|
|
68
|
+
((BBUF[2 * b] = Bl), (BBUF[2 * b + 1] = Bh));
|
|
69
|
+
((BBUF[2 * c] = Cl), (BBUF[2 * c + 1] = Ch));
|
|
70
|
+
((BBUF[2 * d] = Dl), (BBUF[2 * d + 1] = Dh));
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Second half-round of the same LE-limb BLAKE2b G mix; `x` is the message word offset.
|
|
74
|
+
function G2b(a: number, b: number, c: number, d: number, msg: TArg<Uint32Array>, x: number) {
|
|
75
|
+
// NOTE: V is LE here
|
|
76
|
+
const Xl = msg[x], Xh = msg[x + 1]; // prettier-ignore
|
|
77
|
+
let Al = BBUF[2 * a], Ah = BBUF[2 * a + 1]; // prettier-ignore
|
|
78
|
+
let Bl = BBUF[2 * b], Bh = BBUF[2 * b + 1]; // prettier-ignore
|
|
79
|
+
let Cl = BBUF[2 * c], Ch = BBUF[2 * c + 1]; // prettier-ignore
|
|
80
|
+
let Dl = BBUF[2 * d], Dh = BBUF[2 * d + 1]; // prettier-ignore
|
|
81
|
+
// v[a] = (v[a] + v[b] + x) | 0;
|
|
82
|
+
let ll = u64.add3L(Al, Bl, Xl);
|
|
83
|
+
Ah = u64.add3H(ll, Ah, Bh, Xh);
|
|
84
|
+
Al = ll | 0;
|
|
85
|
+
// v[d] = rotr(v[d] ^ v[a], 16)
|
|
86
|
+
({ Dh, Dl } = { Dh: Dh ^ Ah, Dl: Dl ^ Al });
|
|
87
|
+
({ Dh, Dl } = { Dh: u64.rotrSH(Dh, Dl, 16), Dl: u64.rotrSL(Dh, Dl, 16) });
|
|
88
|
+
// v[c] = (v[c] + v[d]) | 0;
|
|
89
|
+
({ h: Ch, l: Cl } = u64.add(Ch, Cl, Dh, Dl));
|
|
90
|
+
// v[b] = rotr(v[b] ^ v[c], 63)
|
|
91
|
+
({ Bh, Bl } = { Bh: Bh ^ Ch, Bl: Bl ^ Cl });
|
|
92
|
+
({ Bh, Bl } = { Bh: u64.rotrBH(Bh, Bl, 63), Bl: u64.rotrBL(Bh, Bl, 63) });
|
|
93
|
+
((BBUF[2 * a] = Al), (BBUF[2 * a + 1] = Ah));
|
|
94
|
+
((BBUF[2 * b] = Bl), (BBUF[2 * b + 1] = Bh));
|
|
95
|
+
((BBUF[2 * c] = Cl), (BBUF[2 * c + 1] = Ch));
|
|
96
|
+
((BBUF[2 * d] = Dl), (BBUF[2 * d + 1] = Dh));
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
function checkBlake2Opts(
|
|
100
|
+
outputLen: number,
|
|
101
|
+
opts: TArg<Blake2Opts | undefined> = {},
|
|
102
|
+
keyLen: number,
|
|
103
|
+
saltLen: number,
|
|
104
|
+
persLen: number
|
|
105
|
+
) {
|
|
106
|
+
anumber(keyLen);
|
|
107
|
+
// RFC 7693 §2.1 requires digest length nn in 1..keyLen.
|
|
108
|
+
if (outputLen <= 0 || outputLen > keyLen) throw new Error('outputLen bigger than keyLen');
|
|
109
|
+
const { key, salt, personalization } = opts;
|
|
110
|
+
// This API uses `undefined` for the RFC 7693 `kk = 0` case, so a provided key must be non-empty.
|
|
111
|
+
if (key !== undefined && (key.length < 1 || key.length > keyLen))
|
|
112
|
+
throw new Error('"key" expected to be undefined or of length=1..' + keyLen);
|
|
113
|
+
if (salt !== undefined) abytes(salt, saltLen, 'salt');
|
|
114
|
+
if (personalization !== undefined) abytes(personalization, persLen, 'personalization');
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/** Internal base class for BLAKE2. */
|
|
118
|
+
export abstract class _BLAKE2<T extends _BLAKE2<T>> implements Hash<T> {
|
|
119
|
+
protected abstract compress(msg: Uint32Array, offset: number, isLast: boolean): void;
|
|
120
|
+
protected abstract get(): number[];
|
|
121
|
+
protected abstract set(...args: number[]): void;
|
|
122
|
+
abstract destroy(): void;
|
|
123
|
+
protected buffer: Uint8Array;
|
|
124
|
+
protected buffer32: Uint32Array;
|
|
125
|
+
protected finished = false;
|
|
126
|
+
protected destroyed = false;
|
|
127
|
+
protected length: number = 0;
|
|
128
|
+
protected pos: number = 0;
|
|
129
|
+
readonly blockLen: number;
|
|
130
|
+
readonly outputLen: number;
|
|
131
|
+
readonly canXOF: boolean = false;
|
|
132
|
+
|
|
133
|
+
constructor(blockLen: number, outputLen: number) {
|
|
134
|
+
anumber(blockLen);
|
|
135
|
+
anumber(outputLen);
|
|
136
|
+
this.blockLen = blockLen;
|
|
137
|
+
this.outputLen = outputLen;
|
|
138
|
+
this.buffer = new Uint8Array(blockLen);
|
|
139
|
+
this.buffer32 = u32(this.buffer);
|
|
140
|
+
}
|
|
141
|
+
update(data: TArg<Uint8Array>): this {
|
|
142
|
+
aexists(this);
|
|
143
|
+
abytes(data);
|
|
144
|
+
// Main difference with other hashes: there is flag for last block,
|
|
145
|
+
// so we cannot process current block before we know that there
|
|
146
|
+
// is the next one. This significantly complicates logic and reduces ability
|
|
147
|
+
// to do zero-copy processing
|
|
148
|
+
const { blockLen, buffer, buffer32 } = this;
|
|
149
|
+
const len = data.length;
|
|
150
|
+
const offset = data.byteOffset;
|
|
151
|
+
const buf = data.buffer;
|
|
152
|
+
for (let pos = 0; pos < len; ) {
|
|
153
|
+
// If buffer is full and we still have input (don't process last block, same as blake2s)
|
|
154
|
+
if (this.pos === blockLen) {
|
|
155
|
+
swap32IfBE(buffer32);
|
|
156
|
+
this.compress(buffer32, 0, false);
|
|
157
|
+
swap32IfBE(buffer32);
|
|
158
|
+
this.pos = 0;
|
|
159
|
+
}
|
|
160
|
+
const take = Math.min(blockLen - this.pos, len - pos);
|
|
161
|
+
const dataOffset = offset + pos;
|
|
162
|
+
// Zero-copy only for full, 4-byte-aligned, non-final blocks.
|
|
163
|
+
if (take === blockLen && !(dataOffset % 4) && pos + take < len) {
|
|
164
|
+
const data32 = new Uint32Array(buf, dataOffset, Math.floor((len - pos) / 4));
|
|
165
|
+
swap32IfBE(data32);
|
|
166
|
+
for (let pos32 = 0; pos + blockLen < len; pos32 += buffer32.length, pos += blockLen) {
|
|
167
|
+
this.length += blockLen;
|
|
168
|
+
this.compress(data32, pos32, false);
|
|
169
|
+
}
|
|
170
|
+
swap32IfBE(data32);
|
|
171
|
+
continue;
|
|
172
|
+
}
|
|
173
|
+
buffer.set(data.subarray(pos, pos + take), this.pos);
|
|
174
|
+
this.pos += take;
|
|
175
|
+
this.length += take;
|
|
176
|
+
pos += take;
|
|
177
|
+
}
|
|
178
|
+
return this;
|
|
179
|
+
}
|
|
180
|
+
digestInto(out: TArg<Uint8Array>): void {
|
|
181
|
+
aexists(this);
|
|
182
|
+
aoutput(out, this);
|
|
183
|
+
const { pos, buffer32 } = this;
|
|
184
|
+
this.finished = true;
|
|
185
|
+
// Padding
|
|
186
|
+
clean(this.buffer.subarray(pos));
|
|
187
|
+
swap32IfBE(buffer32);
|
|
188
|
+
this.compress(buffer32, 0, true);
|
|
189
|
+
swap32IfBE(buffer32);
|
|
190
|
+
// Reject unaligned views explicitly instead of hiding them behind a full scratch copy.
|
|
191
|
+
if (out.byteOffset & 3)
|
|
192
|
+
throw new RangeError(
|
|
193
|
+
'"digestInto() output" expected 4-byte aligned byteOffset, got ' + out.byteOffset
|
|
194
|
+
);
|
|
195
|
+
const state = this.get();
|
|
196
|
+
const out32 = u32(out);
|
|
197
|
+
const full = Math.floor(this.outputLen / 4);
|
|
198
|
+
for (let i = 0; i < full; i++) out32[i] = swap8IfBE(state[i]);
|
|
199
|
+
const tail = this.outputLen % 4;
|
|
200
|
+
if (!tail) return;
|
|
201
|
+
const off = full * 4;
|
|
202
|
+
const word = state[full];
|
|
203
|
+
for (let i = 0; i < tail; i++) out[off + i] = word >>> (8 * i);
|
|
204
|
+
}
|
|
205
|
+
digest(): TRet<Uint8Array> {
|
|
206
|
+
const { buffer, outputLen } = this;
|
|
207
|
+
this.digestInto(buffer);
|
|
208
|
+
// Return a copy so callers do not alias the instance scratch buffer used during finalization.
|
|
209
|
+
const res = buffer.slice(0, outputLen);
|
|
210
|
+
this.destroy();
|
|
211
|
+
return res as TRet<Uint8Array>;
|
|
212
|
+
}
|
|
213
|
+
_cloneInto(to?: T): T {
|
|
214
|
+
const { buffer, length, finished, destroyed, outputLen, pos } = this;
|
|
215
|
+
// Recreate only `dkLen`; key/salt/personalization are already absorbed into the copied state.
|
|
216
|
+
to ||= new (this.constructor as any)({ dkLen: outputLen }) as T;
|
|
217
|
+
to.set(...this.get());
|
|
218
|
+
to.buffer.set(buffer);
|
|
219
|
+
to.destroyed = destroyed;
|
|
220
|
+
to.finished = finished;
|
|
221
|
+
to.length = length;
|
|
222
|
+
to.pos = pos;
|
|
223
|
+
// @ts-ignore
|
|
224
|
+
to.outputLen = outputLen;
|
|
225
|
+
return to;
|
|
226
|
+
}
|
|
227
|
+
clone(): T {
|
|
228
|
+
return this._cloneInto();
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/** Internal blake2b hash class with state stored as LE u32 low/high halves. */
|
|
233
|
+
export class _BLAKE2b extends _BLAKE2<_BLAKE2b> {
|
|
234
|
+
// Same IV words as SHA-512 / BLAKE2b, encoded as LE u32 low/high halves.
|
|
235
|
+
private v0l = B2B_IV[0] | 0;
|
|
236
|
+
private v0h = B2B_IV[1] | 0;
|
|
237
|
+
private v1l = B2B_IV[2] | 0;
|
|
238
|
+
private v1h = B2B_IV[3] | 0;
|
|
239
|
+
private v2l = B2B_IV[4] | 0;
|
|
240
|
+
private v2h = B2B_IV[5] | 0;
|
|
241
|
+
private v3l = B2B_IV[6] | 0;
|
|
242
|
+
private v3h = B2B_IV[7] | 0;
|
|
243
|
+
private v4l = B2B_IV[8] | 0;
|
|
244
|
+
private v4h = B2B_IV[9] | 0;
|
|
245
|
+
private v5l = B2B_IV[10] | 0;
|
|
246
|
+
private v5h = B2B_IV[11] | 0;
|
|
247
|
+
private v6l = B2B_IV[12] | 0;
|
|
248
|
+
private v6h = B2B_IV[13] | 0;
|
|
249
|
+
private v7l = B2B_IV[14] | 0;
|
|
250
|
+
private v7h = B2B_IV[15] | 0;
|
|
251
|
+
|
|
252
|
+
constructor(opts: Blake2Opts = {}) {
|
|
253
|
+
const olen = opts.dkLen === undefined ? 64 : opts.dkLen;
|
|
254
|
+
super(128, olen);
|
|
255
|
+
checkBlake2Opts(olen, opts, 64, 16, 16);
|
|
256
|
+
let { key, personalization, salt } = opts;
|
|
257
|
+
let keyLength = 0;
|
|
258
|
+
if (key !== undefined) {
|
|
259
|
+
abytes(key, undefined, 'key');
|
|
260
|
+
keyLength = key.length;
|
|
261
|
+
}
|
|
262
|
+
// RFC 7693 §2.5: xor `p[0] = 0x0101kknn` into the low 32 bits of `h[0]`;
|
|
263
|
+
// the high 32 bits stay at `IV[0]`.
|
|
264
|
+
this.v0l ^= this.outputLen | (keyLength << 8) | (0x01 << 16) | (0x01 << 24);
|
|
265
|
+
if (salt !== undefined) {
|
|
266
|
+
abytes(salt, undefined, 'salt');
|
|
267
|
+
const slt = u32(salt);
|
|
268
|
+
this.v4l ^= swap8IfBE(slt[0]);
|
|
269
|
+
this.v4h ^= swap8IfBE(slt[1]);
|
|
270
|
+
this.v5l ^= swap8IfBE(slt[2]);
|
|
271
|
+
this.v5h ^= swap8IfBE(slt[3]);
|
|
272
|
+
}
|
|
273
|
+
if (personalization !== undefined) {
|
|
274
|
+
abytes(personalization, undefined, 'personalization');
|
|
275
|
+
const pers = u32(personalization);
|
|
276
|
+
this.v6l ^= swap8IfBE(pers[0]);
|
|
277
|
+
this.v6h ^= swap8IfBE(pers[1]);
|
|
278
|
+
this.v7l ^= swap8IfBE(pers[2]);
|
|
279
|
+
this.v7h ^= swap8IfBE(pers[3]);
|
|
280
|
+
}
|
|
281
|
+
if (key !== undefined) {
|
|
282
|
+
// Pad to blockLen and update
|
|
283
|
+
const tmp = new Uint8Array(this.blockLen);
|
|
284
|
+
tmp.set(key);
|
|
285
|
+
this.update(tmp);
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
// prettier-ignore
|
|
289
|
+
protected get(): [
|
|
290
|
+
number, number, number, number, number, number, number, number,
|
|
291
|
+
number, number, number, number, number, number, number, number
|
|
292
|
+
] {
|
|
293
|
+
let { v0l, v0h, v1l, v1h, v2l, v2h, v3l, v3h, v4l, v4h, v5l, v5h, v6l, v6h, v7l, v7h } = this;
|
|
294
|
+
return [v0l, v0h, v1l, v1h, v2l, v2h, v3l, v3h, v4l, v4h, v5l, v5h, v6l, v6h, v7l, v7h];
|
|
295
|
+
}
|
|
296
|
+
// prettier-ignore
|
|
297
|
+
protected set(
|
|
298
|
+
v0l: number, v0h: number, v1l: number, v1h: number,
|
|
299
|
+
v2l: number, v2h: number, v3l: number, v3h: number,
|
|
300
|
+
v4l: number, v4h: number, v5l: number, v5h: number,
|
|
301
|
+
v6l: number, v6h: number, v7l: number, v7h: number
|
|
302
|
+
): void {
|
|
303
|
+
this.v0l = v0l | 0;
|
|
304
|
+
this.v0h = v0h | 0;
|
|
305
|
+
this.v1l = v1l | 0;
|
|
306
|
+
this.v1h = v1h | 0;
|
|
307
|
+
this.v2l = v2l | 0;
|
|
308
|
+
this.v2h = v2h | 0;
|
|
309
|
+
this.v3l = v3l | 0;
|
|
310
|
+
this.v3h = v3h | 0;
|
|
311
|
+
this.v4l = v4l | 0;
|
|
312
|
+
this.v4h = v4h | 0;
|
|
313
|
+
this.v5l = v5l | 0;
|
|
314
|
+
this.v5h = v5h | 0;
|
|
315
|
+
this.v6l = v6l | 0;
|
|
316
|
+
this.v6h = v6h | 0;
|
|
317
|
+
this.v7l = v7l | 0;
|
|
318
|
+
this.v7h = v7h | 0;
|
|
319
|
+
}
|
|
320
|
+
protected compress(msg: Uint32Array, offset: number, isLast: boolean): void {
|
|
321
|
+
this.get().forEach((v, i) => (BBUF[i] = v)); // First half from state.
|
|
322
|
+
BBUF.set(B2B_IV, 16); // Second half from IV.
|
|
323
|
+
let { h, l } = u64.fromBig(BigInt(this.length));
|
|
324
|
+
BBUF[24] = B2B_IV[8] ^ l; // Low word of the offset.
|
|
325
|
+
BBUF[25] = B2B_IV[9] ^ h; // High word.
|
|
326
|
+
// Invert all bits for last block
|
|
327
|
+
if (isLast) {
|
|
328
|
+
BBUF[28] = ~BBUF[28];
|
|
329
|
+
BBUF[29] = ~BBUF[29];
|
|
330
|
+
}
|
|
331
|
+
let j = 0;
|
|
332
|
+
const s = BSIGMA;
|
|
333
|
+
// SIGMA selects 64-bit message words; multiply by 2 because `msg` stores
|
|
334
|
+
// each word as [low32, high32].
|
|
335
|
+
for (let i = 0; i < 12; i++) {
|
|
336
|
+
G1b(0, 4, 8, 12, msg, offset + 2 * s[j++]);
|
|
337
|
+
G2b(0, 4, 8, 12, msg, offset + 2 * s[j++]);
|
|
338
|
+
G1b(1, 5, 9, 13, msg, offset + 2 * s[j++]);
|
|
339
|
+
G2b(1, 5, 9, 13, msg, offset + 2 * s[j++]);
|
|
340
|
+
G1b(2, 6, 10, 14, msg, offset + 2 * s[j++]);
|
|
341
|
+
G2b(2, 6, 10, 14, msg, offset + 2 * s[j++]);
|
|
342
|
+
G1b(3, 7, 11, 15, msg, offset + 2 * s[j++]);
|
|
343
|
+
G2b(3, 7, 11, 15, msg, offset + 2 * s[j++]);
|
|
344
|
+
|
|
345
|
+
G1b(0, 5, 10, 15, msg, offset + 2 * s[j++]);
|
|
346
|
+
G2b(0, 5, 10, 15, msg, offset + 2 * s[j++]);
|
|
347
|
+
G1b(1, 6, 11, 12, msg, offset + 2 * s[j++]);
|
|
348
|
+
G2b(1, 6, 11, 12, msg, offset + 2 * s[j++]);
|
|
349
|
+
G1b(2, 7, 8, 13, msg, offset + 2 * s[j++]);
|
|
350
|
+
G2b(2, 7, 8, 13, msg, offset + 2 * s[j++]);
|
|
351
|
+
G1b(3, 4, 9, 14, msg, offset + 2 * s[j++]);
|
|
352
|
+
G2b(3, 4, 9, 14, msg, offset + 2 * s[j++]);
|
|
353
|
+
}
|
|
354
|
+
this.v0l ^= BBUF[0] ^ BBUF[16];
|
|
355
|
+
this.v0h ^= BBUF[1] ^ BBUF[17];
|
|
356
|
+
this.v1l ^= BBUF[2] ^ BBUF[18];
|
|
357
|
+
this.v1h ^= BBUF[3] ^ BBUF[19];
|
|
358
|
+
this.v2l ^= BBUF[4] ^ BBUF[20];
|
|
359
|
+
this.v2h ^= BBUF[5] ^ BBUF[21];
|
|
360
|
+
this.v3l ^= BBUF[6] ^ BBUF[22];
|
|
361
|
+
this.v3h ^= BBUF[7] ^ BBUF[23];
|
|
362
|
+
this.v4l ^= BBUF[8] ^ BBUF[24];
|
|
363
|
+
this.v4h ^= BBUF[9] ^ BBUF[25];
|
|
364
|
+
this.v5l ^= BBUF[10] ^ BBUF[26];
|
|
365
|
+
this.v5h ^= BBUF[11] ^ BBUF[27];
|
|
366
|
+
this.v6l ^= BBUF[12] ^ BBUF[28];
|
|
367
|
+
this.v6h ^= BBUF[13] ^ BBUF[29];
|
|
368
|
+
this.v7l ^= BBUF[14] ^ BBUF[30];
|
|
369
|
+
this.v7h ^= BBUF[15] ^ BBUF[31];
|
|
370
|
+
clean(BBUF);
|
|
371
|
+
}
|
|
372
|
+
destroy(): void {
|
|
373
|
+
this.destroyed = true;
|
|
374
|
+
clean(this.buffer32);
|
|
375
|
+
this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
/**
|
|
380
|
+
* Blake2b hash function. 64-bit. 1.5x slower than blake2s in JS.
|
|
381
|
+
* @param msg - message that would be hashed
|
|
382
|
+
* @param opts - Optional output, MAC, salt, and personalization settings.
|
|
383
|
+
* `dkLen` must be 1..64 bytes; `salt` and `personalization`, if present,
|
|
384
|
+
* must be 16 bytes each. See {@link Blake2Opts}.
|
|
385
|
+
* @returns Digest bytes.
|
|
386
|
+
* @example
|
|
387
|
+
* Hash a message with Blake2b.
|
|
388
|
+
* ```ts
|
|
389
|
+
* blake2b(new Uint8Array([97, 98, 99]));
|
|
390
|
+
* ```
|
|
391
|
+
*/
|
|
392
|
+
export const blake2b: TRet<CHash<_BLAKE2b, Blake2Opts>> = /* @__PURE__ */ createHasher(
|
|
393
|
+
(opts) => new _BLAKE2b(opts)
|
|
394
|
+
);
|
|
395
|
+
|
|
396
|
+
// =================
|
|
397
|
+
// Blake2S
|
|
398
|
+
// =================
|
|
399
|
+
|
|
400
|
+
/** Internal type, 16 numbers. */
|
|
401
|
+
// prettier-ignore
|
|
402
|
+
export type _Num16 = {
|
|
403
|
+
v0: number; v1: number; v2: number; v3: number;
|
|
404
|
+
v4: number; v5: number; v6: number; v7: number;
|
|
405
|
+
v8: number; v9: number; v10: number; v11: number;
|
|
406
|
+
v12: number; v13: number; v14: number; v15: number;
|
|
407
|
+
};
|
|
408
|
+
|
|
409
|
+
/**
|
|
410
|
+
* BLAKE2-compress core method.
|
|
411
|
+
* Runs only the round function over a caller-supplied local vector; callers initialize `v0..v15`
|
|
412
|
+
* and apply the final `h[i] ^= v[i] ^ v[i + 8]` fold themselves.
|
|
413
|
+
* @param s - flattened sigma schedule bytes
|
|
414
|
+
* @param offset - starting word offset inside `msg`, not a byte offset
|
|
415
|
+
* @param msg - message words
|
|
416
|
+
* @param rounds - round count to execute
|
|
417
|
+
* @param v0 - state word 0
|
|
418
|
+
* @param v1 - state word 1
|
|
419
|
+
* @param v2 - state word 2
|
|
420
|
+
* @param v3 - state word 3
|
|
421
|
+
* @param v4 - state word 4
|
|
422
|
+
* @param v5 - state word 5
|
|
423
|
+
* @param v6 - state word 6
|
|
424
|
+
* @param v7 - state word 7
|
|
425
|
+
* @param v8 - state word 8
|
|
426
|
+
* @param v9 - state word 9
|
|
427
|
+
* @param v10 - state word 10
|
|
428
|
+
* @param v11 - state word 11
|
|
429
|
+
* @param v12 - state word 12
|
|
430
|
+
* @param v13 - state word 13
|
|
431
|
+
* @param v14 - state word 14
|
|
432
|
+
* @param v15 - state word 15
|
|
433
|
+
* @returns Updated compression state words.
|
|
434
|
+
* @example
|
|
435
|
+
* Run the BLAKE2 compression core on zeroed state and message words.
|
|
436
|
+
* ```ts
|
|
437
|
+
* import { compress } from '@noble/hashes/blake2.js';
|
|
438
|
+
* const state = compress(
|
|
439
|
+
* new Uint8Array(16),
|
|
440
|
+
* 0,
|
|
441
|
+
* new Uint32Array(16),
|
|
442
|
+
* 1,
|
|
443
|
+
* 0, 0, 0, 0, 0, 0, 0, 0,
|
|
444
|
+
* 0, 0, 0, 0, 0, 0, 0, 0
|
|
445
|
+
* );
|
|
446
|
+
* state.v0;
|
|
447
|
+
* ```
|
|
448
|
+
*/
|
|
449
|
+
// prettier-ignore
|
|
450
|
+
export function compress(s: TArg<Uint8Array>, offset: number, msg: TArg<Uint32Array>, rounds: number,
|
|
451
|
+
v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number,
|
|
452
|
+
v8: number, v9: number, v10: number, v11: number, v12: number, v13: number, v14: number, v15: number,
|
|
453
|
+
): _Num16 {
|
|
454
|
+
let j = 0;
|
|
455
|
+
for (let i = 0; i < rounds; i++) {
|
|
456
|
+
({ a: v0, b: v4, c: v8, d: v12 } = G1s(v0, v4, v8, v12, msg[offset + s[j++]]));
|
|
457
|
+
({ a: v0, b: v4, c: v8, d: v12 } = G2s(v0, v4, v8, v12, msg[offset + s[j++]]));
|
|
458
|
+
({ a: v1, b: v5, c: v9, d: v13 } = G1s(v1, v5, v9, v13, msg[offset + s[j++]]));
|
|
459
|
+
({ a: v1, b: v5, c: v9, d: v13 } = G2s(v1, v5, v9, v13, msg[offset + s[j++]]));
|
|
460
|
+
({ a: v2, b: v6, c: v10, d: v14 } = G1s(v2, v6, v10, v14, msg[offset + s[j++]]));
|
|
461
|
+
({ a: v2, b: v6, c: v10, d: v14 } = G2s(v2, v6, v10, v14, msg[offset + s[j++]]));
|
|
462
|
+
({ a: v3, b: v7, c: v11, d: v15 } = G1s(v3, v7, v11, v15, msg[offset + s[j++]]));
|
|
463
|
+
({ a: v3, b: v7, c: v11, d: v15 } = G2s(v3, v7, v11, v15, msg[offset + s[j++]]));
|
|
464
|
+
|
|
465
|
+
({ a: v0, b: v5, c: v10, d: v15 } = G1s(v0, v5, v10, v15, msg[offset + s[j++]]));
|
|
466
|
+
({ a: v0, b: v5, c: v10, d: v15 } = G2s(v0, v5, v10, v15, msg[offset + s[j++]]));
|
|
467
|
+
({ a: v1, b: v6, c: v11, d: v12 } = G1s(v1, v6, v11, v12, msg[offset + s[j++]]));
|
|
468
|
+
({ a: v1, b: v6, c: v11, d: v12 } = G2s(v1, v6, v11, v12, msg[offset + s[j++]]));
|
|
469
|
+
({ a: v2, b: v7, c: v8, d: v13 } = G1s(v2, v7, v8, v13, msg[offset + s[j++]]));
|
|
470
|
+
({ a: v2, b: v7, c: v8, d: v13 } = G2s(v2, v7, v8, v13, msg[offset + s[j++]]));
|
|
471
|
+
({ a: v3, b: v4, c: v9, d: v14 } = G1s(v3, v4, v9, v14, msg[offset + s[j++]]));
|
|
472
|
+
({ a: v3, b: v4, c: v9, d: v14 } = G2s(v3, v4, v9, v14, msg[offset + s[j++]]));
|
|
473
|
+
}
|
|
474
|
+
return { v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15 };
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
// Blake2s reuses the SHA-256 IV words as-is.
|
|
478
|
+
const B2S_IV = /* @__PURE__ */ SHA256_IV.slice();
|
|
479
|
+
|
|
480
|
+
/** Internal blake2s hash class. */
|
|
481
|
+
export class _BLAKE2s extends _BLAKE2<_BLAKE2s> {
|
|
482
|
+
// Internal state, same as SHA-256
|
|
483
|
+
private v0 = B2S_IV[0] | 0;
|
|
484
|
+
private v1 = B2S_IV[1] | 0;
|
|
485
|
+
private v2 = B2S_IV[2] | 0;
|
|
486
|
+
private v3 = B2S_IV[3] | 0;
|
|
487
|
+
private v4 = B2S_IV[4] | 0;
|
|
488
|
+
private v5 = B2S_IV[5] | 0;
|
|
489
|
+
private v6 = B2S_IV[6] | 0;
|
|
490
|
+
private v7 = B2S_IV[7] | 0;
|
|
491
|
+
|
|
492
|
+
constructor(opts: Blake2Opts = {}) {
|
|
493
|
+
const olen = opts.dkLen === undefined ? 32 : opts.dkLen;
|
|
494
|
+
super(64, olen);
|
|
495
|
+
checkBlake2Opts(olen, opts, 32, 8, 8);
|
|
496
|
+
let { key, personalization, salt } = opts;
|
|
497
|
+
let keyLength = 0;
|
|
498
|
+
if (key !== undefined) {
|
|
499
|
+
abytes(key, undefined, 'key');
|
|
500
|
+
keyLength = key.length;
|
|
501
|
+
}
|
|
502
|
+
// RFC 7693 §2.5: xor `p[0] = 0x0101kknn` directly into `h[0]`, since
|
|
503
|
+
// BLAKE2s stores each state word as one `u32`.
|
|
504
|
+
this.v0 ^= this.outputLen | (keyLength << 8) | (0x01 << 16) | (0x01 << 24);
|
|
505
|
+
if (salt !== undefined) {
|
|
506
|
+
abytes(salt, undefined, 'salt');
|
|
507
|
+
const slt = u32(salt as Uint8Array);
|
|
508
|
+
this.v4 ^= swap8IfBE(slt[0]);
|
|
509
|
+
this.v5 ^= swap8IfBE(slt[1]);
|
|
510
|
+
}
|
|
511
|
+
if (personalization !== undefined) {
|
|
512
|
+
abytes(personalization, undefined, 'personalization');
|
|
513
|
+
const pers = u32(personalization as Uint8Array);
|
|
514
|
+
this.v6 ^= swap8IfBE(pers[0]);
|
|
515
|
+
this.v7 ^= swap8IfBE(pers[1]);
|
|
516
|
+
}
|
|
517
|
+
if (key !== undefined) {
|
|
518
|
+
// Pad to blockLen and update
|
|
519
|
+
const tmp = new Uint8Array(this.blockLen);
|
|
520
|
+
tmp.set(key);
|
|
521
|
+
this.update(tmp);
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
protected get(): [number, number, number, number, number, number, number, number] {
|
|
525
|
+
const { v0, v1, v2, v3, v4, v5, v6, v7 } = this;
|
|
526
|
+
return [v0, v1, v2, v3, v4, v5, v6, v7];
|
|
527
|
+
}
|
|
528
|
+
// prettier-ignore
|
|
529
|
+
protected set(
|
|
530
|
+
v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number
|
|
531
|
+
): void {
|
|
532
|
+
this.v0 = v0 | 0;
|
|
533
|
+
this.v1 = v1 | 0;
|
|
534
|
+
this.v2 = v2 | 0;
|
|
535
|
+
this.v3 = v3 | 0;
|
|
536
|
+
this.v4 = v4 | 0;
|
|
537
|
+
this.v5 = v5 | 0;
|
|
538
|
+
this.v6 = v6 | 0;
|
|
539
|
+
this.v7 = v7 | 0;
|
|
540
|
+
}
|
|
541
|
+
protected compress(msg: Uint32Array, offset: number, isLast: boolean): void {
|
|
542
|
+
const { h, l } = u64.fromBig(BigInt(this.length));
|
|
543
|
+
// Seed v8..v15 from the IV, xor the low/high 32-bit byte counter into
|
|
544
|
+
// v12/v13, and invert v14 on the final block.
|
|
545
|
+
// prettier-ignore
|
|
546
|
+
const { v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15 } =
|
|
547
|
+
compress(
|
|
548
|
+
BSIGMA, offset, msg, 10,
|
|
549
|
+
this.v0, this.v1, this.v2, this.v3, this.v4, this.v5, this.v6, this.v7,
|
|
550
|
+
B2S_IV[0], B2S_IV[1], B2S_IV[2], B2S_IV[3], l ^ B2S_IV[4], h ^ B2S_IV[5], isLast ? ~B2S_IV[6] : B2S_IV[6], B2S_IV[7]
|
|
551
|
+
);
|
|
552
|
+
this.v0 ^= v0 ^ v8;
|
|
553
|
+
this.v1 ^= v1 ^ v9;
|
|
554
|
+
this.v2 ^= v2 ^ v10;
|
|
555
|
+
this.v3 ^= v3 ^ v11;
|
|
556
|
+
this.v4 ^= v4 ^ v12;
|
|
557
|
+
this.v5 ^= v5 ^ v13;
|
|
558
|
+
this.v6 ^= v6 ^ v14;
|
|
559
|
+
this.v7 ^= v7 ^ v15;
|
|
560
|
+
}
|
|
561
|
+
destroy(): void {
|
|
562
|
+
this.destroyed = true;
|
|
563
|
+
clean(this.buffer32);
|
|
564
|
+
this.set(0, 0, 0, 0, 0, 0, 0, 0);
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
|
|
568
|
+
/**
|
|
569
|
+
* Blake2s hash function. Focuses on 8-bit to 32-bit platforms. 1.5x faster than blake2b in JS.
|
|
570
|
+
* @param msg - message that would be hashed
|
|
571
|
+
* @param opts - Optional output, MAC, salt, and personalization settings.
|
|
572
|
+
* `dkLen` must be 1..32 bytes; `salt` and `personalization`, if present,
|
|
573
|
+
* must be 8 bytes each. See {@link Blake2Opts}.
|
|
574
|
+
* @returns Digest bytes.
|
|
575
|
+
* @example
|
|
576
|
+
* Hash a message with Blake2s.
|
|
577
|
+
* ```ts
|
|
578
|
+
* blake2s(new Uint8Array([97, 98, 99]));
|
|
579
|
+
* ```
|
|
580
|
+
*/
|
|
581
|
+
export const blake2s: TRet<CHash<_BLAKE2s, Blake2Opts>> = /* @__PURE__ */ createHasher(
|
|
582
|
+
(opts) => new _BLAKE2s(opts)
|
|
583
|
+
);
|