Bitcoin thin client for iOS & Android. Built with React Native
Go to file
2020-07-24 12:54:10 +01:00
__mocks__ ADD: Mock for RNLocalize 2020-06-15 18:39:13 -04:00
.circleci TST: hope to improve CI tests 2020-04-04 19:35:53 +01:00
.github/workflows OPS: github actions only on pull requests 2020-06-30 12:54:06 +01:00
android REL: ver bump & release notes 2020-07-18 21:34:29 +01:00
blue_modules Revert "Update notifications.js" 2020-07-23 19:12:49 +01:00
class ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
components ADD: Dark Mode 2020-07-15 18:32:59 +01:00
img ADD: Dark Mode 2020-07-15 18:32:59 +01:00
ios ADD: Keychain clear if password is lost 2020-07-20 15:58:35 +01:00
loc REF: Improve localization 2020-07-20 14:38:46 +01:00
models REF: rearrange modules, move from root to blue_modules/ 2020-07-02 15:04:44 +01:00
screen ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
scripts OPS: up detox ver; fix glados so it wont post master builds to unrelated prs 2020-05-25 12:55:51 +01:00
tests ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
.babelrc ...Android... 2019-01-19 00:40:41 -05:00
.buckconfig ...Android... 2019-01-19 00:40:41 -05:00
.eslintrc REF: upgrade eslint, prettier, fix errors, reformat everything 2020-06-04 11:48:07 +01:00
.flowconfig OPS: Upgrade RN to 62 2020-06-18 16:49:36 +01:00
.gitattributes OPS: Upgrade RN to 62 2020-06-18 16:49:36 +01:00
.gitignore OPS: Upgrade RN 2020-03-23 13:21:00 +00:00
.travis.yml OPS: github-actions 2020-06-29 17:57:16 +01:00
.watchmanconfig ...Android... 2019-01-19 00:40:41 -05:00
App.js REF: Improve localization 2020-07-20 14:38:46 +01:00
appcenter-post-build.sh REF: organizing scripts 2020-05-19 23:26:56 +01:00
babel.config.js FIX: Many layout bug fixes. 2019-01-25 01:12:07 -05:00
BlueApp.js ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
BlueComponents.js ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
CODE_OF_CONDUCT.md DOC: operations 2019-11-29 00:22:57 +00:00
CONTRIBUTING.md Update CONTRIBUTING.md 2020-06-17 11:21:20 +01:00
index.js REF: disable some warnings 2020-07-06 16:32:55 +01:00
LICENSE Initial commit 2018-01-14 20:14:03 +00:00
LoadingScreen.js Update LoadingScreen.js 2020-06-22 12:23:41 +01:00
Navigation.js ADD: lnurl-pay support 2020-07-24 12:50:33 +01:00
NavigationService.js REF: Use NavigationContainer Ref for NavigationService 2020-06-19 13:42:50 +01:00
package-lock.json ADD: Keychain clear if password is lost 2020-07-20 15:58:35 +01:00
package.json ADD: Keychain clear if password is lost 2020-07-20 15:58:35 +01:00
Privacy.js FIX: Create button was difficult to press on android. (#369) 2019-03-02 12:13:12 +00:00
README.md DOC: Fix README command for starting ios simulator 2020-07-24 12:54:10 +01:00
RELEASE.md REF: organizing scripts 2020-05-19 23:26:56 +01:00
SECURITY.md Create SECURITY.md 2019-08-04 18:57:07 +01:00
shim.js OPS: new RN module for TCP/TLS 2020-06-13 16:49:02 +01:00
UnlockWith.js FIX: Keychain clear attempt reset 2020-07-21 09:51:55 +01:00
WatchConnectivity.android.js REF: lint 2019-11-19 14:49:09 +00:00
WatchConnectivity.ios.js REF: Improve localization 2020-07-20 14:38:46 +01:00

BlueWallet - A Bitcoin & Lightning Wallet

GitHub tag CircleCI e2e on master code style: prettier

Thin Bitcoin Wallet. Built with React Native and Electrum.

Appstore Playstore

Website: bluewallet.io

Community: telegram group

  • Private keys never leave your device
  • Lightning Network supported
  • SegWit-first. Replace-By-Fee support
  • Encryption. Plausible deniability
  • And many more features...

BUILD & RUN IT

Please refer to the engines field in package.json file for the minimum required versions of Node and npm. It is preferred that you use an even-numbered version of Node as these are LTS versions.

To view the version of Node and npm in your environment, run the following in your console:

node --version && npm --version
  • In your console:
git clone https://github.com/BlueWallet/BlueWallet.git
cd BlueWallet
npm install

Please make sure that your console is running the most stable versions of npm and node (even-numbered versions).

  • To run on Android:

You will now need to either connect an Android device to your computer or run an emulated Android device using AVD Manager which comes shipped with Android Studio. To run an emulator using AVD Manager:

  1. Download and run Android Studio
  2. Click on "Open an existing Android Studio Project"
  3. Open build.gradle file under BlueWallet/android/ folder
  4. Android Studio will take some time to set things up. Once everything is set up, go to Tools -> AVD Manager
  5. Click on "Create Virtual Device..." and go through the steps to create a virtual device
  6. Launch your newly created virtual device by clicking the Play button under Actions column

Once you connected an Android device or launched an emulator, run this:

npx react-native run-android

The above command will build the app and install it. Once you launch the app it will take some time for all of the dependencies to load. Once everything loads up, you should have the built app running.

  • To run on iOS:
cd ios
pod install
cd ..
npm start ios

In another terminal window within the BlueWallet folder:

npx react-native run-ios

TESTS

npm run test

MOTIVATION TO BUILD IT

I was not satisfied with existing iOS Bitcoin apps, especially with BreadWallet (the one I mainly used) where development stalled and they could not even deliver such features as SegWit, RBF and custom fees (at the times where custom fees were especially needed). So I knew I could create one to use myself and let others use it. I had experience with awesome bitcoin-js lib (javascript), and since I dont own any Macs, don't plan to and not going to learn ObjC/Swift - ReactNative (where you also write in javascript) was an obvious choice.

LICENSE

MIT

WANT TO CONTRIBUTE?

Grab an issue from the backlog, try to start or submit a PR, any doubts we will try to guide you. Contributors have a private telegram group, request access by email bluewallet@bluewallet.io

RESPONSIBLE DISCLOSURE

Found critical bugs/vulnerabilities? Please email them bluewallet@bluewallet.io Thanks!