- On restore, register new addresses with websocket as listeners...and new webhooks.
- Move as much of that initialization stuff out of
App.js
- Document initialization flows
- New wallet initialization
- Wallet startup for already-initialized wallet
- Restore initialization
- Fork
react-native-bitcoinjs-lib
andreact-native-bip39
myself? I will control it (more secure) and I can updatebitcoinjs-lib
to support things like Segwit. - Update to main
react-native-randombytes
repo - Support multiple coins
- bitcoin
- litecoin
- dash
- ethereum
- bitcoin testnet3
- blockcypher test chain
- Security review. Make sure that
react-native-crypto
andcrypto-browserify
are secure. - Fix view height with something like
react-native-status-bar-size
when hotspot status bar size increases. Or using the<View />
'sonLayout()
prop.
Some dependencies rely on crypto
and other libraries that are usually bundled with Node but which are missing from the React Native environment. Those missing libraries must be shimmed with something like browserify and similar tools. One method for including such shims is React Nativify, which relies on babel-plugin-rewrite-require to point existing require
or import
scripts to the shimmed packages.
Instead of babel-plugin-rewrite-require
, I'm using the more popular babel-plugin-module-resolver
, as detailed in this Stack Overflow Post. I'm also declaring my transformers within .babelrc
. It's simpler and fixes two issues: slow rebuilds and slow chrome debugger source maps.
- The alternative to the React Nativify method is rn-nodeify, but that's messy and scary.
- node-libs-browser should be installed to provide many of the basic node functions.
- We may have issues with Jest tests when we use them. If so, refer to this SO Thread. One person said that was fixed by remembering to include a
.babelrc
file. We'll see when we get there.
- There are several libraries that attempt to shim
crypto
: react-native-crypto (a clone of crypto-browserify withrandomBytes
replaced) and native-crypto. I opted for the former. Haven't tried the latter yet. - pbkdf2 If
pbkdf2
errors out, ensure that it is frozen at 3.0.8. Annpm list pbkdf2
should show only 3.0.8. react-native-crypto
relies on react-native-randombytes for random byte generation, which in turn relies on SJCL (Standford Javascript Crypto Library) for synchronous generation and iOS'sSecRandomCopyBytes
for asynchronous generation.react-native-randombytes
recommends linking withrnpm link
, however that andreact-native link
is not currently working for me. The Manual method must be used. Furthermore, two files must be manually modified in Xcode for newer versions of React Native: mvayngrib/react-native-randombytes#15. Hopefully that will be merged soon. In the meantime, I'm depending on my branch (listed inpackage.json
) with those files fixed already. That library must be installed, added to the.babelrc
file.- Here's another interesting take on React Native Synchronous Secure Random Number Generation.
- Currently using
react-native-bip39
, a port ofbip39
. Will likely see if I can figure out how to usebip39
directly, or forkbip39
myself for security reasons. - Online Mnemonic Code Converter: https://iancoleman.github.io/bip39/
- Using
react-native-bitcoinjs-lib
, a fork ofbitcoinjs
. Will likely fork the latter myself for security reasons and to get access to the latest features, like Segwit.
So, there are more catches: https://github.com/bitcoinjs/bitcoinjs-lib#browser
- Buffer Version: If we run into issues with
bitcoinjs-lib
(especially on iOS 10), we may needbuffer@5.0.5
or greater. - React Native will mangle things it shouldn't when uglifying for Release:
- React Native Issue re: Minification/Uglify Mangling
- Current Location:
./node_modules/react-native/packager/src/JSTransformer/worker/minify.js
addmangle: false
- Ensure any dev tunneling changes are reverted (especially App Transport Security Settings exceptions.)
state:
initialized: false
walletUUID: null
mnemonic: null
componentWillMount:
set up websocket and connect
componentDidMount:
(loading-wallet screen renders)
initialize: get or generate: walletUUID, mnemonic, addresses
See: https://iancoleman.github.io/bip39/
- Receive (Main) Addresses:
m/44'/1'/0'/0
- Change Addresses:
m/44'/1'/0'/1
nose hello extra summer elder capital marine term glide choice plate release