ReactNative-ready Bitcoin BIP39: Mnemonic code for generating deterministic keys
npm install @mfellner/react-native-bip39



ReactNative-ready fork of the original Javascript implementation of Bitcoin BIP39: Mnemonic code for generating deterministic keys
``sh`
yarn add \
@mfellner/react-native-bip39 \
@mfellner/react-native-fast-create-hash \
react-native-fast-crypto \
react-native-securerandom
- Native generation of random bytes using react-native-randombytes
- Partial implementation of node's crypto for react-native, using react-native-crypto
_Please remember to allow recovery from mnemonic phrases that have invalid checksums (or that you don't have the wordlist)_
When a checksum is invalid, warn the user that the phrase is not something generated by your app, and ask if they would like to use it anyway. This way, your app only needs to hold the wordlists for your supported languages, but you can recover phrases made by other apps in other languages.
However, there should be other checks in place, such as checking to make sure the user is inputting 12 words or more separated by a space. ie. phrase.trim().split(/\s+/g).length >= 12
`js
import bip39 from '@mfellner/react-native-bip39'
// Generate a random mnemonic (uses react-native-randombytes under the hood), defaults to 128-bits of entropy
// NOTE: react-native-bip39's generateMnemonic in async, while original bip39's is sync
// this is due to react-native-randombytes which is forced to return natively generated
// bytes with a callback
static generateMnemonic = async () => {
try {
return await bip39.generateMnemonic(256) // default to 128
} catch(e) {
return false
}
}
// => 'reveal man culture nominee tag abuse keen behave refuse warfare crisp thunder valve knock unique try fold energy torch news thought access hawk table'
bip39.mnemonicToSeedHex('basket actual')
// => '5cf2d4a8b0355e90295bdfc565a022a409af063d5365bb57bf74d9528f494bfa4400f53d8349b80fdae44082d7f9541e1dba2b003bcfec9d0d53781ca676651f'
bip39.mnemonicToSeed('basket actual')
// =>
bip39.validateMnemonic(myMnemonic)
// => true
bip39.validateMnemonic('basket actual')
// => false
`
`js
import bip39 from '@mfellner/react-native-bip39';
// defaults to BIP39 English word list
// uses HEX strings for entropy
const mnemonic = bip39.entropyToMnemonic('133755ff');
// => basket rival lemon
// reversible
bip39.mnemonicToEntropy(mnemonic);
// => '133755ff'
``