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
2023-01-18 09:01:11 +01:00
.github/workflows Add test variables to workflow for external PR support 2022-12-28 22:20:37 +02:00
android Update permission check logic 2023-01-18 09:01:11 +01:00
assets Add Support for Arabic Language 2023-01-06 17:14:33 +02:00
cw_bitcoin fix disappearance of pending transaction 2023-01-03 23:59:08 +02:00
cw_core Fix haven currencies not getting serialized 2022-12-29 16:02:09 +02:00
cw_haven Merge pull request #529 from cake-tech/CW-182-allow-trusted-nodes 2022-12-04 02:17:35 +02:00
cw_monero Update permission check logic 2023-01-18 09:01:11 +01:00
cw_shared_external Hv (#295) 2022-03-30 17:57:04 +02:00
ios Update permission check logic 2023-01-18 09:01:11 +01:00
lib Update permission check logic 2023-01-18 09:01:11 +01:00
res/values Merge pull request #717 from Telsbat/patch-1 2023-01-10 04:06:53 +02:00
scripts new version 2023-01-04 20:39:36 +02:00
test Fixes 2020-09-28 18:47:43 +03:00
tool - Fix haven and litecoin fee transaction priority issue 2022-12-08 17:23:17 +02:00
.gitignore Add haven.dart into .gitignore 2022-04-07 11:51:43 +01: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 Flutter upgrade 2022-10-12 13:09:57 -04:00
howto-build-android.md App Center Integration with CI/CD workflow (#644) 2022-11-27 15:10:21 -05:00
LICENSE.md Minor: license change 2023-01-09 10:47:14 -06:00
model_generator.sh Add bash script to run all generation commands in one time 2022-12-01 20:47:13 +02:00
PRIVACY.md Fix privacy policy spelling error (#429) 2022-07-28 19:32:24 +01:00
pubspec_base.yaml replace webview plugin with inappwebview plugin to check camera permission once in app 2023-01-05 09:40:05 +01:00
pubspec_description.yaml Flutter upgrade 2022-10-12 13:09:57 -04:00
README.md Add Support for Arabic Language 2023-01-06 17:14:33 +02:00
Refund Pollicy.md Add files via upload 2021-10-22 18:17:23 +01:00
screenshot-android.jpg Added iOS and Android screenshots to repository to allow for CakeWallet to be submitted to Bitcoin.org 2021-04-06 19:10:42 -05:00
screenshot-ios.jpg Added iOS and Android screenshots to repository to allow for CakeWallet to be submitted to Bitcoin.org 2021-04-06 19:10:42 -05:00

Cake Wallet for Android and iOS

Open Source Multi-Currency Wallet

Features

App-Wide Features

  • Completely noncustodial. Your keys, your coins.
  • Built-in exchange for dozens of pairs
  • Buy cryptocurrency with credit/debit/bank
  • Sell cryptocurrency by bank transfer
  • Scan QR codes for easy cryptocurrency transfers
  • Create several wallets
  • Select your own custom nodes/servers
  • Address book
  • Backup to external location or iCloud
  • Send to OpenAlias, Unstoppable Domains, Yats, and FIO Crypto Handles
  • Set custom fee levels
  • Store local transaction notes
  • Extremely simple user experience
  • Convenient exchange and sending templates for recurring payments

Monero Specific Features

  • The Monero view key is retained on the device for maximum privacy
  • Full support for Monero subaddresses and accounts
  • Specify restore height for faster syncing
  • Specify multiple recipients for batch sending

Bitcoin Specific Features

  • Bitcoin coin control (specify specific outputs to spend)
  • Automatically generate new addresses
  • Specify multiple recipients for batch sending
  • Buy BTC with over a dozen fiat currencies
  • Sell BTC for USD

Litecoin Specific Features

  • Litecoin coin control (specify specific outputs to spend)
  • Automatically generate new addresses
  • Specify multiple recipients for batch sending
  • Buy LTC with over a dozen fiat currencies

Haven Specific Features

  • Send, receive, and store XHV and all xAssets like xUSD, xEUR, xAG, etc.

Monero.com by Cake Wallet for Android and iOS

Open Source Monero-Only Wallet

Exchanging to/from other assets is also supported.

Support

We have 24/7 free support. Please contact support@cakewallet.com

Build Instructions

More instructions to follow

For instructions on how to build for Android: please view file howto-build-android.md

Contributing

Improving translations

Edit the applicable strings_XX.arb file in res/values/ and open a pull request with the changes.

Current list of language files:

  • English
  • Spanish
  • French
  • German
  • Italian
  • Portugese
  • Dutch
  • Polish
  • Croatian
  • Russian
  • Ukranian
  • Hindi
  • Japanese
  • Chinese
  • Korean
  • Arabic

Add a new language

  1. Create a new strings_XX.arb file in res/values/, replacing XX with the language's ISO 639-1 code.

  2. Edit the strings in this file, replacing XXX below with the translation for each string.

"welcome" : "Welcome to", -> "welcome" : "XXX",

  1. For strings where there is a variable, denoted by a $ symbol and braces, such as ${status}, the string in braces should not be translated. For example, when editing line 106:

"time" : "${minutes}m ${seconds}s"

The only parts to be translated, if needed, are the values m and s after the variables.

  1. Add the language to lib/entities/language_service.dart under both supportedLocales and localeCountryCode. Use the name of the language in the local language and in English in parentheses after for supportedLocales. Use the ISO 3166-1 alpha-3 code for localeCountryCode. You must choose one country, so choose the country with the most native speakers of this language or is otherwise best associated with this language.

  2. Add a relevant flag to assets/images/flags/XXXX.png, replacing XXXX with the 3 digit localeCountryCode. The image must be 42x36 pixels with a 3 pixels of transparent margin on all 4 sides.

Add a new fiat currency

  1. Check with Cake Wallet support to see if the desired new fiat currency is available through our fiat API. Not all fiat currencies are.

  2. If the currency is associated strongly with a specific issuing country, map the ISO 4217 currency code with the applicable ISO 3166-1 alpha-3 code in lib/entities/fiat_currency.dart. If the currency is used in a whole region or organization, then map with a reasonable interpretation of this (eg: eur countryCode for EUR symbol).

  3. Add the raw mapping underneath in lib/entities/fiat_currency.dart following the same format as the others.

  4. Add a flag of the issuing country or organization to assets/images/flags/XXXX.png, replacing XXXX with the ISO 3166-1 alpha-3 code used above (eg: usa.png, eur.png). Do not add this if the flag with the same name already exists. The image must be 42x36 pixels with a 3 pixels of transparent margin on all 4 sides.