@noble/post-quantum 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
package/slh-dsa.js ADDED
@@ -0,0 +1,605 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.slh_dsa_sha2_256s = exports.slh_dsa_sha2_256f = exports.slh_dsa_sha2_192s = exports.slh_dsa_sha2_192f = exports.slh_dsa_sha2_128s = exports.slh_dsa_sha2_128f = exports.sphincs_sha2_256s_robust = exports.sphincs_sha2_256s_simple = exports.sphincs_sha2_256f_robust = exports.sphincs_sha2_256f_simple = exports.sphincs_sha2_192s_robust = exports.sphincs_sha2_192s_simple = exports.sphincs_sha2_192f_robust = exports.sphincs_sha2_192f_simple = exports.sphincs_sha2_128s_robust = exports.sphincs_sha2_128s_simple = exports.sphincs_sha2_128f_robust = exports.sphincs_sha2_128f_simple = exports.slh_dsa_shake_256s = exports.slh_dsa_shake_256f = exports.slh_dsa_shake_192s = exports.slh_dsa_shake_192f = exports.slh_dsa_shake_128s = exports.slh_dsa_shake_128f = exports.sphincs_shake_256s_robust = exports.sphincs_shake_256s_simple = exports.sphincs_shake_256f_robust = exports.sphincs_shake_256f_simple = exports.sphincs_shake_192s_robust = exports.sphincs_shake_192s_simple = exports.sphincs_shake_192f_robust = exports.sphincs_shake_192f_simple = exports.sphincs_shake_128s_robust = exports.sphincs_shake_128s_simple = exports.sphincs_shake_128f_robust = exports.sphincs_shake_128f_simple = exports.PARAMS = void 0;
4
+ /*! noble-post-quantum - MIT License (c) 2024 Paul Miller (paulmillr.com) */
5
+ const hmac_1 = require("@noble/hashes/hmac");
6
+ const sha2_1 = require("@noble/hashes/sha2");
7
+ const sha3_1 = require("@noble/hashes/sha3");
8
+ const utils_1 = require("@noble/hashes/utils");
9
+ const utils_js_1 = require("./utils.js");
10
+ exports.PARAMS = {
11
+ '128f': { W: 16, N: 16, H: 66, D: 22, K: 33, A: 6 },
12
+ '128s': { W: 16, N: 16, H: 63, D: 7, K: 14, A: 12 },
13
+ '192f': { W: 16, N: 24, H: 66, D: 22, K: 33, A: 8 },
14
+ '192s': { W: 16, N: 24, H: 63, D: 7, K: 17, A: 14 },
15
+ '256f': { W: 16, N: 32, H: 68, D: 17, K: 35, A: 9 },
16
+ '256s': { W: 16, N: 32, H: 64, D: 8, K: 22, A: 14 },
17
+ };
18
+ function hexToNumber(hex) {
19
+ if (typeof hex !== 'string')
20
+ throw new Error('hex string expected, got ' + typeof hex);
21
+ // Big Endian
22
+ return BigInt(hex === '' ? '0' : `0x${hex}`);
23
+ }
24
+ // BE: Big Endian, LE: Little Endian
25
+ function bytesToNumberBE(bytes) {
26
+ return hexToNumber((0, utils_1.bytesToHex)(bytes));
27
+ }
28
+ function numberToBytesBE(n, len) {
29
+ return (0, utils_1.hexToBytes)(n.toString(16).padStart(len * 2, '0'));
30
+ }
31
+ // Same as bitsCoder.decode, but bits are BE instead of LE (so we cannot re-use it).
32
+ // NOTE: difference happens only if d < 8.
33
+ const base_2bBE = (N, d) => {
34
+ const mask = (0, utils_js_1.getMask)(d);
35
+ return (bytes) => {
36
+ const r = new Uint32Array(N);
37
+ for (let i = 0, buf = 0, bufLen = 0, pos = 0; i < bytes.length; i++) {
38
+ buf |= bytes[i] << bufLen;
39
+ bufLen += 8;
40
+ for (; bufLen >= d; bufLen -= d)
41
+ r[pos++] = (buf >>> (bufLen - d)) & mask;
42
+ buf &= (0, utils_js_1.getMask)(bufLen);
43
+ }
44
+ return r;
45
+ };
46
+ };
47
+ // Same as bitsCoder.decode, but maybe spec will change and unify with base2bBE.
48
+ const base_2bLE = (N, d) => {
49
+ const mask = (0, utils_js_1.getMask)(d);
50
+ return (bytes) => {
51
+ const r = new Uint32Array(N);
52
+ for (let i = 0, buf = 0, bufLen = 0, pos = 0; i < bytes.length; i++) {
53
+ buf |= bytes[i] << bufLen;
54
+ bufLen += 8;
55
+ for (; bufLen >= d; bufLen -= d, buf >>= d)
56
+ r[pos++] = buf & mask;
57
+ }
58
+ return r;
59
+ };
60
+ };
61
+ function getMaskBig(bits) {
62
+ return (1n << BigInt(bits)) - 1n; // 4 -> 0b1111
63
+ }
64
+ function gen(opts, hashOpts) {
65
+ const { N, W, H, D, K, A } = opts;
66
+ const getContext = hashOpts.getContext(opts);
67
+ if (W !== 16)
68
+ throw new Error('Unsupported Winternitz parameter');
69
+ const WOTS_LOGW = 4;
70
+ const WOTS_LEN1 = Math.floor((8 * N) / WOTS_LOGW);
71
+ const WOTS_LEN2 = N <= 8 ? 2 : N <= 136 ? 3 : 4;
72
+ const TREE_HEIGHT = Math.floor(H / D);
73
+ const WOTS_LEN = WOTS_LEN1 + WOTS_LEN2;
74
+ let ADDR_BYTES = 22;
75
+ let OFFSET_LAYER = 0;
76
+ let OFFSET_TREE = 1;
77
+ let OFFSET_TYPE = 9;
78
+ let OFFSET_KP_ADDR2 = 12;
79
+ let OFFSET_KP_ADDR1 = 13;
80
+ let OFFSET_CHAIN_ADDR = 17;
81
+ let OFFSET_TREE_INDEX = 18;
82
+ let OFFSET_HASH_ADDR = 21;
83
+ if (!hashOpts.isCompressed) {
84
+ ADDR_BYTES = 32;
85
+ OFFSET_LAYER += 3;
86
+ OFFSET_TREE += 7;
87
+ OFFSET_TYPE += 10;
88
+ OFFSET_KP_ADDR2 += 10;
89
+ OFFSET_KP_ADDR1 += 10;
90
+ OFFSET_CHAIN_ADDR += 10;
91
+ OFFSET_TREE_INDEX += 10;
92
+ OFFSET_HASH_ADDR += 10;
93
+ }
94
+ const setAddr = (opts, addr = new Uint8Array(ADDR_BYTES)) => {
95
+ const { type, height, tree, layer, index, chain, hash, keypair } = opts;
96
+ const { subtreeAddr, keypairAddr } = opts;
97
+ const v = (0, utils_1.createView)(addr);
98
+ if (height !== undefined)
99
+ addr[OFFSET_CHAIN_ADDR] = height;
100
+ if (layer !== undefined)
101
+ addr[OFFSET_LAYER] = layer;
102
+ if (type !== undefined)
103
+ addr[OFFSET_TYPE] = type;
104
+ if (chain !== undefined)
105
+ addr[OFFSET_CHAIN_ADDR] = chain;
106
+ if (hash !== undefined)
107
+ addr[OFFSET_HASH_ADDR] = hash;
108
+ if (index !== undefined)
109
+ v.setUint32(OFFSET_TREE_INDEX, index, false);
110
+ if (subtreeAddr)
111
+ addr.set(subtreeAddr.subarray(0, OFFSET_TREE + 8));
112
+ if (tree !== undefined)
113
+ v.setBigUint64(OFFSET_TREE, tree, false);
114
+ if (keypair !== undefined) {
115
+ addr[OFFSET_KP_ADDR1] = keypair;
116
+ if (TREE_HEIGHT > 8)
117
+ addr[OFFSET_KP_ADDR2] = keypair >>> 8;
118
+ }
119
+ if (keypairAddr) {
120
+ addr.set(keypairAddr.subarray(0, OFFSET_TREE + 8));
121
+ addr[OFFSET_KP_ADDR1] = keypairAddr[OFFSET_KP_ADDR1];
122
+ if (TREE_HEIGHT > 8)
123
+ addr[OFFSET_KP_ADDR2] = keypairAddr[OFFSET_KP_ADDR2];
124
+ }
125
+ return addr;
126
+ };
127
+ const chainCoder = base_2bBE(WOTS_LEN2, WOTS_LOGW);
128
+ const chainLengths = (msg) => {
129
+ const W1 = base_2bBE(WOTS_LEN1, WOTS_LOGW)(msg);
130
+ let csum = 0;
131
+ for (let i = 0; i < W1.length; i++)
132
+ csum += W - 1 - W1[i]; // ▷ Compute checksum
133
+ csum <<= (8 - ((WOTS_LEN2 * WOTS_LOGW) % 8)) % 8; // csum ← csum ≪ ((8 − ((len2 · lg(w)) mod 8)) mod 8
134
+ // Checksum to base(LOG_W)
135
+ const W2 = chainCoder(numberToBytesBE(csum, Math.ceil((WOTS_LEN2 * WOTS_LOGW) / 8)));
136
+ // W1 || W2 (concatBytes cannot concat TypedArrays)
137
+ const lengths = new Uint32Array(WOTS_LEN);
138
+ lengths.set(W1);
139
+ lengths.set(W2, W1.length);
140
+ return lengths;
141
+ };
142
+ // Hm, why BE vs LE?
143
+ const msgCoder = base_2bLE(K, A);
144
+ const messageToIndices = (msg) => msgCoder(msg);
145
+ const TREE_BITS = TREE_HEIGHT * (D - 1);
146
+ const LEAF_BITS = TREE_HEIGHT;
147
+ const hashMsgCoder = (0, utils_js_1.splitCoder)(Math.ceil((A * K) / 8), Math.ceil(TREE_BITS / 8), Math.ceil(TREE_HEIGHT / 8));
148
+ const hashMessage = (R, pkSeed, msg, context) => {
149
+ const digest = context.Hmsg(R, pkSeed, msg, hashMsgCoder.bytesLen); // digest ← Hmsg(R, PK.seed, PK.root, M)
150
+ const [md, tmpIdxTree, tmpIdxLeaf] = hashMsgCoder.decode(digest);
151
+ const tree = bytesToNumberBE(tmpIdxTree) & getMaskBig(TREE_BITS);
152
+ const leafIdx = Number(bytesToNumberBE(tmpIdxLeaf)) & (0, utils_js_1.getMask)(LEAF_BITS);
153
+ return { tree, leafIdx, md };
154
+ };
155
+ const treehash = (height, fn) => function treehash_i(context, leafIdx, idxOffset, treeAddr, info) {
156
+ const maxIdx = (1 << height) - 1;
157
+ const stack = new Uint8Array(height * N);
158
+ const authPath = new Uint8Array(height * N);
159
+ for (let idx = 0;; idx++) {
160
+ const current = new Uint8Array(2 * N);
161
+ const cur0 = current.subarray(0, N);
162
+ const cur1 = current.subarray(N);
163
+ const addrOffset = idx + idxOffset;
164
+ cur1.set(fn(leafIdx, addrOffset, context, info));
165
+ let h = 0;
166
+ for (let i = idx, o = idxOffset, l = leafIdx;; h++, i >>>= 1, l >>>= 1, o >>>= 1) {
167
+ if (h === height)
168
+ return { root: cur1, authPath }; // Returns from here
169
+ if ((i ^ l) === 1)
170
+ authPath.subarray(h * N).set(cur1); // authPath.push(cur1)
171
+ if ((i & 1) === 0 && idx < maxIdx)
172
+ break;
173
+ setAddr({ height: h + 1, index: (i >> 1) + (o >> 1) }, treeAddr);
174
+ cur0.set(stack.subarray(h * N).subarray(0, N));
175
+ cur1.set(context.thashN(2, current, treeAddr));
176
+ }
177
+ stack.subarray(h * N).set(cur1); // stack.push(cur1)
178
+ }
179
+ // @ts-ignore
180
+ throw new Error('Unreachable code path reached, report this error');
181
+ };
182
+ const wotsTreehash = treehash(TREE_HEIGHT, (leafIdx, addrOffset, context, info) => {
183
+ const wotsPk = new Uint8Array(WOTS_LEN * N);
184
+ const wotsKmask = addrOffset === leafIdx ? 0 : ~0 >>> 0;
185
+ setAddr({ keypair: addrOffset }, info.leafAddr);
186
+ setAddr({ keypair: addrOffset }, info.pkAddr);
187
+ for (let i = 0; i < WOTS_LEN; i++) {
188
+ const wotsK = info.wotsSteps[i] | wotsKmask;
189
+ const pk = wotsPk.subarray(i * N, (i + 1) * N);
190
+ setAddr({ chain: i, hash: 0, type: 5 /* AddressType.WOTSPRF */ }, info.leafAddr);
191
+ pk.set(context.PRFaddr(info.leafAddr));
192
+ setAddr({ type: 0 /* AddressType.WOTS */ }, info.leafAddr);
193
+ for (let k = 0;; k++) {
194
+ if (k === wotsK)
195
+ info.wotsSig.subarray(i * N).set(pk); //wotsSig.push()
196
+ if (k === W - 1)
197
+ break;
198
+ setAddr({ hash: k }, info.leafAddr);
199
+ pk.set(context.thash1(pk, info.leafAddr));
200
+ }
201
+ }
202
+ return context.thashN(WOTS_LEN, wotsPk, info.pkAddr);
203
+ });
204
+ const forsTreehash = treehash(A, (_, addrOffset, context, forsLeafAddr) => {
205
+ setAddr({ type: 6 /* AddressType.FORSPRF */, index: addrOffset }, forsLeafAddr);
206
+ const prf = context.PRFaddr(forsLeafAddr);
207
+ setAddr({ type: 3 /* AddressType.FORSTREE */ }, forsLeafAddr);
208
+ return context.thash1(prf, forsLeafAddr);
209
+ });
210
+ const merkleSign = (context, wotsAddr, treeAddr, leafIdx, prevRoot = new Uint8Array(N)) => {
211
+ setAddr({ type: 2 /* AddressType.HASHTREE */ }, treeAddr);
212
+ // State variables
213
+ const info = {
214
+ wotsSig: new Uint8Array(wotsCoder.bytesLen),
215
+ wotsSteps: chainLengths(prevRoot),
216
+ leafAddr: setAddr({ subtreeAddr: wotsAddr }),
217
+ pkAddr: setAddr({ type: 1 /* AddressType.WOTSPK */, subtreeAddr: wotsAddr }),
218
+ };
219
+ const { root, authPath } = wotsTreehash(context, leafIdx, 0, treeAddr, info);
220
+ return {
221
+ root,
222
+ sigWots: info.wotsSig.subarray(0, WOTS_LEN * N),
223
+ sigAuth: authPath,
224
+ };
225
+ };
226
+ const computeRoot = (leaf, leafIdx, idxOffset, authPath, treeHeight, context, addr) => {
227
+ const buffer = new Uint8Array(2 * N);
228
+ const b0 = buffer.subarray(0, N);
229
+ const b1 = buffer.subarray(N, 2 * N);
230
+ // First iter
231
+ if ((leafIdx & 1) !== 0) {
232
+ b1.set(leaf.subarray(0, N));
233
+ b0.set(authPath.subarray(0, N));
234
+ }
235
+ else {
236
+ b0.set(leaf.subarray(0, N));
237
+ b1.set(authPath.subarray(0, N));
238
+ }
239
+ leafIdx >>>= 1;
240
+ idxOffset >>>= 1;
241
+ // Rest
242
+ for (let i = 0; i < treeHeight - 1; i++, leafIdx >>= 1, idxOffset >>= 1) {
243
+ setAddr({ height: i + 1, index: leafIdx + idxOffset }, addr);
244
+ const a = authPath.subarray((i + 1) * N, (i + 2) * N);
245
+ if ((leafIdx & 1) !== 0) {
246
+ b1.set(context.thashN(2, buffer, addr));
247
+ b0.set(a);
248
+ }
249
+ else {
250
+ buffer.set(context.thashN(2, buffer, addr));
251
+ b1.set(a);
252
+ }
253
+ }
254
+ // Root
255
+ setAddr({ height: treeHeight, index: leafIdx + idxOffset }, addr);
256
+ return context.thashN(2, buffer, addr);
257
+ };
258
+ const seedCoder = (0, utils_js_1.splitCoder)(N, N, N);
259
+ const publicCoder = (0, utils_js_1.splitCoder)(N, N);
260
+ const secretCoder = (0, utils_js_1.splitCoder)(N, N, publicCoder.bytesLen);
261
+ const forsCoder = (0, utils_js_1.vecCoder)((0, utils_js_1.splitCoder)(N, N * A), K);
262
+ const wotsCoder = (0, utils_js_1.vecCoder)((0, utils_js_1.splitCoder)(WOTS_LEN * N, TREE_HEIGHT * N), D);
263
+ const sigCoder = (0, utils_js_1.splitCoder)(N, forsCoder, wotsCoder); // random || fors || wots
264
+ return {
265
+ seedLen: seedCoder.bytesLen,
266
+ signRandBytes: N,
267
+ keygen(seed = (0, utils_js_1.randomBytes)(seedCoder.bytesLen)) {
268
+ // Set SK.seed, SK.prf, and PK.seed to random n-byte
269
+ const [secretSeed, secretPRF, publicSeed] = seedCoder.decode(seed);
270
+ const context = getContext(publicSeed, secretSeed);
271
+ // ADRS.setLayerAddress(d − 1)
272
+ const topTreeAddr = setAddr({ layer: D - 1 });
273
+ const wotsAddr = setAddr({ layer: D - 1 });
274
+ //PK.root ←_xmss node(SK.seed, 0, h′, PK.seed, ADRS)
275
+ const { root } = merkleSign(context, wotsAddr, topTreeAddr, ~0 >>> 0);
276
+ const publicKey = publicCoder.encode([publicSeed, root]);
277
+ const secretKey = secretCoder.encode([secretSeed, secretPRF, publicKey]);
278
+ context.clean();
279
+ (0, utils_js_1.cleanBytes)(secretSeed, secretPRF, root, wotsAddr, topTreeAddr);
280
+ return { publicKey, secretKey };
281
+ },
282
+ sign: (sk, msg, random) => {
283
+ const [skSeed, skPRF, pk] = secretCoder.decode(sk); // todo: fix
284
+ const [pkSeed, _] = publicCoder.decode(pk);
285
+ // Set opt_rand to either PK.seed or to a random n-byte string
286
+ if (!random)
287
+ random = pkSeed.slice();
288
+ (0, utils_js_1.ensureBytes)(random, N);
289
+ const context = getContext(pkSeed, skSeed);
290
+ // Generate randomizer
291
+ const R = context.PRFmsg(skPRF, random, msg); // R ← PRFmsg(SK.prf, opt_rand, M)
292
+ let { tree, leafIdx, md } = hashMessage(R, pk, msg, context);
293
+ // Create FORS signatures
294
+ const wotsAddr = setAddr({
295
+ type: 0 /* AddressType.WOTS */,
296
+ tree,
297
+ keypair: leafIdx,
298
+ });
299
+ const roots = [];
300
+ const forsLeaf = setAddr({ keypairAddr: wotsAddr });
301
+ const forsTreeAddr = setAddr({ keypairAddr: wotsAddr });
302
+ const indices = messageToIndices(md);
303
+ const fors = [];
304
+ for (let i = 0; i < indices.length; i++) {
305
+ const idxOffset = i << A;
306
+ setAddr({
307
+ type: 6 /* AddressType.FORSPRF */,
308
+ height: 0,
309
+ index: indices[i] + idxOffset,
310
+ }, forsTreeAddr);
311
+ const prf = context.PRFaddr(forsTreeAddr);
312
+ setAddr({ type: 3 /* AddressType.FORSTREE */ }, forsTreeAddr);
313
+ const { root, authPath } = forsTreehash(context, indices[i], idxOffset, forsTreeAddr, forsLeaf);
314
+ roots.push(root);
315
+ fors.push([prf, authPath]);
316
+ }
317
+ const forsPkAddr = setAddr({
318
+ type: 4 /* AddressType.FORSPK */,
319
+ keypairAddr: wotsAddr,
320
+ });
321
+ const root = context.thashN(K, (0, utils_1.concatBytes)(...roots), forsPkAddr);
322
+ // WOTS signatures
323
+ const treeAddr = setAddr({ type: 2 /* AddressType.HASHTREE */ });
324
+ const wots = [];
325
+ for (let i = 0; i < D; i++, tree >>= BigInt(TREE_HEIGHT)) {
326
+ setAddr({ tree, layer: i }, treeAddr);
327
+ setAddr({ subtreeAddr: treeAddr, keypair: leafIdx }, wotsAddr);
328
+ const { sigWots, sigAuth, root: r, } = merkleSign(context, wotsAddr, treeAddr, leafIdx, root);
329
+ root.set(r);
330
+ r.fill(0);
331
+ wots.push([sigWots, sigAuth]);
332
+ leafIdx = Number(tree & getMaskBig(TREE_HEIGHT));
333
+ }
334
+ context.clean();
335
+ const SIG = sigCoder.encode([R, fors, wots]);
336
+ (0, utils_js_1.cleanBytes)(R, random, treeAddr, wotsAddr, forsLeaf, forsTreeAddr, indices, roots);
337
+ return SIG;
338
+ },
339
+ verify: (publicKey, msg, sig) => {
340
+ const [pkSeed, pubRoot] = publicCoder.decode(publicKey);
341
+ const [random, forsVec, wotsVec] = sigCoder.decode(sig);
342
+ const pk = publicKey;
343
+ if (sig.length !== sigCoder.bytesLen)
344
+ return false;
345
+ const context = getContext(pkSeed);
346
+ let { tree, leafIdx, md } = hashMessage(random, pk, msg, context);
347
+ const wotsAddr = setAddr({
348
+ type: 0 /* AddressType.WOTS */,
349
+ tree,
350
+ keypair: leafIdx,
351
+ });
352
+ // FORS signature
353
+ const roots = [];
354
+ const forsTreeAddr = setAddr({
355
+ type: 3 /* AddressType.FORSTREE */,
356
+ keypairAddr: wotsAddr,
357
+ });
358
+ const indices = messageToIndices(md);
359
+ for (let i = 0; i < forsVec.length; i++) {
360
+ const [prf, authPath] = forsVec[i];
361
+ const idxOffset = i << A;
362
+ setAddr({ height: 0, index: indices[i] + idxOffset }, forsTreeAddr);
363
+ const leaf = context.thash1(prf, forsTreeAddr);
364
+ // Compute inplace, because we need all roots in same byte array
365
+ roots.push(computeRoot(leaf, indices[i], idxOffset, authPath, A, context, forsTreeAddr));
366
+ }
367
+ const forsPkAddr = setAddr({
368
+ type: 4 /* AddressType.FORSPK */,
369
+ keypairAddr: wotsAddr,
370
+ });
371
+ let root = context.thashN(K, (0, utils_1.concatBytes)(...roots), forsPkAddr); // root = thash()
372
+ // WOTS signature
373
+ const treeAddr = setAddr({ type: 2 /* AddressType.HASHTREE */ });
374
+ const wotsPkAddr = setAddr({ type: 1 /* AddressType.WOTSPK */ });
375
+ const wotsPk = new Uint8Array(WOTS_LEN * N);
376
+ for (let i = 0; i < wotsVec.length; i++, tree >>= BigInt(TREE_HEIGHT)) {
377
+ const [wots, sigAuth] = wotsVec[i];
378
+ setAddr({ tree, layer: i }, treeAddr);
379
+ setAddr({ subtreeAddr: treeAddr, keypair: leafIdx }, wotsAddr);
380
+ setAddr({ keypairAddr: wotsAddr }, wotsPkAddr);
381
+ const lengths = chainLengths(root);
382
+ for (let i = 0; i < WOTS_LEN; i++) {
383
+ setAddr({ chain: i }, wotsAddr);
384
+ const steps = W - 1 - lengths[i];
385
+ const start = lengths[i];
386
+ const out = wotsPk.subarray(i * N);
387
+ out.set(wots.subarray(i * N, (i + 1) * N));
388
+ for (let j = start; j < start + steps && j < W; j++) {
389
+ setAddr({ hash: j }, wotsAddr);
390
+ out.set(context.thash1(out, wotsAddr));
391
+ }
392
+ }
393
+ const leaf = context.thashN(WOTS_LEN, wotsPk, wotsPkAddr);
394
+ root = computeRoot(leaf, leafIdx, 0, sigAuth, TREE_HEIGHT, context, treeAddr);
395
+ leafIdx = Number(tree & getMaskBig(TREE_HEIGHT));
396
+ }
397
+ return (0, utils_js_1.equalBytes)(root, pubRoot);
398
+ },
399
+ };
400
+ }
401
+ const genShake = (robust) => (opts) => (pubSeed, skSeed) => {
402
+ const ADDR_BYTES = 32;
403
+ const { N } = opts;
404
+ const stats = { prf: 0, thash: 0, hmsg: 0, gen_message_random: 0 };
405
+ const h0 = sha3_1.shake256.create({}).update(pubSeed);
406
+ const h0tmp = h0.clone();
407
+ const thash_simple = (blocks, input, addr) => {
408
+ stats.thash++;
409
+ return h0
410
+ ._cloneInto(h0tmp)
411
+ .update(addr)
412
+ .update(input.subarray(0, blocks * N))
413
+ .xof(N);
414
+ };
415
+ const thash_robust = (blocks, input, addr) => {
416
+ stats.thash++;
417
+ const buf = new Uint8Array(ADDR_BYTES + (blocks + 1) * N);
418
+ buf.subarray(0, N).set(pubSeed);
419
+ buf.subarray(N, N + ADDR_BYTES).set(addr);
420
+ sha3_1.shake256
421
+ .create({})
422
+ .update(buf.subarray(0, N + ADDR_BYTES))
423
+ .xofInto(buf.subarray(N + ADDR_BYTES));
424
+ for (let i = 0; i < blocks * N; i++)
425
+ buf[N + ADDR_BYTES + i] ^= input[i];
426
+ return sha3_1.shake256.create({}).update(buf).xof(N);
427
+ };
428
+ const thash = robust ? thash_robust : thash_simple;
429
+ return {
430
+ PRFaddr: (addr) => {
431
+ if (!skSeed)
432
+ throw new Error('no sk seed');
433
+ stats.prf++;
434
+ return h0._cloneInto(h0tmp).update(addr).update(skSeed).xof(N);
435
+ },
436
+ PRFmsg: (skPRF, random, msg) => {
437
+ stats.gen_message_random++;
438
+ return sha3_1.shake256.create({}).update(skPRF).update(random).update(msg).digest().subarray(0, N);
439
+ },
440
+ Hmsg: (R, pk, m, outLen) => {
441
+ stats.hmsg++;
442
+ return sha3_1.shake256.create({}).update(R.subarray(0, N)).update(pk).update(m).xof(outLen);
443
+ },
444
+ thash1: thash.bind(null, 1),
445
+ thashN: thash,
446
+ clean: () => {
447
+ h0.destroy();
448
+ h0tmp.destroy();
449
+ //console.log(stats);
450
+ },
451
+ };
452
+ };
453
+ const SHAKE_SIMPLE = { getContext: genShake(false) };
454
+ const SHAKE_ROBUST = { getContext: genShake(true) };
455
+ exports.sphincs_shake_128f_simple = gen(exports.PARAMS['128f'], SHAKE_SIMPLE);
456
+ exports.sphincs_shake_128f_robust = gen(exports.PARAMS['128f'], SHAKE_ROBUST);
457
+ exports.sphincs_shake_128s_simple = gen(exports.PARAMS['128s'], SHAKE_SIMPLE);
458
+ exports.sphincs_shake_128s_robust = gen(exports.PARAMS['128s'], SHAKE_ROBUST);
459
+ exports.sphincs_shake_192f_simple = gen(exports.PARAMS['192f'], SHAKE_SIMPLE);
460
+ exports.sphincs_shake_192f_robust = gen(exports.PARAMS['192f'], SHAKE_ROBUST);
461
+ exports.sphincs_shake_192s_simple = gen(exports.PARAMS['192s'], SHAKE_SIMPLE);
462
+ exports.sphincs_shake_192s_robust = gen(exports.PARAMS['192s'], SHAKE_ROBUST);
463
+ exports.sphincs_shake_256f_simple = gen(exports.PARAMS['256f'], SHAKE_SIMPLE);
464
+ exports.sphincs_shake_256f_robust = gen(exports.PARAMS['256f'], SHAKE_ROBUST);
465
+ exports.sphincs_shake_256s_simple = gen(exports.PARAMS['256s'], SHAKE_SIMPLE);
466
+ exports.sphincs_shake_256s_robust = gen(exports.PARAMS['256s'], SHAKE_ROBUST);
467
+ // Only simple mode in SLH-DSA
468
+ exports.slh_dsa_shake_128f = gen(exports.PARAMS['128f'], SHAKE_SIMPLE);
469
+ exports.slh_dsa_shake_128s = gen(exports.PARAMS['128s'], SHAKE_SIMPLE);
470
+ exports.slh_dsa_shake_192f = gen(exports.PARAMS['192f'], SHAKE_SIMPLE);
471
+ exports.slh_dsa_shake_192s = gen(exports.PARAMS['192s'], SHAKE_SIMPLE);
472
+ exports.slh_dsa_shake_256f = gen(exports.PARAMS['256f'], SHAKE_SIMPLE);
473
+ exports.slh_dsa_shake_256s = gen(exports.PARAMS['256s'], SHAKE_SIMPLE);
474
+ const genSha = (h0, h1, robust) => (opts) => (pub_seed, sk_seed) => {
475
+ const { N } = opts;
476
+ /*
477
+ Perf debug stats, how much hashes we call?
478
+ 128f_simple: { prf: 8305, thash: 96_922, hmsg: 1, gen_message_random: 1, mgf1: 2 }
479
+ 256s_robust: { prf: 497_686, thash: 2_783_203, hmsg: 1, gen_message_random: 1, mgf1: 2_783_205}
480
+ 256f_simple: { prf: 36_179, thash: 309_693, hmsg: 1, gen_message_random: 1, mgf1: 2 }
481
+ */
482
+ const stats = { prf: 0, thash: 0, hmsg: 0, gen_message_random: 0, mgf1: 0 };
483
+ const counterB = new Uint8Array(4);
484
+ const counterV = (0, utils_1.createView)(counterB);
485
+ const h0ps = h0
486
+ .create()
487
+ .update(pub_seed)
488
+ .update(new Uint8Array(h0.blockLen - N));
489
+ const h1ps = h1
490
+ .create()
491
+ .update(pub_seed)
492
+ .update(new Uint8Array(h1.blockLen - N));
493
+ const h0tmp = h0ps.clone();
494
+ const h1tmp = h1ps.clone();
495
+ function mgf1(seed, length, hash) {
496
+ stats.mgf1++;
497
+ const out = new Uint8Array(Math.ceil(length / hash.outputLen) * hash.outputLen);
498
+ if (length > 2 ** 32)
499
+ throw new Error('mask too long');
500
+ for (let counter = 0, o = out; o.length; counter++) {
501
+ counterV.setUint32(0, counter, false);
502
+ hash.create().update(seed).update(counterB).digestInto(o);
503
+ o = o.subarray(hash.outputLen);
504
+ }
505
+ out.subarray(length).fill(0);
506
+ return out.subarray(0, length);
507
+ }
508
+ const thash_simple = (_, h, hTmp) => (blocks, input, addr) => {
509
+ stats.thash++;
510
+ const d = h
511
+ ._cloneInto(hTmp)
512
+ .update(addr)
513
+ .update(input.subarray(0, blocks * N))
514
+ .digest();
515
+ return d.subarray(0, N);
516
+ };
517
+ const thash_robust = (sha, h, _) => (blocks, input, addr) => {
518
+ stats.thash++;
519
+ stats.mgf1++;
520
+ // inlined mgf1
521
+ const addr8 = addr;
522
+ const hh = sha.create().update(pub_seed).update(addr8);
523
+ let bitmask = new Uint8Array(Math.ceil((blocks * N) / sha.outputLen) * sha.outputLen);
524
+ for (let counter = 0, o = bitmask; o.length; counter++) {
525
+ counterV.setUint32(0, counter, false);
526
+ hh.clone().update(counterB).digestInto(o);
527
+ o = o.subarray(sha.outputLen);
528
+ }
529
+ bitmask = bitmask.subarray(0, blocks * N);
530
+ const ou32 = (0, utils_1.u32)(input);
531
+ const bm32 = (0, utils_1.u32)(bitmask);
532
+ for (let i = 0; i < bm32.length; i++)
533
+ bm32[i] ^= ou32[i];
534
+ const d = h.clone().update(addr8).update(bitmask).digest();
535
+ return d.subarray(0, N);
536
+ };
537
+ const thash = robust ? thash_robust : thash_simple;
538
+ return {
539
+ PRFaddr: (addr) => {
540
+ if (!sk_seed)
541
+ throw new Error('No sk seed');
542
+ stats.prf++;
543
+ return h0ps
544
+ ._cloneInto(h0tmp)
545
+ .update(addr)
546
+ .update(sk_seed)
547
+ .digest()
548
+ .subarray(0, N);
549
+ },
550
+ PRFmsg: (skPRF, random, msg) => {
551
+ stats.gen_message_random++;
552
+ return new hmac_1.HMAC(h1, skPRF).update(random).update(msg).digest().subarray(0, N);
553
+ },
554
+ Hmsg: (R, pk, m, outLen) => {
555
+ stats.hmsg++;
556
+ const seed = (0, utils_1.concatBytes)(R.subarray(0, N), pk.subarray(0, N), h1.create().update(R.subarray(0, N)).update(pk).update(m).digest());
557
+ return mgf1(seed, outLen, h1);
558
+ },
559
+ thash1: thash(h0, h0ps, h0tmp).bind(null, 1),
560
+ thashN: thash(h1, h1ps, h1tmp),
561
+ clean: () => {
562
+ h0ps.destroy();
563
+ h1ps.destroy();
564
+ h0tmp.destroy();
565
+ h1tmp.destroy();
566
+ //console.log(stats);
567
+ },
568
+ };
569
+ };
570
+ const SHA256_SIMPLE = {
571
+ isCompressed: true,
572
+ getContext: genSha(sha2_1.sha256, sha2_1.sha256, false),
573
+ };
574
+ const SHA256_ROBUST = {
575
+ isCompressed: true,
576
+ getContext: genSha(sha2_1.sha256, sha2_1.sha256, true),
577
+ };
578
+ const SHA512_SIMPLE = {
579
+ isCompressed: true,
580
+ getContext: genSha(sha2_1.sha256, sha2_1.sha512, false),
581
+ };
582
+ const SHA512_ROBUST = {
583
+ isCompressed: true,
584
+ getContext: genSha(sha2_1.sha256, sha2_1.sha512, true),
585
+ };
586
+ exports.sphincs_sha2_128f_simple = gen(exports.PARAMS['128f'], SHA256_SIMPLE);
587
+ exports.sphincs_sha2_128f_robust = gen(exports.PARAMS['128f'], SHA256_ROBUST);
588
+ exports.sphincs_sha2_128s_simple = gen(exports.PARAMS['128s'], SHA256_SIMPLE);
589
+ exports.sphincs_sha2_128s_robust = gen(exports.PARAMS['128s'], SHA256_ROBUST);
590
+ exports.sphincs_sha2_192f_simple = gen(exports.PARAMS['192f'], SHA512_SIMPLE);
591
+ exports.sphincs_sha2_192f_robust = gen(exports.PARAMS['192f'], SHA512_ROBUST);
592
+ exports.sphincs_sha2_192s_simple = gen(exports.PARAMS['192s'], SHA512_SIMPLE);
593
+ exports.sphincs_sha2_192s_robust = gen(exports.PARAMS['192s'], SHA512_ROBUST);
594
+ exports.sphincs_sha2_256f_simple = gen(exports.PARAMS['256f'], SHA512_SIMPLE);
595
+ exports.sphincs_sha2_256f_robust = gen(exports.PARAMS['256f'], SHA512_ROBUST);
596
+ exports.sphincs_sha2_256s_simple = gen(exports.PARAMS['256s'], SHA512_SIMPLE);
597
+ exports.sphincs_sha2_256s_robust = gen(exports.PARAMS['256s'], SHA512_ROBUST);
598
+ // Only simple mode in SLH-DSA
599
+ exports.slh_dsa_sha2_128f = gen(exports.PARAMS['128f'], SHA256_SIMPLE);
600
+ exports.slh_dsa_sha2_128s = gen(exports.PARAMS['128s'], SHA256_SIMPLE);
601
+ exports.slh_dsa_sha2_192f = gen(exports.PARAMS['192f'], SHA512_SIMPLE);
602
+ exports.slh_dsa_sha2_192s = gen(exports.PARAMS['192s'], SHA512_SIMPLE);
603
+ exports.slh_dsa_sha2_256f = gen(exports.PARAMS['256f'], SHA512_SIMPLE);
604
+ exports.slh_dsa_sha2_256s = gen(exports.PARAMS['256s'], SHA512_SIMPLE);
605
+ //# sourceMappingURL=slh-dsa.js.map
package/slh-dsa.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slh-dsa.js","sourceRoot":"","sources":["src/slh-dsa.ts"],"names":[],"mappings":"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"}