2024-07-19 02:37:20 +00:00
# Building Cake Wallet for Android
2021-03-21 02:40:22 +00:00
## Requirements and Setup
2024-07-19 02:37:20 +00:00
The following are the system requirements to build Cake Wallet for your Android device.
2021-03-21 02:40:22 +00:00
```
2023-08-18 15:37:17 +00:00
Ubuntu >= 20.04
2023-08-04 17:01:49 +00:00
Android SDK 29 or higher (better to have the latest one 33)
2021-03-21 02:40:22 +00:00
Android NDK 17c
2024-11-25 14:08:30 +00:00
Flutter 3.24.4
2021-03-21 02:40:22 +00:00
```
### 1. Installing Package Dependencies
2024-07-19 02:37:20 +00:00
CakeWallet cannot be built without the following packages installed on your system.
2021-03-21 02:40:22 +00:00
2022-04-01 09:13:22 +00:00
- curl
2021-03-21 02:40:22 +00:00
- unzip
- automake
- build-essential
- file
- pkg-config
- git
- python
- libtool
- libtinfo5
- cmake
- openjdk-8-jre-headless
2022-04-01 09:13:22 +00:00
- clang
2022-03-09 11:43:18 +00:00
You may easily install them on your build system with the following command:
2021-03-21 02:40:22 +00:00
2022-04-01 09:13:22 +00:00
`$ sudo apt-get install -y curl unzip automake build-essential file pkg-config git python libtool libtinfo5 cmake openjdk-8-jre-headless clang`
2021-03-21 02:40:22 +00:00
### 2. Installing Android Studio and Android toolchain
2024-07-19 02:37:20 +00:00
You may download and install the latest version of Android Studio [here ](https://developer.android.com/studio#downloads ). 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 Cake Wallet. **Be sure you are installing SDK version 28 or later when stepping through the wizard**
2021-03-21 02:40:22 +00:00
### 3. Installing Flutter
2024-11-25 14:08:30 +00:00
Install Flutter with version `3.24.4` . For this please check section [Install Flutter manually ](https://docs.flutter.dev/get-started/install/linux#install-flutter-manually ).
2024-07-19 02:37:20 +00:00
### 4. Installing rustup
Install rustup from the [rustup.rs ](https://rustup.rs/ ) website.
2021-03-21 02:40:22 +00:00
2024-07-19 02:37:20 +00:00
### 5. Verify Installations
2021-03-21 02:40:22 +00:00
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):
2024-11-25 14:08:30 +00:00
[✓] Flutter (Channel stable, 3.24.4, on Linux, locale en_US.UTF-8)
2023-08-04 17:01:49 +00:00
[✓] Android toolchain - develop for Android devices (Android SDK version 29 or higher)
[✓] Android Studio (version 4.0 or higher)
2021-03-21 02:40:22 +00:00
```
2024-07-19 02:37:20 +00:00
### 6. Generate a secure keystore for Android
2021-03-21 02:40:22 +00:00
`$ 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.
2024-07-19 02:37:20 +00:00
### 7. Acquiring the Cake Wallet Source Code
2021-03-21 02:40:22 +00:00
2024-07-19 02:37:20 +00:00
Create the directory that will be use to store the Cake Wallet source...
2021-03-21 02:40:22 +00:00
```
$ sudo mkdir -p /opt/android
$ sudo chown $USER /opt/android
$ cd /opt/android
```
..and download the source code into that directory.
2021-04-12 03:48:20 +00:00
`$ git clone https://github.com/cake-tech/cake_wallet.git --branch main`
2021-03-21 02:40:22 +00:00
Proceed into the source code before proceeding with the next steps:
`$ cd cake_wallet/scripts/android/`
2024-07-19 02:37:20 +00:00
### 8. Installing Android NDK
2021-03-21 02:40:22 +00:00
`$ ./install_ndk.sh`
2024-07-19 02:37:20 +00:00
### 9. Execute Build & Setup Commands for Cak eWallet
2021-03-21 02:40:22 +00:00
2022-01-06 11:47:01 +00:00
We need to generate project settings like app name, app icon, package name, etc. For this need to setup environment variables and configure project files.
Please pick what app you want to build: cakewallet or monero.com.
2022-01-08 11:19:40 +00:00
`$ source ./app_env.sh <cakewallet OR monero.com>`
(it should be like `$ source ./app_env.sh cakewallet` or `$ source ./app_env.sh monero.com` )
2022-01-06 11:47:01 +00:00
Then run configuration script for setup app name, app icon and etc:
`$ ./app_config.sh`
2021-03-21 02:40:22 +00:00
Build the Monero libraries and their dependencies:
`$ ./build_all.sh`
2024-07-19 02:37:20 +00:00
It is now time to change back to the base directory of the Cake Wallet source code:
2021-03-21 02:40:22 +00:00
`$ cd ../../`
Install Flutter package dependencies with this command:
`$ flutter pub get`
2024-07-19 02:37:20 +00:00
Your Cake Wallet 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:
2021-03-21 02:40:22 +00:00
2024-11-25 14:08:30 +00:00
`$ dart run tool/generate_new_secrets.dart`
2021-03-21 02:40:22 +00:00
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).
2024-11-25 14:08:30 +00:00
`$ dart run tool/generate_android_key_properties.dart keyAlias=key storeFile=$HOME/key.jks storePassword=<store password> keyPassword=<key password>`
2021-03-21 02:40:22 +00:00
**REMINDER:** The *above* command will **not** succeed unless you replaced the `storePassword` and `keyPassword` variables with the correct passwords for your keystore.
2021-03-31 09:09:30 +00:00
Then we need to generate localization files.
2024-11-25 14:08:30 +00:00
`$ dart run tool/generate_localization.dart`
2021-03-31 09:09:30 +00:00
2022-01-06 11:47:01 +00:00
Finally build mobx models for the app:
Cw 453 (#1306)
* feat: rebase btc-addr-types, migrate to bitcoin_base
* feat: allow scanning elect-rs using get_tweaks
* feat: scanning and adding addresses working with getTweaks, add btc SP address type
* chore: pubspec.lock
* chore: pubspec.lock
* fix: scan when switching, fix multiple unspents in same tx
* fix: initial scan
* fix: initial scan
* fix: scanning issues
* fix: sync, storing silent unspents
* chore: deps
* fix: label issues, clear spent utxo
* chore: deps
* fix: build
* fix: missing types
* feat: new electrs API & changes, fixes for last block scanning
* feat: Scan Silent Payments homepage toggle
* chore: build configure
* feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes
* fix: invalid Object in sendData
* feat: improve addresses page & address book displays
* feat: silent payments labeled addresses disclaimer
* fix: missing i18n
* chore: print
* feat: single block scan, rescan by date working for btc mainnet
* feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert
* feat: delete silent addresses
* fix: red dot in non ssl nodes
* fix: inconsistent connection states, fix tx history
* fix: tx & balance displays, cpfp sending
* feat: new rust lib
* chore: node path
* fix: check node based on network
* fix: missing txcount from addresses
* style: padding in feature page cards
* fix: restore not getting all wallet addresses by type
* fix: auto switch node broken
* fix: silent payment txs not being restored
* feat: change scanning to subscription model, sync improvements
* fix: scan re-subscription
* fix: default nodes
* fix: improve scanning by date, fix single block scan
* refactor: common function for input tx selection
* fix: nodes & build
* fix: send all with multiple outs
* refactor: unchanged file
* Update pr_test_build.yml
* chore: upgrade
* chore: merge changes
* refactor: unchanged files [skip ci]
* fix: scan fixes, add date, allow sending while scanning
* feat: sync fixes, sp settings
* feat: fix resyncing
* fix: date from height logic, status disconnected & chain tip get
* fix: params
* feat: electrum migration if using cake electrum
* fix nodes
update versions
* re-enable tron
* update sp_scanner to work on iOS [skip ci]
* fix: wrong socket for old electrum nodes
* Fix unchecked wallet type call
* fix: double balance
* feat: node domain
* fix: menu name
* fix: update tip on set scanning
* fix: connection switching back and forth
* feat: check if node is electrs, and supports sp
* chore: fix build
* minor enhancements
* fixes and enhancements
* solve conflicts with main
* fix: status toggle
* minor enhancement
* Monero.com fixes
* update sp_scanner to include windows and linux
---------
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-05-29 14:43:48 +00:00
`$ ./model_generator.sh`
2021-03-21 02:40:22 +00:00
2024-07-19 02:37:20 +00:00
### 10. Build!
2021-03-21 02:40:22 +00:00
2022-01-08 02:10:05 +00:00
`$ flutter build apk --release`
2021-03-21 02:40:22 +00:00
2024-07-19 02:37:20 +00:00
Copyright (c) 2024 Cake Labs LLC