UNPKG

@li0ard/strumok

Version:

Strumok (DSTU 8845:2019) cipher implementation in pure TypeScript

66 lines (65 loc) 2.44 kB
export const bytesToUint64s = (b) => { const size = Math.floor(b.length / 8); const result = new BigUint64Array(size); for (let i = 0; i < size; i++) result[i] = bytesToNumberBE(b.slice(i * 8, i * 8 + 8)); return result; }; export const uint64sToBytes = (w) => { const result = new Uint8Array(w.length * 8); for (let i = 0; i < w.length; i++) result.set(numberToBytesBE(w[i], 8), i * 8); return result; }; // Code from `@noble/curves` export function hexToNumber(hex) { if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex); return hex === '' ? 0n : BigInt('0x' + hex); } const asciis = { _0: 48, _9: 57, A: 65, F: 70, a: 97, f: 102 }; function asciiToBase16(ch) { if (ch >= asciis._0 && ch <= asciis._9) return ch - asciis._0; // '2' => 50-48 if (ch >= asciis.A && ch <= asciis.F) return ch - (asciis.A - 10); // 'B' => 66-(65-10) if (ch >= asciis.a && ch <= asciis.f) return ch - (asciis.a - 10); // 'b' => 98-(97-10) return; } export function hexToBytes(hex) { if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex); const hl = hex.length; const al = hl / 2; if (hl % 2) throw new Error('hex string expected, got unpadded hex of length ' + hl); const array = new Uint8Array(al); for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) { const n1 = asciiToBase16(hex.charCodeAt(hi)); const n2 = asciiToBase16(hex.charCodeAt(hi + 1)); if (n1 === undefined || n2 === undefined) { const char = hex[hi] + hex[hi + 1]; throw new Error('hex string expected, got non-hex character "' + char + '" at index ' + hi); } array[ai] = n1 * 16 + n2; // multiply first octet, e.g. 'a3' => 10*16+3 => 160 + 3 => 163 } return array; } const hexes = Array.from({ length: 256 }, (_, i) => i.toString(16).padStart(2, '0')); export function bytesToHex(bytes) { // pre-caching improves the speed 6x let hex = ''; for (let i = 0; i < bytes.length; i++) hex += hexes[bytes[i]]; return hex; } export function numberToBytesBE(n, len) { let num = n.toString(16).padStart(len * 2, '0'); while (num.length % 2 != 0) num = "0" + num; return hexToBytes(num); } export function bytesToNumberBE(bytes) { return hexToNumber(bytesToHex(bytes.slice())); }