| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | import { BLAKE, SIGMA } from './_blake.js';import { fromBig } from './_u64.js';import { rotr, toBytes, wrapConstructorWithOpts, u32, byteSwapIfBE } from './utils.js';// Initial state: same as SHA256// first 32 bits of the fractional parts of the square roots of the first 8 primes 2..19// prettier-ignoreexport const B2S_IV = /* @__PURE__ */ new Uint32Array([    0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19]);// Mixing function G splitted in two halfsfunction G1s(a, b, c, d, x) {    a = (a + b + x) | 0;    d = rotr(d ^ a, 16);    c = (c + d) | 0;    b = rotr(b ^ c, 12);    return { a, b, c, d };}function G2s(a, b, c, d, x) {    a = (a + b + x) | 0;    d = rotr(d ^ a, 8);    c = (c + d) | 0;    b = rotr(b ^ c, 7);    return { a, b, c, d };}// prettier-ignoreexport function compress(s, offset, msg, rounds, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15) {    let j = 0;    for (let i = 0; i < rounds; i++) {        ({ a: v0, b: v4, c: v8, d: v12 } = G1s(v0, v4, v8, v12, msg[offset + s[j++]]));        ({ a: v0, b: v4, c: v8, d: v12 } = G2s(v0, v4, v8, v12, msg[offset + s[j++]]));        ({ a: v1, b: v5, c: v9, d: v13 } = G1s(v1, v5, v9, v13, msg[offset + s[j++]]));        ({ a: v1, b: v5, c: v9, d: v13 } = G2s(v1, v5, v9, v13, msg[offset + s[j++]]));        ({ a: v2, b: v6, c: v10, d: v14 } = G1s(v2, v6, v10, v14, msg[offset + s[j++]]));        ({ a: v2, b: v6, c: v10, d: v14 } = G2s(v2, v6, v10, v14, msg[offset + s[j++]]));        ({ a: v3, b: v7, c: v11, d: v15 } = G1s(v3, v7, v11, v15, msg[offset + s[j++]]));        ({ a: v3, b: v7, c: v11, d: v15 } = G2s(v3, v7, v11, v15, msg[offset + s[j++]]));        ({ a: v0, b: v5, c: v10, d: v15 } = G1s(v0, v5, v10, v15, msg[offset + s[j++]]));        ({ a: v0, b: v5, c: v10, d: v15 } = G2s(v0, v5, v10, v15, msg[offset + s[j++]]));        ({ a: v1, b: v6, c: v11, d: v12 } = G1s(v1, v6, v11, v12, msg[offset + s[j++]]));        ({ a: v1, b: v6, c: v11, d: v12 } = G2s(v1, v6, v11, v12, msg[offset + s[j++]]));        ({ a: v2, b: v7, c: v8, d: v13 } = G1s(v2, v7, v8, v13, msg[offset + s[j++]]));        ({ a: v2, b: v7, c: v8, d: v13 } = G2s(v2, v7, v8, v13, msg[offset + s[j++]]));        ({ a: v3, b: v4, c: v9, d: v14 } = G1s(v3, v4, v9, v14, msg[offset + s[j++]]));        ({ a: v3, b: v4, c: v9, d: v14 } = G2s(v3, v4, v9, v14, msg[offset + s[j++]]));    }    return { v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15 };}class BLAKE2s extends BLAKE {    constructor(opts = {}) {        super(64, opts.dkLen === undefined ? 32 : opts.dkLen, opts, 32, 8, 8);        // Internal state, same as SHA-256        this.v0 = B2S_IV[0] | 0;        this.v1 = B2S_IV[1] | 0;        this.v2 = B2S_IV[2] | 0;        this.v3 = B2S_IV[3] | 0;        this.v4 = B2S_IV[4] | 0;        this.v5 = B2S_IV[5] | 0;        this.v6 = B2S_IV[6] | 0;        this.v7 = B2S_IV[7] | 0;        const keyLength = opts.key ? opts.key.length : 0;        this.v0 ^= this.outputLen | (keyLength << 8) | (0x01 << 16) | (0x01 << 24);        if (opts.salt) {            const salt = u32(toBytes(opts.salt));            this.v4 ^= byteSwapIfBE(salt[0]);            this.v5 ^= byteSwapIfBE(salt[1]);        }        if (opts.personalization) {            const pers = u32(toBytes(opts.personalization));            this.v6 ^= byteSwapIfBE(pers[0]);            this.v7 ^= byteSwapIfBE(pers[1]);        }        if (opts.key) {            // Pad to blockLen and update            const tmp = new Uint8Array(this.blockLen);            tmp.set(toBytes(opts.key));            this.update(tmp);        }    }    get() {        const { v0, v1, v2, v3, v4, v5, v6, v7 } = this;        return [v0, v1, v2, v3, v4, v5, v6, v7];    }    // prettier-ignore    set(v0, v1, v2, v3, v4, v5, v6, v7) {        this.v0 = v0 | 0;        this.v1 = v1 | 0;        this.v2 = v2 | 0;        this.v3 = v3 | 0;        this.v4 = v4 | 0;        this.v5 = v5 | 0;        this.v6 = v6 | 0;        this.v7 = v7 | 0;    }    compress(msg, offset, isLast) {        const { h, l } = fromBig(BigInt(this.length));        // prettier-ignore        const { v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15 } = compress(SIGMA, offset, msg, 10, this.v0, this.v1, this.v2, this.v3, this.v4, this.v5, this.v6, this.v7, 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]);        this.v0 ^= v0 ^ v8;        this.v1 ^= v1 ^ v9;        this.v2 ^= v2 ^ v10;        this.v3 ^= v3 ^ v11;        this.v4 ^= v4 ^ v12;        this.v5 ^= v5 ^ v13;        this.v6 ^= v6 ^ v14;        this.v7 ^= v7 ^ v15;    }    destroy() {        this.destroyed = true;        this.buffer32.fill(0);        this.set(0, 0, 0, 0, 0, 0, 0, 0);    }}/** * BLAKE2s - optimized for 32-bit platforms. JS doesn't have uint64, so it's faster than BLAKE2b. * @param msg - message that would be hashed * @param opts - dkLen, key, salt, personalization */export const blake2s = /* @__PURE__ */ wrapConstructorWithOpts((opts) => new BLAKE2s(opts));//# sourceMappingURL=blake2s.js.map
 |