summaryrefslogtreecommitdiff
path: root/core/crypto/bigint.js
blob: d34432650e747097bcc6f3580dc153464c580a41 (plain)
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
export function modPow(b, e, m) {
    let r = 1n;
    b = b % m;
    while (e > 0n) {
        if ((e & 1n) === 1n) {
            r = (r * b) % m;
        }
        e = e >> 1n;
        b = (b * b) % m;
    }
    return r;
}

export function bigIntToU8Array(bigint, padLength=0) {
    let hex = bigint.toString(16);
    if (padLength === 0) {
        padLength = Math.ceil(hex.length / 2);
    }
    hex = hex.padStart(padLength * 2, '0');
    const length = hex.length / 2;
    const arr = new Uint8Array(length);
    for (let i = 0; i < length; i++) {
        arr[i] = parseInt(hex.slice(i * 2, i * 2 + 2), 16);
    }
    return arr;
}

export function u8ArrayToBigInt(arr) {
    let hex = '0x';
    for (let i = 0; i < arr.length; i++) {
        hex += arr[i].toString(16).padStart(2, '0');
    }
    return BigInt(hex);
}