Skip to content

Commit

Permalink
📝 (transports): Add missing readme.md to transport packages
Browse files Browse the repository at this point in the history
  • Loading branch information
valpinkman committed Jan 24, 2025
1 parent 40a001e commit 550a75a
Show file tree
Hide file tree
Showing 5 changed files with 201 additions and 45 deletions.
12 changes: 9 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -189,12 +189,12 @@ Device Management Kit main module.
pnpm dmk build
```

### Signer
### Signers

Transaction and message signer module.

```bash
pnpm signer build
pnpm signer-eth build
```

### Trusted Apps
Expand All @@ -221,6 +221,12 @@ Sample application module.
pnpm sample build
```

#### Documentation

```bash
pnpm doc build
```

# Processes & usage

## Continuous integration
Expand Down Expand Up @@ -295,7 +301,7 @@ It includes background information about the project and how to setup, run and b

## Reference API

Please refer to the core package [**readme**](https://github.com/LedgerHQ/device-sdk-ts/blob/develop/packages/core/README.md).
Please refer to the core package [**readme**](https://github.com/LedgerHQ/device-sdk-ts/blob/develop/packages/device-management-kit/README.md).

# Contributing

Expand Down
22 changes: 11 additions & 11 deletions danger/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { execSync } from "child_process";
type FailFn = (message: MarkdownString, file?: string, line?: number) => void;
type MessageFn = (
message: MarkdownString,
opts?: { file?: string; line?: number; icon?: MarkdownString },
opts?: { file?: string; line?: number; icon?: MarkdownString }
) => void;

export const BRANCH_PREFIX = [
Expand Down Expand Up @@ -44,13 +44,13 @@ export const isFork = (pr: GitHubPRDSL) => pr?.head?.repo?.fork ?? false;
const Branch = (
danger: DangerDSLType,
fail: FailFn,
isFork: boolean = false,
isFork: boolean = false
) => ({
regex: isFork
? new RegExp(`^(${BRANCH_PREFIX.join("|")})\/.+`, "i")
: new RegExp(
`^(${BRANCH_PREFIX.join("|")})\/((dsdk)-[0-9]+|no-issue|issue-[0-9]+)\-.+`,
"i",
"i"
),

getBranch: () => {
Expand Down Expand Up @@ -99,7 +99,7 @@ Please fix the PR branch name to match the convention, see [CONTRIBUTING.md](htt
export const checkBranches = (
danger: DangerDSLType,
fail: FailFn,
fork: boolean = false,
fork: boolean = false
) => {
const config = Branch(danger, fail, fork);
const currentBranch = config.getBranch();
Expand All @@ -115,7 +115,7 @@ export const checkBranches = (
const Commits = (
danger: DangerDSLType,
fail: FailFn,
fork: boolean = false,
fork: boolean = false
) => ({
regex: /^.+\(([a-z]+\-?){1,}\): [A-Z].*/,

Expand Down Expand Up @@ -146,7 +146,7 @@ Example: \`💚 (scope): My feature\`\

const currentBranch = Branch(danger, fail, fork).getBranch();
return execSync(
`git log origin/develop..${currentBranch} --pretty=format:%s`,
`git log origin/develop..${currentBranch} --pretty=format:%s`
)
.toString()
.split("\n");
Expand All @@ -156,14 +156,14 @@ Example: \`💚 (scope): My feature\`\
export const checkCommits = (
danger: DangerDSLType,
fail: FailFn,
fork: boolean = false,
fork: boolean = false
) => {
const config = Commits(danger, fail, fork);
const branchCommits = config.getCommits();
console.log("Branch commits:", branchCommits);

const wrongCommits = branchCommits.filter(
(commit) => !config.regex.test(commit),
(commit) => !config.regex.test(commit)
);

if (wrongCommits.length > 0) {
Expand Down Expand Up @@ -225,7 +225,7 @@ Please fix the PR title to match the convention, see [CONTRIBUTING.md](https://g
export const checkTitle = (
danger: DangerDSLType,
fail: FailFn,
fork: boolean = false,
fork: boolean = false
) => {
const config = Title(danger, fail, fork);
if (!config.regex.test(danger.github.pr.title)) {
Expand All @@ -240,10 +240,10 @@ export const checkChangesets = (danger: DangerDSLType, message: MessageFn) => {
const changesetFiles = danger.git.fileMatch("**/.changeset/*.md");
if (changesetFiles.edited === false) {
message(
`\ No changeset file found in the PR. Please add a changeset file.`,
`\ No changeset file found. Please make sure this is intended or add a changeset file.`,
{
icon: "⚠️",
},
}
);
return false;
}
Expand Down
58 changes: 27 additions & 31 deletions packages/device-management-kit/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
- [Installation](#installation)
- [Usage](#usage)
- [Compatibility](#compatibility)
- [Pre-requisites](#pre-requisites)
- [Main Features](#main-features)
- [Setting up the SDK](#setting-up-the-sdk)
- [Connecting to a Device](#connecting-to-a-device)
Expand Down Expand Up @@ -37,13 +36,9 @@ npm install @ledgerhq/device-management-kit

## Usage

### Compatibility

This library works in [any browser supporting the WebHID API](https://developer.mozilla.org/en-US/docs/Web/API/WebHID_API#browser_compatibility).

### Pre-requisites

Some of the APIs exposed return objects of type `Observable` from RxJS. Ensure you are familiar with the basics of the Observer pattern and RxJS before using this SDK. You can refer to [RxJS documentation](https://rxjs.dev/guide/overview) for more information.
Some of the APIs exposed return objects of type `Observable` from RxJS. Ensure you are familiar with the basics of the Observer pattern and RxJS before using this dmk. You can refer to [RxJS documentation](https://rxjs.dev/guide/overview) for more information.

### Main Features

Expand All @@ -60,48 +55,49 @@ Some of the APIs exposed return objects of type `Observable` from RxJS. Ensure y
> [!NOTE]
> At the moment we do not provide the possibility to distinguish two devices of the same model, via USB and to avoid connection to the same device twice.
### Setting up the SDK
### Setting up the DMK

The core package exposes an SDK builder `DeviceSdkBuilder` which will be used to initialise the SDK with your configuration.
The core package exposes a DMK builder `DeviceManagementKitBuilder` which will be used to initialise the DMK with your configuration.

For now it allows you to add one or more custom loggers.

In the following example, we add a console logger (`.addLogger(new ConsoleLogger())`). Then we build the SDK with `.build()`.
In the following example, we add a console logger (`.addLogger(new ConsoleLogger())`) and a WebHID transport. Then we build the DMK with `.build()`.

**The returned object will be the entrypoint for all your interactions with the SDK.**
**The returned object will be the entrypoint for all your interactions with the DMK.**

The SDK should be built only once in your application runtime so keep a reference of this object somewhere.
The DMK should be built only once in your application runtime so keep a reference of this object somewhere.

```ts
import {
ConsoleLogger,
DeviceSdk,
DeviceSdkBuilder,
DeviceManagementKitBuilder,
} from "@ledgerhq/device-management-kit";
import { webHidTransportFactory } from "@ledgerhq/device-transport-kit-web-hid";

export const sdk = new DeviceSdkBuilder()
export const sdk = new DeviceManagementKitBuilder()
.addLogger(new ConsoleLogger())
.addTransport(webHidTransportFactory)
.build();
```

### Connecting to a Device

There are two steps to connecting to a device:

- **Discovery**: `sdk.startDiscovering()`
- **Discovery**: `dmk.startDiscovering()`
- Returns an observable which will emit a new `DiscoveredDevice` for every scanned device.
- The `DiscoveredDevice` objects contain information about the device model.
- Use one of these values to connect to a given discovered device.
- **Connection**: `sdk.connect({ deviceId: device.id })`
- **Connection**: `dmk.connect({ deviceId: device.id })`
- Returns a Promise resolving in a device session identifier `DeviceSessionId`.
- **Keep this device session identifier to further interact with the device.**
- Then, `sdk.getConnectedDevice({ sessionId })` returns the `ConnectedDevice`, which contains information about the device model and its name.
- Then, `dmk.getConnectedDevice({ sessionId })` returns the `ConnectedDevice`, which contains information about the device model and its name.

```ts
sdk.startDiscovering().subscribe({
dmk.startDiscovering().subscribe({
next: (device) => {
sdk.connect({ deviceId: device.id }).then((sessionId) => {
const connectedDevice = sdk.getConnectedDevice({ sessionId });
dmk.connect({ deviceId: device.id }).then((sessionId) => {
const connectedDevice = dmk.getConnectedDevice({ sessionId });
});
},
error: (error) => {
Expand All @@ -112,8 +108,8 @@ sdk.startDiscovering().subscribe({

Then once a device is connected:

- **Disconnection**: `sdk.disconnect({ sessionId })`
- **Observe the device session state**: `sdk.getDeviceSessionState({ sessionId })`
- **Disconnection**: `dmk.disconnect({ sessionId })`
- **Observe the device session state**: `dmk.getDeviceSessionState({ sessionId })`
- This will return an `Observable<DeviceSessionState>` to listen to the known information about the device:
- device status:
- ready to process a command
Expand Down Expand Up @@ -154,7 +150,7 @@ const apdu = new ApduBuilder(openAppApduArgs)

// ### 2. Sending the APDU

const apduResponse = await sdk.sendApdu({ sessionId, apdu });
const apduResponse = await dmk.sendApdu({ sessionId, apdu });

// ### 3. Parsing the result

Expand All @@ -178,7 +174,7 @@ The `sendCommand` method will take care of building the APDU, sending it to the
> ### ❗️ Error Responses
>
> Most of the commands will reject with an error if the device is locked.
> Ensure that the device is unlocked before sending commands. You can check the device session state (`sdk.getDeviceSessionState`) to know if the device is locked.
> Ensure that the device is unlocked before sending commands. You can check the device session state (`dmk.getDeviceSessionState`) to know if the device is locked.
>
> Most of the commands will reject with an error if the response status word is not `0x9000` (success response from the device).
Expand All @@ -191,7 +187,7 @@ import { OpenAppCommand } from "@ledgerhq/device-management-kit";

const command = new OpenAppCommand("Bitcoin"); // Open the Bitcoin app

await sdk.sendCommand({ sessionId, command });
await dmk.sendCommand({ sessionId, command });
```

#### Close App
Expand All @@ -203,36 +199,36 @@ import { CloseAppCommand } from "@ledgerhq/device-management-kit";

const command = new CloseAppCommand();

await sdk.sendCommand({ sessionId, command });
await dmk.sendCommand({ sessionId, command });
```

#### Get OS Version

This command will return information about the currently installed OS on the device.

> ℹ️ If you want this information you can simply get it from the device session state by observing it with `sdk.getDeviceSessionState({ sessionId })`.
> ℹ️ If you want this information you can simply get it from the device session state by observing it with `dmk.getDeviceSessionState({ sessionId })`.
```ts
import { GetOsVersionCommand } from "@ledgerhq/device-management-kit";

const command = new GetOsVersionCommand();

const { seVersion, mcuSephVersion, mcuBootloaderVersion } =
await sdk.sendCommand({ sessionId, command });
await dmk.sendCommand({ sessionId, command });
```

#### Get App and Version

This command will return the name and version of the currently running app on the device.

> ℹ️ If you want this information you can simply get it from the device session state by observing it with `sdk.getDeviceSessionState({ sessionId })`.
> ℹ️ If you want this information you can simply get it from the device session state by observing it with `dmk.getDeviceSessionState({ sessionId })`.
```ts
import { GetAppAndVersionCommand } from "@ledgerhq/device-management-kit";

const command = new GetAppAndVersionCommand();

const { name, version } = await sdk.sendCommand({ sessionId, command });
const { name, version } = await dmk.sendCommand({ sessionId, command });
```

### Building a Custom Command
Expand Down Expand Up @@ -264,7 +260,7 @@ import {

const openAppDeviceAction = new OpenAppDeviceAction({ appName: "Bitcoin" });

const { observable, cancel } = await sdk.executeDeviceAction({
const { observable, cancel } = await dmk.executeDeviceAction({
deviceAction: openAppDeviceAction,
command,
});
Expand Down
77 changes: 77 additions & 0 deletions packages/transport/web-ble/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
# Transport Device Kit Web BLE

> [!CAUTION]
> This is still under development and we are free to make new interfaces which may lead to breaking changes.
- [Transport Device Kit Web HID Documentation](#transport-device-kit-web-ble)
- [Description](#description)
- [Installation](#installation)
- [Usage](#usage)
- [Compatibility](#compatibility)
- [Pre-requisites](#pre-requisites)
- [Main Features](#main-features)
- [How To](#how-to)

## Description

This transport is used to interact with a Ledger device through the Web BLE (Bluetooth) implementation.

## Installation

To install the core package, run the following command:

```sh
npm install @ledgerhq/device-transport-kit-web-ble
```

## Usage

### Compatibility

This library works in [any browser supporting the Web Bluetooth API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Bluetooth_API#browser_compatibility).

### Pre-requisites

To use this transport, you need to have the DMK installed on your project as well.

### Main Features

- Exposing a transport factory to be injected into the DeviceManagementKit
- Exposing the transport directly for a custom configuration

### How To

To use the transport, you need to inject it in the DeviceManagementKitBuilder before the build. This will allow the DMK to find and interact with devices on the Web BLE protocol.

```typescript
import { DeviceManagementKitBuilder } from "@ledgerhq/device-management-kit"
import { webBleTransportFactory, WebBleTransport } from "@ledgerhq/device-transport-kit-web-ble"

// Easy setup with the factory
const dmk = new DeviceManagementKitBuilder()
.addTransport(webBleTransportFactory)
.build();


// With custom config
const dmk = new DeviceManagementKitBuilder()
.addTransport(({
deviceModelDataSource: DeviceModelDataSource;
loggerServiceFactory: (tag: string) => LoggerPublisherService;
config: DmkConfig;
apduSenderServiceFactory: ApduSenderServiceFactory;
apduReceiverServiceFactory: ApduReceiverServiceFactory;
}) => {
// custom code
return new WebBleTransport(
deviceModelDataSource,
loggerServiceFactory,
config,
apduSenderServiceFactory,
apduReceiverServiceFactory,
);
})
.build();

// Youn can then make use of the DMK
```
Loading

0 comments on commit 550a75a

Please sign in to comment.