cosmos / ledger-cosmos

Apache License 2.0
53 stars 107 forks source link

Ledger Cosmos app

License GithubActions


zondax_light zondax_dark

Please visit our website at zondax.ch

You can also visit Zondax Hub to test any of the versions of the app


This project contains the Cosmos app for Ledger Nano S, Nano S+, X and Stax.

ATTENTION

Please:

Tip:

Download and install a prerelease

Once the app is approved by Ledger, it will be available in their app store (Ledger Live). You can get builds generated by CircleCI from the release tab. THESE ARE UNVETTED DEVELOPMENT RELEASES

Download a release from here (https://github.com/Zondax/ledger-cosmos/releases). You only need zxtool.sh

If the file is not executable, run

chmod +x ./zxtool.sh

then run:

./installer_s.sh load

Development

Preconditions

Warning: Some IDEs may not use the same python interpreter or virtual enviroment as the one you used when running pip. If you see conan is not found, check that you installed the package in the same interpreter as the one that launches cmake.

How to build ?

We like clion or vscode but let's have some reproducible command line steps

Running tests

How to test with Zemu?

What is Zemu?? Great you asked!! As part of this project, we are making public a beta version of our internal testing+emulation framework for Ledger apps.

Npm Package here: https://www.npmjs.com/package/@zondax/zemu

Repo here: https://github.com/Zondax/zemu

Let's go! First install everything:

At this moment, if you change the app you will need to run make before running the test again.

make zemu_install

Then you can run JS tests:

make zemu_test

To run a single specific test:

At the moment, the recommendation is to run from the IDE. Remember to run make if you change the app.

Using a real device

How to prepare your DEVELOPMENT! device:

You can use an emulated device for development. This is only required if you are using a physical device

Please do not use a Ledger device with funds for development purposes.

Have a separate and marked device that is used ONLY for development and testing

There are a few additional steps that increase reproducibility and simplify development:

1 - Ensure your device works in your OS

2 - Set a test mnemonic

Many of our integration tests expect the device to be configured with a known test mnemonic.

3 - Add a development certificate

Loading into your development device

The Makefile will build the firmware in a docker container and leave the binary in the correct directory.

APDU Specifications

DISCLAIMER

Ledger NanoS does not support Cosmos Textual Mode due to memory restriction