@pezkuwi/x-randomvalues 14.0.22 → 14.0.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/build/browser.d.ts +3 -0
  2. package/build/fallback.d.ts +1 -0
  3. package/build/node.d.ts +3 -0
  4. package/build/packageInfo.d.ts +6 -0
  5. package/build/react-native.d.ts +12 -0
  6. package/build/shim.d.ts +1 -0
  7. package/build-deno/README.md +3 -0
  8. package/build-deno/browser.ts +10 -0
  9. package/build-deno/fallback.ts +22 -0
  10. package/build-deno/mod.ts +2 -0
  11. package/build-deno/node.ts +12 -0
  12. package/build-deno/packageInfo.ts +3 -0
  13. package/build-deno/react-native.ts +64 -0
  14. package/build-deno/shim.ts +7 -0
  15. package/build-tsc/browser.d.ts +3 -0
  16. package/build-tsc/fallback.d.ts +1 -0
  17. package/build-tsc/node.d.ts +3 -0
  18. package/build-tsc/packageInfo.d.ts +6 -0
  19. package/build-tsc/react-native.d.ts +12 -0
  20. package/build-tsc/shim.d.ts +1 -0
  21. package/build-tsc-cjs/browser.js +15 -0
  22. package/build-tsc-cjs/fallback.js +24 -0
  23. package/build-tsc-cjs/node.js +18 -0
  24. package/build-tsc-cjs/packageInfo.js +7 -0
  25. package/build-tsc-cjs/react-native.js +42 -0
  26. package/build-tsc-cjs/shim.js +7 -0
  27. package/build-tsc-esm/browser.js +10 -0
  28. package/build-tsc-esm/fallback.js +21 -0
  29. package/build-tsc-esm/node.js +12 -0
  30. package/build-tsc-esm/packageInfo.js +4 -0
  31. package/build-tsc-esm/react-native.js +38 -0
  32. package/build-tsc-esm/shim.js +5 -0
  33. package/cjs/packageInfo.js +1 -1
  34. package/package.json +56 -14
  35. package/packageInfo.js +1 -1
  36. package/src/browser.ts +14 -0
  37. package/src/fallback.spec.ts +22 -0
  38. package/src/fallback.ts +28 -0
  39. package/src/mod.ts +4 -0
  40. package/src/node.ts +17 -0
  41. package/src/packageInfo.ts +6 -0
  42. package/src/react-native.ts +64 -0
  43. package/src/shim.ts +7 -0
  44. package/tsconfig.build.json +15 -0
  45. package/tsconfig.build.tsbuildinfo +1 -0
  46. package/tsconfig.spec.json +17 -0
  47. package/tsconfig.spec.tsbuildinfo +1 -0
@@ -0,0 +1,3 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ export declare const crypto: Crypto;
3
+ export declare function getRandomValues<T extends Uint8Array>(arr: T): T;
@@ -0,0 +1 @@
1
+ export declare function insecureRandomValues<T extends Uint8Array>(arr: T): T;
@@ -0,0 +1,3 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ export declare const crypto: Crypto;
3
+ export declare function getRandomValues<T extends Uint8Array>(output: T): T;
@@ -0,0 +1,6 @@
1
+ export declare const packageInfo: {
2
+ name: string;
3
+ path: string;
4
+ type: string;
5
+ version: string;
6
+ };
@@ -0,0 +1,12 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ /**
3
+ * @internal
4
+ *
5
+ * A getRandomValues util that detects and uses the available RN
6
+ * random utiliy generation functions.
7
+ **/
8
+ declare function getRandomValuesRn(output: Uint8Array): Uint8Array;
9
+ export declare const getRandomValues: typeof getRandomValuesRn;
10
+ export declare const crypto: Crypto | {
11
+ getRandomValues: typeof getRandomValuesRn;
12
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,3 @@
1
+ # @pezkuwi/x-randomvalues
2
+
3
+ A cross-environment `window.crypto.getRandomValues`.
@@ -0,0 +1,10 @@
1
+
2
+ import { xglobal } from 'https://deno.land/x/pezkuwi/x-global/mod.ts';
3
+
4
+ export { packageInfo } from './packageInfo.ts';
5
+
6
+ export const crypto = xglobal.crypto;
7
+
8
+ export function getRandomValues <T extends Uint8Array> (arr: T): T {
9
+ return crypto.getRandomValues(arr);
10
+ }
@@ -0,0 +1,22 @@
1
+
2
+
3
+ let warned = false;
4
+
5
+ export function insecureRandomValues <T extends Uint8Array> (arr: T): T {
6
+ if (!warned) {
7
+ console.warn('Using an insecure random number generator, this should only happen when running in a debugger without support for crypto');
8
+ warned = true;
9
+ }
10
+
11
+ let r = 0;
12
+
13
+ for (let i = 0, count = arr.length; i < count; i++) {
14
+ if ((i & 0b11) === 0) {
15
+ r = Math.random() * 0x100000000;
16
+ }
17
+
18
+ arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
19
+ }
20
+
21
+ return arr;
22
+ }
@@ -0,0 +1,2 @@
1
+
2
+ export * from './browser.ts';
@@ -0,0 +1,12 @@
1
+
2
+ import nodeCrypto from 'node:crypto';
3
+
4
+ import { extractGlobal } from 'https://deno.land/x/pezkuwi/x-global/mod.ts';
5
+
6
+ export { packageInfo } from './packageInfo.ts';
7
+
8
+ export const crypto = /*#__PURE__*/ extractGlobal('crypto', nodeCrypto.webcrypto);
9
+
10
+ export function getRandomValues <T extends Uint8Array> (output: T): T {
11
+ return crypto.getRandomValues(output);
12
+ }
@@ -0,0 +1,3 @@
1
+
2
+
3
+ export const packageInfo = { name: '@pezkuwi/x-randomvalues', path: 'auto', type: 'auto', version: '14.0.23' };
@@ -0,0 +1,64 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
5
+ //
6
+ // Copyright (c) 2018, 2020 Linus Unnebäck
7
+ // SPDX-License-Identifier: MIT
8
+
9
+ import { NativeModules } from 'react-native';
10
+
11
+ import { base64Decode } from '@pezkuwi/wasm-util/base64';
12
+ import { xglobal } from '@pezkuwi/x-global';
13
+
14
+ import { crypto as cryptoBrowser, getRandomValues as getRandomValuesBrowser } from './browser.js';
15
+
16
+ export { packageInfo } from './packageInfo.js';
17
+
18
+ interface RNExt {
19
+ ExpoRandom: {
20
+ getRandomBase64String: (length: number) => string;
21
+ };
22
+ RNGetRandomValues: {
23
+ getRandomBase64: (length: number) => string;
24
+ }
25
+ }
26
+
27
+ /**
28
+ * @internal
29
+ *
30
+ * A getRandomValues util that detects and uses the available RN
31
+ * random utiliy generation functions.
32
+ **/
33
+ function getRandomValuesRn (output: Uint8Array): Uint8Array {
34
+ if (!NativeModules['ExpoRandom'] && !(NativeModules as RNExt).RNGetRandomValues) {
35
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues and no React Native secure RNG module is available.');
36
+ }
37
+
38
+ return base64Decode(
39
+ (NativeModules as RNExt).RNGetRandomValues
40
+ ? (NativeModules as RNExt).RNGetRandomValues.getRandomBase64(output.length)
41
+ : (NativeModules as RNExt).ExpoRandom.getRandomBase64String(output.length),
42
+ output
43
+ );
44
+ }
45
+
46
+ // Check for native RN modules first (highest priority)
47
+ const hasNativeRNModules = !!NativeModules['ExpoRandom'] || !!(NativeModules as RNExt).RNGetRandomValues;
48
+ const hasNativeCrypto = typeof xglobal.crypto === 'object' && typeof xglobal.crypto.getRandomValues === 'function';
49
+
50
+ export const getRandomValues = (
51
+ hasNativeRNModules
52
+ ? getRandomValuesRn
53
+ : hasNativeCrypto
54
+ ? getRandomValuesBrowser
55
+ : () => {
56
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
57
+ }
58
+ );
59
+
60
+ export const crypto = (
61
+ getRandomValues === getRandomValuesBrowser
62
+ ? cryptoBrowser
63
+ : { getRandomValues }
64
+ );
@@ -0,0 +1,7 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ import { exposeGlobal } from '@pezkuwi/x-global';
5
+ import { crypto } from '@pezkuwi/x-randomvalues';
6
+
7
+ exposeGlobal('crypto', crypto);
@@ -0,0 +1,3 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ export declare const crypto: Crypto;
3
+ export declare function getRandomValues<T extends Uint8Array>(arr: T): T;
@@ -0,0 +1 @@
1
+ export declare function insecureRandomValues<T extends Uint8Array>(arr: T): T;
@@ -0,0 +1,3 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ export declare const crypto: Crypto;
3
+ export declare function getRandomValues<T extends Uint8Array>(output: T): T;
@@ -0,0 +1,6 @@
1
+ export declare const packageInfo: {
2
+ name: string;
3
+ path: string;
4
+ type: string;
5
+ version: string;
6
+ };
@@ -0,0 +1,12 @@
1
+ export { packageInfo } from './packageInfo.js';
2
+ /**
3
+ * @internal
4
+ *
5
+ * A getRandomValues util that detects and uses the available RN
6
+ * random utiliy generation functions.
7
+ **/
8
+ declare function getRandomValuesRn(output: Uint8Array): Uint8Array;
9
+ export declare const getRandomValues: typeof getRandomValuesRn;
10
+ export declare const crypto: Crypto | {
11
+ getRandomValues: typeof getRandomValuesRn;
12
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.crypto = exports.packageInfo = void 0;
6
+ exports.getRandomValues = getRandomValues;
7
+ const x_global_1 = require("@pezkuwi/x-global");
8
+ var packageInfo_js_1 = require("./packageInfo.js");
9
+ Object.defineProperty(exports, "packageInfo", { enumerable: true, get: function () { return packageInfo_js_1.packageInfo; } });
10
+ exports.crypto = x_global_1.xglobal.crypto;
11
+ // getRandomValues needs to be called on the crypto object,
12
+ // hence the need for the wrapper function
13
+ function getRandomValues(arr) {
14
+ return exports.crypto.getRandomValues(arr);
15
+ }
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.insecureRandomValues = insecureRandomValues;
6
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
7
+ //
8
+ // Copyright (c) 2018, 2020 Linus Unnebäck
9
+ // SPDX-License-Identifier: MIT
10
+ let warned = false;
11
+ function insecureRandomValues(arr) {
12
+ if (!warned) {
13
+ console.warn('Using an insecure random number generator, this should only happen when running in a debugger without support for crypto');
14
+ warned = true;
15
+ }
16
+ let r = 0;
17
+ for (let i = 0, count = arr.length; i < count; i++) {
18
+ if ((i & 0b11) === 0) {
19
+ r = Math.random() * 0x100000000;
20
+ }
21
+ arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
22
+ }
23
+ return arr;
24
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.crypto = exports.packageInfo = void 0;
6
+ exports.getRandomValues = getRandomValues;
7
+ const tslib_1 = require("tslib");
8
+ // Needs Node 15+ for webcrypto
9
+ const node_crypto_1 = tslib_1.__importDefault(require("node:crypto"));
10
+ const x_global_1 = require("@pezkuwi/x-global");
11
+ var packageInfo_js_1 = require("./packageInfo.js");
12
+ Object.defineProperty(exports, "packageInfo", { enumerable: true, get: function () { return packageInfo_js_1.packageInfo; } });
13
+ exports.crypto = (0, x_global_1.extractGlobal)('crypto', node_crypto_1.default.webcrypto);
14
+ // getRandomValues needs to be called on the crypto object,
15
+ // hence the need for the wrapper function
16
+ function getRandomValues(output) {
17
+ return exports.crypto.getRandomValues(output);
18
+ }
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ // Copyright 2017-2026 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.packageInfo = void 0;
6
+ // Do not edit, auto-generated by @pezkuwi/dev
7
+ exports.packageInfo = { name: '@pezkuwi/x-randomvalues', path: 'auto', type: 'auto', version: '14.0.23' };
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.crypto = exports.getRandomValues = exports.packageInfo = void 0;
6
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
7
+ //
8
+ // Copyright (c) 2018, 2020 Linus Unnebäck
9
+ // SPDX-License-Identifier: MIT
10
+ const react_native_1 = require("react-native");
11
+ const base64_1 = require("@pezkuwi/wasm-util/base64");
12
+ const x_global_1 = require("@pezkuwi/x-global");
13
+ const browser_js_1 = require("./browser.js");
14
+ var packageInfo_js_1 = require("./packageInfo.js");
15
+ Object.defineProperty(exports, "packageInfo", { enumerable: true, get: function () { return packageInfo_js_1.packageInfo; } });
16
+ /**
17
+ * @internal
18
+ *
19
+ * A getRandomValues util that detects and uses the available RN
20
+ * random utiliy generation functions.
21
+ **/
22
+ function getRandomValuesRn(output) {
23
+ if (!react_native_1.NativeModules['ExpoRandom'] && !react_native_1.NativeModules.RNGetRandomValues) {
24
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues and no React Native secure RNG module is available.');
25
+ }
26
+ return (0, base64_1.base64Decode)(react_native_1.NativeModules.RNGetRandomValues
27
+ ? react_native_1.NativeModules.RNGetRandomValues.getRandomBase64(output.length)
28
+ : react_native_1.NativeModules.ExpoRandom.getRandomBase64String(output.length), output);
29
+ }
30
+ // Check for native RN modules first (highest priority)
31
+ const hasNativeRNModules = !!react_native_1.NativeModules['ExpoRandom'] || !!react_native_1.NativeModules.RNGetRandomValues;
32
+ const hasNativeCrypto = typeof x_global_1.xglobal.crypto === 'object' && typeof x_global_1.xglobal.crypto.getRandomValues === 'function';
33
+ exports.getRandomValues = (hasNativeRNModules
34
+ ? getRandomValuesRn
35
+ : hasNativeCrypto
36
+ ? browser_js_1.getRandomValues
37
+ : () => {
38
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
39
+ });
40
+ exports.crypto = (exports.getRandomValues === browser_js_1.getRandomValues
41
+ ? browser_js_1.crypto
42
+ : { getRandomValues: exports.getRandomValues });
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ const x_global_1 = require("@pezkuwi/x-global");
6
+ const x_randomvalues_1 = require("@pezkuwi/x-randomvalues");
7
+ (0, x_global_1.exposeGlobal)('crypto', x_randomvalues_1.crypto);
@@ -0,0 +1,10 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ import { xglobal } from '@pezkuwi/x-global';
4
+ export { packageInfo } from './packageInfo.js';
5
+ export const crypto = xglobal.crypto;
6
+ // getRandomValues needs to be called on the crypto object,
7
+ // hence the need for the wrapper function
8
+ export function getRandomValues(arr) {
9
+ return crypto.getRandomValues(arr);
10
+ }
@@ -0,0 +1,21 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
4
+ //
5
+ // Copyright (c) 2018, 2020 Linus Unnebäck
6
+ // SPDX-License-Identifier: MIT
7
+ let warned = false;
8
+ export function insecureRandomValues(arr) {
9
+ if (!warned) {
10
+ console.warn('Using an insecure random number generator, this should only happen when running in a debugger without support for crypto');
11
+ warned = true;
12
+ }
13
+ let r = 0;
14
+ for (let i = 0, count = arr.length; i < count; i++) {
15
+ if ((i & 0b11) === 0) {
16
+ r = Math.random() * 0x100000000;
17
+ }
18
+ arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
19
+ }
20
+ return arr;
21
+ }
@@ -0,0 +1,12 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ // Needs Node 15+ for webcrypto
4
+ import nodeCrypto from 'node:crypto';
5
+ import { extractGlobal } from '@pezkuwi/x-global';
6
+ export { packageInfo } from './packageInfo.js';
7
+ export const crypto = /*#__PURE__*/ extractGlobal('crypto', nodeCrypto.webcrypto);
8
+ // getRandomValues needs to be called on the crypto object,
9
+ // hence the need for the wrapper function
10
+ export function getRandomValues(output) {
11
+ return crypto.getRandomValues(output);
12
+ }
@@ -0,0 +1,4 @@
1
+ // Copyright 2017-2026 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ // Do not edit, auto-generated by @pezkuwi/dev
4
+ export const packageInfo = { name: '@pezkuwi/x-randomvalues', path: 'auto', type: 'auto', version: '14.0.23' };
@@ -0,0 +1,38 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
4
+ //
5
+ // Copyright (c) 2018, 2020 Linus Unnebäck
6
+ // SPDX-License-Identifier: MIT
7
+ import { NativeModules } from 'react-native';
8
+ import { base64Decode } from '@pezkuwi/wasm-util/base64';
9
+ import { xglobal } from '@pezkuwi/x-global';
10
+ import { crypto as cryptoBrowser, getRandomValues as getRandomValuesBrowser } from './browser.js';
11
+ export { packageInfo } from './packageInfo.js';
12
+ /**
13
+ * @internal
14
+ *
15
+ * A getRandomValues util that detects and uses the available RN
16
+ * random utiliy generation functions.
17
+ **/
18
+ function getRandomValuesRn(output) {
19
+ if (!NativeModules['ExpoRandom'] && !NativeModules.RNGetRandomValues) {
20
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues and no React Native secure RNG module is available.');
21
+ }
22
+ return base64Decode(NativeModules.RNGetRandomValues
23
+ ? NativeModules.RNGetRandomValues.getRandomBase64(output.length)
24
+ : NativeModules.ExpoRandom.getRandomBase64String(output.length), output);
25
+ }
26
+ // Check for native RN modules first (highest priority)
27
+ const hasNativeRNModules = !!NativeModules['ExpoRandom'] || !!NativeModules.RNGetRandomValues;
28
+ const hasNativeCrypto = typeof xglobal.crypto === 'object' && typeof xglobal.crypto.getRandomValues === 'function';
29
+ export const getRandomValues = (hasNativeRNModules
30
+ ? getRandomValuesRn
31
+ : hasNativeCrypto
32
+ ? getRandomValuesBrowser
33
+ : () => {
34
+ throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
35
+ });
36
+ export const crypto = (getRandomValues === getRandomValuesBrowser
37
+ ? cryptoBrowser
38
+ : { getRandomValues });
@@ -0,0 +1,5 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+ import { exposeGlobal } from '@pezkuwi/x-global';
4
+ import { crypto } from '@pezkuwi/x-randomvalues';
5
+ exposeGlobal('crypto', crypto);
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.packageInfo = void 0;
4
- exports.packageInfo = { name: '@pezkuwi/x-randomvalues', path: typeof __dirname === 'string' ? __dirname : 'auto', type: 'cjs', version: '14.0.22' };
4
+ exports.packageInfo = { name: '@pezkuwi/x-randomvalues', path: typeof __dirname === 'string' ? __dirname : 'auto', type: 'cjs', version: '14.0.10' };
package/package.json CHANGED
@@ -15,20 +15,57 @@
15
15
  },
16
16
  "sideEffects": false,
17
17
  "type": "module",
18
- "version": "14.0.22",
19
- "main": "./cjs/node.js",
20
- "module": "./cjs/node.js",
18
+ "types": "./node.d.ts",
19
+ "version": "14.0.23",
21
20
  "browser": "./cjs/browser.js",
21
+ "main": "./cjs/node.js",
22
+ "module": "./node.js",
22
23
  "react-native": "./cjs/react-native.js",
23
- "types": "./cjs/node.d.ts",
24
24
  "exports": {
25
- "./cjs/package.json": "./cjs/package.json",
26
- "./cjs/*": "./cjs/*.js",
27
25
  ".": {
28
- "types": "./cjs/node.d.ts",
29
- "react-native": "./cjs/react-native.js",
30
- "browser": "./cjs/browser.js",
31
- "node": "./cjs/node.js"
26
+ "types": "./node.d.ts",
27
+ "react-native": {
28
+ "module": {
29
+ "types": "./react-native.d.ts",
30
+ "default": "./react-native.js"
31
+ },
32
+ "require": {
33
+ "types": "./cjs/react-native.d.ts",
34
+ "default": "./cjs/react-native.js"
35
+ },
36
+ "default": {
37
+ "types": "./react-native.d.ts",
38
+ "default": "./react-native.js"
39
+ }
40
+ },
41
+ "browser": {
42
+ "module": {
43
+ "types": "./browser.d.ts",
44
+ "default": "./browser.js"
45
+ },
46
+ "require": {
47
+ "types": "./cjs/browser.d.ts",
48
+ "default": "./cjs/browser.js"
49
+ },
50
+ "default": {
51
+ "types": "./browser.d.ts",
52
+ "default": "./browser.js"
53
+ }
54
+ },
55
+ "node": {
56
+ "module": {
57
+ "types": "./node.d.ts",
58
+ "default": "./node.js"
59
+ },
60
+ "require": {
61
+ "types": "./cjs/node.d.ts",
62
+ "default": "./cjs/node.js"
63
+ },
64
+ "default": {
65
+ "types": "./node.d.ts",
66
+ "default": "./node.js"
67
+ }
68
+ }
32
69
  },
33
70
  "./browser": {
34
71
  "module": {
@@ -44,6 +81,8 @@
44
81
  "default": "./browser.js"
45
82
  }
46
83
  },
84
+ "./cjs/*": "./cjs/*.js",
85
+ "./cjs/package.json": "./cjs/package.json",
47
86
  "./fallback": {
48
87
  "module": {
49
88
  "types": "./fallback.d.ts",
@@ -76,7 +115,7 @@
76
115
  "require": "./cjs/package.json",
77
116
  "default": "./package.json"
78
117
  },
79
- "./packageInfo.js": {
118
+ "./packageInfo": {
80
119
  "module": {
81
120
  "types": "./packageInfo.d.ts",
82
121
  "default": "./packageInfo.js"
@@ -90,7 +129,7 @@
90
129
  "default": "./packageInfo.js"
91
130
  }
92
131
  },
93
- "./packageInfo": {
132
+ "./packageInfo.js": {
94
133
  "module": {
95
134
  "types": "./packageInfo.d.ts",
96
135
  "default": "./packageInfo.js"
@@ -118,7 +157,7 @@
118
157
  "default": "./react-native.js"
119
158
  }
120
159
  },
121
- "./shim.js": {
160
+ "./shim": {
122
161
  "module": {
123
162
  "types": "./shim.d.ts",
124
163
  "default": "./shim.js"
@@ -132,7 +171,7 @@
132
171
  "default": "./shim.js"
133
172
  }
134
173
  },
135
- "./shim": {
174
+ "./shim.js": {
136
175
  "module": {
137
176
  "types": "./shim.d.ts",
138
177
  "default": "./shim.js"
@@ -151,6 +190,9 @@
151
190
  "@pezkuwi/x-global": "14.0.22",
152
191
  "tslib": "^2.8.0"
153
192
  },
193
+ "devDependencies": {
194
+ "@types/react-native": "^0.73.0"
195
+ },
154
196
  "peerDependencies": {
155
197
  "@pezkuwi/util": "14.0.22",
156
198
  "@pezkuwi/wasm-util": "*"
package/packageInfo.js CHANGED
@@ -1 +1 @@
1
- export const packageInfo = { name: '@pezkuwi/x-randomvalues', path: (import.meta && import.meta.url) ? new URL(import.meta.url).pathname.substring(0, new URL(import.meta.url).pathname.lastIndexOf('/') + 1) : 'auto', type: 'esm', version: '14.0.22' };
1
+ export const packageInfo = { name: '@pezkuwi/x-randomvalues', path: (import.meta && import.meta.url) ? new URL(import.meta.url).pathname.substring(0, new URL(import.meta.url).pathname.lastIndexOf('/') + 1) : 'auto', type: 'esm', version: '14.0.10' };
package/src/browser.ts ADDED
@@ -0,0 +1,14 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ import { xglobal } from '@pezkuwi/x-global';
5
+
6
+ export { packageInfo } from './packageInfo.js';
7
+
8
+ export const crypto = xglobal.crypto;
9
+
10
+ // getRandomValues needs to be called on the crypto object,
11
+ // hence the need for the wrapper function
12
+ export function getRandomValues <T extends Uint8Array> (arr: T): T {
13
+ return crypto.getRandomValues(arr);
14
+ }
@@ -0,0 +1,22 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ /// <reference types="@pezkuwi/dev-test/globals.d.ts" />
5
+
6
+ import { insecureRandomValues } from './fallback.js';
7
+
8
+ describe('fallback (insecure)', (): void => {
9
+ it('subsequent results does not match', (): void => {
10
+ expect(
11
+ insecureRandomValues(new Uint8Array(32)).toString()
12
+ ).not.toEqual(
13
+ insecureRandomValues(new Uint8Array(32)).toString()
14
+ );
15
+ });
16
+
17
+ it('generates with the supplied length', (): void => {
18
+ expect(
19
+ insecureRandomValues(new Uint8Array(128))
20
+ ).toHaveLength(128);
21
+ });
22
+ });
@@ -0,0 +1,28 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ // Adapted from https://github.com/LinusU/react-native-get-random-values/blob/85f48393821c23b83b89a8177f56d3a81dc8b733/index.js
5
+ //
6
+ // Copyright (c) 2018, 2020 Linus Unnebäck
7
+ // SPDX-License-Identifier: MIT
8
+
9
+ let warned = false;
10
+
11
+ export function insecureRandomValues <T extends Uint8Array> (arr: T): T {
12
+ if (!warned) {
13
+ console.warn('Using an insecure random number generator, this should only happen when running in a debugger without support for crypto');
14
+ warned = true;
15
+ }
16
+
17
+ let r = 0;
18
+
19
+ for (let i = 0, count = arr.length; i < count; i++) {
20
+ if ((i & 0b11) === 0) {
21
+ r = Math.random() * 0x100000000;
22
+ }
23
+
24
+ arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
25
+ }
26
+
27
+ return arr;
28
+ }
package/src/mod.ts ADDED
@@ -0,0 +1,4 @@
1
+ // Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ export * from './browser.js';