Documentation
Setup and build

Requirements and installation

Introduction

All the JavaScript code related to the Ledger Live applications is in the ledger-live monorepository. The work to integrate a Blockchain in Ledger Live will all happen in this monorepository.

Ledger Live Common (./libs/ledger-live-common) is the shared core library used by Ledger Live Desktop and Mobile, that also includes a CLI for testing purpose or for using Ledger Live features directly from a terminal (in a limited way).

This library is built upon a pretty standard ES6 + Typescript stack and relies on a bunch of ledgerjs (opens in a new tab) packages, RxJS 6.x (opens in a new tab), bignumber.js (opens in a new tab) and React (opens in a new tab) + Redux (opens in a new tab) for some front-end utilities and hooks.

It is designed to have very generic models and mechanics (for currencies, accounts, storage, synchronisation, events...) that also facilitates new blockchain integrations through flexibility. All integrated coins are implemented in their own package in the libs directory, following the naming convention. To be fully integrated, a libs/ledger-live-common/src/families dedicated folder needs to contain a few "glue" files - that can be shared by multiple crypto-assets that use the same implementation (i.e. Bitcoin-like coins share the same bitcoin family).

This document only concerns new blockchain integrations using Typescript - we will use an imaginary coin named MyCoin as a walkthrough.

Setup

Requirements

Development tools (used or required)

Hardware prerequisites

  • A physical device (Ledger Nano S, S Plus, X or a Stax)
  • MyCoin app installed on device

Installation

Structure

Your whole implementation of MyCoin must reside in a mycoin folder in libs/coin-modules/coin-mycoin. You will also need some code in libs/ledger-live-common/src/families/mycoin, for injection, setup and UI specific requirements.

Here is a typical family folder structure (TS integration):

./libs
β”œβ”€β”€ coin-modules/coin-mycoin/src
β”‚   β”œβ”€β”€ api
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ bridge
β”‚   β”‚   β”œβ”€β”€ broadcast.ts
β”‚   β”‚   β”œβ”€β”€ buildTransaction.ts
β”‚   β”‚   β”œβ”€β”€ createTransaction.ts
β”‚   β”‚   β”œβ”€β”€ estimateMaxSpendable.ts
β”‚   β”‚   β”œβ”€β”€ formatters.ts
β”‚   β”‚   β”œβ”€β”€ getFeesForTransaction.ts
β”‚   β”‚   β”œβ”€β”€ getTransactionStatus.ts
β”‚   β”‚   β”œβ”€β”€ prepareTransaction.ts
β”‚   β”‚   β”œβ”€β”€ signOperation.ts
β”‚   β”‚   β”œβ”€β”€ synchronization.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ logic
β”‚   β”‚   β”œβ”€β”€ broadcast.ts
β”‚   β”‚   β”œβ”€β”€ craftTransaction.ts
β”‚   β”‚   β”œβ”€β”€ estimateFees.ts
β”‚   β”‚   β”œβ”€β”€ getBalance.ts
β”‚   β”‚   β”œβ”€β”€ lastBlock.ts
β”‚   β”‚   β”œβ”€β”€ listOperations.ts
β”‚   β”‚   β”œβ”€β”€ signTransaction.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ network
β”‚   β”‚   β”œβ”€β”€ explorer.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ signer
β”‚   β”‚   β”œβ”€β”€ getAddress.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ test
β”‚   β”‚   β”œβ”€β”€ bot-deviceActions.ts
β”‚   β”‚   β”œβ”€β”€ bot-specs.ts
β”‚   β”‚   β”œβ”€β”€ bridgeDatasetTest.ts
β”‚   β”‚   β”œβ”€β”€ cli.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ types
β”‚   β”‚   β”œβ”€β”€ bridge.ts
β”‚   β”‚   β”œβ”€β”€ errors.ts
β”‚   β”‚   β”œβ”€β”€ model.ts
β”‚   β”‚   β”œβ”€β”€ signer.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ config.ts
β”‚   └── index.ts
β”œβ”€β”€ ledger-live-common/src/families/mycoin
β”‚   β”œβ”€β”€ bridge.integration.test.ts
β”‚   β”œβ”€β”€ config.ts
β”‚   β”œβ”€β”€ logic.ts
β”‚   β”œβ”€β”€ react.ts
β”‚   β”œβ”€β”€ setup.ts
β”‚   β”œβ”€β”€ types.ts
β”‚   └── walletApiAdapter.ts
└── ledgerjs/packages/hw-app-mycoin/src
β”‚   β”œβ”€β”€ MyCoin.ts
β”‚   └── index.ts
ℹ️

You can refer to existing implementations to complete given examples, like Polkadot integration.

Coin-module

  • src/api directory: Contains the implementation of B2B interface (a.k.a. Alpaca) - TBD.
  • src/bridge/* files: Split of CurrencyBridge and AccountBridge logic in dedicated files.
  • src/bridge/index.ts file: Entry point of Ledger Live integration of the coin-module. This file lists CurrencyBridge and AccountBridge implementation.
  • src/network directory: Contains all the logic to send requests to the explorer.
  • src/signer/getAddress.ts file: Logic on how to interact with device-app to retrieve addresses.
  • src/test/bot-specs.ts file: Definition of tests to be run on the bot.
  • src/types/signer.ts file: Interface definition of the ledger device-app related to this coin.

Ledger live-common

  • src/config.ts: TBD.
  • src/logic.ts: Lists coin specific business logic.
  • src/react.ts: Defines and lists coin specfic react hooks for UI.
  • src/setup.ts: Glue file for coin integration.
  • src/types.ts: Lists coin specific types.
  • src/walletApiAdapter.ts: TBD.

LedgerJS

All files related to communication with the device-app.

Ledger
Copyright Β© Ledger SAS. All rights reserved. Ledger, Ledger Nano S, Ledger Vault, Bolos are registered trademarks of Ledger SAS