26 lines
1.1 KiB
JavaScript
26 lines
1.1 KiB
JavaScript
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.default = rng;
|
||
|
// Unique ID creation requires a high quality random # generator. In the browser we therefore
|
||
|
// require the crypto API and do not support built-in fallback to lower quality random number
|
||
|
// generators (like Math.random()).
|
||
|
let getRandomValues;
|
||
|
const rnds8 = new Uint8Array(16);
|
||
|
|
||
|
function rng() {
|
||
|
// lazy load so that environments that need to polyfill have a chance to do so
|
||
|
if (!getRandomValues) {
|
||
|
// getRandomValues needs to be invoked in a context where "this" is a Crypto implementation. Also,
|
||
|
// find the complete implementation of crypto (msCrypto) on IE11.
|
||
|
getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);
|
||
|
|
||
|
if (!getRandomValues) {
|
||
|
throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return getRandomValues(rnds8);
|
||
|
}
|