@ledgerhq/device-signer-kit-ethereum 0.0.0-signer-eth-20250122093657 → 0.0.0-sol-signer-20251203164116

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 (886) hide show
  1. package/README.md +139 -16
  2. package/lib/cjs/api/SignerEth.js +1 -1
  3. package/lib/cjs/api/SignerEth.js.map +1 -1
  4. package/lib/cjs/api/SignerEthBuilder.js +1 -1
  5. package/lib/cjs/api/SignerEthBuilder.js.map +3 -3
  6. package/lib/cjs/api/SignerEthBuilder.test.js +1 -1
  7. package/lib/cjs/api/SignerEthBuilder.test.js.map +3 -3
  8. package/lib/cjs/api/app-binder/GetConfigCommandTypes.js +2 -0
  9. package/lib/cjs/api/app-binder/GetConfigCommandTypes.js.map +7 -0
  10. package/lib/cjs/api/app-binder/SignDelegationAuthorizationTypes.js +2 -0
  11. package/lib/cjs/api/app-binder/SignDelegationAuthorizationTypes.js.map +7 -0
  12. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js +1 -1
  13. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +1 -1
  14. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  15. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +3 -3
  16. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
  17. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +3 -3
  18. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  19. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  20. package/lib/cjs/api/index.js +1 -1
  21. package/lib/cjs/api/index.js.map +3 -3
  22. package/lib/cjs/api/model/AddressOptions.js +1 -1
  23. package/lib/cjs/api/model/AddressOptions.js.map +1 -1
  24. package/lib/cjs/api/model/ClearSigningType.js +2 -0
  25. package/lib/cjs/api/model/ClearSigningType.js.map +7 -0
  26. package/lib/cjs/api/model/MessageOptions.js +2 -0
  27. package/lib/cjs/api/model/MessageOptions.js.map +7 -0
  28. package/lib/cjs/api/model/SafeAddressOptions.js +2 -0
  29. package/lib/cjs/api/model/SafeAddressOptions.js.map +7 -0
  30. package/lib/cjs/api/model/TransactionOptions.js +1 -1
  31. package/lib/cjs/api/model/TransactionOptions.js.map +1 -1
  32. package/lib/cjs/api/model/TypedDataOptions.js +2 -0
  33. package/lib/cjs/api/model/TypedDataOptions.js.map +7 -0
  34. package/lib/cjs/index.js.map +1 -1
  35. package/lib/cjs/internal/DefaultSignerEth.js +1 -1
  36. package/lib/cjs/internal/DefaultSignerEth.js.map +3 -3
  37. package/lib/cjs/internal/DefaultSignerEth.test.js +1 -1
  38. package/lib/cjs/internal/DefaultSignerEth.test.js.map +3 -3
  39. package/lib/cjs/internal/address/di/addressModule.js +1 -1
  40. package/lib/cjs/internal/address/di/addressModule.js.map +3 -3
  41. package/lib/cjs/internal/address/di/addressModule.test.js +1 -1
  42. package/lib/cjs/internal/address/di/addressModule.test.js.map +2 -2
  43. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js +1 -1
  44. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js.map +2 -2
  45. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js +1 -1
  46. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
  47. package/lib/cjs/internal/app-binder/EthAppBinder.js +1 -1
  48. package/lib/cjs/internal/app-binder/EthAppBinder.js.map +3 -3
  49. package/lib/cjs/internal/app-binder/EthAppBinder.test.js +1 -1
  50. package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +3 -3
  51. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js +1 -1
  52. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js.map +2 -2
  53. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js +1 -1
  54. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
  55. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js +2 -0
  56. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js.map +7 -0
  57. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js +2 -0
  58. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +7 -0
  59. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +1 -1
  60. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  61. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  62. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  63. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js +1 -1
  64. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
  65. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
  66. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
  67. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
  68. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
  69. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
  70. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
  71. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  72. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  73. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  74. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  75. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
  76. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
  77. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
  78. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
  79. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  80. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  81. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  82. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  83. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
  84. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
  85. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
  86. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
  87. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
  88. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
  89. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
  90. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
  91. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
  92. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
  93. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
  94. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
  95. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
  96. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
  97. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
  98. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
  99. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js +2 -0
  100. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +7 -0
  101. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +2 -0
  102. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +7 -0
  103. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  104. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  105. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  106. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  107. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
  108. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
  109. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
  110. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
  111. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
  112. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
  113. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
  114. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
  115. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
  116. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
  117. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
  118. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
  119. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js +1 -1
  120. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js.map +2 -2
  121. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js +2 -2
  122. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
  123. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
  124. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
  125. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
  126. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
  127. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js +1 -1
  128. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js.map +3 -3
  129. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js +1 -1
  130. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
  131. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
  132. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
  133. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
  134. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
  135. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +1 -1
  136. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
  137. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  138. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  139. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js +1 -1
  140. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
  141. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
  142. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
  143. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js +1 -1
  144. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
  145. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
  146. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
  147. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js +2 -0
  148. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js.map +7 -0
  149. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js +2 -0
  150. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +7 -0
  151. package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js +1 -1
  152. package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js.map +2 -2
  153. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  154. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  155. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  156. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  157. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  158. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
  159. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  160. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  161. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  162. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  163. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  164. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  165. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
  166. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
  167. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +1 -1
  168. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +2 -2
  169. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +1 -1
  170. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +3 -3
  171. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  172. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  173. package/lib/cjs/internal/app-binder/di/appBinderModule.js +1 -1
  174. package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +3 -3
  175. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js +2 -0
  176. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  177. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  178. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  179. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  180. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  181. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  182. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  183. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  184. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  185. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  186. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  187. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  188. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  189. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  190. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  191. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  192. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  193. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  194. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  195. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  196. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  197. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  198. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  199. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js +2 -0
  200. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  201. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  202. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  203. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js +2 -0
  204. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  205. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  206. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  207. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  208. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  209. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  210. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  211. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  212. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  213. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  214. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  215. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js +1 -1
  216. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +2 -2
  217. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  218. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  219. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  220. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  221. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
  222. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
  223. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
  224. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
  225. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js +1 -1
  226. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +2 -2
  227. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +1 -1
  228. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
  229. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
  230. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
  231. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
  232. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
  233. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
  234. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
  235. package/lib/cjs/internal/di.js +1 -1
  236. package/lib/cjs/internal/di.js.map +3 -3
  237. package/lib/cjs/internal/eip7702/di/eip7702Module.js +2 -0
  238. package/lib/cjs/internal/eip7702/di/eip7702Module.js.map +7 -0
  239. package/lib/cjs/internal/eip7702/di/eip7702Module.test.js +2 -0
  240. package/lib/cjs/internal/eip7702/di/eip7702Module.test.js.map +7 -0
  241. package/lib/cjs/internal/eip7702/di/eip7702Types.js +2 -0
  242. package/lib/cjs/internal/eip7702/di/eip7702Types.js.map +7 -0
  243. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
  244. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
  245. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
  246. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
  247. package/lib/cjs/internal/message/di/messageModule.js +1 -1
  248. package/lib/cjs/internal/message/di/messageModule.js.map +3 -3
  249. package/lib/cjs/internal/message/di/messageModule.test.js +1 -1
  250. package/lib/cjs/internal/message/di/messageModule.test.js.map +2 -2
  251. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +1 -1
  252. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +3 -3
  253. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +1 -1
  254. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
  255. package/lib/cjs/internal/safe/di/safeModule.js +2 -0
  256. package/lib/cjs/internal/safe/di/safeModule.js.map +7 -0
  257. package/lib/cjs/internal/safe/di/safeModule.test.js +2 -0
  258. package/lib/cjs/internal/safe/di/safeModule.test.js.map +7 -0
  259. package/lib/cjs/internal/safe/di/safeTypes.js +2 -0
  260. package/lib/cjs/internal/safe/di/safeTypes.js.map +7 -0
  261. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  262. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  263. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  264. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  265. package/lib/cjs/internal/shared/utils/ApplicationChecker.js +2 -0
  266. package/lib/cjs/internal/shared/utils/ApplicationChecker.js.map +7 -0
  267. package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js +2 -0
  268. package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js.map +7 -0
  269. package/lib/cjs/internal/transaction/di/transactionModule.js +1 -1
  270. package/lib/cjs/internal/transaction/di/transactionModule.js.map +3 -3
  271. package/lib/cjs/internal/transaction/di/transactionModule.test.js +1 -1
  272. package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +2 -2
  273. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
  274. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
  275. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
  276. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
  277. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +1 -1
  278. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +3 -3
  279. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +1 -1
  280. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
  281. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  282. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
  283. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js +1 -1
  284. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js.map +2 -2
  285. package/lib/cjs/internal/typed-data/di/typedDataModule.js +1 -1
  286. package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +3 -3
  287. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +1 -1
  288. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +2 -2
  289. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
  290. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
  291. package/lib/cjs/internal/typed-data/service/TypedDataParser.js +1 -1
  292. package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +3 -3
  293. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +1 -1
  294. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
  295. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
  296. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
  297. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
  298. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
  299. package/lib/cjs/package.json +44 -41
  300. package/lib/esm/api/SignerEthBuilder.js +1 -1
  301. package/lib/esm/api/SignerEthBuilder.js.map +3 -3
  302. package/lib/esm/api/SignerEthBuilder.test.js +1 -1
  303. package/lib/esm/api/SignerEthBuilder.test.js.map +3 -3
  304. package/lib/esm/api/app-binder/GetConfigCommandTypes.js +1 -0
  305. package/lib/esm/api/app-binder/SignDelegationAuthorizationTypes.js +1 -0
  306. package/lib/esm/api/app-binder/SignDelegationAuthorizationTypes.js.map +7 -0
  307. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -0
  308. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +4 -4
  309. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -0
  310. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +4 -4
  311. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  312. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  313. package/lib/esm/api/index.js +1 -1
  314. package/lib/esm/api/index.js.map +3 -3
  315. package/lib/esm/api/model/ClearSigningType.js +2 -0
  316. package/lib/esm/api/model/ClearSigningType.js.map +7 -0
  317. package/lib/esm/api/model/MessageOptions.js +1 -0
  318. package/lib/esm/api/model/MessageOptions.js.map +7 -0
  319. package/lib/esm/api/model/SafeAddressOptions.js +1 -0
  320. package/lib/esm/api/model/SafeAddressOptions.js.map +7 -0
  321. package/lib/esm/api/model/TypedDataOptions.js +1 -0
  322. package/lib/esm/api/model/TypedDataOptions.js.map +7 -0
  323. package/lib/esm/internal/DefaultSignerEth.js +1 -1
  324. package/lib/esm/internal/DefaultSignerEth.js.map +3 -3
  325. package/lib/esm/internal/DefaultSignerEth.test.js +1 -1
  326. package/lib/esm/internal/DefaultSignerEth.test.js.map +3 -3
  327. package/lib/esm/internal/address/di/addressModule.js +1 -1
  328. package/lib/esm/internal/address/di/addressModule.js.map +3 -3
  329. package/lib/esm/internal/address/di/addressModule.test.js +1 -1
  330. package/lib/esm/internal/address/di/addressModule.test.js.map +2 -2
  331. package/lib/esm/internal/address/use-case/GetAddressUseCase.js +1 -1
  332. package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +2 -2
  333. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +1 -1
  334. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
  335. package/lib/esm/internal/app-binder/EthAppBinder.js +1 -1
  336. package/lib/esm/internal/app-binder/EthAppBinder.js.map +3 -3
  337. package/lib/esm/internal/app-binder/EthAppBinder.test.js +1 -1
  338. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +3 -3
  339. package/lib/esm/internal/app-binder/command/GetAddressCommand.js +1 -1
  340. package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +2 -2
  341. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +1 -1
  342. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
  343. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js +2 -0
  344. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js.map +7 -0
  345. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js +2 -0
  346. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +7 -0
  347. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +1 -1
  348. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  349. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  350. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  351. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +1 -1
  352. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
  353. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
  354. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
  355. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
  356. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
  357. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
  358. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
  359. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  360. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  361. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  362. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  363. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
  364. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
  365. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
  366. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
  367. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  368. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  369. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  370. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  371. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
  372. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
  373. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
  374. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
  375. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
  376. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
  377. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
  378. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
  379. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
  380. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
  381. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
  382. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
  383. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
  384. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
  385. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
  386. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
  387. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js +2 -0
  388. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +7 -0
  389. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +2 -0
  390. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +7 -0
  391. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  392. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  393. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  394. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  395. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
  396. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
  397. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
  398. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
  399. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
  400. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
  401. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
  402. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
  403. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
  404. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
  405. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
  406. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
  407. package/lib/esm/internal/app-binder/command/SetPluginCommand.js +1 -1
  408. package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +2 -2
  409. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +2 -2
  410. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
  411. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
  412. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
  413. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
  414. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
  415. package/lib/esm/internal/app-binder/command/SignEIP712Command.js +1 -1
  416. package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +2 -2
  417. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +1 -1
  418. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
  419. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
  420. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
  421. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
  422. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
  423. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +1 -1
  424. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
  425. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  426. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  427. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +1 -1
  428. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
  429. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
  430. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
  431. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +1 -1
  432. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
  433. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
  434. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
  435. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js +2 -0
  436. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js.map +7 -0
  437. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js +2 -0
  438. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +7 -0
  439. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js +1 -1
  440. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js.map +2 -2
  441. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  442. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  443. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  444. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  445. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  446. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
  447. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  448. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  449. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  450. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  451. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  452. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  453. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
  454. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
  455. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +1 -1
  456. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +2 -2
  457. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +1 -1
  458. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +3 -3
  459. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  460. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  461. package/lib/esm/internal/app-binder/di/appBinderModule.js +1 -1
  462. package/lib/esm/internal/app-binder/di/appBinderModule.js.map +3 -3
  463. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js +2 -0
  464. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  465. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  466. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  467. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  468. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  469. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  470. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  471. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  472. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  473. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  474. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  475. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  476. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  477. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  478. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  479. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  480. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  481. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  482. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  483. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  484. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  485. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  486. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  487. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js +2 -0
  488. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  489. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  490. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  491. package/lib/esm/internal/app-binder/task/ProvideContextTask.js +2 -0
  492. package/lib/esm/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  493. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  494. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  495. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  496. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  497. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  498. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  499. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  500. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  501. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  502. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  503. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js +1 -1
  504. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +2 -2
  505. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  506. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  507. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  508. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  509. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
  510. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
  511. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
  512. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
  513. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js +1 -1
  514. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +2 -2
  515. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js +1 -1
  516. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
  517. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
  518. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
  519. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
  520. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
  521. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
  522. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
  523. package/lib/esm/internal/di.js +1 -1
  524. package/lib/esm/internal/di.js.map +3 -3
  525. package/lib/esm/internal/eip7702/di/eip7702Module.js +2 -0
  526. package/lib/esm/internal/eip7702/di/eip7702Module.js.map +7 -0
  527. package/lib/esm/internal/eip7702/di/eip7702Module.test.js +2 -0
  528. package/lib/esm/internal/eip7702/di/eip7702Module.test.js.map +7 -0
  529. package/lib/esm/internal/eip7702/di/eip7702Types.js +2 -0
  530. package/lib/esm/internal/eip7702/di/eip7702Types.js.map +7 -0
  531. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
  532. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
  533. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
  534. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
  535. package/lib/esm/internal/message/di/messageModule.js +1 -1
  536. package/lib/esm/internal/message/di/messageModule.js.map +3 -3
  537. package/lib/esm/internal/message/di/messageModule.test.js +1 -1
  538. package/lib/esm/internal/message/di/messageModule.test.js.map +2 -2
  539. package/lib/esm/internal/message/use-case/SignMessageUseCase.js +1 -1
  540. package/lib/esm/internal/message/use-case/SignMessageUseCase.js.map +3 -3
  541. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js +1 -1
  542. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
  543. package/lib/esm/internal/safe/di/safeModule.js +2 -0
  544. package/lib/esm/internal/safe/di/safeModule.js.map +7 -0
  545. package/lib/esm/internal/safe/di/safeModule.test.js +2 -0
  546. package/lib/esm/internal/safe/di/safeModule.test.js.map +7 -0
  547. package/lib/esm/internal/safe/di/safeTypes.js +2 -0
  548. package/lib/esm/internal/safe/di/safeTypes.js.map +7 -0
  549. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  550. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  551. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  552. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  553. package/lib/esm/internal/shared/utils/ApplicationChecker.js +2 -0
  554. package/lib/esm/internal/shared/utils/ApplicationChecker.js.map +7 -0
  555. package/lib/esm/internal/shared/utils/ApplicationChecker.test.js +2 -0
  556. package/lib/esm/internal/shared/utils/ApplicationChecker.test.js.map +7 -0
  557. package/lib/esm/internal/transaction/di/transactionModule.js +1 -1
  558. package/lib/esm/internal/transaction/di/transactionModule.js.map +3 -3
  559. package/lib/esm/internal/transaction/di/transactionModule.test.js +1 -1
  560. package/lib/esm/internal/transaction/di/transactionModule.test.js.map +2 -2
  561. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
  562. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
  563. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
  564. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
  565. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +0 -1
  566. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +4 -4
  567. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +1 -1
  568. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
  569. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  570. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
  571. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js +1 -1
  572. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js.map +2 -2
  573. package/lib/esm/internal/typed-data/di/typedDataModule.js +1 -1
  574. package/lib/esm/internal/typed-data/di/typedDataModule.js.map +3 -3
  575. package/lib/esm/internal/typed-data/di/typedDataModule.test.js +1 -1
  576. package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +2 -2
  577. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
  578. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
  579. package/lib/esm/internal/typed-data/service/TypedDataParser.js +1 -1
  580. package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +3 -3
  581. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +1 -1
  582. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
  583. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
  584. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
  585. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
  586. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
  587. package/lib/esm/package.json +44 -41
  588. package/lib/types/api/SignerEth.d.ts +11 -4
  589. package/lib/types/api/SignerEth.d.ts.map +1 -1
  590. package/lib/types/api/SignerEthBuilder.d.ts +4 -2
  591. package/lib/types/api/SignerEthBuilder.d.ts.map +1 -1
  592. package/lib/types/api/app-binder/GetConfigCommandTypes.d.ts +7 -0
  593. package/lib/types/api/app-binder/GetConfigCommandTypes.d.ts.map +1 -0
  594. package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts +19 -0
  595. package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts.map +1 -0
  596. package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +1 -10
  597. package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +1 -1
  598. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +26 -8
  599. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
  600. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +26 -1
  601. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -1
  602. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts +30 -0
  603. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts.map +1 -0
  604. package/lib/types/api/index.d.ts +5 -4
  605. package/lib/types/api/index.d.ts.map +1 -1
  606. package/lib/types/api/model/AddressOptions.d.ts +1 -0
  607. package/lib/types/api/model/AddressOptions.d.ts.map +1 -1
  608. package/lib/types/api/model/ClearSigningType.d.ts +5 -0
  609. package/lib/types/api/model/ClearSigningType.d.ts.map +1 -0
  610. package/lib/types/api/model/MessageOptions.d.ts +4 -0
  611. package/lib/types/api/model/MessageOptions.d.ts.map +1 -0
  612. package/lib/types/api/model/SafeAddressOptions.d.ts +5 -0
  613. package/lib/types/api/model/SafeAddressOptions.d.ts.map +1 -0
  614. package/lib/types/api/model/TransactionOptions.d.ts +1 -0
  615. package/lib/types/api/model/TransactionOptions.d.ts.map +1 -1
  616. package/lib/types/api/model/TypedDataOptions.d.ts +4 -0
  617. package/lib/types/api/model/TypedDataOptions.d.ts.map +1 -0
  618. package/lib/types/internal/DefaultSignerEth.d.ts +10 -3
  619. package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -1
  620. package/lib/types/internal/address/di/addressModule.d.ts.map +1 -1
  621. package/lib/types/internal/address/use-case/GetAddressUseCase.d.ts.map +1 -1
  622. package/lib/types/internal/app-binder/EthAppBinder.d.ts +19 -3
  623. package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -1
  624. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts +1 -0
  625. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -1
  626. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts +11 -0
  627. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts.map +1 -0
  628. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.test.d.ts +2 -0
  629. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.test.d.ts.map +1 -0
  630. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts +1 -0
  631. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -1
  632. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +1 -0
  633. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -1
  634. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +1 -0
  635. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -1
  636. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts +29 -0
  637. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts.map +1 -0
  638. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts +2 -0
  639. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts.map +1 -0
  640. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts +21 -0
  641. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts.map +1 -0
  642. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts +2 -0
  643. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts.map +1 -0
  644. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts +35 -0
  645. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts.map +1 -0
  646. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts +2 -0
  647. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts.map +1 -0
  648. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +1 -0
  649. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -1
  650. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +1 -0
  651. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -1
  652. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +1 -0
  653. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -1
  654. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +1 -0
  655. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -1
  656. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts +18 -0
  657. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts.map +1 -0
  658. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.test.d.ts +2 -0
  659. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.test.d.ts.map +1 -0
  660. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +37 -1
  661. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -1
  662. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +1 -0
  663. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -1
  664. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +1 -0
  665. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -1
  666. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts +1 -0
  667. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -1
  668. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts +1 -0
  669. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -1
  670. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts +30 -0
  671. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts.map +1 -0
  672. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts +2 -0
  673. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts.map +1 -0
  674. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts +1 -0
  675. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -1
  676. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts +1 -0
  677. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -1
  678. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts +1 -0
  679. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -1
  680. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +1 -0
  681. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -1
  682. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +1 -0
  683. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -1
  684. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts +16 -0
  685. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts.map +1 -0
  686. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.test.d.ts +2 -0
  687. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.test.d.ts.map +1 -0
  688. package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts.map +1 -1
  689. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +23 -35
  690. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -1
  691. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +17 -2
  692. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -1
  693. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts +20 -0
  694. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts.map +1 -0
  695. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts +2 -0
  696. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts.map +1 -0
  697. package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +2 -1
  698. package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
  699. package/lib/types/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +1 -1
  700. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +5 -2
  701. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +1 -1
  702. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts +6 -0
  703. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts.map +1 -0
  704. package/lib/types/internal/app-binder/di/appBinderModule.d.ts.map +1 -1
  705. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts +47 -0
  706. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts.map +1 -0
  707. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts +2 -0
  708. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts.map +1 -0
  709. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts +17 -5
  710. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
  711. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts +39 -0
  712. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts.map +1 -0
  713. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts +2 -0
  714. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts.map +1 -0
  715. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts +19 -0
  716. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts.map +1 -0
  717. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts +2 -0
  718. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts.map +1 -0
  719. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts +28 -0
  720. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts.map +1 -0
  721. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts +2 -0
  722. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts.map +1 -0
  723. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts +21 -0
  724. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts.map +1 -0
  725. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts +2 -0
  726. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts.map +1 -0
  727. package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts +17 -0
  728. package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts.map +1 -0
  729. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts +2 -0
  730. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts.map +1 -0
  731. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts +22 -0
  732. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts.map +1 -0
  733. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts +2 -0
  734. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts.map +1 -0
  735. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +19 -5
  736. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -1
  737. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts +36 -0
  738. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts.map +1 -0
  739. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts +2 -0
  740. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts.map +1 -0
  741. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +2 -2
  742. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -1
  743. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts +18 -0
  744. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts.map +1 -0
  745. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts +2 -0
  746. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts.map +1 -0
  747. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +2 -1
  748. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -1
  749. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts +12 -0
  750. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts.map +1 -0
  751. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts +2 -0
  752. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts.map +1 -0
  753. package/lib/types/internal/di.d.ts.map +1 -1
  754. package/lib/types/internal/eip7702/di/eip7702Module.d.ts +3 -0
  755. package/lib/types/internal/eip7702/di/eip7702Module.d.ts.map +1 -0
  756. package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts +2 -0
  757. package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts.map +1 -0
  758. package/lib/types/internal/eip7702/di/eip7702Types.d.ts +4 -0
  759. package/lib/types/internal/eip7702/di/eip7702Types.d.ts.map +1 -0
  760. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts +8 -0
  761. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts.map +1 -0
  762. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts +2 -0
  763. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts.map +1 -0
  764. package/lib/types/internal/message/di/messageModule.d.ts.map +1 -1
  765. package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts +2 -1
  766. package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
  767. package/lib/types/internal/safe/di/safeModule.d.ts +3 -0
  768. package/lib/types/internal/safe/di/safeModule.d.ts.map +1 -0
  769. package/lib/types/internal/safe/di/safeModule.test.d.ts +2 -0
  770. package/lib/types/internal/safe/di/safeModule.test.d.ts.map +1 -0
  771. package/lib/types/internal/safe/di/safeTypes.d.ts +4 -0
  772. package/lib/types/internal/safe/di/safeTypes.d.ts.map +1 -0
  773. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts +9 -0
  774. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts.map +1 -0
  775. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts +2 -0
  776. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts.map +1 -0
  777. package/lib/types/internal/shared/utils/ApplicationChecker.d.ts +13 -0
  778. package/lib/types/internal/shared/utils/ApplicationChecker.d.ts.map +1 -0
  779. package/lib/types/internal/shared/utils/ApplicationChecker.test.d.ts +2 -0
  780. package/lib/types/internal/shared/utils/ApplicationChecker.test.d.ts.map +1 -0
  781. package/lib/types/internal/transaction/di/transactionModule.d.ts.map +1 -1
  782. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts +8 -0
  783. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts.map +1 -0
  784. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts +2 -0
  785. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts.map +1 -0
  786. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts +4 -7
  787. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +1 -1
  788. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts +2 -2
  789. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts.map +1 -1
  790. package/lib/types/internal/typed-data/di/typedDataModule.d.ts.map +1 -1
  791. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts +4 -2
  792. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -1
  793. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +2 -1
  794. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +1 -1
  795. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  796. package/package.json +42 -39
  797. package/lib/cjs/internal/app-binder/constant/plugins.js +0 -2
  798. package/lib/cjs/internal/app-binder/constant/plugins.js.map +0 -7
  799. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -2
  800. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +0 -7
  801. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +0 -2
  802. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +0 -7
  803. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  804. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  805. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  806. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  807. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  808. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  809. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  810. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  811. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
  812. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
  813. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
  814. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
  815. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
  816. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
  817. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
  818. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
  819. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
  820. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
  821. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
  822. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
  823. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +0 -2
  824. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +0 -7
  825. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
  826. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
  827. package/lib/esm/internal/app-binder/constant/plugins.js +0 -2
  828. package/lib/esm/internal/app-binder/constant/plugins.js.map +0 -7
  829. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -2
  830. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +0 -7
  831. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +0 -2
  832. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +0 -7
  833. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  834. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  835. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  836. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  837. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  838. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  839. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  840. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  841. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
  842. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
  843. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
  844. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
  845. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
  846. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
  847. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
  848. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
  849. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
  850. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
  851. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
  852. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
  853. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +0 -1
  854. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
  855. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
  856. package/lib/types/internal/app-binder/constant/plugins.d.ts +0 -2
  857. package/lib/types/internal/app-binder/constant/plugins.d.ts.map +0 -1
  858. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +0 -18
  859. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
  860. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts +0 -2
  861. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts.map +0 -1
  862. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -27
  863. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  864. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +0 -2
  865. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +0 -1
  866. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -37
  867. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  868. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +0 -2
  869. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +0 -1
  870. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +0 -73
  871. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +0 -1
  872. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +0 -2
  873. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +0 -1
  874. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +0 -26
  875. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +0 -1
  876. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +0 -2
  877. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +0 -1
  878. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts +0 -7
  879. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts.map +0 -1
  880. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts +0 -2
  881. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts.map +0 -1
  882. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -6
  883. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  884. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts +0 -2
  885. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts.map +0 -1
  886. /package/lib/esm/{internal/transaction/service/mapper/TransactionMapper.js.map → api/app-binder/GetConfigCommandTypes.js.map} +0 -0
@@ -1,2 +1,2 @@
1
- import{isSuccessCommandResult as d,OpenAppDeviceAction as g,UnknownDAError as S,UserInteractionRequired as i,XStateDeviceAction as C}from"@ledgerhq/device-management-kit";import{Left as m,Right as T}from"purify-ts";import{assign as n,fromPromise as a,setup as y}from"xstate";import{GetChallengeCommand as h}from"../../../app-binder/command/GetChallengeCommand";import{ETHEREUM_PLUGINS as x}from"../../../app-binder/constant/plugins";import{BuildTransactionContextTask as E}from"../../../app-binder/task/BuildTransactionContextTask";import{ProvideTransactionContextTask as v}from"../../../app-binder/task/ProvideTransactionContextTask";import{ProvideTransactionGenericContextTask as A}from"../../../app-binder/task/ProvideTransactionGenericContextTask";import{SendSignTransactionTask as D}from"../../../app-binder/task/SendSignTransactionTask";class U extends C{makeStateMachine(r){const{getChallenge:o,buildContext:s,provideContext:c,provideGenericContext:l,signTransaction:u}=this.extractDependencies(r);return y({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new g({input:{appName:"Ethereum"}}).makeStateMachine(r),getChallenge:a(o),buildContext:a(s),provideContext:a(c),provideGenericContext:a(l),signTransaction:a(u)},guards:{noInternalError:({context:t})=>t._internalState.error===null,isGenericContext:({context:t})=>t._internalState.clearSignContexts!==null&&typeof t._internalState.clearSignContexts.transactionInfo=="string"},actions:{assignErrorFromEvent:n({_internalState:t=>({...t.context._internalState,error:t.event.error})})}}).createMachine({id:"SignTransactionDeviceAction",initial:"OpenAppDeviceAction",context:({input:t})=>({input:t,intermediateValue:{requiredUserInteraction:i.None},_internalState:{error:null,clearSignContexts:null,serializedTransaction:null,chainId:null,transactionType:null,challenge:null,isLegacy:!0,signature:null}}),states:{OpenAppDeviceAction:{exit:n({intermediateValue:{requiredUserInteraction:i.None}}),invoke:{id:"openAppStateMachine",input:{appName:"Ethereum",compatibleAppNames:x},src:"openAppStateMachine",onSnapshot:{actions:n({intermediateValue:t=>t.event.snapshot.context.intermediateValue})},onDone:{actions:n({_internalState:t=>t.event.output.caseOf({Right:()=>t.context._internalState,Left:e=>({...t.context._internalState,error:e})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"GetChallenge",guard:"noInternalError"},"Error"]},GetChallenge:{invoke:{id:"getChallenge",src:"getChallenge",onDone:{target:"GetChallengeResultCheck",actions:[n({_internalState:({event:t,context:e})=>d(t.output)?{...e._internalState,challenge:t.output.data.challenge}:typeof t.output.error.originalError=="object"&&t.output.error.originalError!==null&&"errorCode"in t.output.error.originalError&&t.output.error.originalError.errorCode==="6d00"?e._internalState:{...e._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetChallengeResultCheck:{always:[{target:"BuildContext",guard:"noInternalError"},"Error"]},BuildContext:{invoke:{id:"buildContext",src:"buildContext",input:({context:t})=>({contextModule:t.input.contextModule,mapper:t.input.mapper,transaction:t.input.transaction,options:t.input.options,challenge:t._internalState.challenge}),onDone:{target:"BuildContextResultCheck",actions:[n({_internalState:({event:t,context:e})=>({...e._internalState,clearSignContexts:t.output.clearSignContexts,serializedTransaction:t.output.serializedTransaction,chainId:t.output.chainId,transactionType:t.output.transactionType})})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},BuildContextResultCheck:{always:[{target:"ProvideGenericContext",guard:"isGenericContext"},{target:"ProvideContext"}]},ProvideContext:{invoke:{id:"provideContext",src:"provideContext",input:({context:t})=>({clearSignContexts:t._internalState.clearSignContexts}),onDone:{target:"SignTransaction"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideGenericContext:{invoke:{id:"provideGenericContext",src:"provideGenericContext",input:({context:t})=>({contextModule:t.input.contextModule,transactionParser:t.input.parser,chainId:t._internalState.chainId,derivationPath:t.input.derivationPath,serializedTransaction:t._internalState.serializedTransaction,context:t._internalState.clearSignContexts}),onDone:{actions:n({_internalState:({event:t,context:e})=>{const{isLegacy:f,...p}=e._internalState;return t.output.caseOf({Just:()=>({...p,isLegacy:!1}),Nothing:()=>({...p,isLegacy:!1})})}}),target:"SignTransaction"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTransaction:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTransaction}}),exit:n({intermediateValue:{requiredUserInteraction:i.None}}),invoke:{id:"signTransaction",src:"signTransaction",input:({context:t})=>({derivationPath:t.input.derivationPath,serializedTransaction:t._internalState.serializedTransaction,chainId:t._internalState.chainId,transactionType:t._internalState.transactionType,isLegacy:t._internalState.isLegacy}),onDone:{target:"SignTransactionResultCheck",actions:[n({_internalState:({event:t,context:e})=>d(t.output)?{...e._internalState,signature:t.output.data}:{...e._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTransactionResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:t})=>t._internalState.signature?T(t._internalState.signature):m(t._internalState.error||new S("No error in final state"))})}extractDependencies(r){return{getChallenge:async()=>r.sendCommand(new h),buildContext:async t=>new E(r,t.input).run(),provideContext:async t=>new v(r,{clearSignContexts:t.input.clearSignContexts}).run(),provideGenericContext:async t=>new A(r,{contextModule:t.input.contextModule,transactionParser:t.input.transactionParser,chainId:t.input.chainId,derivationPath:t.input.derivationPath,serializedTransaction:t.input.serializedTransaction,context:t.input.context}).run(),signTransaction:async t=>new D(r,t.input).run()}}}export{U as SignTransactionDeviceAction};
1
+ import{DeviceModelId as p,isSuccessCommandResult as s,OpenAppDeviceAction as m,UnknownDAError as A,UserInteractionRequired as i,XStateDeviceAction as y}from"@ledgerhq/device-management-kit";import{Left as h,Right as E}from"purify-ts";import{and as I,assign as n,fromPromise as o,setup as k}from"xstate";import{SignTransactionDAStep as a}from"../../../../api/app-binder/SignTransactionDeviceActionTypes";import{ClearSigningType as _}from"../../../../api/model/ClearSigningType";import{GetAddressCommand as f}from"../../../app-binder/command/GetAddressCommand";import{GetAppConfiguration as D}from"../../../app-binder/command/GetAppConfigurationCommand";import{Web3CheckOptInCommand as v}from"../../../app-binder/command/Web3CheckOptInCommand";import{BuildFullContextsTask as P}from"../../../app-binder/task/BuildFullContextsTask";import{ParseTransactionTask as b}from"../../../app-binder/task/ParseTransactionTask";import{ProvideTransactionContextsTask as O}from"../../../app-binder/task/ProvideTransactionContextsTask";import{SendSignTransactionTask as R}from"../../../app-binder/task/SendSignTransactionTask";import{ApplicationChecker as N}from"../../../shared/utils/ApplicationChecker";class H extends y{makeStateMachine(r){const{getAddress:c,getAppConfig:u,web3CheckOptIn:l,parseTransaction:d,buildContexts:g,signTransaction:S,provideContexts:T}=this.extractDependencies(r);return k({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new m({input:{appName:"Ethereum"}}).makeStateMachine(r),getAddress:o(c),getAppConfig:o(u),web3CheckOptIn:o(l),parseTransaction:o(d),buildContexts:o(g),provideContexts:o(T),signTransaction:o(S)},guards:{noInternalError:({context:t})=>t._internalState.error===null,notRefusedByUser:({context:t})=>t._internalState.error!==null&&(!("errorCode"in t._internalState.error)||t._internalState.error.errorCode!=="6985"),isWeb3ChecksSupported:({context:t})=>new N(r.getDeviceSessionState(),t._internalState.appConfig).withMinVersionExclusive("1.15.0").excludeDeviceModel(p.NANO_S).excludeDeviceModel(p.NANO_SP).excludeDeviceModel(p.NANO_X).check(),shouldOptIn:({context:t})=>!t._internalState.appConfig.web3ChecksEnabled&&!t._internalState.appConfig.web3ChecksOptIn,skipOpenApp:({context:t})=>!!t.input.options.skipOpenApp},actions:{assignErrorFromEvent:n({_internalState:t=>({...t.context._internalState,error:t.event.error})})}}).createMachine({id:"SignTransactionDeviceAction",initial:"InitialState",context:({input:t})=>({input:t,intermediateValue:{requiredUserInteraction:i.None,step:a.OPEN_APP},_internalState:{error:null,appConfig:null,subset:null,contexts:[],clearSigningType:null,transactionType:null,signature:null}}),states:{InitialState:{always:[{target:"GetAppConfig",guard:"skipOpenApp"},"OpenAppDeviceAction"]},OpenAppDeviceAction:{invoke:{id:"openAppStateMachine",input:{appName:"Ethereum"},src:"openAppStateMachine",onSnapshot:{actions:n({intermediateValue:t=>({...t.event.snapshot.context.intermediateValue,step:a.OPEN_APP})})},onDone:{actions:n({_internalState:t=>t.event.output.caseOf({Right:()=>t.context._internalState,Left:e=>({...t.context._internalState,error:e})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"GetAppConfig",guard:"noInternalError"},"Error"]},GetAppConfig:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.GET_APP_CONFIG}}),invoke:{id:"getAppConfig",src:"getAppConfig",onDone:{target:"GetAppConfigResultCheck",actions:[n({_internalState:({event:t,context:e})=>s(t.output)?{...e._internalState,appConfig:t.output.data}:{...e._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetAppConfigResultCheck:{always:[{target:"Web3ChecksOptIn",guard:I(["noInternalError","isWeb3ChecksSupported","shouldOptIn"])},{target:"ParseTransaction",guard:"noInternalError"},{target:"Error"}]},Web3ChecksOptIn:{entry:n({intermediateValue:{requiredUserInteraction:i.Web3ChecksOptIn,step:a.WEB3_CHECKS_OPT_IN}}),invoke:{id:"web3CheckOptIn",src:"web3CheckOptIn",onDone:{target:"Web3ChecksOptInResult",actions:[n({_internalState:({event:t,context:e})=>s(t.output)?{...e._internalState,appConfig:{...e._internalState.appConfig,web3ChecksEnabled:t.output.data.enabled}}:e._internalState})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},Web3ChecksOptInResult:{entry:n(({context:t})=>({intermediateValue:{requiredUserInteraction:i.None,step:a.WEB3_CHECKS_OPT_IN_RESULT,result:t._internalState.appConfig.web3ChecksEnabled}})),after:{0:{target:"ParseTransaction"}}},ParseTransaction:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.PARSE_TRANSACTION}}),invoke:{id:"parseTransaction",src:"parseTransaction",input:({context:t})=>({mapper:t.input.mapper,transaction:t.input.transaction}),onDone:{target:"GetAddress",actions:n({_internalState:({event:t,context:e})=>({...e._internalState,subset:t.output.subset,transactionType:t.output.type})})},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetAddress:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.GET_ADDRESS}}),invoke:{id:"getAddress",src:"getAddress",input:({context:t})=>({derivationPath:t.input.derivationPath,checkOnDevice:!1,returnChainCode:!1}),onDone:{target:"BuildContexts",actions:n({_internalState:({event:t,context:e})=>{if(s(t.output)){const C={...e._internalState.subset,from:t.output.data.address};return{...e._internalState,subset:C}}return{...e._internalState}}})},onError:{target:"Error"}}},BuildContexts:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.BUILD_CONTEXTS}}),invoke:{id:"buildContexts",src:"buildContexts",input:({context:t})=>({contextModule:t.input.contextModule,mapper:t.input.mapper,parser:t.input.parser,options:t.input.options,appConfig:t._internalState.appConfig,derivationPath:t.input.derivationPath,subset:t._internalState.subset,transaction:t.input.transaction,deviceModelId:r.getDeviceModel().id}),onDone:{target:"ProvideContexts",actions:[n({_internalState:({event:t,context:e})=>({...e._internalState,contexts:t.output.clearSignContexts,clearSigningType:t.output.clearSigningType})})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContexts:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.PROVIDE_CONTEXTS}}),exit:n({_internalState:({context:t})=>({...t._internalState,contexts:t._internalState.contexts.slice(1)})}),invoke:{id:"provideContexts",src:"provideContexts",input:({context:t})=>({contexts:t._internalState.contexts,derivationPath:t.input.derivationPath,serializedTransaction:t.input.transaction}),onDone:{target:"SignTransaction"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTransaction:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTransaction,step:a.SIGN_TRANSACTION}}),invoke:{id:"signTransaction",src:"signTransaction",input:({context:t})=>({derivationPath:t.input.derivationPath,serializedTransaction:t.input.transaction,chainId:t._internalState.subset.chainId,transactionType:t._internalState.transactionType,clearSigningType:t._internalState.clearSigningType}),onDone:{target:"SignTransactionResultCheck",actions:[n({_internalState:({event:t,context:e})=>s(t.output)?{...e._internalState,signature:t.output.data}:{...e._internalState,error:t.output.error}})]},onError:{target:"SignTransactionResultCheck",actions:"assignErrorFromEvent"}}},SignTransactionResultCheck:{always:[{guard:"noInternalError",target:"Success"},{guard:"notRefusedByUser",target:"BlindSignTransactionFallback"},{target:"Error"}]},BlindSignTransactionFallback:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.BLIND_SIGN_TRANSACTION_FALLBACK}}),invoke:{id:"blindSignTransactionFallback",src:"signTransaction",input:({context:t})=>({derivationPath:t.input.derivationPath,serializedTransaction:t.input.transaction,chainId:t._internalState.subset.chainId,transactionType:t._internalState.transactionType,clearSigningType:_.BASIC}),onDone:{target:"BlindSignTransactionFallbackResultCheck",actions:[n({_internalState:({event:t,context:e})=>s(t.output)?{...e._internalState,signature:t.output.data}:{...e._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},BlindSignTransactionFallbackResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:t})=>t._internalState.signature?E(t._internalState.signature):h(t._internalState.error||new A("No error in final state"))})}extractDependencies(r){return{getAddress:async t=>r.sendCommand(new f(t.input)),getAppConfig:async()=>r.sendCommand(new D),web3CheckOptIn:async()=>r.sendCommand(new v),parseTransaction:async t=>Promise.resolve(new b({mapper:t.input.mapper,transaction:t.input.transaction}).run()),buildContexts:async t=>new P(r,t.input).run(),provideContexts:async t=>new O(r,t.input).run(),signTransaction:async t=>new R(r,{...t.input}).run()}}}export{H as SignTransactionDeviceAction};
2
2
  //# sourceMappingURL=SignTransactionDeviceAction.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.ts"],
4
- "sourcesContent": ["import {\n type ClearSignContextSuccess,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type CommandResult,\n type DeviceActionStateMachine,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, type Maybe, Right } from \"purify-ts\";\nimport { assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type SignTransactionDAError,\n type SignTransactionDAInput,\n type SignTransactionDAIntermediateValue,\n type SignTransactionDAInternalState,\n type SignTransactionDAOutput,\n} from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TransactionOptions } from \"@api/model/TransactionOptions\";\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport {\n GetChallengeCommand,\n type GetChallengeCommandResponse,\n} from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport {\n BuildTransactionContextTask,\n type BuildTransactionContextTaskArgs,\n type BuildTransactionTaskResult,\n} from \"@internal/app-binder/task/BuildTransactionContextTask\";\nimport { ProvideTransactionContextTask } from \"@internal/app-binder/task/ProvideTransactionContextTask\";\nimport {\n type GenericContext,\n ProvideTransactionGenericContextTask,\n type ProvideTransactionGenericContextTaskErrorCodes,\n} from \"@internal/app-binder/task/ProvideTransactionGenericContextTask\";\nimport { SendSignTransactionTask } from \"@internal/app-binder/task/SendSignTransactionTask\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nexport type MachineDependencies = {\n readonly getChallenge: () => Promise<\n CommandResult<GetChallengeCommandResponse, EthErrorCodes>\n >;\n readonly buildContext: (arg0: {\n input: {\n contextModule: ContextModule;\n mapper: TransactionMapperService;\n transaction: Uint8Array;\n options: TransactionOptions;\n challenge: string | null;\n };\n }) => Promise<BuildTransactionTaskResult>;\n readonly provideContext: (arg0: {\n input: {\n clearSignContexts: ClearSignContextSuccess[];\n };\n }) => Promise<Maybe<CommandErrorResult<EthErrorCodes>>>;\n readonly provideGenericContext: (arg0: {\n input: {\n contextModule: ContextModule;\n transactionParser: TransactionParserService;\n chainId: number;\n derivationPath: string;\n serializedTransaction: Uint8Array;\n context: GenericContext;\n };\n }) => Promise<\n Maybe<CommandErrorResult<ProvideTransactionGenericContextTaskErrorCodes>>\n >;\n readonly signTransaction: (arg0: {\n input: {\n derivationPath: string;\n serializedTransaction: Uint8Array;\n chainId: number;\n transactionType: TransactionType;\n isLegacy: boolean;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTransactionDeviceAction extends XStateDeviceAction<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n > {\n type types = StateMachineTypes<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n >;\n\n const {\n getChallenge,\n buildContext,\n provideContext,\n provideGenericContext,\n signTransaction,\n } = this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Ethereum\" },\n }).makeStateMachine(internalApi),\n getChallenge: fromPromise(getChallenge),\n buildContext: fromPromise(buildContext),\n provideContext: fromPromise(provideContext),\n provideGenericContext: fromPromise(provideGenericContext),\n signTransaction: fromPromise(signTransaction),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n isGenericContext: ({ context }) =>\n context._internalState.clearSignContexts !== null &&\n typeof (context._internalState.clearSignContexts as GenericContext)\n .transactionInfo === \"string\",\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n /** @xstate-layout N4IgpgJg5mDOIC5QGUCWUB2AVATgQw1jwGMAXVAewwBEwA3VYsAQTMowDoB5ABzA2Y8etBk1bkqAYghUwHVBjoUA1nIp8BQ5KTykwAWRIALBWADaABgC6iUDwqxUEjLZAAPRABYAzAHYOAJwAHACMAb4ArBYWAEw+FkHeADQgAJ6IwRYcAGwRQUG52TF5EcUAvmUpaJi4BERsVCKMLA2cAMJGYMTKvPyCwvTN4uwASnAArgA2pJKWNkgg9o7Orh4IAcEcpRYhvonZAd4byWmIITtZESEhBTHeEVH33hVV6Nj4hCTOTWKtHB1dHoafo-FrOMawKYzMwheZ2BxOdirDKbba7faHY4pdIIUIcG6+bwWbKeXwxIKeTzkl4garvOpfdig4ZUDgAcTApA6eEmk34MGksnkihUchgXKMPL5GBgc1cS0RVGRCBCngC2Q4aqCewCEWyQUyJxx5x2HBiByCsV8AQsaoinhpdNqn1azL+HIlUv5YEkYBwOAoOA4PEmugAZoGALYccXc3neuULBUrBZrVXqzXBHV6g2Wo1nDaasIWXxkwkxW0xXyOt7O+rfQa-Zzszlx6UwCFQgHdWbWeUIlOgNMBTxBDiJby3MkmiK+bFnCzeEL4mLm4m5aLeB2VWm1j71pmNsHsFue+MysCd6bd5SzWH95ZI1MF0fj7yTorT6Kz+cILfLhJEgiDZslVXwLACGsan3RlGiPFlOAAIXGVBJggNoqD0NwZhkDA5AUJRVA4AAjFC0IwjAsNIRN4UfJVnwQOJPCyIJyWLHYqV1bJf3OGJl3yYlfFA0dsiOZ4dydGDXXgv5kNQ9DMLAbDfX9QNg1DUgIxwaNSPkiiqJoxYByfIdECYli2JtDiYi439PGAjhvArVdrT4skDm3V5oIZaTRGPVk5PIxTsKvCVAV7OEjLolwGPJfJMwrUkjkiNUeIsK4OEJLdLWiUI9ig+kXQbPyEI4QKFMopTSFCm870i5MTPcMz8jHNVEsJcJ7QCX88pySJSlKPw7jCAq61gmgZObAAFAMGAgMB9KqwU8OFQi5B4WbUHmxbsMMhr6NMv9RzHFK8kiLdBu405cQSTV32Ym5slAw4YlGqTiqGP4ZooOaFuCmY-QDIMQ3DKNg027b-r24yDqao74tO7UIguu4rpxbJokCA0rmJCDjk83dvKKw8Sq+iGwA5PCcEYHacKFAjRXBn6top-g-RpqG+yTGGYsO7KTvtM7kfs1HfyszLfDCbIySpdzxK8wqDzg0npvJyn2eIWmVKB9TQe0pnfvV6nNc5+qeeVfnMsFpGUe8NGF3snI8liViQlEolIIkvcfI+psT0kn32GW-CRSIxwiaVjBoei5VmL2M1SSCB4KyTykIh6wtDgKcJJbyAIRq9iPxrdZsA+JqRAbUkHNLB8PFfG6PFV5uG47HOI9mThJ7Xs39fCpJ3tRe4JzTewPlc+0vvfLjAas6HtG8HFuuo4YldiXOJQgpdProCGzMvz-VOOYuPR+nkv-anyPZ-CmEzZjhj7LVFfQMJEIN5uHvrvyTxHPJEtgIKKUXIFQdwYAoPNeACwy6R3PrDfazc1gAFp7YIGQSvaIGDMEYNnKfGBk0Ty9E0AMFWjV4GxxiGLPUCc9SlGCKBSsuDi74NZDeQhIJmEzwmNMB8TdlT6n8HxEIeoP5kichQ66JoYgrzytjDBk5qyF3rr5CeJ4PRtm9DwxeaYbhjkHtla0dtRJzh3knfEs53wbHztaHwjDlF+1ZGoyU54OxcLCt0TRjU0zgW8IECCrF872Q2PaNKq4ci7yeuSPINxqSKLGnY-ySEyIVSoh42Gaw+JHHxIcaIGxOIlnzCqb8mV9QZK3McJOtjfYJLKkk2m193Hc3vodc0r47i7xssBEIS40o+EcouZGRQ3ZOSepUkmKjWTfV+rTVJCDEBLicpqAoeYUqLm6tdVyv9JHaiOPnUZ497GcEmSzI2HNKrYRmRbCCUjSzmjfsjCshw0pu3HK5aWfdbSeBGbE96YyDkcGgeNC5DE-DMRXl080fdKShDWTiCkAR8QHDCLsG05JyjfLHhNEhrIAWtHqcoIFh0qSmNyPkEcHc9Riz4o5UCDx3ZbiXBEPZmLxmcGQOMYgTBYCQNorwh+Ql4VUgSD4J6uRPAhEpRqWhYRjoXCCEy2BnAACiqkcAEpbvyzUKdhVPXtOK66oExwY3VEI1Ffhd4gLKEAA */\n id: \"SignTransactionDeviceAction\",\n initial: \"OpenAppDeviceAction\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n _internalState: {\n error: null,\n clearSignContexts: null,\n serializedTransaction: null,\n chainId: null,\n transactionType: null,\n challenge: null,\n isLegacy: true,\n signature: null,\n },\n };\n },\n states: {\n OpenAppDeviceAction: {\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"openAppStateMachine\",\n input: {\n appName: \"Ethereum\",\n compatibleAppNames: ETHEREUM_PLUGINS,\n },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) =>\n _.event.snapshot.context.intermediateValue,\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<SignTransactionDAInternalState>({\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n });\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"GetChallenge\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n GetChallenge: {\n invoke: {\n id: \"getChallenge\",\n src: \"getChallenge\",\n onDone: {\n target: \"GetChallengeResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n challenge: event.output.data.challenge,\n };\n }\n\n // if the command is not supported, we can skip the error\n if (\n typeof event.output.error.originalError === \"object\" &&\n event.output.error.originalError !== null &&\n \"errorCode\" in event.output.error.originalError &&\n event.output.error.originalError.errorCode === \"6d00\"\n ) {\n return context._internalState;\n }\n\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetChallengeResultCheck: {\n always: [\n {\n target: \"BuildContext\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n BuildContext: {\n invoke: {\n id: \"buildContext\",\n src: \"buildContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n mapper: context.input.mapper,\n transaction: context.input.transaction,\n options: context.input.options,\n challenge: context._internalState.challenge,\n }),\n onDone: {\n target: \"BuildContextResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n clearSignContexts: event.output.clearSignContexts!,\n serializedTransaction: event.output.serializedTransaction,\n chainId: event.output.chainId,\n transactionType: event.output.transactionType,\n }),\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n BuildContextResultCheck: {\n always: [\n {\n target: \"ProvideGenericContext\",\n guard: \"isGenericContext\",\n },\n {\n target: \"ProvideContext\",\n },\n ],\n },\n ProvideContext: {\n invoke: {\n id: \"provideContext\",\n src: \"provideContext\",\n input: ({ context }) => ({\n clearSignContexts: context._internalState\n .clearSignContexts as ClearSignContextSuccess[],\n }),\n onDone: {\n target: \"SignTransaction\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideGenericContext: {\n invoke: {\n id: \"provideGenericContext\",\n src: \"provideGenericContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n transactionParser: context.input.parser,\n chainId: context._internalState.chainId!,\n derivationPath: context.input.derivationPath,\n serializedTransaction:\n context._internalState.serializedTransaction!,\n context: context._internalState\n .clearSignContexts as GenericContext,\n }),\n onDone: {\n actions: assign({\n _internalState: ({ event, context }) => {\n const { isLegacy: _, ...rest } = context._internalState;\n return event.output.caseOf({\n Just: () => ({\n ...rest,\n isLegacy: false,\n }),\n Nothing: () => ({\n ...rest,\n isLegacy: false,\n }),\n });\n },\n }),\n // NOTE: don't check errors to fallback to blind signing\n target: \"SignTransaction\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTransaction: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"signTransaction\",\n src: \"signTransaction\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n serializedTransaction:\n context._internalState.serializedTransaction!,\n chainId: context._internalState.chainId!,\n transactionType: context._internalState.transactionType!,\n isLegacy: context._internalState.isLegacy,\n }),\n onDone: {\n target: \"SignTransactionResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTransactionResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.signature\n ? Right(context._internalState.signature)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(internalApi: InternalApi): MachineDependencies {\n const getChallenge = async () =>\n internalApi.sendCommand(new GetChallengeCommand());\n const buildContext = async (arg0: {\n input: BuildTransactionContextTaskArgs;\n }) => new BuildTransactionContextTask(internalApi, arg0.input).run();\n\n const provideContext = async (arg0: {\n input: {\n clearSignContexts: ClearSignContextSuccess[];\n };\n }) =>\n new ProvideTransactionContextTask(internalApi, {\n clearSignContexts: arg0.input.clearSignContexts,\n }).run();\n\n const provideGenericContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n transactionParser: TransactionParserService;\n chainId: number;\n derivationPath: string;\n serializedTransaction: Uint8Array;\n context: GenericContext;\n };\n }) =>\n new ProvideTransactionGenericContextTask(internalApi, {\n contextModule: arg0.input.contextModule,\n transactionParser: arg0.input.transactionParser,\n chainId: arg0.input.chainId,\n derivationPath: arg0.input.derivationPath,\n serializedTransaction: arg0.input.serializedTransaction,\n context: arg0.input.context,\n }).run();\n\n const signTransaction = async (arg0: {\n input: {\n derivationPath: string;\n serializedTransaction: Uint8Array;\n chainId: number;\n transactionType: TransactionType;\n isLegacy: boolean;\n };\n }) => new SendSignTransactionTask(internalApi, arg0.input).run();\n\n return {\n getChallenge,\n buildContext,\n provideContext,\n provideGenericContext,\n signTransaction,\n };\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "Left", "Right", "assign", "fromPromise", "setup", "GetChallengeCommand", "ETHEREUM_PLUGINS", "BuildTransactionContextTask", "ProvideTransactionContextTask", "ProvideTransactionGenericContextTask", "SendSignTransactionTask", "SignTransactionDeviceAction", "internalApi", "getChallenge", "buildContext", "provideContext", "provideGenericContext", "signTransaction", "context", "_", "input", "error", "event", "rest", "arg0"]
4
+ "sourcesContent": ["import {\n type CommandResult,\n type DeviceActionStateMachine,\n DeviceModelId,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\nimport { and, assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type GetAddressCommandArgs,\n type GetAddressCommandResponse,\n} from \"@api/app-binder/GetAddressCommandTypes\";\nimport { type GetConfigCommandResponse } from \"@api/app-binder/GetConfigCommandTypes\";\nimport {\n type SignTransactionDAError,\n type SignTransactionDAInput,\n type SignTransactionDAIntermediateValue,\n type SignTransactionDAInternalState,\n type SignTransactionDAOutput,\n SignTransactionDAStep,\n} from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { ClearSigningType } from \"@api/model/ClearSigningType\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport { GetAddressCommand } from \"@internal/app-binder/command/GetAddressCommand\";\nimport { GetAppConfiguration } from \"@internal/app-binder/command/GetAppConfigurationCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport {\n Web3CheckOptInCommand,\n type Web3CheckOptInCommandResponse,\n} from \"@internal/app-binder/command/Web3CheckOptInCommand\";\nimport {\n BuildFullContextsTask,\n type BuildFullContextsTaskArgs,\n type BuildFullContextsTaskResult,\n} from \"@internal/app-binder/task/BuildFullContextsTask\";\nimport {\n ParseTransactionTask,\n type ParseTransactionTaskArgs,\n type ParseTransactionTaskResult,\n} from \"@internal/app-binder/task/ParseTransactionTask\";\nimport {\n ProvideTransactionContextsTask,\n type ProvideTransactionContextsTaskArgs,\n type ProvideTransactionContextsTaskResult,\n} from \"@internal/app-binder/task/ProvideTransactionContextsTask\";\nimport { SendSignTransactionTask } from \"@internal/app-binder/task/SendSignTransactionTask\";\nimport { ApplicationChecker } from \"@internal/shared/utils/ApplicationChecker\";\n\nexport type MachineDependencies = {\n readonly getAddress: (arg0: {\n input: GetAddressCommandArgs;\n }) => Promise<CommandResult<GetAddressCommandResponse, EthErrorCodes>>;\n readonly getAppConfig: () => Promise<\n CommandResult<GetConfigCommandResponse, EthErrorCodes>\n >;\n readonly web3CheckOptIn: () => Promise<\n CommandResult<Web3CheckOptInCommandResponse, EthErrorCodes>\n >;\n readonly parseTransaction: (arg0: {\n input: ParseTransactionTaskArgs;\n }) => Promise<ParseTransactionTaskResult>;\n readonly buildContexts: (arg0: {\n input: BuildFullContextsTaskArgs;\n }) => Promise<BuildFullContextsTaskResult>;\n readonly provideContexts: (arg0: {\n input: ProvideTransactionContextsTaskArgs;\n }) => Promise<ProvideTransactionContextsTaskResult>;\n readonly signTransaction: (arg0: {\n input: {\n derivationPath: string;\n serializedTransaction: Uint8Array;\n chainId: number;\n transactionType: TransactionType;\n clearSigningType: ClearSigningType;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTransactionDeviceAction extends XStateDeviceAction<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n > {\n type types = StateMachineTypes<\n SignTransactionDAOutput,\n SignTransactionDAInput,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n SignTransactionDAInternalState\n >;\n\n const {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n parseTransaction,\n buildContexts,\n signTransaction,\n provideContexts,\n } = this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Ethereum\" },\n }).makeStateMachine(internalApi),\n getAddress: fromPromise(getAddress),\n getAppConfig: fromPromise(getAppConfig),\n web3CheckOptIn: fromPromise(web3CheckOptIn),\n parseTransaction: fromPromise(parseTransaction),\n buildContexts: fromPromise(buildContexts),\n provideContexts: fromPromise(provideContexts),\n signTransaction: fromPromise(signTransaction),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n notRefusedByUser: ({ context }) =>\n context._internalState.error !== null &&\n (!(\"errorCode\" in context._internalState.error) ||\n context._internalState.error.errorCode !== \"6985\"),\n isWeb3ChecksSupported: ({ context }) =>\n new ApplicationChecker(\n internalApi.getDeviceSessionState(),\n context._internalState.appConfig!,\n )\n .withMinVersionExclusive(\"1.15.0\")\n .excludeDeviceModel(DeviceModelId.NANO_S)\n .excludeDeviceModel(DeviceModelId.NANO_SP)\n .excludeDeviceModel(DeviceModelId.NANO_X)\n .check(),\n shouldOptIn: ({ context }) =>\n !context._internalState.appConfig!.web3ChecksEnabled &&\n !context._internalState.appConfig!.web3ChecksOptIn,\n skipOpenApp: ({ context }) => !!context.input.options.skipOpenApp,\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n /** @xstate-layout N4IgpgJg5mDOIC5QGUCWUB2AVATgQw1jwGMAXVAewwBEwA3VYsAQTMowDoBJDVcvADbJSeUmADEAbQAMAXUSgADhVh92CkAA9EARgDsAZg4AOACzGAnAFYDNgGxXpF6ToA0IAJ67TOgEwcDHTsLCz9pQN9bAF8o9zRMXAIiNipaBiZWcipuXn4hETEpHXkkEGVVLIwNbQR9IzNLG3tHZzdPXV87aQ5I5ztfSON+zpi49Gx8QhJKtMYWFM4AeUUwDGZFRVmMhfEIKjAOVAw6CgBrA4oVtY3hUTAAWRIACyOwGRKlFTUqasQ9RxMVjMdgcdj0xnBvncXlqkTsHAsQxcnVMvmM4TsoxA8QmSWm7C280qHAAwk8wMRTstVutNvQ5pl2AAlOAAVwEpCkcg05W+VVKNR0gW6IOsoWMfgMdlMdmhHRBHActisFnMMqCmNi2PGiSmC0JjOyZIpVKutINCxZsHZnMkxR5X0qv1qwsVwRVOglcJlcoQEo4ns9pmkQL00mCFgMWJxuuSM3p22JAHEwKRaSSqAAzdC7faHY5nA4wNMbDMYbNQd4OirqAW6CVWDhWPR2fR2Yy+Fu+UwGX1C4zGHoGcPSDuGCx6HTRnWTOMEhNE9gcFMlxRliviMA4HAUHAcRQCUSZ3cAWw4xfTWfQVdKvKdddqDabLbbY-6Pb7IQ4I+sPdR1n+KMtRjWd8VSBdDU4FdL3LdArRtY1KS5D4ykdWtQBqAYO2-MFwyBHRTEjNoYT8Lpv3CKwrG7Zt0VMPRpwSUD9QghZl1TGCK3gjlENOIoULvdCtEQLD-HDMMHAlQjAj7VEdADENg1MYNhQMUwGNxPV43SRdsmg0srygLjSB4qRfH4tCfgfEScPE-CpOIxBVO6HQiLbVUQR8dTYzAmgWOJAB1MAACMDB42BllIHhcwwA4jhOc4OAAd2C0LyUpCKeBvT4a0sjDhKGfxmxDXwMT0SIDF7dpYUono9B7YxbAI4xHGMLymK0hlWMCkKwoyjBN23Xd90PUhjxwM9kp6tLTUijAstQnL+TyhA0X6Z9itK8rKphUwgW-MrfFCXpKJcejgJnPFmO0yCOG61KTXCxRZqM8RNFgAoDjwTMxBwAAKaQAEpxBAy6OsTJc7t6p6eCM+aBNyoSEAqgjFVIz0LE6CxWz0PtOz0Dg9HBMquh8LowTa0H52u1iAAU8BwWAwG8nY9hi-N4oORR6cZ5nKjhiylsRgxwQsJtCOlIIdFHaQWz7AwJ2-FyCMGEMMbOsZGMp8DqeJOmGaZ9r2AGnc9wPI9T33bmDa1ubuVvAXnWFywxax0mpfRWWqpVUWSqUgYw2F5xWvOzXNKpzriQAIVZVABAgMsxE0UhYGi2KCwSoKY7jhOwCT2B+cW50e09RUSshJwQ0nGSdEbKx-1bUI7IsCmw+1iOl2j2P46oRPk+NoazdGi3M67nO84Lvki8CQd+hljsK+bByEDq7oKocbtI3BOurBbuc2-B7IaZ3BgIDAMe+9ZtOOf3Y-UFP8-87t7LJ4fcwyqbbGezq-orFlKqCLIs4XwVFgjSFOr-XePkLS61vvfHuuc+5bhNsNc240b4UBPmfeB48n4LRfstN+hVP7CxlMAv+MIBxyRlAVSck5xSQKuu3bIINW79UvuzQsHBVChz3rbcyhcHx1xKhwVEwwQgV0nFYGSv8EQDCFD4GuehVQ7xDhpXh0ClwsN4f3U2I0xpnm4WonyE97zLSEd0URAxxHOEkX2aQAxFRgLKqqVWDYGFgx0pwLRPkjImRMYJGoQJnBNiFIdCSIJwgySGE2SwZVwgr1DO48OB8vEXVYb46afFqz4MRkE7oVhQlYyBBE7augDC+DkgUiUZgqnlLqkk-eniOCRwEEcCA3iFgADFBACCCiQXi7C4qcKCq0jA7S0m8O6QIXp-T-EIxqNKFs35VQSlVDKQmpg5aohESqAcnQQT1NUbzZJTSWltI6ZUKZMykJIIHno4eozxk8J8lcvplI5mCwWeYRsEkWzNXbJ2YwfY-D42kKieJHY2zNgab5HWHdHkXPYK8-pGSTTIWyaYxGk5IjPmsHXfQeEoT-1UqLfowpKIdlWUBDWRjGEpOaQiiZLyelvNOKipCdp+E5JqNiowzY8U+FskSkiw5TAmGlCEQioR-j6BiFqDAFBT7wFKIixpkEMUBMQAAWnIdqxsIQQiE3BGClx0QjmGzVaxHgahBC3DEBq+ZiBUQyXCE2YWSjJxgOFtC81NsNHZGpNcOkcKEbw0+Y5OuJg1ZDCUSqQFuNgHfmDN2AOYCnBTl9aw-1nAeKBvNH5ZkbIOQOvDQgA1AQxy2BbKdWwuNmwmDqo4cwjRykwuzWxVc650AludDXMBPRmoGAlP8cwTg5aRs6GGGu+g0RgJUTS45lrkzsX0rBQyRbjLTR7VZex-g0QuU6HXIdE5Sm1GDKLHQSsgkShDMLNtBbsiQ2mo9Wa27lrANdWYP2-QPKdikf-ORAQpZKLBUKds96Q2cCfQ9PqRk31Cxlvjaw7YKIQk9iRYB-hKUFJogU4BEGmGcD1jzC1gsw2Ox7EYYWql5aqS6MUuWdgjAhjrpQ7GSiCP0s7tnbByd4M1GDK6hwlEpRbyBcS-0-LURlTqiEMwnGmlHwwXfLBGBe7KufpigTVFGzlKVJ6cMX65YQnkljaVUo-DdgUzdVVZGHaCNHP4Fy2KP32OCDJBx1gzCIkIuiexzdM3qIfak55loN08X44gX+nYAzlOA-oKio4ZKExMFLFUQJ4mnWs6xM5YzbPIspJFhAXR0QBkOkKLGdUOybIA4YAIwDDCehVCCfDgWoHBYZecplXSWUovC1u+2AjlpgiYyIicl6St4SXvI7oX7RzWCDFhbLxJkCsmIEwWAGm8Fab+LYIwLk66tnCEOsFyXdPyKGO7QIGaF2kfbQAUUGjgIrhgbABl-EdiqtFfT-HxgOd0TsQMdjlVEIAA */\n id: \"SignTransactionDeviceAction\",\n initial: \"InitialState\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n _internalState: {\n error: null,\n appConfig: null,\n subset: null,\n contexts: [],\n clearSigningType: null,\n transactionType: null,\n signature: null,\n },\n };\n },\n states: {\n InitialState: {\n always: [\n {\n target: \"GetAppConfig\",\n guard: \"skipOpenApp\",\n },\n \"OpenAppDeviceAction\",\n ],\n },\n OpenAppDeviceAction: {\n invoke: {\n id: \"openAppStateMachine\",\n input: {\n appName: \"Ethereum\",\n },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) => ({\n ..._.event.snapshot.context.intermediateValue,\n step: SignTransactionDAStep.OPEN_APP,\n }),\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<SignTransactionDAInternalState>({\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n });\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"GetAppConfig\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n GetAppConfig: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n }),\n invoke: {\n id: \"getAppConfig\",\n src: \"getAppConfig\",\n onDone: {\n target: \"GetAppConfigResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: event.output.data,\n };\n } else {\n return {\n ...context._internalState,\n error: event.output.error,\n };\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetAppConfigResultCheck: {\n always: [\n {\n target: \"Web3ChecksOptIn\",\n guard: and([\n \"noInternalError\",\n \"isWeb3ChecksSupported\",\n \"shouldOptIn\",\n ]),\n },\n {\n target: \"ParseTransaction\",\n guard: \"noInternalError\",\n },\n {\n target: \"Error\",\n },\n ],\n },\n Web3ChecksOptIn: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTransactionDAStep.WEB3_CHECKS_OPT_IN,\n },\n }),\n invoke: {\n id: \"web3CheckOptIn\",\n src: \"web3CheckOptIn\",\n onDone: {\n target: \"Web3ChecksOptInResult\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: {\n ...context._internalState.appConfig!,\n web3ChecksEnabled: event.output.data.enabled,\n },\n };\n } else {\n return context._internalState;\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n Web3ChecksOptInResult: {\n entry: assign(({ context }) => ({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.WEB3_CHECKS_OPT_IN_RESULT,\n result: context._internalState.appConfig!.web3ChecksEnabled,\n },\n })),\n // Using after transition to force a snapshot of the state after the entry action\n // This ensures the intermediateValue is captured before moving to ParseTransaction\n after: {\n 0: {\n target: \"ParseTransaction\",\n },\n },\n },\n ParseTransaction: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PARSE_TRANSACTION,\n },\n }),\n invoke: {\n id: \"parseTransaction\",\n src: \"parseTransaction\",\n input: ({ context }) => ({\n mapper: context.input.mapper,\n transaction: context.input.transaction,\n }),\n onDone: {\n target: \"GetAddress\",\n actions: assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n subset: event.output.subset,\n transactionType: event.output.type,\n }),\n }),\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetAddress: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_ADDRESS,\n },\n }),\n invoke: {\n id: \"getAddress\",\n src: \"getAddress\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n checkOnDevice: false,\n returnChainCode: false,\n }),\n onDone: {\n target: \"BuildContexts\",\n actions: assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n const subset = {\n ...context._internalState.subset!,\n from: event.output.data.address,\n };\n return {\n ...context._internalState,\n subset,\n };\n }\n return {\n ...context._internalState,\n };\n },\n }),\n },\n onError: {\n target: \"Error\",\n },\n },\n },\n BuildContexts: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXTS,\n },\n }),\n invoke: {\n id: \"buildContexts\",\n src: \"buildContexts\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n mapper: context.input.mapper,\n parser: context.input.parser,\n options: context.input.options,\n appConfig: context._internalState.appConfig!,\n derivationPath: context.input.derivationPath,\n subset: context._internalState.subset!,\n transaction: context.input.transaction,\n deviceModelId: internalApi.getDeviceModel().id,\n }),\n onDone: {\n target: \"ProvideContexts\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n contexts: event.output.clearSignContexts,\n clearSigningType: event.output.clearSigningType,\n }),\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContexts: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXTS,\n },\n }),\n exit: assign({\n // remove the first context of the first transaction details as it has been consumed\n _internalState: ({ context }) => {\n return {\n ...context._internalState,\n contexts: context._internalState.contexts.slice(1),\n };\n },\n }),\n invoke: {\n id: \"provideContexts\",\n src: \"provideContexts\",\n input: ({ context }) => ({\n contexts: context._internalState.contexts,\n derivationPath: context.input.derivationPath,\n serializedTransaction: context.input.transaction,\n }),\n onDone: {\n target: \"SignTransaction\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTransaction: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n }),\n invoke: {\n id: \"signTransaction\",\n src: \"signTransaction\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n serializedTransaction: context.input.transaction,\n chainId: context._internalState.subset!.chainId,\n transactionType: context._internalState.transactionType!,\n clearSigningType: context._internalState.clearSigningType!,\n }),\n onDone: {\n target: \"SignTransactionResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"SignTransactionResultCheck\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTransactionResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n {\n guard: \"notRefusedByUser\",\n target: \"BlindSignTransactionFallback\",\n },\n { target: \"Error\" },\n ],\n },\n BlindSignTransactionFallback: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BLIND_SIGN_TRANSACTION_FALLBACK,\n },\n }),\n invoke: {\n id: \"blindSignTransactionFallback\",\n src: \"signTransaction\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n serializedTransaction: context.input.transaction,\n chainId: context._internalState.subset!.chainId,\n transactionType: context._internalState.transactionType!,\n clearSigningType: ClearSigningType.BASIC,\n }),\n onDone: {\n target: \"BlindSignTransactionFallbackResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n BlindSignTransactionFallbackResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.signature\n ? Right(context._internalState.signature)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(internalApi: InternalApi): MachineDependencies {\n const getAddress = async (arg0: { input: GetAddressCommandArgs }) =>\n internalApi.sendCommand(new GetAddressCommand(arg0.input));\n const getAppConfig = async () =>\n internalApi.sendCommand(new GetAppConfiguration());\n const web3CheckOptIn = async () =>\n internalApi.sendCommand(new Web3CheckOptInCommand());\n const parseTransaction = async (arg0: {\n input: ParseTransactionTaskArgs;\n }) =>\n Promise.resolve(\n new ParseTransactionTask({\n mapper: arg0.input.mapper,\n transaction: arg0.input.transaction,\n }).run(),\n );\n const buildContexts = async (arg0: { input: BuildFullContextsTaskArgs }) =>\n new BuildFullContextsTask(internalApi, arg0.input).run();\n\n const provideContexts = async (arg0: {\n input: ProvideTransactionContextsTaskArgs;\n }) => {\n return new ProvideTransactionContextsTask(internalApi, arg0.input).run();\n };\n\n const signTransaction = async (arg0: {\n input: {\n derivationPath: string;\n serializedTransaction: Uint8Array;\n chainId: number;\n transactionType: TransactionType;\n clearSigningType: ClearSigningType;\n };\n }) =>\n new SendSignTransactionTask(internalApi, {\n ...arg0.input,\n }).run();\n\n return {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n parseTransaction,\n buildContexts,\n provideContexts,\n signTransaction,\n };\n }\n}\n"],
5
+ "mappings": "AAAA,OAGE,iBAAAA,EAEA,0BAAAC,EACA,uBAAAC,EAEA,kBAAAC,EACA,2BAAAC,EACA,sBAAAC,MACK,kCACP,OAAS,QAAAC,EAAM,SAAAC,MAAa,YAC5B,OAAS,OAAAC,EAAK,UAAAC,EAAQ,eAAAC,EAAa,SAAAC,MAAa,SAOhD,OAME,yBAAAC,MACK,mDACP,OAAS,oBAAAC,MAAwB,8BAGjC,OAAS,qBAAAC,MAAyB,iDAClC,OAAS,uBAAAC,MAA2B,0DAEpC,OACE,yBAAAC,MAEK,qDACP,OACE,yBAAAC,MAGK,kDACP,OACE,wBAAAC,MAGK,iDACP,OACE,kCAAAC,MAGK,2DACP,OAAS,2BAAAC,MAA+B,oDACxC,OAAS,sBAAAC,MAA0B,4CAgC5B,MAAMC,UAAoCjB,CAM/C,CACA,iBACEkB,EAOA,CASA,KAAM,CACJ,WAAAC,EACA,aAAAC,EACA,eAAAC,EACA,iBAAAC,EACA,cAAAC,EACA,gBAAAC,EACA,gBAAAC,CACF,EAAI,KAAK,oBAAoBP,CAAW,EAExC,OAAOZ,EAAM,CACX,MAAO,CACL,MAAO,CAAC,EACR,QAAS,CAAC,EACV,OAAQ,CAAC,CACX,EACA,OAAQ,CACN,oBAAqB,IAAIT,EAAoB,CAC3C,MAAO,CAAE,QAAS,UAAW,CAC/B,CAAC,EAAE,iBAAiBqB,CAAW,EAC/B,WAAYb,EAAYc,CAAU,EAClC,aAAcd,EAAYe,CAAY,EACtC,eAAgBf,EAAYgB,CAAc,EAC1C,iBAAkBhB,EAAYiB,CAAgB,EAC9C,cAAejB,EAAYkB,CAAa,EACxC,gBAAiBlB,EAAYoB,CAAe,EAC5C,gBAAiBpB,EAAYmB,CAAe,CAC9C,EACA,OAAQ,CACN,gBAAiB,CAAC,CAAE,QAAAE,CAAQ,IAAMA,EAAQ,eAAe,QAAU,KACnE,iBAAkB,CAAC,CAAE,QAAAA,CAAQ,IAC3BA,EAAQ,eAAe,QAAU,OAChC,EAAE,cAAeA,EAAQ,eAAe,QACvCA,EAAQ,eAAe,MAAM,YAAc,QAC/C,sBAAuB,CAAC,CAAE,QAAAA,CAAQ,IAChC,IAAIV,EACFE,EAAY,sBAAsB,EAClCQ,EAAQ,eAAe,SACzB,EACG,wBAAwB,QAAQ,EAChC,mBAAmB/B,EAAc,MAAM,EACvC,mBAAmBA,EAAc,OAAO,EACxC,mBAAmBA,EAAc,MAAM,EACvC,MAAM,EACX,YAAa,CAAC,CAAE,QAAA+B,CAAQ,IACtB,CAACA,EAAQ,eAAe,UAAW,mBACnC,CAACA,EAAQ,eAAe,UAAW,gBACrC,YAAa,CAAC,CAAE,QAAAA,CAAQ,IAAM,CAAC,CAACA,EAAQ,MAAM,QAAQ,WACxD,EACA,QAAS,CACP,qBAAsBtB,EAAO,CAC3B,eAAiBuB,IAAO,CACtB,GAAGA,EAAE,QAAQ,eACb,MAAOA,EAAE,MAAM,KACjB,EACF,CAAC,CACH,CACF,CAAC,EAAE,cAAc,CAEf,GAAI,8BACJ,QAAS,eACT,QAAS,CAAC,CAAE,MAAAC,CAAM,KACT,CACL,MAAAA,EACA,kBAAmB,CACjB,wBAAyB7B,EAAwB,KACjD,KAAMQ,EAAsB,QAC9B,EACA,eAAgB,CACd,MAAO,KACP,UAAW,KACX,OAAQ,KACR,SAAU,CAAC,EACX,iBAAkB,KAClB,gBAAiB,KACjB,UAAW,IACb,CACF,GAEF,OAAQ,CACN,aAAc,CACZ,OAAQ,CACN,CACE,OAAQ,eACR,MAAO,aACT,EACA,qBACF,CACF,EACA,oBAAqB,CACnB,OAAQ,CACN,GAAI,sBACJ,MAAO,CACL,QAAS,UACX,EACA,IAAK,sBACL,WAAY,CACV,QAASH,EAAO,CACd,kBAAoBuB,IAAO,CACzB,GAAGA,EAAE,MAAM,SAAS,QAAQ,kBAC5B,KAAMpB,EAAsB,QAC9B,EACF,CAAC,CACH,EACA,OAAQ,CACN,QAASH,EAAO,CACd,eAAiBuB,GACRA,EAAE,MAAM,OAAO,OAAuC,CAC3D,MAAO,IAAMA,EAAE,QAAQ,eACvB,KAAOE,IAAW,CAChB,GAAGF,EAAE,QAAQ,eACb,MAAAE,CACF,EACF,CAAC,CAEL,CAAC,EACD,OAAQ,gCACV,CACF,CACF,EACA,+BAAgC,CAC9B,OAAQ,CACN,CACE,OAAQ,eACR,MAAO,iBACT,EACA,OACF,CACF,EACA,aAAc,CACZ,MAAOzB,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,cAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,eACJ,IAAK,eACL,OAAQ,CACN,OAAQ,0BACR,QAAS,CACPH,EAAO,CACL,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,IAC5B9B,EAAuBkC,EAAM,MAAM,EAC9B,CACL,GAAGJ,EAAQ,eACX,UAAWI,EAAM,OAAO,IAC1B,EAEO,CACL,GAAGJ,EAAQ,eACX,MAAOI,EAAM,OAAO,KACtB,CAGN,CAAC,CACH,CACF,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,wBAAyB,CACvB,OAAQ,CACN,CACE,OAAQ,kBACR,MAAO3B,EAAI,CACT,kBACA,wBACA,aACF,CAAC,CACH,EACA,CACE,OAAQ,mBACR,MAAO,iBACT,EACA,CACE,OAAQ,OACV,CACF,CACF,EACA,gBAAiB,CACf,MAAOC,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,gBACjD,KAAMQ,EAAsB,kBAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,iBACJ,IAAK,iBACL,OAAQ,CACN,OAAQ,wBACR,QAAS,CACPH,EAAO,CACL,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,IAC5B9B,EAAuBkC,EAAM,MAAM,EAC9B,CACL,GAAGJ,EAAQ,eACX,UAAW,CACT,GAAGA,EAAQ,eAAe,UAC1B,kBAAmBI,EAAM,OAAO,KAAK,OACvC,CACF,EAEOJ,EAAQ,cAGrB,CAAC,CACH,CACF,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,sBAAuB,CACrB,MAAOtB,EAAO,CAAC,CAAE,QAAAsB,CAAQ,KAAO,CAC9B,kBAAmB,CACjB,wBAAyB3B,EAAwB,KACjD,KAAMQ,EAAsB,0BAC5B,OAAQmB,EAAQ,eAAe,UAAW,iBAC5C,CACF,EAAE,EAGF,MAAO,CACL,EAAG,CACD,OAAQ,kBACV,CACF,CACF,EACA,iBAAkB,CAChB,MAAOtB,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,iBAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,mBACJ,IAAK,mBACL,MAAO,CAAC,CAAE,QAAAmB,CAAQ,KAAO,CACvB,OAAQA,EAAQ,MAAM,OACtB,YAAaA,EAAQ,MAAM,WAC7B,GACA,OAAQ,CACN,OAAQ,aACR,QAAStB,EAAO,CACd,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,KAAO,CACvC,GAAGA,EAAQ,eACX,OAAQI,EAAM,OAAO,OACrB,gBAAiBA,EAAM,OAAO,IAChC,EACF,CAAC,CACH,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,WAAY,CACV,MAAO1B,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,WAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,aACJ,IAAK,aACL,MAAO,CAAC,CAAE,QAAAmB,CAAQ,KAAO,CACvB,eAAgBA,EAAQ,MAAM,eAC9B,cAAe,GACf,gBAAiB,EACnB,GACA,OAAQ,CACN,OAAQ,gBACR,QAAStB,EAAO,CACd,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,IAAM,CACtC,GAAI9B,EAAuBkC,EAAM,MAAM,EAAG,CACxC,MAAMC,EAAS,CACb,GAAGL,EAAQ,eAAe,OAC1B,KAAMI,EAAM,OAAO,KAAK,OAC1B,EACA,MAAO,CACL,GAAGJ,EAAQ,eACX,OAAAK,CACF,CACF,CACA,MAAO,CACL,GAAGL,EAAQ,cACb,CACF,CACF,CAAC,CACH,EACA,QAAS,CACP,OAAQ,OACV,CACF,CACF,EACA,cAAe,CACb,MAAOtB,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,cAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,gBACJ,IAAK,gBACL,MAAO,CAAC,CAAE,QAAAmB,CAAQ,KAAO,CACvB,cAAeA,EAAQ,MAAM,cAC7B,OAAQA,EAAQ,MAAM,OACtB,OAAQA,EAAQ,MAAM,OACtB,QAASA,EAAQ,MAAM,QACvB,UAAWA,EAAQ,eAAe,UAClC,eAAgBA,EAAQ,MAAM,eAC9B,OAAQA,EAAQ,eAAe,OAC/B,YAAaA,EAAQ,MAAM,YAC3B,cAAeR,EAAY,eAAe,EAAE,EAC9C,GACA,OAAQ,CACN,OAAQ,kBACR,QAAS,CACPd,EAAO,CACL,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,KAAO,CACvC,GAAGA,EAAQ,eACX,SAAUI,EAAM,OAAO,kBACvB,iBAAkBA,EAAM,OAAO,gBACjC,EACF,CAAC,CACH,CACF,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,gBAAiB,CACf,MAAO1B,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,gBAC9B,CACF,CAAC,EACD,KAAMH,EAAO,CAEX,eAAgB,CAAC,CAAE,QAAAsB,CAAQ,KAClB,CACL,GAAGA,EAAQ,eACX,SAAUA,EAAQ,eAAe,SAAS,MAAM,CAAC,CACnD,EAEJ,CAAC,EACD,OAAQ,CACN,GAAI,kBACJ,IAAK,kBACL,MAAO,CAAC,CAAE,QAAAA,CAAQ,KAAO,CACvB,SAAUA,EAAQ,eAAe,SACjC,eAAgBA,EAAQ,MAAM,eAC9B,sBAAuBA,EAAQ,MAAM,WACvC,GACA,OAAQ,CACN,OAAQ,iBACV,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,gBAAiB,CACf,MAAOtB,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,gBACjD,KAAMQ,EAAsB,gBAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,kBACJ,IAAK,kBACL,MAAO,CAAC,CAAE,QAAAmB,CAAQ,KAAO,CACvB,eAAgBA,EAAQ,MAAM,eAC9B,sBAAuBA,EAAQ,MAAM,YACrC,QAASA,EAAQ,eAAe,OAAQ,QACxC,gBAAiBA,EAAQ,eAAe,gBACxC,iBAAkBA,EAAQ,eAAe,gBAC3C,GACA,OAAQ,CACN,OAAQ,6BACR,QAAS,CACPtB,EAAO,CACL,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,IAC5B9B,EAAuBkC,EAAM,MAAM,EAC9B,CACL,GAAGJ,EAAQ,eACX,UAAWI,EAAM,OAAO,IAC1B,EAEK,CACL,GAAGJ,EAAQ,eACX,MAAOI,EAAM,OAAO,KACtB,CAEJ,CAAC,CACH,CACF,EACA,QAAS,CACP,OAAQ,6BACR,QAAS,sBACX,CACF,CACF,EACA,2BAA4B,CAC1B,OAAQ,CACN,CAAE,MAAO,kBAAmB,OAAQ,SAAU,EAC9C,CACE,MAAO,mBACP,OAAQ,8BACV,EACA,CAAE,OAAQ,OAAQ,CACpB,CACF,EACA,6BAA8B,CAC5B,MAAO1B,EAAO,CACZ,kBAAmB,CACjB,wBAAyBL,EAAwB,KACjD,KAAMQ,EAAsB,+BAC9B,CACF,CAAC,EACD,OAAQ,CACN,GAAI,+BACJ,IAAK,kBACL,MAAO,CAAC,CAAE,QAAAmB,CAAQ,KAAO,CACvB,eAAgBA,EAAQ,MAAM,eAC9B,sBAAuBA,EAAQ,MAAM,YACrC,QAASA,EAAQ,eAAe,OAAQ,QACxC,gBAAiBA,EAAQ,eAAe,gBACxC,iBAAkBlB,EAAiB,KACrC,GACA,OAAQ,CACN,OAAQ,0CACR,QAAS,CACPJ,EAAO,CACL,eAAgB,CAAC,CAAE,MAAA0B,EAAO,QAAAJ,CAAQ,IAC5B9B,EAAuBkC,EAAM,MAAM,EAC9B,CACL,GAAGJ,EAAQ,eACX,UAAWI,EAAM,OAAO,IAC1B,EAEK,CACL,GAAGJ,EAAQ,eACX,MAAOI,EAAM,OAAO,KACtB,CAEJ,CAAC,CACH,CACF,EACA,QAAS,CACP,OAAQ,QACR,QAAS,sBACX,CACF,CACF,EACA,wCAAyC,CACvC,OAAQ,CACN,CAAE,MAAO,kBAAmB,OAAQ,SAAU,EAC9C,CAAE,OAAQ,OAAQ,CACpB,CACF,EACA,QAAS,CACP,KAAM,OACR,EACA,MAAO,CACL,KAAM,OACR,CACF,EACA,OAAQ,CAAC,CAAE,QAAAJ,CAAQ,IACjBA,EAAQ,eAAe,UACnBxB,EAAMwB,EAAQ,eAAe,SAAS,EACtCzB,EACEyB,EAAQ,eAAe,OACrB,IAAI5B,EAAe,yBAAyB,CAChD,CACR,CAAC,CACH,CAEA,oBAAoBoB,EAA+C,CAsCjE,MAAO,CACL,WAtCiB,MAAOc,GACxBd,EAAY,YAAY,IAAIT,EAAkBuB,EAAK,KAAK,CAAC,EAsCzD,aArCmB,SACnBd,EAAY,YAAY,IAAIR,CAAqB,EAqCjD,eApCqB,SACrBQ,EAAY,YAAY,IAAIP,CAAuB,EAoCnD,iBAnCuB,MAAOqB,GAG9B,QAAQ,QACN,IAAInB,EAAqB,CACvB,OAAQmB,EAAK,MAAM,OACnB,YAAaA,EAAK,MAAM,WAC1B,CAAC,EAAE,IAAI,CACT,EA4BA,cA3BoB,MAAOA,GAC3B,IAAIpB,EAAsBM,EAAac,EAAK,KAAK,EAAE,IAAI,EA2BvD,gBAzBsB,MAAOA,GAGtB,IAAIlB,EAA+BI,EAAac,EAAK,KAAK,EAAE,IAAI,EAuBvE,gBApBsB,MAAOA,GAS7B,IAAIjB,EAAwBG,EAAa,CACvC,GAAGc,EAAK,KACV,CAAC,EAAE,IAAI,CAUT,CACF,CACF",
6
+ "names": ["DeviceModelId", "isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "Left", "Right", "and", "assign", "fromPromise", "setup", "SignTransactionDAStep", "ClearSigningType", "GetAddressCommand", "GetAppConfiguration", "Web3CheckOptInCommand", "BuildFullContextsTask", "ParseTransactionTask", "ProvideTransactionContextsTask", "SendSignTransactionTask", "ApplicationChecker", "SignTransactionDeviceAction", "internalApi", "getAddress", "getAppConfig", "web3CheckOptIn", "parseTransaction", "buildContexts", "signTransaction", "provideContexts", "context", "_", "input", "error", "event", "subset", "arg0"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{CommandResultFactory as o,DeviceActionStatus as e,hexaStringToBuffer as U,UnknownDAError as I,UnknownDeviceExchangeError as S,UserInteractionRequired as t}from"@ledgerhq/device-management-kit";import{InvalidStatusWordError as m}from"@ledgerhq/device-management-kit";import{Transaction as T}from"ethers";import{Just as k,Nothing as A}from"purify-ts";import{TransactionType as C}from"../../../../api/model/TransactionType";import{makeDeviceActionInternalApiMock as f}from"../../../app-binder/device-action/__test-utils__/makeInternalApi";import{setupOpenAppDAMock as v}from"../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock";import{testDeviceActionStates as h}from"../../../app-binder/device-action/__test-utils__/testDeviceActionStates";import{SignTransactionDeviceAction as b}from"./SignTransactionDeviceAction";jest.mock("@ledgerhq/device-management-kit",()=>({...jest.requireActual("@ledgerhq/device-management-kit"),OpenAppDeviceAction:jest.fn(()=>({makeStateMachine:jest.fn()}))}));describe("SignTransactionDeviceAction",()=>{const i={getContext:jest.fn(),getContexts:jest.fn(),getTypedDataFilters:jest.fn()},c={mapTransactionToSubset:jest.fn()},p={extractValue:jest.fn()},s=jest.fn(),u=jest.fn(),y=jest.fn(),P=jest.fn(),x=jest.fn();function g(){return{getChallenge:s,buildContext:u,provideContext:y,provideGenericContext:P,signTransaction:x}}const d={domain:"domain-name.eth"},l=U(T.from({chainId:1n,nonce:0,data:"0x"}).unsignedSerialized);beforeEach(()=>{jest.clearAllMocks()}),describe("Happy path",()=>{it("should call external dependencies with the correct parameters",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:[{type:"token",payload:"payload-1"}],serializedTransaction:new Uint8Array([1,2,3]),chainId:1,transactionType:C.LEGACY}),y.mockResolvedValueOnce(A),x.mockResolvedValueOnce(o({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:V}=h(n,r,f(),a);V.subscribe({complete:()=>{expect(s).toHaveBeenCalled(),expect(u).toHaveBeenCalledWith(expect.objectContaining({input:{challenge:"challenge",contextModule:i,mapper:c,options:d,transaction:l}})),expect(y).toHaveBeenCalledWith(expect.objectContaining({input:{clearSignContexts:[{type:"token",payload:"payload-1"}]}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),isLegacy:!0,chainId:1,transactionType:C.LEGACY}}))}})}),it("should call external dependencies with the correct parameters with the generic parser",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:{transactionInfo:"payload-1",transactionFields:[{type:"enum",payload:"payload-2"}]},serializedTransaction:new Uint8Array([1,2,3]),chainId:7,transactionType:C.EIP1559}),P.mockResolvedValueOnce(A),x.mockResolvedValueOnce(o({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:V}=h(n,r,f(),a);V.subscribe({complete:()=>{expect(s).toHaveBeenCalled(),expect(u).toHaveBeenCalledWith(expect.objectContaining({input:{challenge:"challenge",contextModule:i,mapper:c,options:d,transaction:l}})),expect(P).toHaveBeenCalledWith(expect.objectContaining({input:{chainId:7,context:{transactionInfo:"payload-1",transactionFields:[{type:"enum",payload:"payload-2"}]},contextModule:i,derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),transactionParser:p}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),isLegacy:!1,chainId:7,transactionType:C.EIP1559}}))}})}),it("should fallback to blind signing if provideContext return an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:[{type:"token",payload:"payload-1"}],serializedTransaction:new Uint8Array([1,2,3]),chainId:1,transactionType:C.LEGACY}),y.mockResolvedValueOnce(k(o({error:new m("provideContext error")}))),x.mockResolvedValueOnce(o({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:V}=h(n,r,f(),a);V.subscribe({complete:()=>{expect(s).toHaveBeenCalled(),expect(u).toHaveBeenCalledWith(expect.objectContaining({input:{challenge:"challenge",contextModule:i,mapper:c,options:d,transaction:l}})),expect(y).toHaveBeenCalledWith(expect.objectContaining({input:{clearSignContexts:[{type:"token",payload:"payload-1"}]}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),isLegacy:!0,chainId:1,transactionType:C.LEGACY}}))}})}),it("should fallback to blind signing if provideGenericContext return an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:{transactionInfo:"payload-1",transactionFields:[{type:"enum",payload:"payload-2"}]},serializedTransaction:new Uint8Array([1,2,3]),chainId:7,transactionType:C.EIP1559}),P.mockResolvedValueOnce(k(o({error:new m("provideGenericContext error")}))),x.mockResolvedValueOnce(o({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:V}=h(n,r,f(),a);V.subscribe({complete:()=>{expect(s).toHaveBeenCalled(),expect(u).toHaveBeenCalledWith(expect.objectContaining({input:{challenge:"challenge",contextModule:i,mapper:c,options:d,transaction:l}})),expect(P).toHaveBeenCalledWith(expect.objectContaining({input:{chainId:7,context:{transactionInfo:"payload-1",transactionFields:[{type:"enum",payload:"payload-2"}]},contextModule:i,derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),transactionParser:p}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),isLegacy:!1,chainId:7,transactionType:C.EIP1559}}))}})}),it("should continue if getChallenge return an error 6d00 not supported",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({error:new S({message:"UnknownError",errorCode:"6d00"})})),u.mockResolvedValueOnce({clearSignContexts:[],serializedTransaction:new Uint8Array([1,2,3]),chainId:7,transactionType:C.EIP1559}),P.mockResolvedValueOnce(A),x.mockResolvedValueOnce(o({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:V}=h(n,r,f(),a);V.subscribe({complete:()=>{expect(s).toHaveBeenCalled(),expect(u).toHaveBeenCalledWith(expect.objectContaining({input:{challenge:null,contextModule:i,mapper:c,options:d,transaction:l}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:new Uint8Array([1,2,3]),isLegacy:!0,chainId:7,transactionType:C.EIP1559}}))}})})}),describe("OpenApp errors",()=>{it("should fail if OpenApp throw an error",a=>{v(new I("OpenApp error"));const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{error:new I("OpenApp error"),status:e.Error}];h(n,r,f(),a)})}),describe("GetChallenge errors",()=>{it("should fail if getChallenge throws an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockRejectedValueOnce(new m("getChallenge error")),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{error:new m("getChallenge error"),status:e.Error}];h(n,r,f(),a)}),it("should fail if getChallenge return an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({error:new m("getChallenge error")})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{error:new m("getChallenge error"),status:e.Error}];h(n,r,f(),a)})}),describe("BuildContext errors",()=>{it("should fail if buildContext throws an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockRejectedValueOnce(new m("buildContext error")),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{error:new m("buildContext error"),status:e.Error}];h(n,r,f(),a)})}),describe("ProvideContext errors",()=>{it("should fail if provideContext throws an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:[{type:"token",payload:"payload-1"}],serializedTransaction:new Uint8Array([1,2,3])}),y.mockRejectedValueOnce(new m("provideContext error")),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{error:new m("provideContext error"),status:e.Error}];h(n,r,f(),a)})}),describe("SignTransaction errors",()=>{it("should fail if signTransaction returns an error",a=>{v();const n=new b({input:{derivationPath:"44'/60'/0'/0/0",transaction:l,options:d,contextModule:i,mapper:c,parser:p}});s.mockResolvedValueOnce(o({data:{challenge:"challenge"}})),u.mockResolvedValueOnce({clearSignContexts:[{type:"token",payload:"payload-1"}],serializedTransaction:new Uint8Array([1,2,3])}),y.mockResolvedValueOnce(A),x.mockResolvedValueOnce(o({error:new m("signTransaction error")})),jest.spyOn(n,"extractDependencies").mockReturnValue(g());const r=[{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTransaction},status:e.Pending},{error:new m("signTransaction error"),status:e.Error}];h(n,r,f(),a)})})});
1
+ import{ClearSignContextType as D}from"@ledgerhq/context-module";import{CommandResultFactory as n,DeviceActionStatus as g,DeviceModelId as P,DeviceSessionStateType as _,DeviceStatus as N,hexaStringToBuffer as H,InvalidStatusWordError as T,UserInteractionRequired as q}from"@ledgerhq/device-management-kit";import{Transaction as W}from"ethers";import{Just as R}from"purify-ts";import{lastValueFrom as S}from"rxjs";import{SignTransactionDAStep as E}from"../../../../api/app-binder/SignTransactionDeviceActionTypes";import{ClearSigningType as x}from"../../../../api/model/ClearSigningType";import{TransactionType as m}from"../../../../api/model/TransactionType";import{makeDeviceActionInternalApiMock as j}from"../../../app-binder/device-action/__test-utils__/makeInternalApi";import{setupOpenAppDAMock as f}from"../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock";import{executeUntilStep as k}from"../../../app-binder/device-action/__test-utils__/testDeviceActionUntilStep";import{SignTransactionDeviceAction as v}from"./SignTransactionDeviceAction";vi.mock("@ledgerhq/device-management-kit",async a=>({...await a(),OpenAppDeviceAction:vi.fn(()=>({makeStateMachine:vi.fn()}))}));describe("SignTransactionDeviceAction",()=>{let a;const c={getFieldContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},r={mapTransactionToSubset:vi.fn()},d={extractValue:vi.fn()},M=vi.fn(),A=vi.fn(),b=vi.fn(),h=vi.fn(),O=vi.fn(),o=vi.fn(),w=vi.fn();function p(){return{getAppConfig:M,web3CheckOptIn:A,parseTransaction:b,buildContexts:h,provideContexts:O,signTransaction:o,getAddress:w}}const i=j(),l={domain:"domain-name.eth"},s=H(W.from({chainId:1n,nonce:0,data:"0x"}).unsignedSerialized),y={chainId:1,data:"0x",selector:"0x",to:"0x",value:0n},V="0x8ceb23fd6bc0add59e62ac25578270cff1b9f619";function B(e,t,I){return{blindSigningEnabled:!1,web3ChecksEnabled:t,web3ChecksOptIn:I,version:e}}function u(e,t,I){i.getDeviceSessionState.mockReturnValueOnce({sessionStateType:_.ReadyWithoutSecureChannel,deviceStatus:N.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:e},deviceModelId:P.FLEX,isSecureConnectionAllowed:!1}),i.getDeviceModel.mockReturnValueOnce({id:P.FLEX}),M.mockResolvedValue(n({data:B(e,t,I)}))}const C=(e,t)=>{if(e[t]?.status!==g.Pending)throw new Error(`Step ${t} is not pending: ${JSON.stringify(e[t])}`);return e[t]};describe("Happy path",()=>{describe("should sign a transaction",()=>{const e=[{context:{type:D.TRANSACTION_INFO,payload:"payload-1"},subcontextCallbacks:[]},{context:{type:D.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},subcontextCallbacks:[]}];beforeEach(()=>{vi.resetAllMocks(),f(),u("1.15.0",!1,!1),w.mockResolvedValueOnce(n({data:{address:V}})),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),h.mockResolvedValueOnce({clearSignContexts:e,clearSigningType:x.EIP7730}),O.mockResolvedValueOnce(R(void 0)),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const t=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(t,"extractDependencies").mockReturnValue(p()),a=t._execute(i).observable}),it("should open the app",async()=>{const{steps:t}=await k(0,a);expect(C(t,0).intermediateValue.step).toBe(E.OPEN_APP)}),it("should confirm open app",async()=>{const{steps:t}=await k(1,a);expect(C(t,1).intermediateValue.requiredUserInteraction).toBe(q.ConfirmOpenApp)}),it("should get app config",async()=>{const{steps:t}=await k(2,a);expect(C(t,2).intermediateValue.step).toBe(E.GET_APP_CONFIG)}),it("should prebuild context",async()=>{const{steps:t}=await k(3,a);expect(C(t,3).intermediateValue.step).toBe(E.PARSE_TRANSACTION),expect(b).toHaveBeenCalledTimes(1),expect(b).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{mapper:r,transaction:s}}))}),it("should get address",async()=>{const{steps:t}=await k(4,a);expect(C(t,4).intermediateValue.step).toBe(E.GET_ADDRESS)}),it("should build context",async()=>{const{steps:t}=await k(5,a);expect(C(t,5).intermediateValue.step).toBe(E.BUILD_CONTEXTS),expect(h).toHaveBeenCalledTimes(1),expect(h).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{contextModule:c,parser:d,mapper:r,options:l,subset:{...y,from:V},transaction:s,appConfig:B("1.15.0",!1,!1),derivationPath:"44'/60'/0'/0/0",deviceModelId:P.FLEX}}))}),it("should provide context",async()=>{const{steps:t}=await k(6,a);expect(C(t,6).intermediateValue.step).toBe(E.PROVIDE_CONTEXTS),expect(O).toHaveBeenCalledTimes(1),expect(O).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{contexts:e,serializedTransaction:s,derivationPath:"44'/60'/0'/0/0"}}))}),it("should sign transaction",async()=>{const{steps:t}=await k(7,a);expect(C(t,7).intermediateValue.step).toBe(E.SIGN_TRANSACTION),expect(o).toHaveBeenCalledTimes(1),expect(o).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:s,chainId:1,transactionType:m.EIP1559,clearSigningType:x.EIP7730}}))}),it("should return the signature",async()=>{const t=await S(a);expect(t).toEqual({status:g.Completed,output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})})}),describe("should skip open app",()=>{beforeEach(()=>{vi.resetAllMocks(),f(),u("1.15.0",!1,!1),w.mockResolvedValueOnce(n({data:{address:V}}));const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:{...l,skipOpenApp:!0},contextModule:c,mapper:r,parser:d}});b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),O.mockResolvedValueOnce(R(void 0)),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),vi.spyOn(e,"extractDependencies").mockReturnValue(p()),a=e._execute(i).observable}),it("should skip open app and get app config directly",async()=>{const{steps:e}=await k(0,a);expect(C(e,0).intermediateValue.step).toBe(E.GET_APP_CONFIG)})}),describe("should opt in to web3 checks",()=>{beforeEach(()=>{vi.resetAllMocks(),f(),u("1.16.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),A.mockResolvedValueOnce(n({data:{enabled:!0}})),a=e._execute(i).observable}),it("should opt in to web3 checks if app config is supported and not already enabled",async()=>{const{steps:e}=await k(4,a);expect(C(e,3).intermediateValue.step).toBe(E.WEB3_CHECKS_OPT_IN),expect(A).toHaveBeenCalledTimes(1),expect(C(e,4).intermediateValue.step).toBe(E.WEB3_CHECKS_OPT_IN_RESULT),expect(C(e,4).intermediateValue.result).toBe(!0)})}),describe("should not opt in to web3 checks",()=>{beforeEach(()=>{vi.resetAllMocks(),f();const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),a=e._execute(i).observable}),it("should not opt in to web3 checks if app config is not supported",async()=>{u("1.15.0",!1,!1),await k(3,a),expect(A).not.toHaveBeenCalled()}),it("should not opt in to web3 checks if already enabled",async()=>{u("1.16.0",!0,!1),await k(3,a),expect(A).not.toHaveBeenCalled()}),it("should not opt in to web3 checks if already opted out",async()=>{u("1.16.0",!1,!0),await k(3,a),expect(A).not.toHaveBeenCalled()})})}),describe("Error cases",()=>{beforeEach(()=>{vi.resetAllMocks()}),it("should return an error if the open app throw an error",async()=>{f(new Error("Open app failed")),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new Error("Open app failed")})}),it("should return an error if the get app config return an error",async()=>{f(),M.mockResolvedValueOnce(n({error:new T("Get app config failed")}));const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new T("Get app config failed")})}),it("should return an error if the get app config throw an error",async()=>{f(),M.mockRejectedValueOnce(new Error("Get app config failed"));const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new Error("Get app config failed")})}),it("should ignore the web3checks result if the command fails",async()=>{f(),u("1.16.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),A.mockResolvedValueOnce(n({error:new T("web3 check opt in failed")})),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Completed,output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})}),it("should return an error if the parse transaction throw an error",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockRejectedValueOnce(new Error("Parse transaction failed")),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new Error("Parse transaction failed")})}),it("should blind sign if the first sign transaction fails and the second sign transaction succeeds",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),O.mockResolvedValueOnce(R(void 0)),o.mockResolvedValueOnce(n({error:new T("Sign transaction failed")})),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Completed,output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})}),it("should blind sign if the first sign transaction throws an error and the second sign transaction succeeds",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.EIP7730}),O.mockResolvedValueOnce(R(void 0)),o.mockRejectedValueOnce(new Error("Sign transaction failed")),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Completed,output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}),expect(o).toHaveBeenCalledTimes(2),expect(o).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:s,chainId:1,transactionType:m.EIP1559,clearSigningType:x.EIP7730}})),expect(o).toHaveBeenNthCalledWith(2,expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:s,chainId:1,transactionType:m.EIP1559,clearSigningType:x.BASIC}}))}),it("should return an error if the sign transaction return two times an error",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),O.mockResolvedValueOnce(R(void 0)),o.mockResolvedValueOnce(n({error:new T("Sign transaction failed")})),o.mockResolvedValueOnce(n({error:new T("Blind sign transaction failed")})),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new T("Blind sign transaction failed")})}),it("should return an error if the blind sign transaction fallback throws an error",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),O.mockResolvedValueOnce(R(void 0)),o.mockResolvedValueOnce(n({error:new T("Sign transaction failed")})),o.mockRejectedValueOnce(new Error("Blind sign transaction fallback failed")),a=e._execute(i).observable;const t=await S(a);expect(t).toEqual({status:g.Error,error:new Error("Blind sign transaction fallback failed")})}),it("should return an error without trying blind sign fallback when user refuses transaction (error code 6985)",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.BASIC}),O.mockResolvedValueOnce(R(void 0));const t=new T("User refused transaction");t.errorCode="6985",o.mockResolvedValueOnce(n({error:t})),a=e._execute(i).observable;const I=await S(a);expect(I).toEqual({status:g.Error,error:t}),expect(o).toHaveBeenCalledTimes(1)}),it("should try blind sign fallback when error is not user refusal (different error code)",async()=>{f(),u("1.15.0",!1,!1);const e=new v({input:{derivationPath:"44'/60'/0'/0/0",transaction:s,options:l,contextModule:c,mapper:r,parser:d}});vi.spyOn(e,"extractDependencies").mockReturnValue(p()),b.mockResolvedValueOnce({subset:y,type:m.EIP1559}),w.mockResolvedValueOnce(n({data:{address:V}})),h.mockResolvedValueOnce({clearSignContexts:[],clearSignContextsOptional:[],clearSigningType:x.EIP7730}),O.mockResolvedValueOnce(R(void 0));const t=new T("Some other error");t.errorCode="6A80",o.mockResolvedValueOnce(n({error:t})),o.mockResolvedValueOnce(n({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}})),a=e._execute(i).observable;const I=await S(a);expect(I).toEqual({status:g.Completed,output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}),expect(o).toHaveBeenCalledTimes(2),expect(o).toHaveBeenNthCalledWith(1,expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:s,chainId:1,transactionType:m.EIP1559,clearSigningType:x.EIP7730}})),expect(o).toHaveBeenNthCalledWith(2,expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0",serializedTransaction:s,chainId:1,transactionType:m.EIP1559,clearSigningType:x.BASIC}}))})})});
2
2
  //# sourceMappingURL=SignTransactionDeviceAction.test.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.ts"],
4
- "sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionStatus,\n hexaStringToBuffer,\n UnknownDAError,\n UnknownDeviceExchangeError,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { InvalidStatusWordError } from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport { type SignTransactionDAState } from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { TransactionType } from \"@api/model/TransactionType\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { setupOpenAppDAMock } from \"@internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock\";\nimport { testDeviceActionStates } from \"@internal/app-binder/device-action/__test-utils__/testDeviceActionStates\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport { SignTransactionDeviceAction } from \"./SignTransactionDeviceAction\";\n\njest.mock(\n \"@ledgerhq/device-management-kit\",\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n () => ({\n ...jest.requireActual(\"@ledgerhq/device-management-kit\"),\n OpenAppDeviceAction: jest.fn(() => ({\n makeStateMachine: jest.fn(),\n })),\n }),\n);\n\ndescribe(\"SignTransactionDeviceAction\", () => {\n const contextModuleMock: ContextModule = {\n getContext: jest.fn(),\n getContexts: jest.fn(),\n getTypedDataFilters: jest.fn(),\n };\n const mapperMock: TransactionMapperService = {\n mapTransactionToSubset: jest.fn(),\n } as unknown as TransactionMapperService;\n const parserMock: TransactionParserService = {\n extractValue: jest.fn(),\n } as unknown as TransactionParserService;\n const getChallengeMock = jest.fn();\n const buildContextMock = jest.fn();\n const provideContextMock = jest.fn();\n const provideGenericContextMock = jest.fn();\n const signTransactionMock = jest.fn();\n function extractDependenciesMock() {\n return {\n getChallenge: getChallengeMock,\n buildContext: buildContextMock,\n provideContext: provideContextMock,\n provideGenericContext: provideGenericContextMock,\n signTransaction: signTransactionMock,\n };\n }\n const defaultOptions = {\n domain: \"domain-name.eth\",\n };\n const defaultTransaction: Uint8Array = hexaStringToBuffer(\n Transaction.from({\n chainId: 1n,\n nonce: 0,\n data: \"0x\",\n }).unsignedSerialized,\n )!;\n\n beforeEach(() => {\n jest.clearAllMocks();\n });\n\n describe(\"Happy path\", () => {\n it(\"should call external dependencies with the correct parameters\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n });\n provideContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetChallenge -> BuildContext -> ProvideContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n const { observable } = testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n\n // Verify mocks calls parameters\n observable.subscribe({\n complete: () => {\n expect(getChallengeMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n challenge: \"challenge\",\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n },\n }),\n );\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n },\n }),\n );\n },\n });\n });\n\n it(\"should call external dependencies with the correct parameters with the generic parser\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n });\n provideGenericContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetChallenge -> BuildContext -> ProvideGenericContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n const { observable } = testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n\n // Verify mocks calls parameters\n observable.subscribe({\n complete: () => {\n expect(getChallengeMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n challenge: \"challenge\",\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n },\n }),\n );\n expect(provideGenericContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n chainId: 7,\n context: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n contextModule: contextModuleMock,\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n transactionParser: parserMock,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: false,\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n },\n }),\n );\n },\n });\n });\n\n it(\"should fallback to blind signing if provideContext return an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n });\n provideContextMock.mockResolvedValueOnce(\n Just(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"provideContext error\"),\n }),\n ),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetChallenge -> BuildContext -> ProvideContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n const { observable } = testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n\n // Verify mocks calls parameters\n observable.subscribe({\n complete: () => {\n expect(getChallengeMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n challenge: \"challenge\",\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n },\n }),\n );\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n },\n }),\n );\n },\n });\n });\n\n it(\"should fallback to blind signing if provideGenericContext return an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n });\n provideGenericContextMock.mockResolvedValueOnce(\n Just(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"provideGenericContext error\"),\n }),\n ),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetChallenge -> BuildContext -> ProvideGenericContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n const { observable } = testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n\n // Verify mocks calls parameters\n observable.subscribe({\n complete: () => {\n expect(getChallengeMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n challenge: \"challenge\",\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n },\n }),\n );\n expect(provideGenericContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n chainId: 7,\n context: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n contextModule: contextModuleMock,\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n transactionParser: parserMock,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: false,\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n },\n }),\n );\n },\n });\n });\n\n it(\"should continue if getChallenge return an error 6d00 not supported\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError({\n message: \"UnknownError\",\n errorCode: \"6d00\",\n }),\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n });\n provideGenericContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetChallenge -> BuildContext -> ProvideGenericContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n const { observable } = testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n\n // Verify mocks calls parameters\n observable.subscribe({\n complete: () => {\n expect(getChallengeMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n challenge: null,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n },\n }),\n );\n },\n });\n });\n });\n\n describe(\"OpenApp errors\", () => {\n it(\"should fail if OpenApp throw an error\", (done) => {\n setupOpenAppDAMock(new UnknownDAError(\"OpenApp error\"));\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp error\n {\n error: new UnknownDAError(\"OpenApp error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n\n describe(\"GetChallenge errors\", () => {\n it(\"should fail if getChallenge throws an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n getChallengeMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"getChallenge error\"),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge error\n {\n error: new InvalidStatusWordError(\"getChallenge error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n\n it(\"should fail if getChallenge return an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"getChallenge error\"),\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge error\n {\n error: new InvalidStatusWordError(\"getChallenge error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n\n describe(\"BuildContext errors\", () => {\n it(\"should fail if buildContext throws an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n\n describe(\"ProvideContext errors\", () => {\n it(\"should fail if provideContext throws an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n });\n provideContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"provideContext error\"),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext error\n {\n error: new InvalidStatusWordError(\"provideContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n\n describe(\"SignTransaction errors\", () => {\n it(\"should fail if signTransaction returns an error\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n getChallengeMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { challenge: \"challenge\" },\n }),\n );\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n });\n provideContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"signTransaction error\"),\n }),\n );\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetChallenge state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction error\n {\n error: new InvalidStatusWordError(\"signTransaction error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n});\n"],
5
- "mappings": "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",
6
- "names": ["CommandResultFactory", "DeviceActionStatus", "hexaStringToBuffer", "UnknownDAError", "UnknownDeviceExchangeError", "UserInteractionRequired", "InvalidStatusWordError", "Transaction", "Just", "Nothing", "TransactionType", "makeDeviceActionInternalApiMock", "setupOpenAppDAMock", "testDeviceActionStates", "SignTransactionDeviceAction", "contextModuleMock", "mapperMock", "parserMock", "getChallengeMock", "buildContextMock", "provideContextMock", "provideGenericContextMock", "signTransactionMock", "extractDependenciesMock", "defaultOptions", "defaultTransaction", "done", "deviceAction", "expectedStates", "observable"]
4
+ "sourcesContent": ["/* eslint @typescript-eslint/consistent-type-imports: 0 */\nimport {\n ClearSignContextType,\n type ContextModule,\n TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionState,\n DeviceActionStatus,\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n InvalidStatusWordError,\n TransportDeviceModel,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Just } from \"purify-ts\";\nimport { lastValueFrom, Observable } from \"rxjs\";\n\nimport {\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n type SignTransactionDAState,\n SignTransactionDAStep,\n} from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { Signature } from \"@api/index\";\nimport { ClearSigningType } from \"@api/model/ClearSigningType\";\nimport { TransactionType } from \"@api/model/TransactionType\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { setupOpenAppDAMock } from \"@internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock\";\nimport { executeUntilStep } from \"@internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep\";\nimport { ContextWithSubContexts } from \"@internal/app-binder/task/BuildFullContextsTask\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport { SignTransactionDeviceAction } from \"./SignTransactionDeviceAction\";\n\nvi.mock(\"@ledgerhq/device-management-kit\", async (importOriginal) => {\n const original =\n await importOriginal<typeof import(\"@ledgerhq/device-management-kit\")>();\n return {\n ...original,\n OpenAppDeviceAction: vi.fn(() => ({\n makeStateMachine: vi.fn(),\n })),\n };\n});\n\ndescribe(\"SignTransactionDeviceAction\", () => {\n let observable: Observable<\n DeviceActionState<\n Signature,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue\n >\n >;\n const contextModuleMock = {\n getFieldContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const mapperMock: TransactionMapperService = {\n mapTransactionToSubset: vi.fn(),\n } as unknown as TransactionMapperService;\n const parserMock: TransactionParserService = {\n extractValue: vi.fn(),\n } as unknown as TransactionParserService;\n const getAppConfigMock = vi.fn();\n const web3CheckOptInMock = vi.fn();\n const parseTransactionMock = vi.fn();\n const buildContextsMock = vi.fn();\n const provideContextsMock = vi.fn();\n const signTransactionMock = vi.fn();\n const getAddressMock = vi.fn();\n function extractDependenciesMock() {\n return {\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n parseTransaction: parseTransactionMock,\n buildContexts: buildContextsMock,\n provideContexts: provideContextsMock,\n signTransaction: signTransactionMock,\n getAddress: getAddressMock,\n };\n }\n const apiMock = makeDeviceActionInternalApiMock();\n const defaultOptions = {\n domain: \"domain-name.eth\",\n };\n const defaultTransaction: Uint8Array = hexaStringToBuffer(\n Transaction.from({\n chainId: 1n,\n nonce: 0,\n data: \"0x\",\n }).unsignedSerialized,\n )!;\n const defaultSubset: TransactionSubset = {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n to: \"0x\",\n value: 0n,\n };\n const defaultAddress = \"0x8ceb23fd6bc0add59e62ac25578270cff1b9f619\";\n\n function createAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n return {\n blindSigningEnabled: false,\n web3ChecksEnabled,\n web3ChecksOptIn,\n version,\n };\n }\n\n function setupAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version },\n deviceModelId: DeviceModelId.FLEX,\n isSecureConnectionAllowed: false,\n });\n apiMock.getDeviceModel.mockReturnValueOnce({\n id: DeviceModelId.FLEX,\n } as unknown as TransportDeviceModel);\n getAppConfigMock.mockResolvedValue(\n CommandResultFactory({\n data: createAppConfig(version, web3ChecksEnabled, web3ChecksOptIn),\n }),\n );\n }\n\n const getStep = (s: Array<SignTransactionDAState>, index: number) => {\n if (s[index]?.status !== DeviceActionStatus.Pending) {\n throw new Error(\n `Step ${index} is not pending: ${JSON.stringify(s[index])}`,\n );\n }\n return s[index];\n };\n\n describe(\"Happy path\", () => {\n describe(\"should sign a transaction\", () => {\n const contexts: ContextWithSubContexts[] = [\n {\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n subcontextCallbacks: [],\n },\n {\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n subcontextCallbacks: [],\n },\n ];\n\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n\n // Mock the dependencies to return some sample data\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: contexts,\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should open the app\", async () => {\n const { steps } = await executeUntilStep(0, observable);\n expect(getStep(steps, 0).intermediateValue.step).toBe(\n SignTransactionDAStep.OPEN_APP,\n );\n });\n\n it(\"should confirm open app\", async () => {\n const { steps } = await executeUntilStep(1, observable);\n expect(\n getStep(steps, 1).intermediateValue.requiredUserInteraction,\n ).toBe(UserInteractionRequired.ConfirmOpenApp);\n });\n\n it(\"should get app config\", async () => {\n const { steps } = await executeUntilStep(2, observable);\n expect(getStep(steps, 2).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_APP_CONFIG,\n );\n });\n\n it(\"should prebuild context\", async () => {\n const { steps } = await executeUntilStep(3, observable);\n expect(getStep(steps, 3).intermediateValue.step).toBe(\n SignTransactionDAStep.PARSE_TRANSACTION,\n );\n expect(parseTransactionMock).toHaveBeenCalledTimes(1);\n expect(parseTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n mapper: mapperMock,\n transaction: defaultTransaction,\n },\n }),\n );\n });\n\n it(\"should get address\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n expect(getStep(steps, 4).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_ADDRESS,\n );\n });\n\n it(\"should build context\", async () => {\n const { steps } = await executeUntilStep(5, observable);\n expect(getStep(steps, 5).intermediateValue.step).toBe(\n SignTransactionDAStep.BUILD_CONTEXTS,\n );\n expect(buildContextsMock).toHaveBeenCalledTimes(1);\n expect(buildContextsMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n parser: parserMock,\n mapper: mapperMock,\n options: defaultOptions,\n subset: { ...defaultSubset, from: defaultAddress },\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n deviceModelId: DeviceModelId.FLEX,\n },\n }),\n );\n });\n\n it(\"should provide context\", async () => {\n const { steps } = await executeUntilStep(6, observable);\n expect(getStep(steps, 6).intermediateValue.step).toBe(\n SignTransactionDAStep.PROVIDE_CONTEXTS,\n );\n expect(provideContextsMock).toHaveBeenCalledTimes(1);\n expect(provideContextsMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n contexts: contexts,\n serializedTransaction: defaultTransaction,\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n });\n\n it(\"should sign transaction\", async () => {\n const { steps } = await executeUntilStep(7, observable);\n expect(getStep(steps, 7).intermediateValue.step).toBe(\n SignTransactionDAStep.SIGN_TRANSACTION,\n );\n expect(signTransactionMock).toHaveBeenCalledTimes(1);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n });\n\n it(\"should return the signature\", async () => {\n const result = await lastValueFrom(observable);\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n });\n\n describe(\"should skip open app\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: { ...defaultOptions, skipOpenApp: true },\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should skip open app and get app config directly\", async () => {\n const { steps } = await executeUntilStep(0, observable);\n\n expect(getStep(steps, 0).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_APP_CONFIG,\n );\n });\n });\n\n describe(\"should opt in to web3 checks\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({ data: { enabled: true } }),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should opt in to web3 checks if app config is supported and not already enabled\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n\n expect(getStep(steps, 3).intermediateValue.step).toBe(\n SignTransactionDAStep.WEB3_CHECKS_OPT_IN,\n );\n expect(web3CheckOptInMock).toHaveBeenCalledTimes(1);\n\n expect(getStep(steps, 4).intermediateValue.step).toBe(\n SignTransactionDAStep.WEB3_CHECKS_OPT_IN_RESULT,\n );\n // @ts-expect-error - result is not typed\n expect(getStep(steps, 4).intermediateValue.result).toBe(true);\n });\n });\n\n describe(\"should not opt in to web3 checks\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should not opt in to web3 checks if app config is not supported\", async () => {\n setupAppConfig(\"1.15.0\", false, false);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n\n it(\"should not opt in to web3 checks if already enabled\", async () => {\n setupAppConfig(\"1.16.0\", true, false);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n\n it(\"should not opt in to web3 checks if already opted out\", async () => {\n setupAppConfig(\"1.16.0\", false, true);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n });\n });\n\n describe(\"Error cases\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n it(\"should return an error if the open app throw an error\", async () => {\n // GIVEN\n setupOpenAppDAMock(new Error(\"Open app failed\"));\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Open app failed\"),\n });\n });\n\n it(\"should return an error if the get app config return an error\", async () => {\n // GIVEN\n setupOpenAppDAMock();\n getAppConfigMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Get app config failed\"),\n }),\n );\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new InvalidStatusWordError(\"Get app config failed\"),\n });\n });\n\n it(\"should return an error if the get app config throw an error\", async () => {\n // GIVEN\n setupOpenAppDAMock();\n getAppConfigMock.mockRejectedValueOnce(\n new Error(\"Get app config failed\"),\n );\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Get app config failed\"),\n });\n });\n\n it(\"should ignore the web3checks result if the command fails\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"web3 check opt in failed\"),\n }),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n\n it(\"should return an error if the parse transaction throw an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockRejectedValueOnce(\n new Error(\"Parse transaction failed\"),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Parse transaction failed\"),\n });\n });\n\n it(\"should blind sign if the first sign transaction fails and the second sign transaction succeeds\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n\n it(\"should blind sign if the first sign transaction throws an error and the second sign transaction succeeds\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Sign transaction failed\"),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n expect(signTransactionMock).toHaveBeenCalledTimes(2);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 2,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.BASIC, // fallback to basic\n },\n }),\n );\n });\n\n it(\"should return an error if the sign transaction return two times an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Blind sign transaction failed\"),\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new InvalidStatusWordError(\"Blind sign transaction failed\"),\n });\n });\n\n it(\"should return an error if the blind sign transaction fallback throws an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Blind sign transaction fallback failed\"),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Blind sign transaction fallback failed\"),\n });\n });\n\n it(\"should return an error without trying blind sign fallback when user refuses transaction (error code 6985)\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n\n // Create an error with the user refusal error code\n const userRefusalError = new InvalidStatusWordError(\n \"User refused transaction\",\n );\n (\n userRefusalError as InvalidStatusWordError & { errorCode: string }\n ).errorCode = \"6985\";\n\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: userRefusalError,\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: userRefusalError,\n });\n // Verify that signTransaction was only called once (no blind sign fallback attempt)\n expect(signTransactionMock).toHaveBeenCalledTimes(1);\n });\n\n it(\"should try blind sign fallback when error is not user refusal (different error code)\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n\n // Create an error with a different error code (not user refusal)\n const otherError = new InvalidStatusWordError(\"Some other error\");\n (otherError as InvalidStatusWordError & { errorCode: string }).errorCode =\n \"6A80\";\n\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: otherError,\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n // Verify that signTransaction was called twice (first attempt + blind sign fallback)\n expect(signTransactionMock).toHaveBeenCalledTimes(2);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 2,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.BASIC, // fallback to basic\n },\n }),\n );\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["ClearSignContextType", "CommandResultFactory", "DeviceActionStatus", "DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "hexaStringToBuffer", "InvalidStatusWordError", "UserInteractionRequired", "Transaction", "Just", "lastValueFrom", "SignTransactionDAStep", "ClearSigningType", "TransactionType", "makeDeviceActionInternalApiMock", "setupOpenAppDAMock", "executeUntilStep", "SignTransactionDeviceAction", "importOriginal", "observable", "contextModuleMock", "mapperMock", "parserMock", "getAppConfigMock", "web3CheckOptInMock", "parseTransactionMock", "buildContextsMock", "provideContextsMock", "signTransactionMock", "getAddressMock", "extractDependenciesMock", "apiMock", "defaultOptions", "defaultTransaction", "defaultSubset", "defaultAddress", "createAppConfig", "version", "web3ChecksEnabled", "web3ChecksOptIn", "setupAppConfig", "getStep", "s", "index", "contexts", "deviceAction", "steps", "result", "userRefusalError", "otherError"]
7
7
  }