Cake Wallet is an open-source, non-custodial, and private multi-currency crypto wallet for Android, iOS, macOS, and Linux. Cake Wallet includes support for several cryptocurrencies, including: Monero (XMR), Bitcoin (BTC), Ethereum (ETH), Litecoin (LTC), Bitcoin Cash (BCH), Polygon (POL), Solana (SOL), Tron (TRX), Nano (XNO), Zano (ZANO), Decred (DCR), Wownero (WOW).
README
Cake Wallet
Cake Wallet is an open-source, non-custodial, and private multi-currency crypto wallet for Android, iOS, macOS, and Linux.
Cake Wallet includes support for several cryptocurrencies, including:
Monero (XMR)
Bitcoin (BTC)
Ethereum (ETH)
Litecoin (LTC)
Bitcoin Cash (BCH)
Polygon (POL)
Solana (SOL)
Tron (TRX)
Nano (XNO)
Zano (ZANO)
Decred (DCR)
Wownero (WOW)
Features
App-Wide Features
Completely noncustodial. Your keys, your coins.
Built-in exchange for dozens of pairs
Easily pay cryptocurrency invoices with fixed rate exchanges
Buy cryptocurrency (BTC/LTC/XMR/ETH) 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 an external location or iCloud
Send to OpenAlias, Unstoppable Domains, Yats, and FIO Crypto Handles
Set desired network fee level
Store local transaction notes
Extremely simple user experience
Convenient exchange and sending templates for recurring payments
Create donation links and invoices in the receive screen
Cake Wallet is an open-source, non-custodial multi-currency crypto wallet designed to provide users with secure and private access to various cryptocurrencies across Android, iOS, macOS, and Linux platforms. It supports a wide range of digital assets, including Monero (XMR), Bitcoin (BTC), Ethereum (ETH), Litecoin (LTC), Bitcoin Cash (BCH), Polygon (POL), Solana (SOL), Tron (TRX), Nano (XNO), Zano (ZANO), Decred (DCR), and Wownero (WOW).
Key Features:
Noncustodial security: Users retain full control of their private keys.
Multi-currency support: Access to over 12 cryptocurrencies with dedicated features for each, such as Monero subaddresses and Bitcoin coin control.
Built-in exchange functionality: Facilitates easy cryptocurrency transactions and payments.
Privacy-enhanced settings: Includes options like Tor-only connections and Cake 2FA for added security.
Audience & Benefit:
Ideal for crypto enthusiasts, investors, and businesses seeking a secure, user-friendly platform to manage multiple digital assets. Cake Wallet empowers users with control over their funds while offering robust privacy and security features to protect their transactions.
Robust security settings (eg: Cake 2FA)
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
Optionally set Monero nodes as trusted for faster syncing
Specify a proxy for Monero nodes, compatible with Tor and i2p
Bitcoin Specific Features
Bitcoin coin control (specify specific outputs to spend)
Automatically generate new addresses
Specify multiple recipients for batch sending
Ethereum Specific Features
Store ETH and all ERc-20 tokens
Add custom tokens by contract address
Enable or disable Etherscan for transaction history
Litecoin Specific Features
Litecoin coin control (specify specific outputs to spend)
Automatically generate new addresses
Specify multiple recipients for batch sending
Monero.com by Cake Wallet for Android and iOS
Open Source Monero-Only Wallet
Exchanging to/from other assets is also supported.
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
Portuguese
Dutch
Polish
Croatian
Russian
Ukrainian
Hindi
Japanese
Chinese
Korean
Thai
Arabic
Turkish
Burmese
Urdu
Bulgarian
Czech
Indonesian
Hausa
Yoruba
Add a new language
Create a new strings_XX.arb file in res/values/, replacing XX with the language's ISO 639-1 code.
Edit the strings in this file, replacing XXX below with the translation for each string.
"welcome": "Welcome to", -> "welcome": "XXX",
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.
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.
Add a relevant flag to assets/images/flags/XXXX.png, replacing XXXX with the 3 letters localeCountryCode. The image must be 42x26 pixels with 3 pixels of transparent margin on all 4 sides. You can resize the flag with paint.net to 36x20 pixels, expand the canvas to 42x26 pixels with the flag anchored in the middle, and then manually delete the 3 pixels on each side to make it transparent. Or you can use another program like Photoshop.
Add the new language code to tool/utils/translation/translation_constants.dart
Add a new fiat currency
Check with Cake Wallet support to see if the desired new fiat currency is available through our fiat API. Not all fiat currencies are.
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).
Add the raw mapping underneath in lib/entities/fiat_currency.dart following the same format as the others.
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 42x26 pixels with a 3 pixels of transparent margin on all 4 sides.