Go to file
Honza Rychnovský cf45a0ef34
[#942] New Wallet Recovery Phrase Screen
[#942] New Wallet Recovery Phrase Screen

[#1006] Enhance VersionInfo with other fields

[#947] About screen UI + logic + tests

[#1040] Extract logo and title on top of screens

- Place it into a separate UI component
- Used across several screens
- Closes #1040

Remove long version of the Backup screen

- We previously had a configuration field that controlled which version of the screen should be displayed to a user
- Removed
- Partly solves #1003

Backup screen view redesign

Tests + docummentation

Update links to the Zashi Github repository

As the GitHub repository was recently moved from Zcash under the ECC company

[#1014] Unify screen name with Figma design

[#1045] Adopt Zcash SDK v2.0.3

Closes #1045

Fix screenshot test

The new wallet recovery screen is now much taller; scrolling to the acting button is needed.

Fix Restore screen test

Lint tools warnings
2023-11-23 10:00:13 +01:00
.github [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
.idea [#948] Updated Settings screen UI 2023-09-28 14:17:21 +02:00
app [#1031] Export of private app data 2023-11-13 14:53:16 +01:00
build-conventions-secant [#992][#1025] Custom Google Play publishing 2023-11-13 11:50:57 +01:00
build-info-lib [#992][#1025] Custom Google Play publishing 2023-11-13 11:50:57 +01:00
buildSrc [#992][#1025] Custom Google Play publishing 2023-11-13 11:50:57 +01:00
configuration-api-lib [#947] About screen UI/logic/tests 2023-10-17 15:56:04 +02:00
configuration-impl-android-lib
crash-android-lib
crash-lib [#969] Kover 0.7.3 2023-09-22 14:30:29 +02:00
docs [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
gradle/wrapper
preference-api-lib [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
preference-impl-android-lib
sdk-ext-lib [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
spackle-android-lib
spackle-lib [#969] Kover 0.7.3 2023-09-22 14:30:29 +02:00
test-lib
tools
ui-benchmark-test
ui-design-lib [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
ui-integration-test [#985] Fix failing UI tests on texts' case 2023-10-03 14:23:43 +02:00
ui-lib [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
ui-screenshot-test [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
.gitignore [#998] Transaction History Compose Preview 2023-11-08 10:47:49 +01:00
LICENSE
README.md [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
build.gradle.kts [#1031] Export of private app data 2023-11-13 14:53:16 +01:00
buildscript-gradle.lockfile [#992][#1025] Custom Google Play publishing 2023-11-13 11:50:57 +01:00
gradle.properties [#942] New Wallet Recovery Phrase Screen 2023-11-23 10:00:13 +01:00
gradlew
gradlew.bat
settings.gradle.kts [#992][#1025] Custom Google Play publishing 2023-11-13 11:50:57 +01:00

README.md

Zashi Android Wallet

This is a sample implementation of a Zcash wallet for Android leveraging the Zcash Android SDK. The goal is to exercise the SDK and related Zcash libraries, as well as demonstrate how the SDK works.

While we aim to continue improving this sample, it is not an official product. We open sourced it as a resource to make wallet development easier for the Zcash ecosystem.

Getting Started

If you'd like to compile this application from source, please see our Setup Documentation to get started.

Reporting an issue

If you wish to report a security issue, please follow our Responsible Disclosure guidelines. See the Wallet App Threat Model for more information about the security and privacy limitations of the wallet.

If you'd like to report a technical issue or feature request for the Android Wallet, please file a GitHub issue.

General Zcash questions and/or support requests and are best directed to either:

Contributing

Contributions are very much welcomed! Please read our Contributing Guidelines to learn about our process.

Forking

If you plan to fork the project to create a new app of your own, please make the following changes. (If you're making a GitHub fork to contribute back to the project, these steps are not necessary.)

  1. Change the app name under gradle.properties
    1. See ZCASH_RELEASE_APP_NAME
  2. Change the package name under app/build.gradle.kts
    1. See ZCASH_RELEASE_PACKAGE_NAME
  3. Change the support email address under gradle.properties
    1. See ZCASH_SUPPORT_EMAIL_ADDRESS
  4. Remove any copyrighted ZCash or Electric Coin Company icons, logos, or assets
    1. ui-lib/src/main/res/common/ - All of the the ic_launcher assets
  5. Optional
    1. Configure secrets and variables for Continuous Integration
    2. Configure Firebase API keys and place them under app/src/debug/google-services.json and app/src/release/google-services.json

Known Issues

  1. During builds, a warning will be printed that says "Unable to detect AGP versions for included builds. All projects in the build should use the same AGP version." This can be safely ignored. The version under build-conventions is the same as the version used elsewhere in the application.
  2. When the code coverage Gradle property IS_ANDROID_INSTRUMENTATION_TEST_COVERAGE_ENABLED is enabled, the debug app APK cannot be run. The coverage flag should therefore only be set when running automated tests.
  3. Test coverage for Compose code will be low, due to known limitations in the interaction between Compose and Jacoco.
  4. Adding the espresso-contrib dependency will cause builds to fail, due to conflicting classes. This is a known issue with the Zcash Android SDK.
  5. Android Studio will warn about the Gradle checksum. This is a known issue and can be safely ignored.
  6. #96 - Release builds print some R8 warnings which can be safely ignored.
  7. During app first launch, the following exception starting with AndroidKeysetManager: keyset not found, will generate a new one is printed twice. This exception is not an error, and the code is not being invoked twice.