The open source repository for Cake Wallet, a noncustodial multi-currency wallet, and Monero.com, a noncustodial Monero-only wallet. Need help? Check out https://guides.cakewallet.com
Find a file
2021-03-17 19:45:39 -05:00
android Fixes for backups for Android. Fixes for send almost all amount. 2021-01-29 22:18:07 +02:00
assets Fixes. Changed terms of use text. 2021-02-01 20:12:37 +02:00
cw_monero Changed monero dependencies path for android. Changed scripts for generation of secrets. 2021-03-16 15:20:46 +02:00
ios Estimated fee rates. 2021-02-13 00:38:34 +02:00
lib Changed monero dependencies path for android. Changed scripts for generation of secrets. 2021-03-16 15:20:46 +02:00
res/values Merge branch 'main' into CAKE-278-implement-fixed-rate-flow-for-changenow 2021-03-01 19:34:15 +02:00
scripts/android Added build scripts for android. 2021-03-16 20:18:54 +02:00
test Fixes 2020-09-28 18:47:43 +03:00
tool Added script for generate key.properties file. 2021-03-17 22:19:51 +02:00
.gitignore Changed monero dependencies path for android. Changed scripts for generation of secrets. 2021-03-16 15:20:46 +02:00
.gitmodules TMP 4 2020-06-20 10:10:00 +03:00
.metadata Added the project 2020-01-04 21:31:52 +02:00
analysis_options.yaml Merge redesign part 7. 2020-09-15 23:35:49 +03:00
LICENSE.md Added the project 2020-01-04 21:31:52 +02:00
PRIVACY.md Update PRIVACY.md 2021-02-24 17:32:35 +02:00
pubspec.lock Fixes for backups for Android. Fixes for send almost all amount. 2021-01-29 22:18:07 +02:00
pubspec.yaml Changed semibold font name. 2021-03-17 12:54:01 +02:00
README.md initial readme created 2021-03-17 19:45:39 -05:00

CakeWallet - Open Source Bitcoin and Monero Wallet

Requirements and Setup

The following are the system requirements to build CakeWallet for your Android device.

Ubuntu >= 16.04 
Android SDK 28
Android NDK 17c
Flutter 1.22.6

Building CakeWallet on Android

These steps will help you configure and execute a build of CakeWallet from its source code.

1. Installing Package Dependencies

CakeWallet cannot be built without the following packages installed on your build system.

  • unzip

  • automake

  • build-essential

  • file

  • pkg-config

  • git

  • python

  • libtool

  • libtinfo5

  • cmake

  • openjdk-8-jre-headless

You may easily install them on your build sytem with the following command:

$ sudo apt-get install -y unzip automake build-essential file pkg-config git python libtool libtinfo5 cmake openjdk-8-jre-headless

2. Installing Android Studio and Android toolchain

You may download and install the latest version of Android Studio here. After installing, start Android Studio, and go through the "Setup Wizard." This installs the latest Android SDK, Android SDK Command-line Tools, and Android SDK Build-Tools, which are required by CakeWallet. Be sure you are installing SDK version 28 or later when stepping through the wizard

3. Installing Flutter

The easiest way to install Flutter is by using the snap package manager. Other means of installing Flutter on your system can be found here.

$ sudo snap install flutter --classic

4. Verify Installations

Verify that the Android toolchain, Flutter, and Android Studio have been correctly installed on your system with the following command:

$ flutter doctor

The output of this command will appear like this, indicating successful installations. If there are problems with your installation, they must be corrected before proceeding.

Doctor summary (to see all details, run flutter doctor -v):
[✓] Flutter (Channel beta, 2.0.2, on Linux, locale en_US.UTF-8)
[✓] Android toolchain - develop for Android devices (Android SDK version 28)
[✓] Android Studio (version 4.0)

5. Generate a secure keystore for Android

$ keytool -genkey -v -keystore $HOME/key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias key

You will be prompted to create two passwords. First you will be prompted for the "store password", followed by a "key password" towards the end of the creation process. TAKE NOTE OF THESE PASSWORDS! You will need them in later steps.

6. Acquiring the CakeWallet Source Code

Create the directory that will be use to store the CakeWallet source...

$ sudo mkdir -p /opt/android
$ sudo chown $USER /opt/android
$ cd /opt/android

..and download the source code into that directory.

$ git clone https://github.com/cake-tech/cake_wallet.git --branch deploy

Proceed into the source code before proceeding with the next steps:

$ cd cake_wallet/scripts/android/

7. Installing Android NDK

$ ./install_ndk.sh

8. Execute Build & Setup Commands for CakeWallet

Build the Monero libraries and their dependencies:

$ ./build_all.sh

Now the dependencies need to be copied into the CakeWallet project with this command:

$ ./copy_monero_deps.sh

It is now time to change back to the base directory of the CakeWallet source code:

$ cd ../../

Install Flutter package dependencies with this command:

$ flutter pub get

Your CakeWallet binary will be built with cryptographic salts, which are used for secure encryption of your data. You may generate these secret salts with the following command:

$ flutter packages pub run tool/generate_new_secrets.dart

Next, we must generate key properties based on the secure keystore you generated for Android (in step 5). MODIFY THE FOLLOWING COMMAND with the "store password" and "key password" you assigned when creating your keystore (in step 5).

$ flutter packages pub run tool/generate_android_key_properties.dart keyAlias=key storeFile=$HOME/key.jks storePassword=<store password> keyPassword=<key password>

REMINDER: The above command will not succeed unless you replaced the storePassword and keyPassword variables with the correct passwords for your keystore.

Lastly, we will generate mobx models for the project.

$ flutter packages pub run build_runner build --delete-conflicting-outputs

9. Build!

$ flutter build apk —release

Copyright (c) 2021 Cake Technologies LLC.