@onekeyfe/hd-core 1.0.34-alpha.0 → 1.0.34-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 (158) hide show
  1. package/dist/api/BaseMethod.d.ts +1 -1
  2. package/dist/api/BaseMethod.d.ts.map +1 -1
  3. package/dist/api/GetPassphraseState.d.ts +1 -1
  4. package/dist/api/GetPassphraseState.d.ts.map +1 -1
  5. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts +3 -1
  6. package/dist/api/allnetwork/AllNetworkGetAddress.d.ts.map +1 -1
  7. package/dist/api/device/DeviceUnlock.d.ts +7 -0
  8. package/dist/api/device/DeviceUnlock.d.ts.map +1 -0
  9. package/dist/api/index.d.ts +1 -0
  10. package/dist/api/index.d.ts.map +1 -1
  11. package/dist/core/index.d.ts.map +1 -1
  12. package/dist/data-manager/DataManager.d.ts.map +1 -1
  13. package/dist/data-manager/TransportManager.d.ts.map +1 -1
  14. package/dist/device/Device.d.ts +9 -3
  15. package/dist/device/Device.d.ts.map +1 -1
  16. package/dist/device/DeviceCommands.d.ts +7 -5
  17. package/dist/device/DeviceCommands.d.ts.map +1 -1
  18. package/dist/events/device.d.ts +3 -0
  19. package/dist/events/device.d.ts.map +1 -1
  20. package/dist/events/ui-request.d.ts +3 -2
  21. package/dist/events/ui-request.d.ts.map +1 -1
  22. package/dist/events/ui-response.d.ts +1 -0
  23. package/dist/events/ui-response.d.ts.map +1 -1
  24. package/dist/index.d.ts +27 -12
  25. package/dist/index.js +322 -170
  26. package/dist/inject.d.ts.map +1 -1
  27. package/dist/types/api/deviceUnlock.d.ts +4 -0
  28. package/dist/types/api/deviceUnlock.d.ts.map +1 -0
  29. package/dist/types/api/index.d.ts +2 -0
  30. package/dist/types/api/index.d.ts.map +1 -1
  31. package/dist/types/settings.d.ts +1 -1
  32. package/dist/types/settings.d.ts.map +1 -1
  33. package/dist/utils/deviceFeaturesUtils.d.ts +16 -2
  34. package/dist/utils/deviceFeaturesUtils.d.ts.map +1 -1
  35. package/dist/utils/logger.d.ts +0 -2
  36. package/dist/utils/logger.d.ts.map +1 -1
  37. package/dist/utils/patch.d.ts +1 -1
  38. package/dist/utils/patch.d.ts.map +1 -1
  39. package/package.json +4 -4
  40. package/src/api/BaseMethod.ts +3 -2
  41. package/src/api/CheckAllFirmwareRelease.ts +1 -1
  42. package/src/api/CheckBLEFirmwareRelease.ts +3 -3
  43. package/src/api/CheckBootloaderRelease.ts +1 -1
  44. package/src/api/CheckBridgeRelease.ts +1 -1
  45. package/src/api/CheckFirmwareRelease.ts +3 -3
  46. package/src/api/CipherKeyValue.ts +1 -1
  47. package/src/api/FirmwareUpdate.ts +1 -1
  48. package/src/api/FirmwareUpdateV2.ts +1 -1
  49. package/src/api/FirmwareUpdateV3.ts +1 -1
  50. package/src/api/GetFeatures.ts +3 -3
  51. package/src/api/GetOnekeyFeatures.ts +3 -3
  52. package/src/api/GetPassphraseState.ts +20 -4
  53. package/src/api/alephium/AlephiumGetAddress.ts +1 -1
  54. package/src/api/alephium/AlephiumSignMessage.ts +1 -1
  55. package/src/api/alephium/AlephiumSignTransaction.ts +1 -1
  56. package/src/api/algo/AlgoGetAddress.ts +1 -1
  57. package/src/api/algo/AlgoSignTransaction.ts +1 -1
  58. package/src/api/allnetwork/AllNetworkGetAddress.ts +19 -21
  59. package/src/api/aptos/AptosGetAddress.ts +1 -1
  60. package/src/api/aptos/AptosGetPublicKey.ts +1 -1
  61. package/src/api/aptos/AptosSignMessage.ts +1 -1
  62. package/src/api/aptos/AptosSignTransaction.ts +1 -1
  63. package/src/api/benfen/BenfenGetAddress.ts +1 -1
  64. package/src/api/benfen/BenfenGetPublicKey.ts +1 -1
  65. package/src/api/benfen/BenfenSignMessage.ts +1 -1
  66. package/src/api/benfen/BenfenSignTransaction.ts +1 -1
  67. package/src/api/btc/BTCGetAddress.ts +1 -1
  68. package/src/api/btc/BTCGetPublicKey.ts +1 -1
  69. package/src/api/btc/BTCSignMessage.ts +1 -1
  70. package/src/api/btc/BTCSignPsbt.ts +1 -1
  71. package/src/api/btc/BTCSignTransaction.ts +1 -1
  72. package/src/api/btc/BTCVerifyMessage.ts +1 -1
  73. package/src/api/cardano/CardanoGetAddress.ts +1 -1
  74. package/src/api/cardano/CardanoGetPublicKey.ts +1 -1
  75. package/src/api/cardano/CardanoSignMessage.ts +1 -1
  76. package/src/api/cardano/CardanoSignTransaction.ts +1 -1
  77. package/src/api/conflux/ConfluxGetAddress.ts +1 -1
  78. package/src/api/conflux/ConfluxSignMessage.ts +1 -1
  79. package/src/api/conflux/ConfluxSignMessageCIP23.ts +1 -1
  80. package/src/api/conflux/ConfluxSignTransaction.ts +1 -1
  81. package/src/api/cosmos/CosmosGetAddress.ts +1 -1
  82. package/src/api/cosmos/CosmosGetPublicKey.ts +1 -1
  83. package/src/api/cosmos/CosmosSignTransaction.ts +1 -1
  84. package/src/api/device/DeviceUnlock.ts +26 -0
  85. package/src/api/device/DeviceUpdateBootloader.ts +1 -1
  86. package/src/api/dynex/DnxGetAddress.ts +1 -1
  87. package/src/api/dynex/DnxSignTransaction.ts +1 -1
  88. package/src/api/evm/EVMGetAddress.ts +1 -1
  89. package/src/api/evm/EVMGetPublicKey.ts +1 -1
  90. package/src/api/evm/EVMSignMessage.ts +1 -1
  91. package/src/api/evm/EVMSignMessageEIP712.ts +1 -1
  92. package/src/api/evm/EVMSignTransaction.ts +1 -1
  93. package/src/api/evm/EVMSignTypedData.ts +1 -1
  94. package/src/api/evm/EVMVerifyMessage.ts +1 -1
  95. package/src/api/filecoin/FilecoinGetAddress.ts +1 -1
  96. package/src/api/filecoin/FilecoinSignTransaction.ts +1 -1
  97. package/src/api/index.ts +1 -0
  98. package/src/api/kaspa/KaspaGetAddress.ts +1 -1
  99. package/src/api/kaspa/KaspaSignTransaction.ts +1 -1
  100. package/src/api/lightning/LnurlAuth.ts +1 -1
  101. package/src/api/near/NearGetAddress.ts +1 -1
  102. package/src/api/near/NearSignTransaction.ts +1 -1
  103. package/src/api/nem/NEMGetAddress.ts +1 -1
  104. package/src/api/nem/NEMSignTransaction.ts +1 -1
  105. package/src/api/neo/NeoGetAddress.ts +1 -1
  106. package/src/api/neo/NeoSignTransaction.ts +1 -1
  107. package/src/api/nervos/NervosGetAddress.ts +1 -1
  108. package/src/api/nervos/NervosSignTransaction.ts +1 -1
  109. package/src/api/nexa/NexaGetAddress.ts +1 -1
  110. package/src/api/nostr/NostrDecryptMessage.ts +1 -1
  111. package/src/api/nostr/NostrEncryptMessage.ts +1 -1
  112. package/src/api/nostr/NostrGetPublicKey.ts +1 -1
  113. package/src/api/nostr/NostrSignEvent.ts +1 -1
  114. package/src/api/nostr/NostrSignSchnorr.ts +1 -1
  115. package/src/api/polkadot/PolkadotGetAddress.ts +1 -1
  116. package/src/api/polkadot/PolkadotSignTransaction.ts +1 -1
  117. package/src/api/scdo/ScdoGetAddress.ts +1 -1
  118. package/src/api/scdo/ScdoSignMessage.ts +1 -1
  119. package/src/api/scdo/ScdoSignTransaction.ts +1 -1
  120. package/src/api/solana/SolGetAddress.ts +1 -1
  121. package/src/api/solana/SolSignMessage.ts +1 -1
  122. package/src/api/solana/SolSignOffchainMessage.ts +1 -1
  123. package/src/api/solana/SolSignTransaction.ts +1 -1
  124. package/src/api/starcoin/StarcoinGetAddress.ts +1 -1
  125. package/src/api/starcoin/StarcoinGetPublicKey.ts +1 -1
  126. package/src/api/starcoin/StarcoinSignMessage.ts +1 -1
  127. package/src/api/starcoin/StarcoinSignTransaction.ts +1 -1
  128. package/src/api/starcoin/StarcoinVerifyMessage.ts +1 -1
  129. package/src/api/stellar/StellarGetAddress.ts +1 -1
  130. package/src/api/stellar/StellarSignTransaction.ts +1 -1
  131. package/src/api/sui/SuiGetAddress.ts +1 -1
  132. package/src/api/sui/SuiGetPublicKey.ts +1 -1
  133. package/src/api/sui/SuiSignMessage.ts +1 -1
  134. package/src/api/sui/SuiSignTransaction.ts +1 -1
  135. package/src/api/test/TestInitializeDeviceDuration.ts +3 -3
  136. package/src/api/ton/TonGetAddress.ts +1 -1
  137. package/src/api/ton/TonSignMessage.ts +1 -1
  138. package/src/api/ton/TonSignProof.ts +1 -1
  139. package/src/api/tron/TronGetAddress.ts +1 -1
  140. package/src/api/tron/TronSignMessage.ts +1 -1
  141. package/src/api/tron/TronSignTransaction.ts +1 -1
  142. package/src/api/xrp/XrpGetAddress.ts +1 -1
  143. package/src/api/xrp/XrpSignTransaction.ts +1 -1
  144. package/src/core/index.ts +13 -8
  145. package/src/data/messages/messages.json +57 -2
  146. package/src/data-manager/DataManager.ts +1 -1
  147. package/src/data-manager/TransportManager.ts +0 -3
  148. package/src/device/Device.ts +77 -9
  149. package/src/device/DeviceCommands.ts +15 -4
  150. package/src/events/device.ts +4 -0
  151. package/src/events/ui-request.ts +3 -2
  152. package/src/events/ui-response.ts +1 -0
  153. package/src/inject.ts +2 -0
  154. package/src/types/api/deviceUnlock.ts +4 -0
  155. package/src/types/api/index.ts +2 -0
  156. package/src/types/settings.ts +1 -9
  157. package/src/utils/deviceFeaturesUtils.ts +71 -7
  158. package/src/utils/logger.ts +0 -2
@@ -10,7 +10,7 @@ export default class FilecoinSignTransaction extends BaseMethod<HardwareFilecoin
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode];
13
+ this.allowDeviceMode = [...this.allowDeviceMode];
14
14
 
15
15
  // check payload
16
16
  validateParams(this.payload, [
package/src/api/index.ts CHANGED
@@ -27,6 +27,7 @@ export { default as deviceWipe } from './device/DeviceWipe';
27
27
  export { default as deviceFullyUploadResource } from './device/DeviceFullyUploadResource';
28
28
  export { default as deviceUpdateBootloader } from './device/DeviceUpdateBootloader';
29
29
  export { default as deviceLock } from './device/DeviceLock';
30
+ export { default as deviceUnlock } from './device/DeviceUnlock';
30
31
  export { default as deviceCancel } from './device/DeviceCancel';
31
32
 
32
33
  export { default as setU2FCounter } from './u2f/SetU2FCounter';
@@ -10,7 +10,7 @@ export default class KaspaGetAddress extends BaseMethod<HardwareKaspaGetAddress[
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -19,7 +19,7 @@ export default class KaspaSignTransaction extends BaseMethod<KaspaSignTransactio
19
19
 
20
20
  init() {
21
21
  this.checkDeviceId = true;
22
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
22
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
23
23
 
24
24
  const payload = this.payload as KaspaSignTransactionParams;
25
25
 
@@ -9,7 +9,7 @@ export default class LnurlAuth1 extends BaseMethod<ILnurlAuth> {
9
9
 
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
 
14
14
  const { payload } = this;
15
15
  validateParams(payload, [
@@ -10,7 +10,7 @@ export default class NearGetAddress extends BaseMethod<HardwareNearGetAddress[]>
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { formatAnyHex } from '../helpers/hexUtils';
8
8
  export default class NearSignTransaction extends BaseMethod<HardwareNearSignTx> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -12,7 +12,7 @@ export default class NEMGetAddress extends BaseMethod<HardwareNEMGetAddress[]> {
12
12
 
13
13
  init() {
14
14
  this.checkDeviceId = true;
15
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
15
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
16
16
 
17
17
  this.hasBundle = !!this.payload?.bundle;
18
18
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -228,7 +228,7 @@ export default class NEMSignTransaction extends BaseMethod<NEMSignTx> {
228
228
 
229
229
  init() {
230
230
  this.checkDeviceId = true;
231
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
231
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
232
232
 
233
233
  validateParams(this.payload, [
234
234
  { name: 'path', required: true },
@@ -10,7 +10,7 @@ export default class NeoGetAddress extends BaseMethod<HardwareNeoGetAddress[]> {
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
  this.strictCheckDeviceSupport = true;
15
15
 
16
16
  this.hasBundle = !!this.payload?.bundle;
@@ -9,7 +9,7 @@ import { formatAnyHex } from '../helpers/hexUtils';
9
9
  export default class NeoSignTransaction extends BaseMethod<NeoSignTx> {
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
  this.strictCheckDeviceSupport = true;
14
14
 
15
15
  validateParams(this.payload, [
@@ -11,7 +11,7 @@ export default class NervosGetAddress extends BaseMethod<HardwareNervosGetAddres
11
11
 
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
14
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
15
15
 
16
16
  this.hasBundle = !!this.payload?.bundle;
17
17
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -16,7 +16,7 @@ export default class NervosSignTransaction extends BaseMethod<NervosSignTx> {
16
16
 
17
17
  init() {
18
18
  this.checkDeviceId = true;
19
- this.notAllowDeviceMode = [...this.notAllowDeviceMode];
19
+ this.allowDeviceMode = [...this.allowDeviceMode];
20
20
 
21
21
  // check payload
22
22
  validateParams(this.payload, [
@@ -10,7 +10,7 @@ export default class NexaGetAddress extends BaseMethod<HardwareNexaGetAddress[]>
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -9,7 +9,7 @@ export default class NostrDecryptMessage extends BaseMethod<DecryptMessage> {
9
9
 
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
 
14
14
  const { payload } = this;
15
15
  validateParams(payload, [
@@ -9,7 +9,7 @@ export default class NostrEncryptMessage extends BaseMethod<EncryptMessage> {
9
9
 
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
 
14
14
  const { payload } = this;
15
15
  validateParams(payload, [
@@ -11,7 +11,7 @@ export default class NostrGetPublicKey extends BaseMethod<GetPublicKey[]> {
11
11
 
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
14
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
15
15
 
16
16
  this.hasBundle = Object.prototype.hasOwnProperty.call(this.payload, 'bundle');
17
17
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -12,7 +12,7 @@ export default class NostrSignEvent extends BaseMethod<SignEvent> {
12
12
 
13
13
  init() {
14
14
  this.checkDeviceId = true;
15
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
15
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
16
16
 
17
17
  const { payload } = this;
18
18
  if (!validateEvent(payload.event)) {
@@ -9,7 +9,7 @@ export default class NostrSignSchnorr extends BaseMethod<SignSchnorr> {
9
9
 
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
 
14
14
  const { payload } = this;
15
15
  validateParams(payload, [
@@ -11,7 +11,7 @@ export default class PolkadotGetAddress extends BaseMethod<HardwarePolkadotGetAd
11
11
 
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode];
14
+ this.allowDeviceMode = [...this.allowDeviceMode];
15
15
 
16
16
  this.hasBundle = !!this.payload?.bundle;
17
17
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -11,7 +11,7 @@ export default class PolkadotSignTransaction extends BaseMethod<HardwarePolkadot
11
11
 
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode];
14
+ this.allowDeviceMode = [...this.allowDeviceMode];
15
15
 
16
16
  // check payload
17
17
  validateParams(this.payload, [
@@ -10,7 +10,7 @@ export default class ScdoGetAddress extends BaseMethod<HardwareScdoGetAddress[]>
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { stripHexPrefix } from '../helpers/hexUtils';
8
8
  export default class ScdoSignMessage extends BaseMethod<HardwareScdoSignMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -11,7 +11,7 @@ import { formatAnyHex, stripHexStartZeroes } from '../helpers/hexUtils';
11
11
  export default class ScdoSignTransaction extends BaseMethod<HardwareScdoSignTx> {
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
14
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
15
15
 
16
16
  // check payload
17
17
  validateParams(this.payload, [
@@ -10,7 +10,7 @@ export default class SolGetAddress extends BaseMethod<SolanaGetAddress[]> {
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { stripHexPrefix } from '../helpers/hexUtils';
8
8
  export default class SolSignMessage extends BaseMethod<HardwareSolSignUnsafeMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -8,7 +8,7 @@ import { stripHexPrefix } from '../helpers/hexUtils';
8
8
  export default class SolSignOffchainMessage extends BaseMethod<HardwareSolSignOffChainMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -11,7 +11,7 @@ export default class SolSignTransaction extends BaseMethod<HardwareSolanaSignTx[
11
11
 
12
12
  init() {
13
13
  this.checkDeviceId = true;
14
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
14
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
15
15
 
16
16
  this.hasBundle = !!this.payload?.bundle;
17
17
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -10,7 +10,7 @@ export default class StarcoinGetAddress extends BaseMethod<HardwareStarcoinGetAd
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -13,7 +13,7 @@ export default class StarcoinGetPublicKey extends BaseMethod<HardwareStarcoinGet
13
13
 
14
14
  init() {
15
15
  this.checkDeviceId = true;
16
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
16
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
17
17
 
18
18
  this.hasBundle = !!this.payload?.bundle;
19
19
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { formatAnyHex } from '../helpers/hexUtils';
8
8
  export default class StarcoinSignMessage extends BaseMethod<HardwareStarcoinSignMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -8,7 +8,7 @@ import { formatAnyHex } from '../helpers/hexUtils';
8
8
  export default class StarcoinSignTransaction extends BaseMethod<StarcoinSignTx> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -7,7 +7,7 @@ import { formatAnyHex } from '../helpers/hexUtils';
7
7
  export default class EVMSignMessage extends BaseMethod<HardwareStarcoinVerifyMessage> {
8
8
  init() {
9
9
  this.checkDeviceId = true;
10
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
10
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
11
11
 
12
12
  validateParams(this.payload, [
13
13
  { name: 'publicKey', type: 'string', required: true },
@@ -10,7 +10,7 @@ export default class StellarGetAddress extends BaseMethod<HardwareStellarGetAddr
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -149,7 +149,7 @@ export default class StellarSignTransaction extends BaseMethod<HardwareStellarSi
149
149
 
150
150
  init() {
151
151
  this.checkDeviceId = true;
152
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
152
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
153
153
 
154
154
  // check payload
155
155
  validateParams(this.payload, [
@@ -16,7 +16,7 @@ export default class SuiGetAddress extends BaseMethod<HardwareSuiGetAddress[]> {
16
16
 
17
17
  init() {
18
18
  this.checkDeviceId = true;
19
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
19
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
20
20
 
21
21
  this.hasBundle = !!this.payload?.bundle;
22
22
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -10,7 +10,7 @@ export default class SuiGetPublicKey extends BaseMethod<any> {
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { stripHexPrefix } from '../helpers/hexUtils';
8
8
  export default class SuiSignMessage extends BaseMethod<HardwareSuiSignMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -15,7 +15,7 @@ type SuiSignTx = Omit<HardwareSuiSignTx, 'data_initial_chunk' | 'data_length'> &
15
15
  export default class SuiSignTransaction extends BaseMethod<SuiSignTx> {
16
16
  init() {
17
17
  this.checkDeviceId = true;
18
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
18
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
19
19
 
20
20
  // check payload
21
21
  validateParams(this.payload, [
@@ -3,9 +3,9 @@ import { BaseMethod } from '../BaseMethod';
3
3
 
4
4
  export default class TestInitializeDeviceDuration extends BaseMethod {
5
5
  init() {
6
- this.notAllowDeviceMode = [
7
- ...this.notAllowDeviceMode,
8
- UI_REQUEST.INITIALIZE,
6
+ this.allowDeviceMode = [
7
+ ...this.allowDeviceMode,
8
+ UI_REQUEST.NOT_INITIALIZE,
9
9
  UI_REQUEST.BOOTLOADER,
10
10
  ];
11
11
  this.useDevicePassphraseState = false;
@@ -14,7 +14,7 @@ export default class TonGetAddress extends BaseMethod<HardwareTonGetAddress[]> {
14
14
  init() {
15
15
  this.strictCheckDeviceSupport = true;
16
16
  this.checkDeviceId = true;
17
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
17
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
18
18
 
19
19
  this.hasBundle = !!this.payload?.bundle;
20
20
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -22,7 +22,7 @@ export default class TonSignMessage extends BaseMethod<HardwareTonSignMessage> {
22
22
  init() {
23
23
  this.strictCheckDeviceSupport = true;
24
24
  this.checkDeviceId = true;
25
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
25
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
26
26
 
27
27
  // init params
28
28
  validateParams(this.payload, [
@@ -10,7 +10,7 @@ export default class TonSignProof extends BaseMethod<HardwareTonSignProof> {
10
10
  init() {
11
11
  this.strictCheckDeviceSupport = true;
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  // init params
16
16
  validateParams(this.payload, [
@@ -10,7 +10,7 @@ export default class TronGetAddress extends BaseMethod<HardwareTronGetAddress[]>
10
10
 
11
11
  init() {
12
12
  this.checkDeviceId = true;
13
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
13
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
14
14
 
15
15
  this.hasBundle = !!this.payload?.bundle;
16
16
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -8,7 +8,7 @@ import { stripHexPrefix } from '../helpers/hexUtils';
8
8
  export default class TronSignMessage extends BaseMethod<HardwareTronSignMessage> {
9
9
  init() {
10
10
  this.checkDeviceId = true;
11
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
11
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
12
12
 
13
13
  // check payload
14
14
  validateParams(this.payload, [
@@ -119,7 +119,7 @@ export default class TronSignTransaction extends BaseMethod<TronSignTx> {
119
119
 
120
120
  init() {
121
121
  this.checkDeviceId = true;
122
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
122
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
123
123
 
124
124
  // check payload
125
125
  validateParams(this.payload, [
@@ -19,7 +19,7 @@ export default class XrpGetAddress extends BaseMethod<
19
19
 
20
20
  init() {
21
21
  this.checkDeviceId = true;
22
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
22
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
23
23
 
24
24
  this.hasBundle = !!this.payload?.bundle;
25
25
  const payload = this.hasBundle ? this.payload : { bundle: [this.payload] };
@@ -9,7 +9,7 @@ export default class XrpGetAddress extends BaseMethod<XrpSignTransactionParams>
9
9
 
10
10
  init() {
11
11
  this.checkDeviceId = true;
12
- this.notAllowDeviceMode = [...this.notAllowDeviceMode, UI_REQUEST.INITIALIZE];
12
+ this.allowDeviceMode = [...this.allowDeviceMode, UI_REQUEST.NOT_INITIALIZE];
13
13
 
14
14
  const { payload } = this;
15
15
  validateParams(payload, [
package/src/core/index.ts CHANGED
@@ -285,7 +285,7 @@ const onCallDevice = async (
285
285
 
286
286
  // check call method mode
287
287
  const unexpectedMode = device.hasUnexpectedMode(
288
- method.notAllowDeviceMode,
288
+ method.allowDeviceMode,
289
289
  method.requireDeviceMode
290
290
  );
291
291
  if (unexpectedMode) {
@@ -342,7 +342,8 @@ const onCallDevice = async (
342
342
 
343
343
  // Check Device passphrase State
344
344
  const passphraseStateSafety = await device.checkPassphraseStateSafety(
345
- method.payload?.passphraseState
345
+ method.payload?.passphraseState,
346
+ method.payload?.useEmptyPassphrase
346
347
  );
347
348
 
348
349
  // Double check, handles the special case of Touch/Pro
@@ -836,12 +837,12 @@ const onDevicePinHandler = async (...[device, type, callback]: DeviceEvents['pin
836
837
  const onDeviceButtonHandler = (...[device, request]: [...DeviceEvents['button']]) => {
837
838
  postMessage(createDeviceMessage(DEVICE.BUTTON, { ...request, device: device.toMessageObject() }));
838
839
 
839
- if (request.code === 'ButtonRequest_PinEntry') {
840
- Log.log('request Confirm Input PIN');
840
+ if (request.code === 'ButtonRequest_PinEntry' || request.code === 'ButtonRequest_AttachPin') {
841
+ Log.log('request Confirm Input PIN or Attach PIN');
841
842
  postMessage(
842
843
  createUiMessage(UI_REQUEST.REQUEST_PIN, {
843
844
  device: device.toMessageObject() as KnownDevice,
844
- type: 'ButtonRequest_PinEntry',
845
+ type: request.code,
845
846
  })
846
847
  );
847
848
  } else {
@@ -854,27 +855,31 @@ const onDeviceFeaturesHandler = (...[_, features]: [...DeviceEvents['features']]
854
855
  postMessage(createDeviceMessage(DEVICE.FEATURES, { ...features }));
855
856
  };
856
857
 
857
- const onDevicePassphraseHandler = async (...[device, callback]: DeviceEvents['passphrase']) => {
858
+ const onDevicePassphraseHandler = async (
859
+ ...[device, requestPayload, callback]: DeviceEvents['passphrase']
860
+ ) => {
858
861
  Log.debug('onDevicePassphraseHandler');
859
862
  const uiPromise = createUiPromise(UI_RESPONSE.RECEIVE_PASSPHRASE, device);
860
863
  postMessage(
861
864
  createUiMessage(UI_REQUEST.REQUEST_PASSPHRASE, {
862
865
  device: device.toMessageObject() as KnownDevice,
863
866
  passphraseState: device.passphraseState,
867
+ existsAttachPinUser: requestPayload.existsAttachPinUser,
864
868
  })
865
869
  );
866
870
  // wait for passphrase
867
871
  const uiResp = await uiPromise.promise;
868
- const { value, passphraseOnDevice, save } = uiResp.payload;
872
+ const { value, passphraseOnDevice, save, attachPinOnDevice } = uiResp.payload;
869
873
  // send as PassphrasePromptResponse
870
874
  callback({
871
875
  passphrase: value.normalize('NFKD'),
872
876
  passphraseOnDevice,
877
+ attachPinOnDevice,
873
878
  cache: save,
874
879
  });
875
880
  };
876
881
 
877
- const onEmptyPassphraseHandler = (...[_, callback]: DeviceEvents['passphrase']) => {
882
+ const onEmptyPassphraseHandler = (...[_, , callback]: DeviceEvents['passphrase']) => {
878
883
  Log.debug('onEmptyPassphraseHandler');
879
884
  // send as PassphrasePromptResponse
880
885
  callback({ passphrase: '' });