@ledgerhq/devices v8.4.4
@ledgerhq/devices
Logic for all Ledger devices.
API
Table of Contents
- receiveAPDU
- createChunkedBuffers
- sendAPDU
- createHIDframing
- makeBlocks
- reduceResponse
- getReducedResult
- IIGenericHID
- blue
- nanoS
- nanoSP
- nanoX
- stax
- europa
- ledgerUSBVendorId
- getDeviceModel
- identifyTargetId
- identifyUSBProductId
- getBluetoothServiceUuids
- getInfosForServiceUuid
- DeviceModel
- BluetoothInfos
receiveAPDU
Parses a raw stream coming from a BLE communication into an APDU response
Parameters
rawStreamObservable<(Buffer | Error)> An observable containing the raw stream as emitted buffersoptions{context: TraceContext?} Optional options containing:* context An optional context object for log/tracing strategy (optional, default{})options.context
Returns Observable[Buffer](https://nodejs.org/api/buffer.html) An observable containing the APDU response as one emitted buffer
createChunkedBuffers
Creates a list of chunked buffer from one buffer
If this is using a Node buffer: the chunked buffers reference to the same memory as the original buffer. If this is using a Uint8Array: each part of the original buffer is copied into the chunked buffers
Parameters
bufferBuffer a Node Buffer, or a Uint8ArraysizeForIndexfunction (arg0: number): number A function that takes an index (on the buffer) and returns the size of the chunk at that index
Returns Array[Buffer](https://nodejs.org/api/buffer.html) a list of chunked buffers
sendAPDU
Sends an APDU by encoding it into chunks and sending the chunks using the given write function
Parameters
writefunction (arg0: Buffer): Promise\ The function to send each chunk to the deviceapduBuffermtuSizenumber The negotiated maximum size of the data to be sent in one chunkoptions{context: TraceContext?} Optional options containing:* context An optional context object for log/tracing strategy (optional, default{})options.context
Returns Observable[Buffer](https://nodejs.org/api/buffer.html) An observable that will only emit if an error occurred, otherwise it will complete
createHIDframing
Object to handle HID frames (encoding and decoding)
Parameters
makeBlocks
Frames/encodes an APDU message into HID USB packets/frames
Parameters
apduBuffer The APDU message to send, in a Buffer containing [cla, ins, p1, p2, data length, data(if not empty)]
Returns Array[Buffer](https://nodejs.org/api/buffer.html) an array of HID USB frames ready to be sent
reduceResponse
Reduces HID USB packets/frames to one response.
Parameters
accResponseAcc The value resulting from (accumulating) the previous call of reduceResponse. On first call initialized toinitialAcc. The accumulator enables handling multi-frames messages.chunkBuffer Current chunk to reduce into accumulator
Returns ResponseAcc An accumulator value updated with the current chunk
getReducedResult
Returns the response message that has been reduced from the HID USB frames
Parameters
accResponseAcc The accumulator
Returns (Buffer | null | undefined) A Buffer containing the cleaned response message, or null if no response message, or undefined if the accumulator is incorrect (message length is not valid)
IIGenericHID
The USB product IDs will be defined as MMII, encoding a model (MM) and an interface bitfield (II)
Model Ledger Nano S : 0x10 Ledger Blue : 0x00 Ledger Nano X : 0x40
Interface support bitfield Generic HID : 0x01 Keyboard HID : 0x02 U2F : 0x04 CCID : 0x08 WebUSB : 0x10
Type: number
blue
Ledger Blue
Type: string
nanoS
Ledger Nano S
Type: string
nanoSP
Ledger Nano S Plus
Type: string
nanoX
Ledger Nano X
Type: string
stax
Ledger Stax
Type: string
europa
Ledger Flex ("europa" is the internal name)
Type: string
ledgerUSBVendorId
Type: number
getDeviceModel
Parameters
idDeviceModelId
Returns DeviceModel
identifyTargetId
Given a targetId, return the deviceModel associated to it,
based on the first two bytes.
Parameters
targetIdnumber
Returns (DeviceModel | null | undefined)
identifyUSBProductId
From a given USB product id, return the deviceModel associated to it.
The mapping from the product id is only based on the 2 most significant bytes. For example, Stax is defined with a product id of 0x60ii, a product id 0x6011 would be mapped to it.
Parameters
usbProductIdnumber
Returns (DeviceModel | null | undefined)
getBluetoothServiceUuids
Returns Array[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)
getInfosForServiceUuid
Parameters
uuidstring
Returns (BluetoothInfos | undefined)
DeviceModel
BluetoothInfos
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
2 years ago
3 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago