// Copyright (c) Jupyter Development Team. // Distributed under the terms of the Modified BSD License. /*----------------------------------------------------------------------------- | Copyright (c) 2014-2017, PhosphorJS Contributors | | Distributed under the terms of the BSD 3-Clause License. | | The full license is in the file LICENSE, distributed with this software. |----------------------------------------------------------------------------*/ import { fallbackRandomValues } from './random'; // Declare ambient variables for `window` and `require` to avoid a // hard dependency on both. This package must run on node. declare let window: any; /** * The namespace for random number related functionality. */ export namespace Random { /** * A function which generates random bytes. * * @param buffer - The `Uint8Array` to fill with random bytes. * * #### Notes * A cryptographically strong random number generator will be used if * available. Otherwise, `Math.random` will be used as a fallback for * randomness. * * The following RNGs are supported, listed in order of precedence: * - `window.crypto.getRandomValues` * - `window.msCrypto.getRandomValues` * - `require('crypto').randomFillSync * - `require('crypto').randomBytes * - `Math.random` */ export const getRandomValues = (() => { // Look up the crypto module if available. const crypto: any = (typeof window !== 'undefined' && (window.crypto || window.msCrypto)) || null; // Modern browsers and IE 11 if (crypto && typeof crypto.getRandomValues === 'function') { return function getRandomValues(buffer: Uint8Array): void { return crypto.getRandomValues(buffer); }; } // Fallback return fallbackRandomValues; })(); }