@onekeyfe/hd-core 1.1.3-alpha.2 → 1.1.3

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.
Files changed (62) hide show
  1. package/dist/api/BaseMethod.d.ts +0 -2
  2. package/dist/api/BaseMethod.d.ts.map +1 -1
  3. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts +28 -4
  4. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts.map +1 -1
  5. package/dist/api/btc/BTCGetPublicKey.d.ts.map +1 -1
  6. package/dist/api/cosmos/CosmosGetPublicKey.d.ts +1 -1
  7. package/dist/api/cosmos/CosmosGetPublicKey.d.ts.map +1 -1
  8. package/dist/api/device/DeviceUnlock.d.ts +2 -0
  9. package/dist/api/device/DeviceUnlock.d.ts.map +1 -1
  10. package/dist/api/evm/EVMGetPublicKey.d.ts +0 -1
  11. package/dist/api/evm/EVMGetPublicKey.d.ts.map +1 -1
  12. package/dist/api/index.d.ts +0 -1
  13. package/dist/api/index.d.ts.map +1 -1
  14. package/dist/core/RequestQueue.d.ts +0 -4
  15. package/dist/core/RequestQueue.d.ts.map +1 -1
  16. package/dist/core/index.d.ts +2 -3
  17. package/dist/core/index.d.ts.map +1 -1
  18. package/dist/device/Device.d.ts +1 -4
  19. package/dist/device/Device.d.ts.map +1 -1
  20. package/dist/device/DeviceCommands.d.ts +4 -4
  21. package/dist/events/call.d.ts +0 -9
  22. package/dist/events/call.d.ts.map +1 -1
  23. package/dist/events/core.d.ts +2 -2
  24. package/dist/events/core.d.ts.map +1 -1
  25. package/dist/events/iframe.d.ts +1 -11
  26. package/dist/events/iframe.d.ts.map +1 -1
  27. package/dist/index.d.ts +12 -40
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +141 -393
  30. package/dist/inject.d.ts +0 -3
  31. package/dist/inject.d.ts.map +1 -1
  32. package/dist/types/api/allNetworkGetAddress.d.ts +2 -9
  33. package/dist/types/api/allNetworkGetAddress.d.ts.map +1 -1
  34. package/dist/types/api/evmGetPublicKey.d.ts +0 -1
  35. package/dist/types/api/evmGetPublicKey.d.ts.map +1 -1
  36. package/dist/types/api/index.d.ts +1 -2
  37. package/dist/types/api/index.d.ts.map +1 -1
  38. package/package.json +4 -4
  39. package/src/api/BaseMethod.ts +0 -3
  40. package/src/api/allnetwork/AllNetworkGetAddress.ts +407 -14
  41. package/src/api/btc/BTCGetPublicKey.ts +0 -13
  42. package/src/api/cosmos/CosmosGetPublicKey.ts +1 -1
  43. package/src/api/device/DeviceUnlock.ts +48 -1
  44. package/src/api/evm/EVMGetPublicKey.ts +3 -9
  45. package/src/api/index.ts +0 -1
  46. package/src/core/RequestQueue.ts +0 -26
  47. package/src/core/index.ts +3 -29
  48. package/src/device/Device.ts +0 -66
  49. package/src/events/call.ts +0 -10
  50. package/src/events/core.ts +1 -7
  51. package/src/events/iframe.ts +1 -12
  52. package/src/index.ts +1 -2
  53. package/src/inject.ts +0 -47
  54. package/src/types/api/allNetworkGetAddress.ts +2 -16
  55. package/src/types/api/evmGetPublicKey.ts +0 -1
  56. package/src/types/api/index.ts +1 -2
  57. package/dist/api/allnetwork/AllNetworkGetAddressBase.d.ts +0 -47
  58. package/dist/api/allnetwork/AllNetworkGetAddressBase.d.ts.map +0 -1
  59. package/dist/api/allnetwork/AllNetworkGetAddressByLoop.d.ts +0 -8
  60. package/dist/api/allnetwork/AllNetworkGetAddressByLoop.d.ts.map +0 -1
  61. package/src/api/allnetwork/AllNetworkGetAddressBase.ts +0 -473
  62. package/src/api/allnetwork/AllNetworkGetAddressByLoop.ts +0 -151
package/dist/index.js CHANGED
@@ -26,82 +26,6 @@ var ByteBuffer__default = /*#__PURE__*/_interopDefaultLegacy(ByteBuffer);
26
26
  var BigNumber__default = /*#__PURE__*/_interopDefaultLegacy(BigNumber);
27
27
  var JSZip__default = /*#__PURE__*/_interopDefaultLegacy(JSZip);
28
28
 
29
- /******************************************************************************
30
- Copyright (c) Microsoft Corporation.
31
-
32
- Permission to use, copy, modify, and/or distribute this software for any
33
- purpose with or without fee is hereby granted.
34
-
35
- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
36
- REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
37
- AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
38
- INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
39
- LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
40
- OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
41
- PERFORMANCE OF THIS SOFTWARE.
42
- ***************************************************************************** */
43
-
44
- function __rest(s, e) {
45
- var t = {};
46
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
47
- t[p] = s[p];
48
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
49
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
50
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
51
- t[p[i]] = s[p[i]];
52
- }
53
- return t;
54
- }
55
-
56
- function __awaiter(thisArg, _arguments, P, generator) {
57
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
58
- return new (P || (P = Promise))(function (resolve, reject) {
59
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
60
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
61
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
62
- step((generator = generator.apply(thisArg, _arguments || [])).next());
63
- });
64
- }
65
-
66
- function __values(o) {
67
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
68
- if (m) return m.call(o);
69
- if (o && typeof o.length === "number") return {
70
- next: function () {
71
- if (o && i >= o.length) o = void 0;
72
- return { value: o && o[i++], done: !o };
73
- }
74
- };
75
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
76
- }
77
-
78
- function __asyncValues(o) {
79
- if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
80
- var m = o[Symbol.asyncIterator], i;
81
- return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
82
- function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
83
- function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
84
- }
85
-
86
- typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
87
- var e = new Error(message);
88
- return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
89
- };
90
-
91
- const callbackManager = new Map();
92
- const generateCallbackId = () => `callback_${Date.now()}_${Math.random().toString(36).substring(2, 11)}`;
93
- const registerCallback = (id, callback) => {
94
- callbackManager.set(id, callback);
95
- };
96
- const executeCallback = (id, ...args) => {
97
- const callback = callbackManager.get(id);
98
- if (callback) {
99
- callback(...args);
100
- }
101
- };
102
- const cleanupCallback = (id) => {
103
- callbackManager.delete(id);
104
- };
105
29
  const inject = ({ call, cancel, dispose, eventEmitter, init, updateSettings, switchTransport, uiResponse, }) => {
106
30
  const api = Object.assign({ on: (type, fn) => {
107
31
  eventEmitter.on(type, fn);
@@ -153,20 +77,6 @@ const createCoreApi = (call) => ({
153
77
  getNextU2FCounter: (connectId, params) => call(Object.assign(Object.assign({}, params), { connectId, method: 'getNextU2FCounter' })),
154
78
  setU2FCounter: (connectId, params) => call(Object.assign(Object.assign({}, params), { connectId, method: 'setU2FCounter' })),
155
79
  allNetworkGetAddress: (connectId, deviceId, params) => call(Object.assign(Object.assign({}, params), { connectId, deviceId, method: 'allNetworkGetAddress' })),
156
- allNetworkGetAddressByLoop: (connectId, deviceId, params) => {
157
- const { onLoopItemResponse, onAllItemsResponse } = params, restParams = __rest(params, ["onLoopItemResponse", "onAllItemsResponse"]);
158
- const callbackId = generateCallbackId();
159
- registerCallback(callbackId, onLoopItemResponse);
160
- const callbackIdFinish = generateCallbackId();
161
- registerCallback(callbackIdFinish, (data) => {
162
- onAllItemsResponse === null || onAllItemsResponse === void 0 ? void 0 : onAllItemsResponse(data);
163
- cleanupCallback(callbackIdFinish);
164
- cleanupCallback(callbackId);
165
- });
166
- return call(Object.assign(Object.assign({}, restParams), { connectId,
167
- deviceId, method: 'allNetworkGetAddressByLoop', callbackId,
168
- callbackIdFinish }));
169
- },
170
80
  evmGetAddress: (connectId, deviceId, params) => call(Object.assign(Object.assign({}, params), { connectId, deviceId, method: 'evmGetAddress' })),
171
81
  evmGetPublicKey: (connectId, deviceId, params) => call(Object.assign(Object.assign({}, params), { connectId, deviceId, method: 'evmGetPublicKey' })),
172
82
  evmSignMessage: (connectId, deviceId, params) => call(Object.assign(Object.assign({}, params), { connectId, deviceId, method: 'evmSignMessage' })),
@@ -774,6 +684,68 @@ const topLevelInject = () => {
774
684
  return api;
775
685
  };
776
686
 
687
+ /******************************************************************************
688
+ Copyright (c) Microsoft Corporation.
689
+
690
+ Permission to use, copy, modify, and/or distribute this software for any
691
+ purpose with or without fee is hereby granted.
692
+
693
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
694
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
695
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
696
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
697
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
698
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
699
+ PERFORMANCE OF THIS SOFTWARE.
700
+ ***************************************************************************** */
701
+
702
+ function __rest(s, e) {
703
+ var t = {};
704
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
705
+ t[p] = s[p];
706
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
707
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
708
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
709
+ t[p[i]] = s[p[i]];
710
+ }
711
+ return t;
712
+ }
713
+
714
+ function __awaiter(thisArg, _arguments, P, generator) {
715
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
716
+ return new (P || (P = Promise))(function (resolve, reject) {
717
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
718
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
719
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
720
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
721
+ });
722
+ }
723
+
724
+ function __values(o) {
725
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
726
+ if (m) return m.call(o);
727
+ if (o && typeof o.length === "number") return {
728
+ next: function () {
729
+ if (o && i >= o.length) o = void 0;
730
+ return { value: o && o[i++], done: !o };
731
+ }
732
+ };
733
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
734
+ }
735
+
736
+ function __asyncValues(o) {
737
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
738
+ var m = o[Symbol.asyncIterator], i;
739
+ return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
740
+ function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
741
+ function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
742
+ }
743
+
744
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
745
+ var e = new Error(message);
746
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
747
+ };
748
+
777
749
  const LOG_EVENT = 'LOG_EVENT';
778
750
  const LOG = {
779
751
  OUTPUT: 'log-output',
@@ -25826,7 +25798,6 @@ const IFRAME = {
25826
25798
  CALL: 'iframe-call',
25827
25799
  CANCEL: 'iframe-cancel',
25828
25800
  SWITCH_TRANSPORT: 'iframe-switch-transport',
25829
- CALLBACK: 'iframe-callback',
25830
25801
  };
25831
25802
  const createIFrameMessage = (type, payload) => ({
25832
25803
  event: UI_EVENT,
@@ -26720,15 +26691,6 @@ class Device extends events.exports {
26720
26691
  const env = DataManager.getSettings('env');
26721
26692
  if ((this.isUsedHere() && !this.keepSession && this.mainId) ||
26722
26693
  (this.mainId && DataManager.isBleConnect(env))) {
26723
- if (this.pendingCallbackPromise) {
26724
- try {
26725
- Log$a.debug('Waiting for callback tasks to complete before releasing device (in release method)');
26726
- yield this.pendingCallbackPromise.promise;
26727
- }
26728
- catch (error) {
26729
- Log$a.error('Error waiting for callback tasks in release method:', error);
26730
- }
26731
- }
26732
26694
  if (this.commands) {
26733
26695
  this.commands.dispose(false);
26734
26696
  if (this.commands.callPromise) {
@@ -27109,46 +27071,6 @@ class Device extends events.exports {
27109
27071
  return res.message;
27110
27072
  });
27111
27073
  }
27112
- supportUnlockVersionRange() {
27113
- return {
27114
- pro: {
27115
- min: '4.15.0',
27116
- },
27117
- };
27118
- }
27119
- unlockDevice() {
27120
- var _a;
27121
- return __awaiter(this, void 0, void 0, function* () {
27122
- const firmwareVersion = (_a = getDeviceFirmwareVersion(this.features)) === null || _a === void 0 ? void 0 : _a.join('.');
27123
- const versionRange = getMethodVersionRange(this.features, type => this.supportUnlockVersionRange()[type]);
27124
- if (versionRange && semver__default["default"].gte(firmwareVersion, versionRange.min)) {
27125
- const res = yield this.commands.typedCall('UnLockDevice', 'UnLockDeviceResponse');
27126
- if (this.features) {
27127
- this.features.unlocked = res.message.unlocked == null ? null : res.message.unlocked;
27128
- this.features.unlocked_attach_pin =
27129
- res.message.unlocked_attach_pin == null ? undefined : res.message.unlocked_attach_pin;
27130
- this.features.passphrase_protection =
27131
- res.message.passphrase_protection == null ? null : res.message.passphrase_protection;
27132
- return Promise.resolve(this.features);
27133
- }
27134
- const featuresRes = yield this.commands.typedCall('GetFeatures', 'Features');
27135
- this._updateFeatures(featuresRes.message);
27136
- return Promise.resolve(featuresRes.message);
27137
- }
27138
- const { type } = yield this.commands.typedCall('GetAddress', 'Address', {
27139
- address_n: [toHardened(44), toHardened(1), toHardened(0), 0, 0],
27140
- coin_name: 'Testnet',
27141
- script_type: 'SPENDADDRESS',
27142
- show_display: false,
27143
- });
27144
- if (type === 'CallMethodError') {
27145
- throw hdShared.ERRORS.TypedError(hdShared.HardwareErrorCode.RuntimeError, 'unlock device error');
27146
- }
27147
- const res = yield this.commands.typedCall('GetFeatures', 'Features');
27148
- this._updateFeatures(res.message);
27149
- return Promise.resolve(res.message);
27150
- });
27151
- }
27152
27074
  checkPassphraseStateSafety(passphraseState, useEmptyPassphrase, skipPassphraseCheck) {
27153
27075
  return __awaiter(this, void 0, void 0, function* () {
27154
27076
  if (!this.features)
@@ -28721,9 +28643,42 @@ class DeviceUnlock extends BaseMethod {
28721
28643
  init() {
28722
28644
  this.useDevicePassphraseState = false;
28723
28645
  }
28646
+ supportUnlockVersionRange() {
28647
+ return {
28648
+ pro: {
28649
+ min: '4.15.0',
28650
+ },
28651
+ };
28652
+ }
28724
28653
  run() {
28654
+ var _a;
28725
28655
  return __awaiter(this, void 0, void 0, function* () {
28726
- return this.device.unlockDevice();
28656
+ const firmwareVersion = (_a = getDeviceFirmwareVersion(this.device.features)) === null || _a === void 0 ? void 0 : _a.join('.');
28657
+ const versionRange = getMethodVersionRange(this.device.features, type => this.supportUnlockVersionRange()[type]);
28658
+ if (versionRange && semver__default["default"].gte(firmwareVersion, versionRange.min)) {
28659
+ const res = yield this.device.commands.typedCall('UnLockDevice', 'UnLockDeviceResponse');
28660
+ if (this.device.features) {
28661
+ this.device.features.unlocked = res.message.unlocked == null ? null : res.message.unlocked;
28662
+ this.device.features.unlocked_attach_pin =
28663
+ res.message.unlocked_attach_pin == null ? undefined : res.message.unlocked_attach_pin;
28664
+ this.device.features.passphrase_protection =
28665
+ res.message.passphrase_protection == null ? null : res.message.passphrase_protection;
28666
+ return Promise.resolve(this.device.features);
28667
+ }
28668
+ const featuresRes = yield this.device.commands.typedCall('GetFeatures', 'Features');
28669
+ return Promise.resolve(featuresRes.message);
28670
+ }
28671
+ const { type } = yield this.device.commands.typedCall('GetAddress', 'Address', {
28672
+ address_n: [toHardened(44), toHardened(1), toHardened(0), 0, 0],
28673
+ coin_name: 'Testnet',
28674
+ script_type: 'SPENDADDRESS',
28675
+ show_display: false,
28676
+ });
28677
+ if (type === 'CallMethodError') {
28678
+ throw hdShared.ERRORS.TypedError(hdShared.HardwareErrorCode.RuntimeError, 'Get the passphrase state error');
28679
+ }
28680
+ const res = yield this.device.commands.typedCall('GetFeatures', 'Features');
28681
+ return Promise.resolve(res.message);
28727
28682
  });
28728
28683
  }
28729
28684
  }
@@ -30086,17 +30041,12 @@ const networkConfigMap = {
30086
30041
  methodName: 'neoGetAddress',
30087
30042
  },
30088
30043
  };
30089
- class AllNetworkGetAddressBase extends BaseMethod {
30090
- constructor() {
30091
- super(...arguments);
30092
- this.abortController = null;
30093
- }
30044
+ class AllNetworkGetAddress extends BaseMethod {
30094
30045
  init() {
30095
- var _a, _b;
30096
30046
  this.checkDeviceId = true;
30097
30047
  this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
30098
30048
  validateParams(this.payload, [{ name: 'bundle', type: 'array' }]);
30099
- (_b = (_a = this.payload) === null || _a === void 0 ? void 0 : _a.bundle) === null || _b === void 0 ? void 0 : _b.forEach((batch) => {
30049
+ this.payload.bundle.forEach((batch) => {
30100
30050
  validateParams(batch, [
30101
30051
  { name: 'path', required: true },
30102
30052
  { name: 'network', type: 'string', required: true },
@@ -30136,24 +30086,6 @@ class AllNetworkGetAddressBase extends BaseMethod {
30136
30086
  try {
30137
30087
  method.init();
30138
30088
  (_a = method.setDevice) === null || _a === void 0 ? void 0 : _a.call(method, this.device);
30139
- method.context = this.context;
30140
- const onSignalAbort = () => {
30141
- var _a;
30142
- console.log('=====>>>>> onSignalAbort');
30143
- (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort(hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]);
30144
- };
30145
- const _onDeviceButtonHandler = (...[device, request]) => {
30146
- if (request.code === 'ButtonRequest_PinEntry' ||
30147
- request.code === 'ButtonRequest_AttachPin') {
30148
- onSignalAbort();
30149
- }
30150
- else {
30151
- onDeviceButtonHandler(device, request);
30152
- }
30153
- };
30154
- this.device.on(DEVICE.BUTTON, _onDeviceButtonHandler);
30155
- this.device.on(DEVICE.PIN, onSignalAbort);
30156
- this.device.on(DEVICE.PASSPHRASE, onSignalAbort);
30157
30089
  preCheckDeviceSupport(this.device, method);
30158
30090
  const response = yield method.run();
30159
30091
  if (!Array.isArray(response) || response.length === 0) {
@@ -30180,19 +30112,45 @@ class AllNetworkGetAddressBase extends BaseMethod {
30180
30112
  });
30181
30113
  }
30182
30114
  run() {
30115
+ var _a, _b;
30183
30116
  return __awaiter(this, void 0, void 0, function* () {
30184
- const features = yield this.device.unlockDevice();
30185
- if (features.passphrase_protection) {
30186
- yield this.device.checkPassphraseStateSafety();
30187
- }
30188
- this.postMessage(createUiMessage(UI_REQUEST.CLOSE_UI_PIN_WINDOW));
30189
- this.abortController = new AbortController();
30190
- return this.getAllNetworkAddress().catch(e => {
30191
- if (e instanceof hdShared.HardwareError && e.errorCode === hdShared.HardwareErrorCode.RepeatUnlocking) {
30192
- throw hdShared.ERRORS.TypedError(hdShared.HardwareErrorCode.RepeatUnlocking, e.message);
30117
+ const responses = [];
30118
+ const resultMap = {};
30119
+ const { bundle } = this.payload;
30120
+ const methodGroups = bundle
30121
+ .map((param, index) => this.generateMethodName({
30122
+ network: param.network,
30123
+ payload: param,
30124
+ originalIndex: index,
30125
+ }))
30126
+ .reduce((acc, cur) => {
30127
+ if (!acc[cur.methodName]) {
30128
+ acc[cur.methodName] = [];
30193
30129
  }
30194
- throw e;
30195
- });
30130
+ acc[cur.methodName].push(cur);
30131
+ return acc;
30132
+ }, {});
30133
+ let i = 0;
30134
+ for (const [methodName, params] of Object.entries(methodGroups)) {
30135
+ const methodParams = {
30136
+ bundle: params.map(param => (Object.assign({}, param.params))),
30137
+ };
30138
+ const response = yield this.callMethod(methodName, methodParams);
30139
+ for (let i = 0; i < params.length; i++) {
30140
+ const { _originRequestParams, _originalIndex } = params[i];
30141
+ const responseKey = `${_originalIndex}`;
30142
+ resultMap[responseKey] = Object.assign(Object.assign({}, _originRequestParams), response[i]);
30143
+ }
30144
+ if (((_b = (_a = this.payload) === null || _a === void 0 ? void 0 : _a.bundle) === null || _b === void 0 ? void 0 : _b.length) > 1) {
30145
+ const progress = Math.round(((i + 1) / this.payload.bundle.length) * 100);
30146
+ this.postMessage(createUiMessage(UI_REQUEST.DEVICE_PROGRESS, { progress }));
30147
+ }
30148
+ i++;
30149
+ }
30150
+ for (let i = 0; i < bundle.length; i++) {
30151
+ responses.push(resultMap[i]);
30152
+ }
30153
+ return Promise.resolve(responses);
30196
30154
  });
30197
30155
  }
30198
30156
  }
@@ -30213,7 +30171,10 @@ function handleSkippableHardwareError(e, device, method) {
30213
30171
  let error;
30214
30172
  if (e instanceof hdShared.HardwareError && e.errorCode !== hdShared.HardwareErrorCode.RuntimeError) {
30215
30173
  const { errorCode } = e;
30216
- if (errorCode === hdShared.HardwareErrorCode.CallMethodNeedUpgradeFirmware) {
30174
+ if (errorCode === hdShared.HardwareErrorCode.CallMethodInvalidParameter) {
30175
+ error = e;
30176
+ }
30177
+ else if (errorCode === hdShared.HardwareErrorCode.CallMethodNeedUpgradeFirmware) {
30217
30178
  error = e;
30218
30179
  }
30219
30180
  else if (errorCode === hdShared.HardwareErrorCode.DeviceNotSupportMethod) {
@@ -30239,164 +30200,6 @@ function handleSkippableHardwareError(e, device, method) {
30239
30200
  return error;
30240
30201
  }
30241
30202
 
30242
- class AllNetworkGetAddress extends AllNetworkGetAddressBase {
30243
- getAllNetworkAddress() {
30244
- var _a, _b, _c, _d;
30245
- return __awaiter(this, void 0, void 0, function* () {
30246
- const responses = [];
30247
- const resultMap = {};
30248
- const { bundle } = this.payload;
30249
- const methodGroups = bundle
30250
- .map((param, index) => this.generateMethodName({
30251
- network: param.network,
30252
- payload: param,
30253
- originalIndex: index,
30254
- }))
30255
- .reduce((acc, cur) => {
30256
- if (!acc[cur.methodName]) {
30257
- acc[cur.methodName] = [];
30258
- }
30259
- acc[cur.methodName].push(cur);
30260
- return acc;
30261
- }, {});
30262
- let i = 0;
30263
- for (const [methodName, params] of Object.entries(methodGroups)) {
30264
- const methodParams = {
30265
- bundle: params.map(param => (Object.assign({}, param.params))),
30266
- };
30267
- if ((_a = this.abortController) === null || _a === void 0 ? void 0 : _a.signal.aborted) {
30268
- throw new Error(hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]);
30269
- }
30270
- const response = yield this.callMethod(methodName, methodParams);
30271
- if ((_b = this.abortController) === null || _b === void 0 ? void 0 : _b.signal.aborted) {
30272
- throw new Error(hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]);
30273
- }
30274
- for (let i = 0; i < params.length; i++) {
30275
- const { _originRequestParams, _originalIndex } = params[i];
30276
- const responseKey = `${_originalIndex}`;
30277
- resultMap[responseKey] = Object.assign(Object.assign({}, _originRequestParams), response[i]);
30278
- }
30279
- if (((_d = (_c = this.payload) === null || _c === void 0 ? void 0 : _c.bundle) === null || _d === void 0 ? void 0 : _d.length) > 1) {
30280
- const progress = Math.round(((i + 1) / this.payload.bundle.length) * 100);
30281
- this.postMessage(createUiMessage(UI_REQUEST.DEVICE_PROGRESS, { progress }));
30282
- }
30283
- i++;
30284
- }
30285
- for (let i = 0; i < bundle.length; i++) {
30286
- responses.push(resultMap[i]);
30287
- }
30288
- this.abortController = null;
30289
- return Promise.resolve(responses);
30290
- });
30291
- }
30292
- }
30293
-
30294
- class AllNetworkGetAddressByLoop extends AllNetworkGetAddressBase {
30295
- getAllNetworkAddress() {
30296
- return __awaiter(this, void 0, void 0, function* () {
30297
- const { callbackId, callbackIdFinish } = this.payload;
30298
- if (!callbackId) {
30299
- throw new Error('callbackId is required');
30300
- }
30301
- if (!callbackIdFinish) {
30302
- throw new Error('callbackIdFinish is required');
30303
- }
30304
- const bundle = this.payload.bundle || [this.payload];
30305
- const callbackPromise = this.processCallbacksInBackground(bundle, callbackId, callbackIdFinish);
30306
- this.device.pendingCallbackPromise = hdShared.createDeferred(callbackPromise);
30307
- if (this.context && this.payload.connectId) {
30308
- this.context.registerCallbackTask(this.payload.connectId, this.device.pendingCallbackPromise);
30309
- }
30310
- return Promise.resolve([]);
30311
- });
30312
- }
30313
- processCallbacksInBackground(bundle, callbackId, callbackIdFinish) {
30314
- var _a, _b, _c;
30315
- return __awaiter(this, void 0, void 0, function* () {
30316
- try {
30317
- const allResults = [];
30318
- for (let i = 0; i < bundle.length; i++) {
30319
- const item = bundle[i];
30320
- if ((_a = this.abortController) === null || _a === void 0 ? void 0 : _a.signal.aborted) {
30321
- throw new Error(hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]);
30322
- }
30323
- const methodParams = this.generateMethodName({
30324
- network: item.network,
30325
- payload: item,
30326
- originalIndex: i,
30327
- });
30328
- const singleMethodParams = {
30329
- bundle: [methodParams.params],
30330
- };
30331
- const response = yield this.callMethod(methodParams.methodName, singleMethodParams);
30332
- if ((_b = this.abortController) === null || _b === void 0 ? void 0 : _b.signal.aborted) {
30333
- throw new Error(hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]);
30334
- }
30335
- const singleResult = Object.assign(Object.assign({}, item), response[0]);
30336
- allResults.push(singleResult);
30337
- this.sendItemCallback(callbackId, singleResult, i);
30338
- }
30339
- this.sendFinishCallback({
30340
- callbackId: callbackIdFinish,
30341
- data: allResults,
30342
- });
30343
- }
30344
- catch (error) {
30345
- let errorCode = error.errorCode || error.code;
30346
- let errorMessage = error.message;
30347
- if (error instanceof hdShared.HardwareError) {
30348
- errorCode = error.errorCode;
30349
- errorMessage = error.message;
30350
- }
30351
- else if (error.message === hdShared.HardwareErrorCodeMessage[hdShared.HardwareErrorCode.RepeatUnlocking]) {
30352
- errorCode = hdShared.HardwareErrorCode.RepeatUnlocking;
30353
- errorMessage = error.message;
30354
- }
30355
- else {
30356
- const hardwareError = hdShared.ERRORS.TypedError(hdShared.HardwareErrorCode.RuntimeError, error.message);
30357
- errorCode = hardwareError.errorCode;
30358
- errorMessage = hardwareError.message;
30359
- }
30360
- this.sendFinishCallback({
30361
- callbackId,
30362
- error: {
30363
- success: false,
30364
- payload: {
30365
- error: errorMessage,
30366
- code: errorCode,
30367
- },
30368
- },
30369
- });
30370
- }
30371
- finally {
30372
- (_c = this.context) === null || _c === void 0 ? void 0 : _c.cancelCallbackTasks(this.payload.connectId);
30373
- this.abortController = null;
30374
- }
30375
- });
30376
- }
30377
- sendFinishCallback({ callbackId, data, error, }) {
30378
- this.postMessage({
30379
- event: IFRAME.CALLBACK,
30380
- type: IFRAME.CALLBACK,
30381
- payload: {
30382
- callbackId,
30383
- data,
30384
- error,
30385
- },
30386
- });
30387
- }
30388
- sendItemCallback(callbackId, data, itemIndex) {
30389
- this.postMessage({
30390
- event: IFRAME.CALLBACK,
30391
- type: IFRAME.CALLBACK,
30392
- payload: {
30393
- callbackId,
30394
- data: Object.assign(Object.assign({}, data), { index: itemIndex }),
30395
- },
30396
- });
30397
- }
30398
- }
30399
-
30400
30203
  var bitcoin = [
30401
30204
  {
30402
30205
  name: "Bitcoin",
@@ -30971,15 +30774,6 @@ class BTCGetPublicKey extends BaseMethod {
30971
30774
  }
30972
30775
  }
30973
30776
  catch (error) {
30974
- if (error instanceof hdShared.HardwareError) {
30975
- const { errorCode } = error;
30976
- if (errorCode === hdShared.HardwareErrorCode.PinCancelled ||
30977
- errorCode === hdShared.HardwareErrorCode.ActionCancelled ||
30978
- errorCode === hdShared.HardwareErrorCode.ResponseUnexpectTypeError ||
30979
- errorCode === hdShared.HardwareErrorCode.PinInvalid) {
30980
- throw error;
30981
- }
30982
- }
30983
30777
  responses = [];
30984
30778
  for (let i = 0; i < this.params.length; i++) {
30985
30779
  const param = this.params[i];
@@ -31819,7 +31613,6 @@ class EVMGetPublicKey extends BaseMethod {
31819
31613
  constructor() {
31820
31614
  super(...arguments);
31821
31615
  this.hasBundle = false;
31822
- this.confirmShowOnOneKey = false;
31823
31616
  this.useBatch = false;
31824
31617
  }
31825
31618
  init() {
@@ -31827,8 +31620,7 @@ class EVMGetPublicKey extends BaseMethod {
31827
31620
  this.checkDeviceId = true;
31828
31621
  this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
31829
31622
  this.hasBundle = !!((_a = this.payload) === null || _a === void 0 ? void 0 : _a.bundle);
31830
- this.confirmShowOnOneKey = (_c = (_b = this.payload) === null || _b === void 0 ? void 0 : _b.bundle) === null || _c === void 0 ? void 0 : _c.some((item) => !!item.showOnOneKey);
31831
- this.useBatch = !this.confirmShowOnOneKey && this.hasBundle && this.payload.useBatch;
31623
+ this.useBatch = (_c = (_b = this.payload) === null || _b === void 0 ? void 0 : _b.bundle) === null || _c === void 0 ? void 0 : _c.every((item) => item.showOnOneKey !== true);
31832
31624
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
31833
31625
  validateParams(payload, [{ name: 'bundle', type: 'array' }]);
31834
31626
  this.params = [];
@@ -31864,7 +31656,7 @@ class EVMGetPublicKey extends BaseMethod {
31864
31656
  var _a;
31865
31657
  return __awaiter(this, void 0, void 0, function* () {
31866
31658
  const responses = [];
31867
- if (this.useBatch && supportBatchPublicKey((_a = this.device) === null || _a === void 0 ? void 0 : _a.features)) {
31659
+ if (this.useBatch && this.hasBundle && supportBatchPublicKey((_a = this.device) === null || _a === void 0 ? void 0 : _a.features)) {
31868
31660
  try {
31869
31661
  const res = yield batchGetPublickeys(this.device, this.params, 'secp256k1', 60, {
31870
31662
  includeNode: false,
@@ -38321,7 +38113,6 @@ var ApiMethods = /*#__PURE__*/Object.freeze({
38321
38113
  promptWebDeviceAccess: PromptWebDeviceAccess,
38322
38114
  cipherKeyValue: CipherKeyValue,
38323
38115
  allNetworkGetAddress: AllNetworkGetAddress,
38324
- allNetworkGetAddressByLoop: AllNetworkGetAddressByLoop,
38325
38116
  btcGetAddress: BTCGetAddress,
38326
38117
  btcGetPublicKey: BTCGetPublicKey,
38327
38118
  btcSignMessage: BTCSignMessage,
@@ -38534,7 +38325,6 @@ const Log$1 = getLogger(exports.LoggerNames.Core);
38534
38325
  class RequestQueue {
38535
38326
  constructor() {
38536
38327
  this.requestQueue = new Map();
38537
- this.pendingCallbackTasks = new Map();
38538
38328
  this.generateRequestId = (method) => {
38539
38329
  if (method && method.responseID != null) {
38540
38330
  return method.responseID;
@@ -38611,28 +38401,6 @@ class RequestQueue {
38611
38401
  releaseTask(requestId) {
38612
38402
  this.requestQueue.delete(requestId);
38613
38403
  }
38614
- registerPendingCallbackTask(connectId, callbackPromise) {
38615
- this.pendingCallbackTasks.set(connectId, callbackPromise);
38616
- callbackPromise.promise.finally(() => {
38617
- Log$1.debug(`Callback task completed for connectId: ${connectId}`);
38618
- this.pendingCallbackTasks.delete(connectId);
38619
- });
38620
- }
38621
- waitForPendingCallbackTasks(connectId) {
38622
- return __awaiter(this, void 0, void 0, function* () {
38623
- const pendingTask = this.pendingCallbackTasks.get(connectId);
38624
- if (pendingTask) {
38625
- Log$1.debug(`Waiting for pending callback task to complete for connectId: ${connectId}`);
38626
- yield pendingTask.promise;
38627
- }
38628
- });
38629
- }
38630
- cancelCallbackTasks(connectId) {
38631
- const pendingTask = this.pendingCallbackTasks.get(connectId);
38632
- if (pendingTask) {
38633
- pendingTask.resolve();
38634
- }
38635
- }
38636
38404
  }
38637
38405
 
38638
38406
  const getMutex = () => {
@@ -38755,9 +38523,6 @@ const onCallDevice = (context, message, method) => __awaiter(void 0, void 0, voi
38755
38523
  Log.debug('passphrase state change, clear device cache');
38756
38524
  DevicePool.clearDeviceCache(method.payload.connectId);
38757
38525
  }
38758
- if (method.connectId) {
38759
- yield context.waitForCallbackTasks(method.connectId);
38760
- }
38761
38526
  yield waitForPendingPromise(getPrePendingCallPromise, setPrePendingCallPromise);
38762
38527
  const task = requestQueue.createTask(method);
38763
38528
  let device;
@@ -38781,7 +38546,6 @@ const onCallDevice = (context, message, method) => __awaiter(void 0, void 0, voi
38781
38546
  }
38782
38547
  Log.debug('Call API - setDevice: ', device.mainId);
38783
38548
  (_b = method.setDevice) === null || _b === void 0 ? void 0 : _b.call(method, device);
38784
- method.context = context;
38785
38549
  device.on(DEVICE.PIN, onDevicePinHandler);
38786
38550
  device.on(DEVICE.BUTTON, onDeviceButtonHandler);
38787
38551
  device.on(DEVICE.PASSPHRASE, message.payload.useEmptyPassphrase ? onEmptyPassphraseHandler : onDevicePassphraseHandler);
@@ -38789,9 +38553,6 @@ const onCallDevice = (context, message, method) => __awaiter(void 0, void 0, voi
38789
38553
  device.on(DEVICE.FEATURES, onDeviceFeaturesHandler);
38790
38554
  device.on(DEVICE.SELECT_DEVICE_IN_BOOTLOADER_FOR_WEB_DEVICE, onSelectDeviceInBootloaderForWebDeviceHandler);
38791
38555
  try {
38792
- if (method.connectId) {
38793
- yield context.waitForCallbackTasks(method.connectId);
38794
- }
38795
38556
  yield waitForPendingPromise(getPrePendingCallPromise, setPrePendingCallPromise);
38796
38557
  const inner = () => __awaiter(void 0, void 0, void 0, function* () {
38797
38558
  var _c, _d, _e, _f, _g;
@@ -39129,7 +38890,6 @@ const cancel = (context, connectId) => {
39129
38890
  const { requestQueue, setPrePendingCallPromise } = context;
39130
38891
  if (connectId) {
39131
38892
  try {
39132
- requestQueue.cancelCallbackTasks(connectId);
39133
38893
  const requestIds = requestQueue.getRequestTasksId();
39134
38894
  Log.debug(`Cancel Api connect requestQueues: length:${requestIds.length} requestIds:${requestIds.join(',')}`);
39135
38895
  const canceledDevices = [];
@@ -39310,11 +39070,6 @@ class Core extends events.exports {
39310
39070
  setPrePendingCallPromise: (promise) => {
39311
39071
  this.prePendingCallPromise = promise;
39312
39072
  },
39313
- registerCallbackTask: (connectId, callbackPromise) => {
39314
- this.requestQueue.registerPendingCallbackTask(connectId, callbackPromise);
39315
- },
39316
- waitForCallbackTasks: (connectId) => this.requestQueue.waitForPendingCallbackTasks(connectId),
39317
- cancelCallbackTasks: (connectId) => this.requestQueue.cancelCallbackTasks(connectId),
39318
39073
  };
39319
39074
  }
39320
39075
  handleMessage(message) {
@@ -39356,11 +39111,6 @@ class Core extends events.exports {
39356
39111
  cancel(this.getCoreContext(), message.payload.connectId);
39357
39112
  break;
39358
39113
  }
39359
- case IFRAME.CALLBACK: {
39360
- Log.log('callback message: ', message);
39361
- postMessage(message);
39362
- break;
39363
- }
39364
39114
  }
39365
39115
  return Promise.resolve(message);
39366
39116
  });
@@ -39459,7 +39209,6 @@ exports.UI_REQUEST = UI_REQUEST;
39459
39209
  exports.UI_RESPONSE = UI_RESPONSE;
39460
39210
  exports.checkNeedUpdateBootForClassicAndMini = checkNeedUpdateBootForClassicAndMini;
39461
39211
  exports.checkNeedUpdateBootForTouch = checkNeedUpdateBootForTouch;
39462
- exports.cleanupCallback = cleanupCallback;
39463
39212
  exports.corsValidator = corsValidator;
39464
39213
  exports.createDeviceMessage = createDeviceMessage;
39465
39214
  exports.createErrorMessage = createErrorMessage;
@@ -39471,7 +39220,6 @@ exports.createUiMessage = createUiMessage;
39471
39220
  exports.createUiResponse = createUiResponse;
39472
39221
  exports["default"] = HardwareSdk;
39473
39222
  exports.enableLog = enableLog;
39474
- exports.executeCallback = executeCallback;
39475
39223
  exports.getDeviceBLEFirmwareVersion = getDeviceBLEFirmwareVersion;
39476
39224
  exports.getDeviceBleName = getDeviceBleName;
39477
39225
  exports.getDeviceBoardloaderVersion = getDeviceBoardloaderVersion;