@pezkuwi/x-randomvalues 14.0.7 → 14.0.11
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.
- package/build/LICENSE +201 -0
- package/build/README.md +3 -0
- package/build/browser.d.ts +3 -0
- package/build/browser.js +6 -0
- package/build/cjs/browser.d.ts +3 -0
- package/build/cjs/browser.js +11 -0
- package/build/cjs/fallback.d.ts +1 -0
- package/build/cjs/fallback.js +18 -0
- package/build/cjs/node.d.ts +3 -0
- package/build/cjs/node.js +13 -0
- package/build/cjs/package.json +3 -0
- package/build/cjs/packageInfo.d.ts +6 -0
- package/build/cjs/packageInfo.js +4 -0
- package/build/cjs/react-native.d.ts +12 -0
- package/build/cjs/react-native.js +35 -0
- package/build/cjs/shim.d.ts +1 -0
- package/build/cjs/shim.js +5 -0
- package/build/fallback.d.ts +1 -0
- package/build/fallback.js +15 -0
- package/build/node.d.ts +3 -0
- package/build/node.js +7 -0
- package/build/package.json +197 -0
- package/build/packageInfo.d.ts +6 -0
- package/build/packageInfo.js +1 -0
- package/build/react-native.d.ts +12 -0
- package/build/react-native.js +31 -0
- package/build/shim.d.ts +1 -0
- package/build/shim.js +3 -0
- package/build-deno/README.md +3 -0
- package/build-deno/browser.ts +10 -0
- package/build-deno/fallback.ts +22 -0
- package/build-deno/mod.ts +2 -0
- package/build-deno/node.ts +12 -0
- package/build-deno/packageInfo.ts +3 -0
- package/build-deno/react-native.ts +57 -0
- package/build-deno/shim.ts +5 -0
- package/build-tsc/browser.d.ts +3 -0
- package/build-tsc/fallback.d.ts +1 -0
- package/build-tsc/node.d.ts +3 -0
- package/build-tsc/packageInfo.d.ts +6 -0
- package/build-tsc/react-native.d.ts +12 -0
- package/build-tsc/shim.d.ts +1 -0
- package/build-tsc-cjs/browser.js +11 -0
- package/build-tsc-cjs/fallback.js +18 -0
- package/build-tsc-cjs/node.js +13 -0
- package/build-tsc-cjs/packageInfo.js +4 -0
- package/build-tsc-cjs/react-native.js +35 -0
- package/build-tsc-cjs/shim.js +5 -0
- package/build-tsc-esm/browser.js +6 -0
- package/build-tsc-esm/fallback.js +15 -0
- package/build-tsc-esm/node.js +7 -0
- package/build-tsc-esm/packageInfo.js +1 -0
- package/build-tsc-esm/react-native.js +31 -0
- package/build-tsc-esm/shim.js +3 -0
- package/cjs/packageInfo.js +1 -1
- package/package.json +4 -4
- package/packageInfo.js +1 -1
- package/src/browser.ts +14 -0
- package/src/fallback.spec.ts +22 -0
- package/src/fallback.ts +28 -0
- package/src/mod.ts +4 -0
- package/src/node.ts +17 -0
- package/src/packageInfo.ts +6 -0
- package/src/react-native.ts +64 -0
- package/src/shim.ts +7 -0
- package/tsconfig.build.json +15 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.spec.json +17 -0
- package/tsconfig.spec.tsbuildinfo +1 -0
|
@@ -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,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,57 @@
|
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
import { NativeModules } from 'https://esm.sh/react-native';
|
|
4
|
+
|
|
5
|
+
import { base64Decode } from 'https://deno.land/x/pezkuwi/wasm-util/base64.ts';
|
|
6
|
+
import { xglobal } from 'https://deno.land/x/pezkuwi/x-global/mod.ts';
|
|
7
|
+
|
|
8
|
+
import { crypto as cryptoBrowser, getRandomValues as getRandomValuesBrowser } from './browser.ts';
|
|
9
|
+
|
|
10
|
+
export { packageInfo } from './packageInfo.ts';
|
|
11
|
+
|
|
12
|
+
interface RNExt {
|
|
13
|
+
ExpoRandom: {
|
|
14
|
+
getRandomBase64String: (length: number) => string;
|
|
15
|
+
};
|
|
16
|
+
RNGetRandomValues: {
|
|
17
|
+
getRandomBase64: (length: number) => string;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @internal
|
|
23
|
+
*
|
|
24
|
+
* A getRandomValues util that detects and uses the available RN
|
|
25
|
+
* random utiliy generation functions.
|
|
26
|
+
**/
|
|
27
|
+
function getRandomValuesRn (output: Uint8Array): Uint8Array {
|
|
28
|
+
if (!NativeModules['ExpoRandom'] && !(NativeModules as RNExt).RNGetRandomValues) {
|
|
29
|
+
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.');
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
return base64Decode(
|
|
33
|
+
(NativeModules as RNExt).RNGetRandomValues
|
|
34
|
+
? (NativeModules as RNExt).RNGetRandomValues.getRandomBase64(output.length)
|
|
35
|
+
: (NativeModules as RNExt).ExpoRandom.getRandomBase64String(output.length),
|
|
36
|
+
output
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const hasNativeRNModules = !!NativeModules['ExpoRandom'] || !!(NativeModules as RNExt).RNGetRandomValues;
|
|
41
|
+
const hasNativeCrypto = typeof xglobal.crypto === 'object' && typeof xglobal.crypto.getRandomValues === 'function';
|
|
42
|
+
|
|
43
|
+
export const getRandomValues = (
|
|
44
|
+
hasNativeRNModules
|
|
45
|
+
? getRandomValuesRn
|
|
46
|
+
: hasNativeCrypto
|
|
47
|
+
? getRandomValuesBrowser
|
|
48
|
+
: () => {
|
|
49
|
+
throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
|
|
50
|
+
}
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
export const crypto = (
|
|
54
|
+
getRandomValues === getRandomValuesBrowser
|
|
55
|
+
? cryptoBrowser
|
|
56
|
+
: { getRandomValues }
|
|
57
|
+
);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function insecureRandomValues<T extends Uint8Array>(arr: T): T;
|
|
@@ -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,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.crypto = exports.packageInfo = void 0;
|
|
4
|
+
exports.getRandomValues = getRandomValues;
|
|
5
|
+
const x_global_1 = require("@pezkuwi/x-global");
|
|
6
|
+
var packageInfo_js_1 = require("./packageInfo.js");
|
|
7
|
+
Object.defineProperty(exports, "packageInfo", { enumerable: true, get: function () { return packageInfo_js_1.packageInfo; } });
|
|
8
|
+
exports.crypto = x_global_1.xglobal.crypto;
|
|
9
|
+
function getRandomValues(arr) {
|
|
10
|
+
return exports.crypto.getRandomValues(arr);
|
|
11
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.insecureRandomValues = insecureRandomValues;
|
|
4
|
+
let warned = false;
|
|
5
|
+
function insecureRandomValues(arr) {
|
|
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
|
+
let r = 0;
|
|
11
|
+
for (let i = 0, count = arr.length; i < count; i++) {
|
|
12
|
+
if ((i & 0b11) === 0) {
|
|
13
|
+
r = Math.random() * 0x100000000;
|
|
14
|
+
}
|
|
15
|
+
arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
|
|
16
|
+
}
|
|
17
|
+
return arr;
|
|
18
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.crypto = exports.packageInfo = void 0;
|
|
4
|
+
exports.getRandomValues = getRandomValues;
|
|
5
|
+
const tslib_1 = require("tslib");
|
|
6
|
+
const node_crypto_1 = tslib_1.__importDefault(require("node:crypto"));
|
|
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 = (0, x_global_1.extractGlobal)('crypto', node_crypto_1.default.webcrypto);
|
|
11
|
+
function getRandomValues(output) {
|
|
12
|
+
return exports.crypto.getRandomValues(output);
|
|
13
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.crypto = exports.getRandomValues = exports.packageInfo = void 0;
|
|
4
|
+
const react_native_1 = require("react-native");
|
|
5
|
+
const base64_1 = require("@pezkuwi/wasm-util/base64");
|
|
6
|
+
const x_global_1 = require("@pezkuwi/x-global");
|
|
7
|
+
const browser_js_1 = require("./browser.js");
|
|
8
|
+
var packageInfo_js_1 = require("./packageInfo.js");
|
|
9
|
+
Object.defineProperty(exports, "packageInfo", { enumerable: true, get: function () { return packageInfo_js_1.packageInfo; } });
|
|
10
|
+
/**
|
|
11
|
+
* @internal
|
|
12
|
+
*
|
|
13
|
+
* A getRandomValues util that detects and uses the available RN
|
|
14
|
+
* random utiliy generation functions.
|
|
15
|
+
**/
|
|
16
|
+
function getRandomValuesRn(output) {
|
|
17
|
+
if (!react_native_1.NativeModules['ExpoRandom'] && !react_native_1.NativeModules.RNGetRandomValues) {
|
|
18
|
+
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.');
|
|
19
|
+
}
|
|
20
|
+
return (0, base64_1.base64Decode)(react_native_1.NativeModules.RNGetRandomValues
|
|
21
|
+
? react_native_1.NativeModules.RNGetRandomValues.getRandomBase64(output.length)
|
|
22
|
+
: react_native_1.NativeModules.ExpoRandom.getRandomBase64String(output.length), output);
|
|
23
|
+
}
|
|
24
|
+
const hasNativeRNModules = !!react_native_1.NativeModules['ExpoRandom'] || !!react_native_1.NativeModules.RNGetRandomValues;
|
|
25
|
+
const hasNativeCrypto = typeof x_global_1.xglobal.crypto === 'object' && typeof x_global_1.xglobal.crypto.getRandomValues === 'function';
|
|
26
|
+
exports.getRandomValues = (hasNativeRNModules
|
|
27
|
+
? getRandomValuesRn
|
|
28
|
+
: hasNativeCrypto
|
|
29
|
+
? browser_js_1.getRandomValues
|
|
30
|
+
: () => {
|
|
31
|
+
throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
|
|
32
|
+
});
|
|
33
|
+
exports.crypto = (exports.getRandomValues === browser_js_1.getRandomValues
|
|
34
|
+
? browser_js_1.crypto
|
|
35
|
+
: { getRandomValues: exports.getRandomValues });
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
let warned = false;
|
|
2
|
+
export function insecureRandomValues(arr) {
|
|
3
|
+
if (!warned) {
|
|
4
|
+
console.warn('Using an insecure random number generator, this should only happen when running in a debugger without support for crypto');
|
|
5
|
+
warned = true;
|
|
6
|
+
}
|
|
7
|
+
let r = 0;
|
|
8
|
+
for (let i = 0, count = arr.length; i < count; i++) {
|
|
9
|
+
if ((i & 0b11) === 0) {
|
|
10
|
+
r = Math.random() * 0x100000000;
|
|
11
|
+
}
|
|
12
|
+
arr[i] = (r >>> ((i & 0b11) << 3)) & 0xff;
|
|
13
|
+
}
|
|
14
|
+
return arr;
|
|
15
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import nodeCrypto from 'node:crypto';
|
|
2
|
+
import { extractGlobal } from '@pezkuwi/x-global';
|
|
3
|
+
export { packageInfo } from './packageInfo.js';
|
|
4
|
+
export const crypto = /*#__PURE__*/ extractGlobal('crypto', nodeCrypto.webcrypto);
|
|
5
|
+
export function getRandomValues(output) {
|
|
6
|
+
return crypto.getRandomValues(output);
|
|
7
|
+
}
|
|
@@ -0,0 +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.10' };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { NativeModules } from 'react-native';
|
|
2
|
+
import { base64Decode } from '@pezkuwi/wasm-util/base64';
|
|
3
|
+
import { xglobal } from '@pezkuwi/x-global';
|
|
4
|
+
import { crypto as cryptoBrowser, getRandomValues as getRandomValuesBrowser } from './browser.js';
|
|
5
|
+
export { packageInfo } from './packageInfo.js';
|
|
6
|
+
/**
|
|
7
|
+
* @internal
|
|
8
|
+
*
|
|
9
|
+
* A getRandomValues util that detects and uses the available RN
|
|
10
|
+
* random utiliy generation functions.
|
|
11
|
+
**/
|
|
12
|
+
function getRandomValuesRn(output) {
|
|
13
|
+
if (!NativeModules['ExpoRandom'] && !NativeModules.RNGetRandomValues) {
|
|
14
|
+
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.');
|
|
15
|
+
}
|
|
16
|
+
return base64Decode(NativeModules.RNGetRandomValues
|
|
17
|
+
? NativeModules.RNGetRandomValues.getRandomBase64(output.length)
|
|
18
|
+
: NativeModules.ExpoRandom.getRandomBase64String(output.length), output);
|
|
19
|
+
}
|
|
20
|
+
const hasNativeRNModules = !!NativeModules['ExpoRandom'] || !!NativeModules.RNGetRandomValues;
|
|
21
|
+
const hasNativeCrypto = typeof xglobal.crypto === 'object' && typeof xglobal.crypto.getRandomValues === 'function';
|
|
22
|
+
export const getRandomValues = (hasNativeRNModules
|
|
23
|
+
? getRandomValuesRn
|
|
24
|
+
: hasNativeCrypto
|
|
25
|
+
? getRandomValuesBrowser
|
|
26
|
+
: () => {
|
|
27
|
+
throw new Error('No secure random number generator available. This environment does not support crypto.getRandomValues.');
|
|
28
|
+
});
|
|
29
|
+
export const crypto = (getRandomValues === getRandomValuesBrowser
|
|
30
|
+
? cryptoBrowser
|
|
31
|
+
: { getRandomValues });
|
package/cjs/packageInfo.js
CHANGED
|
@@ -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.
|
|
4
|
+
exports.packageInfo = { name: '@pezkuwi/x-randomvalues', path: typeof __dirname === 'string' ? __dirname : 'auto', type: 'cjs', version: '14.0.10' };
|
package/package.json
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
{
|
|
2
|
-
"author": "
|
|
2
|
+
"author": "Pezkuwi Team <team@pezkuwichain.app>",
|
|
3
3
|
"bugs": "https://github.com/pezkuwichain/pezkuwi-common/issues",
|
|
4
4
|
"description": "A cross-environment window.crypto.getRandomValues replacement",
|
|
5
5
|
"engines": {
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
},
|
|
16
16
|
"sideEffects": false,
|
|
17
17
|
"type": "module",
|
|
18
|
-
"version": "14.0.
|
|
18
|
+
"version": "14.0.11",
|
|
19
19
|
"main": "./cjs/node.js",
|
|
20
20
|
"module": "./node.js",
|
|
21
21
|
"browser": "./cjs/browser.js",
|
|
@@ -187,11 +187,11 @@
|
|
|
187
187
|
}
|
|
188
188
|
},
|
|
189
189
|
"dependencies": {
|
|
190
|
-
"@pezkuwi/x-global": "14.0.
|
|
190
|
+
"@pezkuwi/x-global": "14.0.11",
|
|
191
191
|
"tslib": "^2.8.0"
|
|
192
192
|
},
|
|
193
193
|
"peerDependencies": {
|
|
194
|
-
"@pezkuwi/util": "14.0.
|
|
194
|
+
"@pezkuwi/util": "14.0.11",
|
|
195
195
|
"@pezkuwi/wasm-util": "*"
|
|
196
196
|
}
|
|
197
197
|
}
|
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.
|
|
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
|
+
});
|
package/src/fallback.ts
ADDED
|
@@ -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
package/src/node.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/x-randomvalues authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
// Needs Node 15+ for webcrypto
|
|
5
|
+
import nodeCrypto from 'node:crypto';
|
|
6
|
+
|
|
7
|
+
import { extractGlobal } from '@pezkuwi/x-global';
|
|
8
|
+
|
|
9
|
+
export { packageInfo } from './packageInfo.js';
|
|
10
|
+
|
|
11
|
+
export const crypto = /*#__PURE__*/ extractGlobal('crypto', nodeCrypto.webcrypto);
|
|
12
|
+
|
|
13
|
+
// getRandomValues needs to be called on the crypto object,
|
|
14
|
+
// hence the need for the wrapper function
|
|
15
|
+
export function getRandomValues <T extends Uint8Array> (output: T): T {
|
|
16
|
+
return crypto.getRandomValues(output);
|
|
17
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
// Copyright 2017-2026 @pezkuwi/x-randomvalues authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
// Do not edit, auto-generated by @pezkuwi/dev
|
|
5
|
+
|
|
6
|
+
export const packageInfo = { name: '@pezkuwi/x-randomvalues', path: 'auto', type: 'auto', version: '14.0.10' };
|
|
@@ -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
|
+
);
|
package/src/shim.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "../../tsconfig.base.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"baseUrl": "..",
|
|
5
|
+
"outDir": "./build",
|
|
6
|
+
"rootDir": "./src"
|
|
7
|
+
},
|
|
8
|
+
"exclude": [
|
|
9
|
+
"**/*.spec.ts",
|
|
10
|
+
"**/mod.ts"
|
|
11
|
+
],
|
|
12
|
+
"references": [
|
|
13
|
+
{ "path": "../x-global/tsconfig.build.json" }
|
|
14
|
+
]
|
|
15
|
+
}
|