@onekeyfe/hd-core 1.1.2 → 1.1.3-alpha.1

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 +2 -0
  2. package/dist/api/BaseMethod.d.ts.map +1 -1
  3. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts +4 -28
  4. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts.map +1 -1
  5. package/dist/api/allnetwork/AllNetworkGetAddressBase.d.ts +47 -0
  6. package/dist/api/allnetwork/AllNetworkGetAddressBase.d.ts.map +1 -0
  7. package/dist/api/allnetwork/AllNetworkGetAddressByLoop.d.ts +8 -0
  8. package/dist/api/allnetwork/AllNetworkGetAddressByLoop.d.ts.map +1 -0
  9. package/dist/api/btc/BTCGetPublicKey.d.ts.map +1 -1
  10. package/dist/api/cosmos/CosmosGetPublicKey.d.ts +1 -1
  11. package/dist/api/cosmos/CosmosGetPublicKey.d.ts.map +1 -1
  12. package/dist/api/device/DeviceUnlock.d.ts +0 -2
  13. package/dist/api/device/DeviceUnlock.d.ts.map +1 -1
  14. package/dist/api/evm/EVMGetPublicKey.d.ts +1 -0
  15. package/dist/api/evm/EVMGetPublicKey.d.ts.map +1 -1
  16. package/dist/api/index.d.ts +1 -0
  17. package/dist/api/index.d.ts.map +1 -1
  18. package/dist/core/RequestQueue.d.ts +4 -0
  19. package/dist/core/RequestQueue.d.ts.map +1 -1
  20. package/dist/core/index.d.ts +3 -2
  21. package/dist/core/index.d.ts.map +1 -1
  22. package/dist/device/Device.d.ts +4 -1
  23. package/dist/device/Device.d.ts.map +1 -1
  24. package/dist/device/DeviceCommands.d.ts +4 -4
  25. package/dist/events/call.d.ts +9 -0
  26. package/dist/events/call.d.ts.map +1 -1
  27. package/dist/events/core.d.ts +2 -2
  28. package/dist/events/core.d.ts.map +1 -1
  29. package/dist/events/iframe.d.ts +11 -1
  30. package/dist/events/iframe.d.ts.map +1 -1
  31. package/dist/index.d.ts +40 -12
  32. package/dist/index.d.ts.map +1 -1
  33. package/dist/index.js +393 -140
  34. package/dist/inject.d.ts +3 -0
  35. package/dist/inject.d.ts.map +1 -1
  36. package/dist/types/api/allNetworkGetAddress.d.ts +9 -2
  37. package/dist/types/api/allNetworkGetAddress.d.ts.map +1 -1
  38. package/dist/types/api/evmGetPublicKey.d.ts +1 -0
  39. package/dist/types/api/evmGetPublicKey.d.ts.map +1 -1
  40. package/dist/types/api/index.d.ts +2 -1
  41. package/dist/types/api/index.d.ts.map +1 -1
  42. package/package.json +4 -4
  43. package/src/api/BaseMethod.ts +3 -0
  44. package/src/api/allnetwork/AllNetworkGetAddress.ts +14 -407
  45. package/src/api/allnetwork/AllNetworkGetAddressBase.ts +473 -0
  46. package/src/api/allnetwork/AllNetworkGetAddressByLoop.ts +151 -0
  47. package/src/api/btc/BTCGetPublicKey.ts +13 -0
  48. package/src/api/cosmos/CosmosGetPublicKey.ts +1 -1
  49. package/src/api/device/DeviceUnlock.ts +1 -48
  50. package/src/api/evm/EVMGetPublicKey.ts +9 -3
  51. package/src/api/index.ts +1 -0
  52. package/src/core/RequestQueue.ts +26 -0
  53. package/src/core/index.ts +29 -3
  54. package/src/device/Device.ts +64 -0
  55. package/src/events/call.ts +10 -0
  56. package/src/events/core.ts +7 -1
  57. package/src/events/iframe.ts +12 -1
  58. package/src/index.ts +2 -1
  59. package/src/inject.ts +47 -0
  60. package/src/types/api/allNetworkGetAddress.ts +16 -2
  61. package/src/types/api/evmGetPublicKey.ts +1 -0
  62. package/src/types/api/index.ts +2 -1
@@ -0,0 +1,473 @@
1
+ import semver from 'semver';
2
+ import {
3
+ ERRORS,
4
+ HardwareError,
5
+ HardwareErrorCode,
6
+ HardwareErrorCodeMessage,
7
+ } from '@onekeyfe/hd-shared';
8
+
9
+ import { serializedPath } from '../helpers/pathUtils';
10
+ import { BaseMethod } from '../BaseMethod';
11
+ import { validateParams } from '../helpers/paramsValidator';
12
+ import { CoreApi } from '../../types';
13
+ import type {
14
+ AllNetworkAddressParams,
15
+ INetwork,
16
+ AllNetworkAddress,
17
+ CommonResponseParams,
18
+ } from '../../types/api/allNetworkGetAddress';
19
+ import { PROTO } from '../../constants';
20
+
21
+ import { findMethod } from '../utils';
22
+ import { createUiMessage, DEVICE, IFRAME } from '../../events';
23
+ import { getDeviceFirmwareVersion, getMethodVersionRange } from '../../utils';
24
+ import { Device, DeviceEvents } from '../../device/Device';
25
+ import { UI_REQUEST } from '../../constants/ui-request';
26
+ import { onDeviceButtonHandler } from '../../core';
27
+
28
+ const Mainnet = 'mainnet';
29
+
30
+ export type NetworkConfig = {
31
+ methodName: keyof CoreApi;
32
+ getParams?: (baseParams: AllNetworkAddressParams, chainName?: string, methodName?: string) => any;
33
+ dependOnMethodName?: (keyof CoreApi)[];
34
+ };
35
+
36
+ export type INetworkReal = Exclude<INetwork, 'tbtc' | 'bch' | 'doge' | 'ltc' | 'neurai'>;
37
+
38
+ export type NetworkConfigMap = {
39
+ [K in INetworkReal]: NetworkConfig;
40
+ };
41
+
42
+ export const networkAliases: {
43
+ [key: string]: { name: INetworkReal; coin: string };
44
+ } = {
45
+ tbtc: { name: 'btc', coin: 'Testnet' },
46
+ bch: { name: 'btc', coin: 'Bcash' },
47
+ doge: { name: 'btc', coin: 'Dogecoin' },
48
+ ltc: { name: 'btc', coin: 'Litecoin' },
49
+ neurai: { name: 'btc', coin: 'Neurai' },
50
+ };
51
+
52
+ const networkConfigMap: NetworkConfigMap = {
53
+ btc: {
54
+ methodName: 'btcGetPublicKey',
55
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => ({
56
+ coin: chainName,
57
+ ...baseParams,
58
+ }),
59
+ },
60
+ evm: {
61
+ methodName: 'evmGetAddress',
62
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
63
+ const { path, showOnOneKey } = baseParams;
64
+ let chainId;
65
+ if (chainName) {
66
+ chainId = parseInt(chainName);
67
+ }
68
+ return {
69
+ chainId,
70
+ path,
71
+ showOnOneKey,
72
+ };
73
+ },
74
+ },
75
+ sol: {
76
+ methodName: 'solGetAddress',
77
+ },
78
+ algo: {
79
+ methodName: 'algoGetAddress',
80
+ },
81
+ near: {
82
+ methodName: 'nearGetAddress',
83
+ },
84
+ stc: {
85
+ methodName: 'starcoinGetAddress',
86
+ },
87
+ cfx: {
88
+ methodName: 'confluxGetAddress',
89
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
90
+ const { path, showOnOneKey } = baseParams;
91
+ return {
92
+ chainId: parseInt(chainName ?? '1029'),
93
+ path,
94
+ showOnOneKey,
95
+ };
96
+ },
97
+ },
98
+ tron: {
99
+ methodName: 'tronGetAddress',
100
+ },
101
+ aptos: {
102
+ methodName: 'aptosGetAddress',
103
+ },
104
+ xrp: {
105
+ methodName: 'xrpGetAddress',
106
+ },
107
+ cosmos: {
108
+ methodName: 'cosmosGetPublicKey',
109
+ getParams: (baseParams: AllNetworkAddressParams) => {
110
+ const { path, prefix, showOnOneKey } = baseParams;
111
+ return {
112
+ hrp: prefix,
113
+ path,
114
+ showOnOneKey,
115
+ };
116
+ },
117
+ },
118
+ ada: {
119
+ methodName: 'cardanoGetAddress',
120
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
121
+ const { path, showOnOneKey } = baseParams;
122
+
123
+ const addressPath =
124
+ typeof path === 'string' ? `${path}/0/0` : serializedPath([...path, 0, 0]);
125
+ const stakingPath =
126
+ typeof path === 'string' ? `${path}/2/0` : serializedPath([...path, 2, 0]);
127
+
128
+ let networkId = 1;
129
+ if (chainName) {
130
+ networkId = chainName === Mainnet ? 1 : 0;
131
+ }
132
+
133
+ return {
134
+ addressParameters: {
135
+ addressType: PROTO.CardanoAddressType.BASE,
136
+ path: addressPath,
137
+ stakingPath,
138
+ },
139
+ protocolMagic: 764824073,
140
+ networkId,
141
+ derivationType: PROTO.CardanoDerivationType.ICARUS,
142
+ showOnOneKey,
143
+ address: '',
144
+ isCheck: false,
145
+ };
146
+ },
147
+ },
148
+ sui: {
149
+ methodName: 'suiGetAddress',
150
+ },
151
+ benfen: {
152
+ methodName: 'benfenGetAddress',
153
+ },
154
+ fil: {
155
+ methodName: 'filecoinGetAddress',
156
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
157
+ const { path, showOnOneKey } = baseParams;
158
+ let isTestnet = false;
159
+ if (chainName) {
160
+ isTestnet = chainName !== Mainnet;
161
+ }
162
+ return {
163
+ isTestnet,
164
+ path,
165
+ showOnOneKey,
166
+ };
167
+ },
168
+ },
169
+ dot: {
170
+ methodName: 'polkadotGetAddress',
171
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
172
+ const { path, prefix, showOnOneKey } = baseParams;
173
+ if (!prefix || !chainName) {
174
+ throw new Error('Invalid params');
175
+ }
176
+ return {
177
+ prefix: parseInt(prefix),
178
+ network: chainName,
179
+ path,
180
+ showOnOneKey,
181
+ };
182
+ },
183
+ },
184
+ kaspa: {
185
+ methodName: 'kaspaGetAddress',
186
+ getParams: (baseParams: AllNetworkAddressParams) => {
187
+ const { path, prefix, showOnOneKey, useTweak } = baseParams;
188
+ return {
189
+ scheme: 'schnorr',
190
+ prefix,
191
+ path,
192
+ showOnOneKey,
193
+ useTweak,
194
+ };
195
+ },
196
+ },
197
+ nexa: {
198
+ methodName: 'nexaGetAddress',
199
+ getParams: (baseParams: AllNetworkAddressParams) => {
200
+ const { path, prefix, showOnOneKey } = baseParams;
201
+ return {
202
+ scheme: 'Schnorr',
203
+ prefix,
204
+ path,
205
+ showOnOneKey,
206
+ };
207
+ },
208
+ },
209
+ dynex: {
210
+ methodName: 'dnxGetAddress',
211
+ },
212
+ nervos: {
213
+ methodName: 'nervosGetAddress',
214
+ getParams: (baseParams: AllNetworkAddressParams, chainName?: string) => {
215
+ const { path, showOnOneKey } = baseParams;
216
+ return {
217
+ network: chainName,
218
+ path,
219
+ showOnOneKey,
220
+ };
221
+ },
222
+ },
223
+ scdo: {
224
+ methodName: 'scdoGetAddress',
225
+ },
226
+ ton: {
227
+ methodName: 'tonGetAddress',
228
+ },
229
+ alph: {
230
+ methodName: 'alephiumGetAddress',
231
+ },
232
+ nostr: {
233
+ methodName: 'nostrGetPublicKey',
234
+ },
235
+ neo: {
236
+ methodName: 'neoGetAddress',
237
+ },
238
+ };
239
+
240
+ type MethodParams = {
241
+ methodName: keyof CoreApi;
242
+ params: Parameters<CoreApi[keyof CoreApi]>[0];
243
+ _originRequestParams: AllNetworkAddressParams;
244
+ _originalIndex: number;
245
+ };
246
+
247
+ export default abstract class AllNetworkGetAddressBase extends BaseMethod<
248
+ {
249
+ address_n: number[];
250
+ show_display: boolean;
251
+ network: string;
252
+ chain_name?: string;
253
+ }[]
254
+ > {
255
+ abortController: AbortController | null = null;
256
+
257
+ init() {
258
+ this.checkDeviceId = true;
259
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
260
+
261
+ // check payload
262
+ validateParams(this.payload, [{ name: 'bundle', type: 'array' }]);
263
+
264
+ // check bundle
265
+ this.payload?.bundle?.forEach((batch: AllNetworkAddressParams) => {
266
+ validateParams(batch, [
267
+ { name: 'path', required: true },
268
+ { name: 'network', type: 'string', required: true },
269
+ { name: 'chainName', type: 'string' },
270
+ { name: 'showOnOneKey', type: 'boolean' },
271
+ ]);
272
+ });
273
+ }
274
+
275
+ generateMethodName({
276
+ network,
277
+ payload,
278
+ originalIndex,
279
+ }: {
280
+ network: INetwork;
281
+ payload: AllNetworkAddressParams;
282
+ originalIndex: number;
283
+ }): MethodParams {
284
+ const { name: networkName, coin } = networkAliases[network] || {
285
+ name: network,
286
+ coin: payload?.chainName,
287
+ };
288
+ const config = networkConfigMap[networkName];
289
+ if (!config) {
290
+ throw new Error(`Unsupported network: ${network}`);
291
+ }
292
+
293
+ return {
294
+ methodName: config.methodName,
295
+ params: {
296
+ ...(config?.getParams?.(payload, coin, config.methodName) ?? payload),
297
+ originPayload: payload,
298
+ },
299
+ _originRequestParams: payload,
300
+ _originalIndex: originalIndex,
301
+ };
302
+ }
303
+
304
+ async callMethod(
305
+ methodName: keyof CoreApi,
306
+ params: any & {
307
+ bundle: (any & { _originRequestParams: CommonResponseParams })[];
308
+ }
309
+ ) {
310
+ const method: BaseMethod = findMethod({
311
+ event: IFRAME.CALL,
312
+ type: IFRAME.CALL,
313
+ payload: {
314
+ connectId: this.payload.connectId,
315
+ deviceId: this.payload.deviceId,
316
+ method: methodName,
317
+ ...params,
318
+ },
319
+ });
320
+
321
+ method.connector = this.connector;
322
+ method.postMessage = this.postMessage;
323
+
324
+ let result: AllNetworkAddress[];
325
+ try {
326
+ method.init();
327
+ method.setDevice?.(this.device);
328
+ method.context = this.context;
329
+
330
+ const onSignalAbort = () => {
331
+ console.log('=====>>>>> onSignalAbort');
332
+ this.abortController?.abort(HardwareErrorCodeMessage[HardwareErrorCode.RepeatUnlocking]);
333
+ };
334
+
335
+ const _onDeviceButtonHandler = (...[device, request]: [...DeviceEvents['button']]) => {
336
+ if (
337
+ request.code === 'ButtonRequest_PinEntry' ||
338
+ request.code === 'ButtonRequest_AttachPin'
339
+ ) {
340
+ onSignalAbort();
341
+ } else {
342
+ onDeviceButtonHandler(device, request);
343
+ }
344
+ };
345
+
346
+ // pro pin event
347
+ this.device.on(DEVICE.BUTTON, _onDeviceButtonHandler);
348
+ // classic pin event
349
+ this.device.on(DEVICE.PIN, onSignalAbort);
350
+ this.device.on(DEVICE.PASSPHRASE, onSignalAbort);
351
+
352
+ preCheckDeviceSupport(this.device, method);
353
+
354
+ const response = await method.run();
355
+
356
+ if (!Array.isArray(response) || response.length === 0) {
357
+ throw new Error('No response');
358
+ }
359
+
360
+ result = response.map((item, index) => ({
361
+ ...params.bundle[index]._originRequestParams,
362
+ success: true,
363
+ payload: item,
364
+ }));
365
+ } catch (e: any) {
366
+ const error = handleSkippableHardwareError(e, this.device, method);
367
+
368
+ if (error) {
369
+ result = params.bundle.map((item: { _originRequestParams: any }) => ({
370
+ ...item._originRequestParams,
371
+ success: false,
372
+ payload: {
373
+ error: error.message,
374
+ code: error.errorCode,
375
+ params: error.params,
376
+ connectId: method.connectId,
377
+ deviceId: method.deviceId,
378
+ },
379
+ }));
380
+ } else {
381
+ throw e;
382
+ }
383
+ }
384
+
385
+ return result;
386
+ }
387
+
388
+ abstract getAllNetworkAddress(): Promise<AllNetworkAddress[]>;
389
+
390
+ async run() {
391
+ if (!this.device.features?.unlocked) {
392
+ // unlock device
393
+ const features = await this.device.unlockDevice();
394
+ if (features.passphrase_protection) {
395
+ // check passphrase state
396
+ await this.device.checkPassphraseStateSafety();
397
+ }
398
+ this.postMessage(createUiMessage(UI_REQUEST.CLOSE_UI_PIN_WINDOW));
399
+ }
400
+
401
+ this.abortController = new AbortController();
402
+
403
+ return this.getAllNetworkAddress().catch(e => {
404
+ if (e instanceof HardwareError && e.errorCode === HardwareErrorCode.RepeatUnlocking) {
405
+ throw ERRORS.TypedError(HardwareErrorCode.RepeatUnlocking, e.message);
406
+ }
407
+ throw e;
408
+ });
409
+ }
410
+ }
411
+
412
+ /**
413
+ * @experiment Check if the device supports the method
414
+ * @param device
415
+ * @param method BaseMethod
416
+ */
417
+ function preCheckDeviceSupport(device: Device, method: BaseMethod) {
418
+ const versionRange = getMethodVersionRange(
419
+ device.features,
420
+ type => method.getVersionRange()[type]
421
+ );
422
+ const currentVersion = getDeviceFirmwareVersion(device.features).join('.');
423
+
424
+ if (
425
+ versionRange &&
426
+ semver.valid(versionRange.min) &&
427
+ semver.lt(currentVersion, versionRange.min)
428
+ ) {
429
+ throw ERRORS.createNeedUpgradeFirmwareHardwareError(currentVersion, versionRange.min);
430
+ } else if (method.strictCheckDeviceSupport && !versionRange) {
431
+ throw ERRORS.TypedError(HardwareErrorCode.DeviceNotSupportMethod);
432
+ }
433
+ }
434
+
435
+ function handleSkippableHardwareError(
436
+ e: any,
437
+ device: Device,
438
+ method: BaseMethod
439
+ ): HardwareError | undefined {
440
+ let error: HardwareError | undefined;
441
+
442
+ if (e instanceof HardwareError && e.errorCode !== HardwareErrorCode.RuntimeError) {
443
+ const { errorCode } = e;
444
+ if (errorCode === HardwareErrorCode.CallMethodNeedUpgradeFirmware) {
445
+ error = e;
446
+ } else if (errorCode === HardwareErrorCode.DeviceNotSupportMethod) {
447
+ error = e;
448
+ }
449
+ } else if (e.message?.includes('Failure_UnexpectedMessage')) {
450
+ const versionRange = getMethodVersionRange(
451
+ device.features,
452
+ type => method.getVersionRange()[type]
453
+ );
454
+ const currentVersion = getDeviceFirmwareVersion(device.features).join('.');
455
+
456
+ if (
457
+ versionRange &&
458
+ semver.valid(versionRange.min) &&
459
+ semver.lt(currentVersion, versionRange.min)
460
+ ) {
461
+ error = ERRORS.createNeedUpgradeFirmwareHardwareError(currentVersion, versionRange.min);
462
+ } else {
463
+ error = ERRORS.TypedError(HardwareErrorCode.DeviceNotSupportMethod, e.message);
464
+ }
465
+ } else if (
466
+ e.message?.toLowerCase()?.includes('forbidden key path') ||
467
+ e.message?.toLowerCase()?.includes('invalid path')
468
+ ) {
469
+ error = ERRORS.TypedError(HardwareErrorCode.CallMethodInvalidParameter, e.message);
470
+ }
471
+
472
+ return error;
473
+ }
@@ -0,0 +1,151 @@
1
+ import {
2
+ createDeferred,
3
+ ERRORS,
4
+ HardwareError,
5
+ HardwareErrorCode,
6
+ HardwareErrorCodeMessage,
7
+ } from '@onekeyfe/hd-shared';
8
+ import type {
9
+ AllNetworkAddress,
10
+ AllNetworkGetAddressParamsByLoop,
11
+ } from '../../types/api/allNetworkGetAddress';
12
+
13
+ import { IFRAME } from '../../events';
14
+ import AllNetworkGetAddressBase from './AllNetworkGetAddressBase';
15
+ import { Unsuccessful } from '../../types';
16
+
17
+ export default class AllNetworkGetAddressByLoop extends AllNetworkGetAddressBase {
18
+ async getAllNetworkAddress() {
19
+ const { callbackId, callbackIdFinish } = this.payload as AllNetworkGetAddressParamsByLoop;
20
+ if (!callbackId) {
21
+ throw new Error('callbackId is required');
22
+ }
23
+ if (!callbackIdFinish) {
24
+ throw new Error('callbackIdFinish is required');
25
+ }
26
+
27
+ const bundle = this.payload.bundle || [this.payload];
28
+
29
+ // process callbacks in background
30
+ const callbackPromise = this.processCallbacksInBackground(bundle, callbackId, callbackIdFinish);
31
+ this.device.pendingCallbackPromise = createDeferred(callbackPromise);
32
+
33
+ // register to context for scheduling management
34
+ if (this.context && this.payload.connectId) {
35
+ this.context.registerCallbackTask(this.payload.connectId, this.device.pendingCallbackPromise);
36
+ }
37
+
38
+ // return empty array immediately
39
+ return Promise.resolve([]);
40
+ }
41
+
42
+ private async processCallbacksInBackground(
43
+ bundle: any[],
44
+ callbackId: string,
45
+ callbackIdFinish: string
46
+ ): Promise<void> {
47
+ try {
48
+ const allResults: AllNetworkAddress[] = [];
49
+
50
+ for (let i = 0; i < bundle.length; i++) {
51
+ const item = bundle[i];
52
+
53
+ if (this.abortController?.signal.aborted) {
54
+ throw new Error(HardwareErrorCodeMessage[HardwareErrorCode.RepeatUnlocking]);
55
+ }
56
+
57
+ const methodParams = this.generateMethodName({
58
+ network: item.network,
59
+ payload: item,
60
+ originalIndex: i,
61
+ });
62
+
63
+ const singleMethodParams = {
64
+ bundle: [methodParams.params],
65
+ };
66
+
67
+ const response = await this.callMethod(methodParams.methodName, singleMethodParams);
68
+
69
+ if (this.abortController?.signal.aborted) {
70
+ throw new Error(HardwareErrorCodeMessage[HardwareErrorCode.RepeatUnlocking]);
71
+ }
72
+
73
+ const singleResult = {
74
+ ...item,
75
+ ...response[0],
76
+ };
77
+ allResults.push(singleResult);
78
+
79
+ this.sendItemCallback(callbackId, singleResult, i);
80
+ }
81
+
82
+ this.sendFinishCallback({
83
+ callbackId: callbackIdFinish,
84
+ data: allResults,
85
+ });
86
+ } catch (error: any) {
87
+ let errorCode = error.errorCode || error.code;
88
+ let errorMessage = error.message;
89
+
90
+ if (error instanceof HardwareError) {
91
+ errorCode = error.errorCode;
92
+ errorMessage = error.message;
93
+ } else if (error.message === HardwareErrorCodeMessage[HardwareErrorCode.RepeatUnlocking]) {
94
+ errorCode = HardwareErrorCode.RepeatUnlocking;
95
+ errorMessage = error.message;
96
+ } else {
97
+ const hardwareError = ERRORS.TypedError(HardwareErrorCode.RuntimeError, error.message);
98
+ errorCode = hardwareError.errorCode;
99
+ errorMessage = hardwareError.message;
100
+ }
101
+
102
+ this.sendFinishCallback({
103
+ callbackId,
104
+ error: {
105
+ success: false,
106
+ payload: {
107
+ error: errorMessage,
108
+ code: errorCode,
109
+ },
110
+ },
111
+ });
112
+ } finally {
113
+ this.context?.cancelCallbackTasks(this.payload.connectId);
114
+ this.abortController = null;
115
+ }
116
+ }
117
+
118
+ private sendFinishCallback({
119
+ callbackId,
120
+ data,
121
+ error,
122
+ }: {
123
+ callbackId: string;
124
+ data?: AllNetworkAddress[];
125
+ error?: Unsuccessful;
126
+ }) {
127
+ this.postMessage({
128
+ event: IFRAME.CALLBACK,
129
+ type: IFRAME.CALLBACK,
130
+ payload: {
131
+ callbackId,
132
+ data,
133
+ error,
134
+ },
135
+ });
136
+ }
137
+
138
+ private sendItemCallback(callbackId: string, data: any, itemIndex: number) {
139
+ this.postMessage({
140
+ event: IFRAME.CALLBACK,
141
+ type: IFRAME.CALLBACK,
142
+ payload: {
143
+ callbackId,
144
+ data: {
145
+ ...data,
146
+ index: itemIndex,
147
+ },
148
+ },
149
+ });
150
+ }
151
+ }
@@ -1,4 +1,5 @@
1
1
  import type { GetPublicKey } from '@onekeyfe/hd-transport';
2
+ import { HardwareError, HardwareErrorCode } from '@onekeyfe/hd-shared';
2
3
  import { UI_REQUEST } from '../../constants/ui-request';
3
4
  import { getScriptType, isTaprootPath, serializedPath, validatePath } from '../helpers/pathUtils';
4
5
  import { BaseMethod } from '../BaseMethod';
@@ -121,6 +122,18 @@ export default class BTCGetPublicKey extends BaseMethod<GetPublicKey[]> {
121
122
  });
122
123
  }
123
124
  } catch (error) {
125
+ if (error instanceof HardwareError) {
126
+ const { errorCode } = error;
127
+ if (
128
+ errorCode === HardwareErrorCode.PinCancelled ||
129
+ errorCode === HardwareErrorCode.ActionCancelled ||
130
+ errorCode === HardwareErrorCode.ResponseUnexpectTypeError ||
131
+ errorCode === HardwareErrorCode.PinInvalid
132
+ ) {
133
+ throw error;
134
+ }
135
+ }
136
+
124
137
  // clear responses
125
138
  responses = [];
126
139
 
@@ -2,7 +2,7 @@ import { UI_REQUEST } from '../../constants/ui-request';
2
2
  import { serializedPath, validatePath } from '../helpers/pathUtils';
3
3
  import { BaseMethod } from '../BaseMethod';
4
4
  import { validateParams, validateResult } from '../helpers/paramsValidator';
5
- import { CosmosAddress, CosmosGetPublicKeyParams } from '../../types';
5
+ import type { CosmosAddress, CosmosGetPublicKeyParams } from '../../types';
6
6
  import { batchGetPublickeys } from '../helpers/batchGetPublickeys';
7
7
 
8
8
  export default class CosmosGetPublicKey extends BaseMethod<any> {