GitHub,
Ledger Devs Discord,
Developer Portal
@ledgerhq/hw-transport-webhid
Allows to communicate with Ledger Hardware Wallets.
[Web] (WebHID) – WebHID check browser support.
Are you adding Ledger support to your software wallet?
You may be using this package to open a USB connection between your web application and the device.
For a smooth and quick integration:
- See the developers’ documentation on the Developer Portal and
- Go on Discord to chat with developer support and the developer community.
FAQ: "DOM Exception" is triggered when creating the transport
The transport functions create()
and listen()
must be called in the context of a user interaction (like a "click" event), otherwise it fails with DOM Exception. This is by WebUSB design. You also must run on HTTPS.
How to use this transport?
Please check @ledgerhq/hw-transport-webusb
documentation because it is very similar paradigm.
Support status
WebUSB is currently only supported on Google Chrome / Chromium DEV version and by explicitly enabling chrome://flags/#enable-experimental-web-platform-features
API
Table of Contents
TransportWebHID
Extends Transport
WebHID Transport implementation
Parameters
Examples
import TransportWebHID from "@ledgerhq/hw-transport-webhid";
...
TransportWebHID.create().then(transport => ...)
close
Release the transport device
Returns Promise<void>
exchange
Exchange with the device using APDU protocol.
Parameters
Returns Promise<Buffer> a promise of apdu response
isSupported
Check if WebUSB transport is supported.
list
List the WebUSB devices that was previously authorized by the user.
listen
Actively listen to WebUSB devices and emit ONE device
that was either accepted before, if not it will trigger the native permission UI.
Important: it must be called in the context of a UI click!
Parameters
observer
Observer<DescriptorEvent<HIDDevice>>
Returns Subscription
request
Similar to create() except it will always display the device permission (even if some devices are already accepted).
openConnected
Similar to create() except it will never display the device permission (it returns a Promise<?Transport>, null if it fails to find a device).
open
Create a Ledger transport with a HIDDevice
Parameters