This is the app for the Ledger Nano S and Ledger Blue that makes it possible sign any transaction for the Eos network (https://eos.io/).
A companion Javascript library is available to communicate with this app. To learn how to use this library and generate a browserified version of it you can take look at the project [ need Eos App info here ]
To build and install the app on your Nano S or Blue you must set up the Ledger Nano S or Blue build environments. Please follow the Getting Started instructions at the Ledger Nano S github repository.
Alternatively, you can set up the Vagrant Virtualbox Ledger environment maintained here. This sets up an Ubuntu virtual machine with the Ledger build environment already set up.
The command to compile and load the app onto the device is:
$ make load
To remove the app from the device do:
$ make delete
// TO DO // add tests for parsing a transaction for display
When a transaction is to be signed it is sent to the device as a serialized binary object. To show the transaction details to the user on the device this binary object must be read. This is done by a purpose-built parser shipped with this app.
Due to memory limitations the transaction maximum size is set to 1kb. This should be sufficient for most usages, including multi-operation transactions up to 15 operations depending on the size of the operations.
Alternatively the user can enable hash signing. In this mode the parsed transaction is not sent to the device but only the hash of the transaction, which is the basis for a valid signature. In this case details for the transaction cannot be displayed and verified which is why this is not the preferred mode of operation. In fact, setting hash signing mode is not persistent and needs be set again whenever the user needs it.