.. | ||
android | ||
ios | ||
windows | ||
.gitattributes | ||
.npmignore | ||
index.js | ||
LICENSE | ||
package.json | ||
README.md | ||
yarn.lock |
react-native-securerandom
A library to generate cryptographically-secure random bytes. Uses SecRandomCopyBytes
on iOS and SecureRandom
on Android.
Usage
The library exports a single function:
generateSecureRandom(length: number) => Promise<Uint8Array>
Takes a length, the number of bytes to generate, and returns a Promise
that resolves with a Uint8Array
.
import { generateSecureRandom } from 'react-native-securerandom';
generateSecureRandom(12).then(randomBytes => console.log(randomBytes));
Installation
$ yarn add react-native-securerandom
Automatic linking with react-native link
$ react-native link react-native-securerandom
Manual linking
iOS
- In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
- Go to
node_modules
➜react-native-securerandom
and addRNSecureRandom.xcodeproj
- In XCode, in the project navigator, select your project. Add
libRNSecureRandom.a
to your project'sBuild Phases
➜Link Binary With Libraries
- Run your project (
Cmd+R
)<
Android
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import net.rhogan.rnsecurerandom.RNSecureRandomPackage;
to the imports at the top of the file - Add
new RNSecureRandomPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-securerandom' project(':react-native-securerandom').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-securerandom/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-securerandom')