@onekeyfe/hwk-ledger-connector-webhid 1.1.26-alpha.100

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,38 @@
1
+ import { DeviceDescriptor, IConnector } from '@onekeyfe/hwk-adapter-core';
2
+ import { DeviceManagementKit } from '@ledgerhq/device-management-kit';
3
+ import { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';
4
+
5
+ interface LedgerWebHidConnectorOptions {
6
+ /**
7
+ * Pre-built DMK instance. If not provided, a DMK will be created
8
+ * lazily on first use via `@ledgerhq/device-management-kit` and
9
+ * `@ledgerhq/device-transport-kit-web-hid`.
10
+ */
11
+ dmk?: DeviceManagementKit;
12
+ }
13
+ /**
14
+ * IConnector implementation for Ledger hardware wallets via WebHID.
15
+ *
16
+ * Extends LedgerConnectorBase with the WebHID transport factory.
17
+ * Overrides connectId resolution to handle BLE devices that may appear
18
+ * via a WebHID+BLE combo transport.
19
+ */
20
+ declare class LedgerWebHidConnector extends LedgerConnectorBase {
21
+ constructor(options?: LedgerWebHidConnectorOptions);
22
+ /**
23
+ * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
24
+ * For USB devices, the DMK path (ephemeral UUID) is used as-is.
25
+ */
26
+ protected _resolveConnectId(descriptor: DeviceDescriptor): string;
27
+ }
28
+
29
+ /**
30
+ * Create a LedgerWebHidConnector.
31
+ *
32
+ * @param dmk - Optional pre-built DMK instance. If omitted, the connector
33
+ * will lazily create one using `@ledgerhq/device-management-kit`
34
+ * and `@ledgerhq/device-transport-kit-web-hid`.
35
+ */
36
+ declare function createLedgerWebHidConnector(dmk?: DeviceManagementKit): IConnector;
37
+
38
+ export { LedgerWebHidConnector, type LedgerWebHidConnectorOptions, createLedgerWebHidConnector };
@@ -0,0 +1,38 @@
1
+ import { DeviceDescriptor, IConnector } from '@onekeyfe/hwk-adapter-core';
2
+ import { DeviceManagementKit } from '@ledgerhq/device-management-kit';
3
+ import { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';
4
+
5
+ interface LedgerWebHidConnectorOptions {
6
+ /**
7
+ * Pre-built DMK instance. If not provided, a DMK will be created
8
+ * lazily on first use via `@ledgerhq/device-management-kit` and
9
+ * `@ledgerhq/device-transport-kit-web-hid`.
10
+ */
11
+ dmk?: DeviceManagementKit;
12
+ }
13
+ /**
14
+ * IConnector implementation for Ledger hardware wallets via WebHID.
15
+ *
16
+ * Extends LedgerConnectorBase with the WebHID transport factory.
17
+ * Overrides connectId resolution to handle BLE devices that may appear
18
+ * via a WebHID+BLE combo transport.
19
+ */
20
+ declare class LedgerWebHidConnector extends LedgerConnectorBase {
21
+ constructor(options?: LedgerWebHidConnectorOptions);
22
+ /**
23
+ * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
24
+ * For USB devices, the DMK path (ephemeral UUID) is used as-is.
25
+ */
26
+ protected _resolveConnectId(descriptor: DeviceDescriptor): string;
27
+ }
28
+
29
+ /**
30
+ * Create a LedgerWebHidConnector.
31
+ *
32
+ * @param dmk - Optional pre-built DMK instance. If omitted, the connector
33
+ * will lazily create one using `@ledgerhq/device-management-kit`
34
+ * and `@ledgerhq/device-transport-kit-web-hid`.
35
+ */
36
+ declare function createLedgerWebHidConnector(dmk?: DeviceManagementKit): IConnector;
37
+
38
+ export { LedgerWebHidConnector, type LedgerWebHidConnectorOptions, createLedgerWebHidConnector };
package/dist/index.js ADDED
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/index.ts
31
+ var index_exports = {};
32
+ __export(index_exports, {
33
+ LedgerWebHidConnector: () => LedgerWebHidConnector,
34
+ createLedgerWebHidConnector: () => createLedgerWebHidConnector
35
+ });
36
+ module.exports = __toCommonJS(index_exports);
37
+
38
+ // src/LedgerWebHidConnector.ts
39
+ var import_hwk_ledger_adapter = require("@onekeyfe/hwk-ledger-adapter");
40
+ function extractBleHexId(name) {
41
+ if (!name) return void 0;
42
+ const match = name.match(/\b([0-9A-Fa-f]{4})$/);
43
+ return match ? match[1].toUpperCase() : void 0;
44
+ }
45
+ var LedgerWebHidConnector = class extends import_hwk_ledger_adapter.LedgerConnectorBase {
46
+ constructor(options) {
47
+ super(
48
+ async () => {
49
+ const { webHidTransportFactory } = await import("@ledgerhq/device-transport-kit-web-hid");
50
+ return webHidTransportFactory;
51
+ },
52
+ { connectionType: "usb", dmk: options?.dmk }
53
+ );
54
+ }
55
+ /**
56
+ * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
57
+ * For USB devices, the DMK path (ephemeral UUID) is used as-is.
58
+ */
59
+ _resolveConnectId(descriptor) {
60
+ if (descriptor.transport === "BLE") {
61
+ return extractBleHexId(descriptor.name) || descriptor.path;
62
+ }
63
+ return descriptor.path;
64
+ }
65
+ };
66
+
67
+ // src/index.ts
68
+ function createLedgerWebHidConnector(dmk) {
69
+ return new LedgerWebHidConnector({ dmk });
70
+ }
71
+ // Annotate the CommonJS export names for ESM import in node:
72
+ 0 && (module.exports = {
73
+ LedgerWebHidConnector,
74
+ createLedgerWebHidConnector
75
+ });
76
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/LedgerWebHidConnector.ts"],"sourcesContent":["import type { IConnector } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\n\nimport { LedgerWebHidConnector } from './LedgerWebHidConnector';\nimport type { LedgerWebHidConnectorOptions } from './LedgerWebHidConnector';\n\nexport { LedgerWebHidConnector };\nexport type { LedgerWebHidConnectorOptions };\n\n/**\n * Create a LedgerWebHidConnector.\n *\n * @param dmk - Optional pre-built DMK instance. If omitted, the connector\n * will lazily create one using `@ledgerhq/device-management-kit`\n * and `@ledgerhq/device-transport-kit-web-hid`.\n */\nexport function createLedgerWebHidConnector(dmk?: DeviceManagementKit): IConnector {\n return new LedgerWebHidConnector({ dmk });\n}\n","import type { DeviceDescriptor } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\nimport { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';\n\n// ---------------------------------------------------------------------------\n// Utilities\n// ---------------------------------------------------------------------------\n\n/**\n * Extract the stable 4-digit HEX identifier from a Ledger BLE device name.\n * e.g., \"Nano X 123A\" -> \"123A\", \"Ledger Nano X AB12\" -> \"AB12\"\n * Returns undefined if no valid HEX suffix found.\n */\nfunction extractBleHexId(name?: string): string | undefined {\n if (!name) return undefined;\n const match = name.match(/\\b([0-9A-Fa-f]{4})$/);\n return match ? match[1].toUpperCase() : undefined;\n}\n\n// ---------------------------------------------------------------------------\n// LedgerWebHidConnector\n// ---------------------------------------------------------------------------\n\nexport interface LedgerWebHidConnectorOptions {\n /**\n * Pre-built DMK instance. If not provided, a DMK will be created\n * lazily on first use via `@ledgerhq/device-management-kit` and\n * `@ledgerhq/device-transport-kit-web-hid`.\n */\n dmk?: DeviceManagementKit;\n}\n\n/**\n * IConnector implementation for Ledger hardware wallets via WebHID.\n *\n * Extends LedgerConnectorBase with the WebHID transport factory.\n * Overrides connectId resolution to handle BLE devices that may appear\n * via a WebHID+BLE combo transport.\n */\nexport class LedgerWebHidConnector extends LedgerConnectorBase {\n constructor(options?: LedgerWebHidConnectorOptions) {\n super(\n async () => {\n const { webHidTransportFactory } = await import('@ledgerhq/device-transport-kit-web-hid');\n return webHidTransportFactory;\n },\n { connectionType: 'usb', dmk: options?.dmk }\n );\n }\n\n /**\n * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.\n * For USB devices, the DMK path (ephemeral UUID) is used as-is.\n */\n protected override _resolveConnectId(descriptor: DeviceDescriptor): string {\n if (descriptor.transport === 'BLE') {\n return extractBleHexId(descriptor.name) || descriptor.path;\n }\n return descriptor.path;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEA,gCAAoC;AAWpC,SAAS,gBAAgB,MAAmC;AAC1D,MAAI,CAAC,KAAM,QAAO;AAClB,QAAM,QAAQ,KAAK,MAAM,qBAAqB;AAC9C,SAAO,QAAQ,MAAM,CAAC,EAAE,YAAY,IAAI;AAC1C;AAsBO,IAAM,wBAAN,cAAoC,8CAAoB;AAAA,EAC7D,YAAY,SAAwC;AAClD;AAAA,MACE,YAAY;AACV,cAAM,EAAE,uBAAuB,IAAI,MAAM,OAAO,wCAAwC;AACxF,eAAO;AAAA,MACT;AAAA,MACA,EAAE,gBAAgB,OAAO,KAAK,SAAS,IAAI;AAAA,IAC7C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMmB,kBAAkB,YAAsC;AACzE,QAAI,WAAW,cAAc,OAAO;AAClC,aAAO,gBAAgB,WAAW,IAAI,KAAK,WAAW;AAAA,IACxD;AACA,WAAO,WAAW;AAAA,EACpB;AACF;;;AD5CO,SAAS,4BAA4B,KAAuC;AACjF,SAAO,IAAI,sBAAsB,EAAE,IAAI,CAAC;AAC1C;","names":[]}
package/dist/index.mjs ADDED
@@ -0,0 +1,38 @@
1
+ // src/LedgerWebHidConnector.ts
2
+ import { LedgerConnectorBase } from "@onekeyfe/hwk-ledger-adapter";
3
+ function extractBleHexId(name) {
4
+ if (!name) return void 0;
5
+ const match = name.match(/\b([0-9A-Fa-f]{4})$/);
6
+ return match ? match[1].toUpperCase() : void 0;
7
+ }
8
+ var LedgerWebHidConnector = class extends LedgerConnectorBase {
9
+ constructor(options) {
10
+ super(
11
+ async () => {
12
+ const { webHidTransportFactory } = await import("@ledgerhq/device-transport-kit-web-hid");
13
+ return webHidTransportFactory;
14
+ },
15
+ { connectionType: "usb", dmk: options?.dmk }
16
+ );
17
+ }
18
+ /**
19
+ * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
20
+ * For USB devices, the DMK path (ephemeral UUID) is used as-is.
21
+ */
22
+ _resolveConnectId(descriptor) {
23
+ if (descriptor.transport === "BLE") {
24
+ return extractBleHexId(descriptor.name) || descriptor.path;
25
+ }
26
+ return descriptor.path;
27
+ }
28
+ };
29
+
30
+ // src/index.ts
31
+ function createLedgerWebHidConnector(dmk) {
32
+ return new LedgerWebHidConnector({ dmk });
33
+ }
34
+ export {
35
+ LedgerWebHidConnector,
36
+ createLedgerWebHidConnector
37
+ };
38
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/LedgerWebHidConnector.ts","../src/index.ts"],"sourcesContent":["import type { DeviceDescriptor } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\nimport { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';\n\n// ---------------------------------------------------------------------------\n// Utilities\n// ---------------------------------------------------------------------------\n\n/**\n * Extract the stable 4-digit HEX identifier from a Ledger BLE device name.\n * e.g., \"Nano X 123A\" -> \"123A\", \"Ledger Nano X AB12\" -> \"AB12\"\n * Returns undefined if no valid HEX suffix found.\n */\nfunction extractBleHexId(name?: string): string | undefined {\n if (!name) return undefined;\n const match = name.match(/\\b([0-9A-Fa-f]{4})$/);\n return match ? match[1].toUpperCase() : undefined;\n}\n\n// ---------------------------------------------------------------------------\n// LedgerWebHidConnector\n// ---------------------------------------------------------------------------\n\nexport interface LedgerWebHidConnectorOptions {\n /**\n * Pre-built DMK instance. If not provided, a DMK will be created\n * lazily on first use via `@ledgerhq/device-management-kit` and\n * `@ledgerhq/device-transport-kit-web-hid`.\n */\n dmk?: DeviceManagementKit;\n}\n\n/**\n * IConnector implementation for Ledger hardware wallets via WebHID.\n *\n * Extends LedgerConnectorBase with the WebHID transport factory.\n * Overrides connectId resolution to handle BLE devices that may appear\n * via a WebHID+BLE combo transport.\n */\nexport class LedgerWebHidConnector extends LedgerConnectorBase {\n constructor(options?: LedgerWebHidConnectorOptions) {\n super(\n async () => {\n const { webHidTransportFactory } = await import('@ledgerhq/device-transport-kit-web-hid');\n return webHidTransportFactory;\n },\n { connectionType: 'usb', dmk: options?.dmk }\n );\n }\n\n /**\n * Override connectId resolution for BLE devices discovered via WebHID+BLE combo.\n * For USB devices, the DMK path (ephemeral UUID) is used as-is.\n */\n protected override _resolveConnectId(descriptor: DeviceDescriptor): string {\n if (descriptor.transport === 'BLE') {\n return extractBleHexId(descriptor.name) || descriptor.path;\n }\n return descriptor.path;\n }\n}\n","import type { IConnector } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\n\nimport { LedgerWebHidConnector } from './LedgerWebHidConnector';\nimport type { LedgerWebHidConnectorOptions } from './LedgerWebHidConnector';\n\nexport { LedgerWebHidConnector };\nexport type { LedgerWebHidConnectorOptions };\n\n/**\n * Create a LedgerWebHidConnector.\n *\n * @param dmk - Optional pre-built DMK instance. If omitted, the connector\n * will lazily create one using `@ledgerhq/device-management-kit`\n * and `@ledgerhq/device-transport-kit-web-hid`.\n */\nexport function createLedgerWebHidConnector(dmk?: DeviceManagementKit): IConnector {\n return new LedgerWebHidConnector({ dmk });\n}\n"],"mappings":";AAEA,SAAS,2BAA2B;AAWpC,SAAS,gBAAgB,MAAmC;AAC1D,MAAI,CAAC,KAAM,QAAO;AAClB,QAAM,QAAQ,KAAK,MAAM,qBAAqB;AAC9C,SAAO,QAAQ,MAAM,CAAC,EAAE,YAAY,IAAI;AAC1C;AAsBO,IAAM,wBAAN,cAAoC,oBAAoB;AAAA,EAC7D,YAAY,SAAwC;AAClD;AAAA,MACE,YAAY;AACV,cAAM,EAAE,uBAAuB,IAAI,MAAM,OAAO,wCAAwC;AACxF,eAAO;AAAA,MACT;AAAA,MACA,EAAE,gBAAgB,OAAO,KAAK,SAAS,IAAI;AAAA,IAC7C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMmB,kBAAkB,YAAsC;AACzE,QAAI,WAAW,cAAc,OAAO;AAClC,aAAO,gBAAgB,WAAW,IAAI,KAAK,WAAW;AAAA,IACxD;AACA,WAAO,WAAW;AAAA,EACpB;AACF;;;AC5CO,SAAS,4BAA4B,KAAuC;AACjF,SAAO,IAAI,sBAAsB,EAAE,IAAI,CAAC;AAC1C;","names":[]}
package/package.json ADDED
@@ -0,0 +1,61 @@
1
+ {
2
+ "name": "@onekeyfe/hwk-ledger-connector-webhid",
3
+ "version": "1.1.26-alpha.100",
4
+ "description": "IConnector implementation for Ledger hardware wallets via WebHID (DMK)",
5
+ "author": "OneKey",
6
+ "license": "MIT",
7
+ "main": "dist/index.js",
8
+ "module": "dist/index.mjs",
9
+ "types": "dist/index.d.ts",
10
+ "exports": {
11
+ ".": {
12
+ "import": {
13
+ "types": "./dist/index.d.mts",
14
+ "default": "./dist/index.mjs"
15
+ },
16
+ "require": {
17
+ "types": "./dist/index.d.ts",
18
+ "default": "./dist/index.js"
19
+ }
20
+ }
21
+ },
22
+ "files": [
23
+ "dist"
24
+ ],
25
+ "scripts": {
26
+ "build": "tsup",
27
+ "dev": "tsup --watch",
28
+ "clean": "rimraf dist",
29
+ "test": "vitest run"
30
+ },
31
+ "publishConfig": {
32
+ "access": "public"
33
+ },
34
+ "repository": {
35
+ "type": "git",
36
+ "url": "https://github.com/OneKeyHQ/hardware-wallet-kit.git",
37
+ "directory": "packages/hwk-ledger-connector-webhid"
38
+ },
39
+ "keywords": [
40
+ "ledger",
41
+ "webhid",
42
+ "hardware-wallet",
43
+ "onekey",
44
+ "connector"
45
+ ],
46
+ "dependencies": {
47
+ "@ledgerhq/device-management-kit": "^1.1.0",
48
+ "@ledgerhq/device-signer-kit-bitcoin": "^1.0.0",
49
+ "@ledgerhq/device-signer-kit-ethereum": "^1.9.0",
50
+ "@ledgerhq/device-signer-kit-solana": "^1.7.0",
51
+ "@ledgerhq/device-transport-kit-web-hid": "^1.0.0",
52
+ "@onekeyfe/hwk-adapter-core": "1.1.26-alpha.100",
53
+ "@onekeyfe/hwk-ledger-adapter": "1.1.26-alpha.100"
54
+ },
55
+ "devDependencies": {
56
+ "rimraf": "^5.0.0",
57
+ "tsup": "^8.0.0",
58
+ "typescript": "^5.4.0"
59
+ },
60
+ "gitHead": "02e9376cb38df57b5743b674326c742fa74d1e8b"
61
+ }