@onekeyfe/hwk-ledger-connector-webhid 1.1.26 → 1.1.27-alpha.31
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.
- package/dist/index.d.mts +10 -4
- package/dist/index.d.ts +10 -4
- package/dist/index.js +10 -34
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +15 -35
- package/dist/index.mjs.map +1 -1
- package/package.json +4 -4
package/dist/index.d.mts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { LedgerConnectorBase
|
|
2
|
-
import {
|
|
1
|
+
import { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';
|
|
2
|
+
import { DeviceDescriptor, IConnector } from '@onekeyfe/hwk-adapter-core';
|
|
3
3
|
import { DeviceManagementKit } from '@ledgerhq/device-management-kit';
|
|
4
4
|
|
|
5
5
|
interface LedgerWebHidConnectorOptions {
|
|
@@ -14,10 +14,16 @@ interface LedgerWebHidConnectorOptions {
|
|
|
14
14
|
* IConnector implementation for Ledger hardware wallets via WebHID.
|
|
15
15
|
*
|
|
16
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.
|
|
17
19
|
*/
|
|
18
|
-
declare class LedgerWebHidConnector extends LedgerConnectorBase
|
|
20
|
+
declare class LedgerWebHidConnector extends LedgerConnectorBase {
|
|
19
21
|
constructor(options?: LedgerWebHidConnectorOptions);
|
|
20
|
-
|
|
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;
|
|
21
27
|
}
|
|
22
28
|
|
|
23
29
|
/**
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { LedgerConnectorBase
|
|
2
|
-
import {
|
|
1
|
+
import { LedgerConnectorBase } from '@onekeyfe/hwk-ledger-adapter';
|
|
2
|
+
import { DeviceDescriptor, IConnector } from '@onekeyfe/hwk-adapter-core';
|
|
3
3
|
import { DeviceManagementKit } from '@ledgerhq/device-management-kit';
|
|
4
4
|
|
|
5
5
|
interface LedgerWebHidConnectorOptions {
|
|
@@ -14,10 +14,16 @@ interface LedgerWebHidConnectorOptions {
|
|
|
14
14
|
* IConnector implementation for Ledger hardware wallets via WebHID.
|
|
15
15
|
*
|
|
16
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.
|
|
17
19
|
*/
|
|
18
|
-
declare class LedgerWebHidConnector extends LedgerConnectorBase
|
|
20
|
+
declare class LedgerWebHidConnector extends LedgerConnectorBase {
|
|
19
21
|
constructor(options?: LedgerWebHidConnectorOptions);
|
|
20
|
-
|
|
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;
|
|
21
27
|
}
|
|
22
28
|
|
|
23
29
|
/**
|
package/dist/index.js
CHANGED
|
@@ -37,49 +37,25 @@ module.exports = __toCommonJS(index_exports);
|
|
|
37
37
|
|
|
38
38
|
// src/LedgerWebHidConnector.ts
|
|
39
39
|
var import_hwk_ledger_adapter = require("@onekeyfe/hwk-ledger-adapter");
|
|
40
|
-
var webHidMetadataByPath = /* @__PURE__ */ new Map();
|
|
41
|
-
function patchLedgerWebHidTransportMetadata(transport) {
|
|
42
|
-
const target = transport;
|
|
43
|
-
const original = target.mapHIDDeviceToTransportDiscoveredDevice;
|
|
44
|
-
if (typeof original !== "function") {
|
|
45
|
-
return transport;
|
|
46
|
-
}
|
|
47
|
-
target.mapHIDDeviceToTransportDiscoveredDevice = function patchedMapHidDevice(device) {
|
|
48
|
-
const mappedDevice = original.call(this, device);
|
|
49
|
-
if (mappedDevice.id) {
|
|
50
|
-
webHidMetadataByPath.set(mappedDevice.id, {
|
|
51
|
-
vendor: device.vendorId,
|
|
52
|
-
product: device.productId,
|
|
53
|
-
productName: device.productName,
|
|
54
|
-
serialNumber: device.serialNumber
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
return mappedDevice;
|
|
58
|
-
};
|
|
59
|
-
return transport;
|
|
60
|
-
}
|
|
61
40
|
var LedgerWebHidConnector = class extends import_hwk_ledger_adapter.LedgerConnectorBase {
|
|
62
41
|
constructor(options) {
|
|
63
42
|
super(
|
|
64
43
|
async () => {
|
|
65
44
|
const { webHidTransportFactory } = await import("@ledgerhq/device-transport-kit-web-hid");
|
|
66
|
-
return
|
|
45
|
+
return webHidTransportFactory;
|
|
67
46
|
},
|
|
68
47
|
{ connectionType: "usb", dmk: options?.dmk }
|
|
69
48
|
);
|
|
70
49
|
}
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
serialNumber: metadata?.serialNumber ?? d.serialNumber
|
|
81
|
-
};
|
|
82
|
-
});
|
|
50
|
+
/**
|
|
51
|
+
* Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
|
|
52
|
+
* For USB devices, the DMK path (ephemeral UUID) is used as-is.
|
|
53
|
+
*/
|
|
54
|
+
_resolveConnectId(descriptor) {
|
|
55
|
+
if ((0, import_hwk_ledger_adapter.isLedgerDmkBleTransport)(descriptor.transport)) {
|
|
56
|
+
return (0, import_hwk_ledger_adapter.extractBleHexId)(descriptor.name) || "";
|
|
57
|
+
}
|
|
58
|
+
return descriptor.path;
|
|
83
59
|
}
|
|
84
60
|
};
|
|
85
61
|
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/LedgerWebHidConnector.ts"],"sourcesContent":["import { LedgerWebHidConnector } from './LedgerWebHidConnector';\n\nimport type { IConnector } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\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 {
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/LedgerWebHidConnector.ts"],"sourcesContent":["import { LedgerWebHidConnector } from './LedgerWebHidConnector';\n\nimport type { IConnector } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\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 {\n LedgerConnectorBase,\n extractBleHexId,\n isLedgerDmkBleTransport,\n} from '@onekeyfe/hwk-ledger-adapter';\n\nimport type { DeviceDescriptor } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\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 (isLedgerDmkBleTransport(descriptor.transport)) {\n return extractBleHexId(descriptor.name) || '';\n }\n return descriptor.path;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,gCAIO;AAqBA,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,YAAI,mDAAwB,WAAW,SAAS,GAAG;AACjD,iBAAO,2CAAgB,WAAW,IAAI,KAAK;AAAA,IAC7C;AACA,WAAO,WAAW;AAAA,EACpB;AACF;;;AD9BO,SAAS,4BAA4B,KAAuC;AACjF,SAAO,IAAI,sBAAsB,EAAE,IAAI,CAAC;AAC1C;","names":[]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,48 +1,28 @@
|
|
|
1
1
|
// src/LedgerWebHidConnector.ts
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
if (typeof original !== "function") {
|
|
8
|
-
return transport;
|
|
9
|
-
}
|
|
10
|
-
target.mapHIDDeviceToTransportDiscoveredDevice = function patchedMapHidDevice(device) {
|
|
11
|
-
const mappedDevice = original.call(this, device);
|
|
12
|
-
if (mappedDevice.id) {
|
|
13
|
-
webHidMetadataByPath.set(mappedDevice.id, {
|
|
14
|
-
vendor: device.vendorId,
|
|
15
|
-
product: device.productId,
|
|
16
|
-
productName: device.productName,
|
|
17
|
-
serialNumber: device.serialNumber
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
return mappedDevice;
|
|
21
|
-
};
|
|
22
|
-
return transport;
|
|
23
|
-
}
|
|
2
|
+
import {
|
|
3
|
+
LedgerConnectorBase,
|
|
4
|
+
extractBleHexId,
|
|
5
|
+
isLedgerDmkBleTransport
|
|
6
|
+
} from "@onekeyfe/hwk-ledger-adapter";
|
|
24
7
|
var LedgerWebHidConnector = class extends LedgerConnectorBase {
|
|
25
8
|
constructor(options) {
|
|
26
9
|
super(
|
|
27
10
|
async () => {
|
|
28
11
|
const { webHidTransportFactory } = await import("@ledgerhq/device-transport-kit-web-hid");
|
|
29
|
-
return
|
|
12
|
+
return webHidTransportFactory;
|
|
30
13
|
},
|
|
31
14
|
{ connectionType: "usb", dmk: options?.dmk }
|
|
32
15
|
);
|
|
33
16
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
serialNumber: metadata?.serialNumber ?? d.serialNumber
|
|
44
|
-
};
|
|
45
|
-
});
|
|
17
|
+
/**
|
|
18
|
+
* Override connectId resolution for BLE devices discovered via WebHID+BLE combo.
|
|
19
|
+
* For USB devices, the DMK path (ephemeral UUID) is used as-is.
|
|
20
|
+
*/
|
|
21
|
+
_resolveConnectId(descriptor) {
|
|
22
|
+
if (isLedgerDmkBleTransport(descriptor.transport)) {
|
|
23
|
+
return extractBleHexId(descriptor.name) || "";
|
|
24
|
+
}
|
|
25
|
+
return descriptor.path;
|
|
46
26
|
}
|
|
47
27
|
};
|
|
48
28
|
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/LedgerWebHidConnector.ts","../src/index.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"sources":["../src/LedgerWebHidConnector.ts","../src/index.ts"],"sourcesContent":["import {\n LedgerConnectorBase,\n extractBleHexId,\n isLedgerDmkBleTransport,\n} from '@onekeyfe/hwk-ledger-adapter';\n\nimport type { DeviceDescriptor } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\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 (isLedgerDmkBleTransport(descriptor.transport)) {\n return extractBleHexId(descriptor.name) || '';\n }\n return descriptor.path;\n }\n}\n","import { LedgerWebHidConnector } from './LedgerWebHidConnector';\n\nimport type { IConnector } from '@onekeyfe/hwk-adapter-core';\nimport type { DeviceManagementKit } from '@ledgerhq/device-management-kit';\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":";AAAA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAqBA,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,wBAAwB,WAAW,SAAS,GAAG;AACjD,aAAO,gBAAgB,WAAW,IAAI,KAAK;AAAA,IAC7C;AACA,WAAO,WAAW;AAAA,EACpB;AACF;;;AC9BO,SAAS,4BAA4B,KAAuC;AACjF,SAAO,IAAI,sBAAsB,EAAE,IAAI,CAAC;AAC1C;","names":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@onekeyfe/hwk-ledger-connector-webhid",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.27-alpha.31",
|
|
4
4
|
"description": "IConnector implementation for Ledger hardware wallets via WebHID (DMK)",
|
|
5
5
|
"author": "OneKey",
|
|
6
6
|
"license": "MIT",
|
|
@@ -49,13 +49,13 @@
|
|
|
49
49
|
"@ledgerhq/device-signer-kit-ethereum": "^1.9.0",
|
|
50
50
|
"@ledgerhq/device-signer-kit-solana": "^1.7.0",
|
|
51
51
|
"@ledgerhq/device-transport-kit-web-hid": "^1.0.0",
|
|
52
|
-
"@onekeyfe/hwk-adapter-core": "1.1.
|
|
53
|
-
"@onekeyfe/hwk-ledger-adapter": "1.1.
|
|
52
|
+
"@onekeyfe/hwk-adapter-core": "1.1.27-alpha.31",
|
|
53
|
+
"@onekeyfe/hwk-ledger-adapter": "1.1.27-alpha.31"
|
|
54
54
|
},
|
|
55
55
|
"devDependencies": {
|
|
56
56
|
"rimraf": "^5.0.0",
|
|
57
57
|
"tsup": "^8.0.0",
|
|
58
58
|
"typescript": "^5.4.0"
|
|
59
59
|
},
|
|
60
|
-
"gitHead": "
|
|
60
|
+
"gitHead": "73a8ecbc0e5e47038966b2f9a5ab30dc2f947d8f"
|
|
61
61
|
}
|