| 123456789101112131415161718192021222324252627282930313233343536 | /** *  A **Cryptographically Secure Random Value** is one that has been *  generated with additional care take to prevent side-channels *  from allowing others to detect it and prevent others from through *  coincidence generate the same values. * *  @_subsection: api/crypto:Random Values  [about-crypto-random] */import { randomBytes as crypto_random } from "./crypto.js";let locked = false;const _randomBytes = function(length: number): Uint8Array {    return new Uint8Array(crypto_random(length));}let __randomBytes = _randomBytes;/** *  Return %%length%% bytes of cryptographically secure random data. * *  @example: *    randomBytes(8) *    //_result: */export function randomBytes(length: number): Uint8Array {    return __randomBytes(length);}randomBytes._ = _randomBytes;randomBytes.lock = function(): void { locked = true; }randomBytes.register = function(func: (length: number) => Uint8Array) {    if (locked) { throw new Error("randomBytes is locked"); }    __randomBytes = func;}Object.freeze(randomBytes);
 |