Last change
on this file since 1ad8e64 was e29cc2e, checked in by Ema <ema_spirova@…>, 3 years ago |
primeNG components
|
-
Property mode
set to
100644
|
File size:
1.3 KB
|
Rev | Line | |
---|
[6a3a178] | 1 | // Unique ID creation requires a high quality random # generator. In the
|
---|
| 2 | // browser this is a little complicated due to unknown quality of Math.random()
|
---|
| 3 | // and inconsistent support for the `crypto` API. We do the best we can via
|
---|
| 4 | // feature-detection
|
---|
| 5 |
|
---|
| 6 | // getRandomValues needs to be invoked in a context where "this" is a Crypto
|
---|
| 7 | // implementation. Also, find the complete implementation of crypto on IE11.
|
---|
| 8 | var getRandomValues = (typeof(crypto) != 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto)) ||
|
---|
| 9 | (typeof(msCrypto) != 'undefined' && typeof window.msCrypto.getRandomValues == 'function' && msCrypto.getRandomValues.bind(msCrypto));
|
---|
| 10 |
|
---|
| 11 | if (getRandomValues) {
|
---|
| 12 | // WHATWG crypto RNG - http://wiki.whatwg.org/wiki/Crypto
|
---|
| 13 | var rnds8 = new Uint8Array(16); // eslint-disable-line no-undef
|
---|
| 14 |
|
---|
| 15 | module.exports = function whatwgRNG() {
|
---|
| 16 | getRandomValues(rnds8);
|
---|
| 17 | return rnds8;
|
---|
| 18 | };
|
---|
| 19 | } else {
|
---|
| 20 | // Math.random()-based (RNG)
|
---|
| 21 | //
|
---|
| 22 | // If all else fails, use Math.random(). It's fast, but is of unspecified
|
---|
| 23 | // quality.
|
---|
| 24 | var rnds = new Array(16);
|
---|
| 25 |
|
---|
| 26 | module.exports = function mathRNG() {
|
---|
| 27 | for (var i = 0, r; i < 16; i++) {
|
---|
| 28 | if ((i & 0x03) === 0) r = Math.random() * 0x100000000;
|
---|
| 29 | rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;
|
---|
| 30 | }
|
---|
| 31 |
|
---|
| 32 | return rnds;
|
---|
| 33 | };
|
---|
| 34 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.