@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 o,OpenAppDeviceAction as y,UnknownDAError as c,UserInteractionRequired as n,XStateDeviceAction as l}from"@ledgerhq/device-management-kit";import{Just as D,Left as m,Nothing as S,Right as T}from"purify-ts";import{assign as e,fromPromise as i,setup as h}from"xstate";import{SignEIP712Command as g}from"../../../app-binder/command/SignEIP712Command";import{ETHEREUM_PLUGINS as C}from"../../../app-binder/constant/plugins";import{BuildEIP712ContextTask as v}from"../../../app-binder/task/BuildEIP712ContextTask";import{ProvideEIP712ContextTask as E}from"../../../app-binder/task/ProvideEIP712ContextTask";class R extends l{makeStateMachine(r){const{buildContext:p,provideContext:s,signTypedData:d,signTypedDataLegacy:u}=this.extractDependencies(r);return h({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new y({input:{appName:"Ethereum"}}).makeStateMachine(r),buildContext:i(p),provideContext:i(s),signTypedData:i(d),signTypedDataLegacy:i(u)},guards:{noInternalError:({context:t})=>t._internalState.error===null},actions:{assignErrorFromEvent:e({_internalState:t=>({...t.context._internalState,error:t.event.error})})}}).createMachine({id:"SignTypedDataDeviceAction",initial:"OpenAppDeviceAction",context:({input:t})=>({input:t,intermediateValue:{requiredUserInteraction:n.None},_internalState:{error:null,typedDataContext:null,signature:null}}),states:{OpenAppDeviceAction:{exit:e({intermediateValue:{requiredUserInteraction:n.None}}),invoke:{id:"openAppStateMachine",input:{appName:"Ethereum",compatibleAppNames:C},src:"openAppStateMachine",onSnapshot:{actions:e({intermediateValue:t=>t.event.snapshot.context.intermediateValue})},onDone:{actions:e({_internalState:t=>t.event.output.caseOf({Right:()=>t.context._internalState,Left:a=>({...t.context._internalState,error:a})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"BuildContext",guard:"noInternalError"},"Error"]},BuildContext:{invoke:{id:"buildContext",src:"buildContext",input:({context:t})=>({contextModule:t.input.contextModule,parser:t.input.parser,data:t.input.data}),onDone:{target:"ProvideContext",actions:[e({_internalState:({event:t,context:a})=>({...a._internalState,typedDataContext:t.output})})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContext:{entry:e({intermediateValue:{requiredUserInteraction:n.SignTypedData}}),exit:e({intermediateValue:{requiredUserInteraction:n.None}}),invoke:{id:"provideContext",src:"provideContext",input:({context:t})=>({taskArgs:t._internalState.typedDataContext}),onDone:{actions:e({_internalState:t=>o(t.event.output)?t.context._internalState:{...t.context._internalState,error:t.event.output.error}}),target:"ProvideContextResultCheck"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContextResultCheck:{always:[{guard:"noInternalError",target:"SignTypedData"},{target:"SignTypedDataLegacy"}]},SignTypedData:{entry:e({intermediateValue:{requiredUserInteraction:n.SignTypedData}}),exit:e({intermediateValue:{requiredUserInteraction:n.None}}),invoke:{id:"signTypedData",src:"signTypedData",input:({context:t})=>({derivationPath:t.input.derivationPath}),onDone:{target:"SignTypedDataResultCheck",actions:[e({_internalState:({event:t,context:a})=>o(t.output)?{...a._internalState,signature:t.output.data}:{...a._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataLegacy:{entry:e({intermediateValue:{requiredUserInteraction:n.SignTypedData}}),exit:e({intermediateValue:{requiredUserInteraction:n.None}}),invoke:{id:"signTypedDataLegacy",src:"signTypedDataLegacy",input:({context:t})=>({derivationPath:t.input.derivationPath,domainHash:t._internalState.typedDataContext.domainHash,messageHash:t._internalState.typedDataContext.messageHash}),onDone:{target:"SignTypedDataResultCheck",actions:[e({_internalState:({event:t,context:a})=>o(t.output)?{...a._internalState,signature:t.output.data}:{...a._internalState,error:t.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataResultCheck:{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 c("No error in final state"))})}extractDependencies(r){return{buildContext:async t=>new v(r,t.input.contextModule,t.input.parser,t.input.data).run(),provideContext:async t=>new E(r,t.input.taskArgs).run(),signTypedData:async t=>r.sendCommand(new g({derivationPath:t.input.derivationPath,legacyArgs:S})),signTypedDataLegacy:async t=>r.sendCommand(new g({derivationPath:t.input.derivationPath,legacyArgs:D({domainHash:t.input.domainHash,messageHash:t.input.messageHash})}))}}}export{R as SignTypedDataDeviceAction};
1
+ import{DeviceModelId as s,isSuccessCommandResult as p,OpenAppDeviceAction as m,UnknownDAError as S,UserInteractionRequired as i,XStateDeviceAction as D}from"@ledgerhq/device-management-kit";import{Left as A,Nothing as T,Right as E}from"purify-ts";import{and as h,assign as n,fromPromise as o,setup as f}from"xstate";import{SignTypedDataDAStateStep as a}from"../../../../api/app-binder/SignTypedDataDeviceActionTypes";import{GetAddressCommand as v}from"../../../app-binder/command/GetAddressCommand";import{GetAppConfiguration as P}from"../../../app-binder/command/GetAppConfigurationCommand";import{SignEIP712Command as I}from"../../../app-binder/command/SignEIP712Command";import{Web3CheckOptInCommand as k}from"../../../app-binder/command/Web3CheckOptInCommand";import{BuildEIP712ContextTask as _}from"../../../app-binder/task/BuildEIP712ContextTask";import{ProvideEIP712ContextTask as x}from"../../../app-binder/task/ProvideEIP712ContextTask";import{SignTypedDataLegacyTask as O}from"../../../app-binder/task/SignTypedDataLegacyTask";import{ApplicationChecker as M}from"../../../shared/utils/ApplicationChecker";class Y extends D{makeStateMachine(r){const{getAddress:d,getAppConfig:u,web3CheckOptIn:g,buildContext:c,provideContext:l,signTypedData:y,signTypedDataLegacy:C}=this.extractDependencies(r);return f({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new m({input:{appName:"Ethereum"}}).makeStateMachine(r),getAddress:o(d),getAppConfig:o(u),web3CheckOptIn:o(g),buildContext:o(c),provideContext:o(l),signTypedData:o(y),signTypedDataLegacy:o(C)},guards:{noInternalError:({context:e})=>e._internalState.error===null,notRefusedByUser:({context:e})=>e._internalState.error!==null&&(!("errorCode"in e._internalState.error)||e._internalState.error.errorCode!=="6985"),isWeb3ChecksSupported:({context:e})=>new M(r.getDeviceSessionState(),e._internalState.appConfig).withMinVersionExclusive("1.15.0").excludeDeviceModel(s.NANO_S).excludeDeviceModel(s.NANO_SP).excludeDeviceModel(s.NANO_X).check(),shouldOptIn:({context:e})=>!e._internalState.appConfig.web3ChecksEnabled&&!e._internalState.appConfig.web3ChecksOptIn,skipOpenApp:({context:e})=>e.input.skipOpenApp},actions:{assignErrorFromEvent:n({_internalState:e=>({...e.context._internalState,error:e.event.error})})}}).createMachine({id:"SignTypedDataDeviceAction",initial:"InitialState",context:({input:e})=>({input:e,intermediateValue:{requiredUserInteraction:i.None,step:a.OPEN_APP},_internalState:{error:null,appConfig:null,from:null,typedDataContext:null,signature:null}}),states:{InitialState:{always:[{target:"GetAppConfig",guard:"skipOpenApp"},"OpenAppDeviceAction"]},OpenAppDeviceAction:{invoke:{id:"openAppStateMachine",input:{appName:"Ethereum"},src:"openAppStateMachine",onSnapshot:{actions:n({intermediateValue:e=>({...e.event.snapshot.context.intermediateValue,step:a.OPEN_APP})})},onDone:{actions:n({_internalState:e=>e.event.output.caseOf({Right:()=>e.context._internalState,Left:t=>({...e.context._internalState,error:t})})}),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:e,context:t})=>p(e.output)?{...t._internalState,appConfig:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetAppConfigResultCheck:{always:[{target:"Web3ChecksOptIn",guard:h(["noInternalError","isWeb3ChecksSupported","shouldOptIn"])},{target:"GetAddress",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:e,context:t})=>p(e.output)?{...t._internalState,appConfig:{...t._internalState.appConfig,web3ChecksEnabled:e.output.data.enabled}}:t._internalState})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},Web3ChecksOptInResult:{entry:n(({context:e})=>({intermediateValue:{requiredUserInteraction:i.None,step:a.WEB3_CHECKS_OPT_IN_RESULT,result:e._internalState.appConfig.web3ChecksEnabled}})),after:{0:{target:"GetAddress"}}},GetAddress:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.GET_ADDRESS}}),invoke:{id:"getAddress",src:"getAddress",input:({context:e})=>({derivationPath:e.input.derivationPath}),onDone:{target:"BuildContext",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,from:e.output.data.address}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error"}}},BuildContext:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.BUILD_CONTEXT}}),invoke:{id:"buildContext",src:"buildContext",input:({context:e})=>({contextModule:e.input.contextModule,parser:e.input.parser,transactionParser:e.input.transactionParser,transactionMapper:e.input.transactionMapper,data:e.input.data,appConfig:e._internalState.appConfig,derivationPath:e.input.derivationPath,from:e._internalState.from}),onDone:{target:"ProvideContext",actions:[n({_internalState:({event:e,context:t})=>({...t._internalState,typedDataContext:e.output})})]},onError:{target:"SignTypedDataLegacy"}}},ProvideContext:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.PROVIDE_CONTEXT}}),invoke:{id:"provideContext",src:"provideContext",input:({context:e})=>({contextModule:e.input.contextModule,taskArgs:e._internalState.typedDataContext}),onDone:{actions:n({_internalState:e=>p(e.event.output)?e.context._internalState:{...e.context._internalState,error:e.event.output.error}}),target:"ProvideContextResultCheck"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContextResultCheck:{always:[{guard:"noInternalError",target:"SignTypedData"},{guard:"notRefusedByUser",target:"SignTypedDataLegacy"},{target:"Error"}]},SignTypedData:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.SIGN_TYPED_DATA}}),invoke:{id:"signTypedData",src:"signTypedData",input:({context:e})=>({derivationPath:e.input.derivationPath}),onDone:{target:"SignTypedDataResultCheck",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,signature:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataResultCheck:{always:[{guard:"noInternalError",target:"Success"},{guard:"notRefusedByUser",target:"SignTypedDataLegacy"},{target:"Error"}]},SignTypedDataLegacy:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY}}),invoke:{id:"signTypedDataLegacy",src:"signTypedDataLegacy",input:({context:e})=>({derivationPath:e.input.derivationPath,data:e.input.data}),onDone:{target:"SignTypedDataLegacyResultCheck",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,signature:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataLegacyResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:e})=>e._internalState.signature?E(e._internalState.signature):A(e._internalState.error||new S("No error in final state"))})}extractDependencies(r){return{getAddress:async e=>r.sendCommand(new v(e.input)),getAppConfig:async()=>r.sendCommand(new P),web3CheckOptIn:async()=>r.sendCommand(new k),buildContext:async e=>new _(r,e.input.contextModule,e.input.parser,e.input.transactionParser,e.input.transactionMapper,e.input.data,e.input.derivationPath,e.input.appConfig,e.input.from).run(),provideContext:async e=>new x(r,e.input.contextModule,e.input.taskArgs).run(),signTypedData:async e=>r.sendCommand(new I({derivationPath:e.input.derivationPath,legacyArgs:T})),signTypedDataLegacy:async e=>new O(r,e.input.data,e.input.derivationPath).run()}}}export{Y as SignTypedDataDeviceAction};
2
2
  //# sourceMappingURL=SignTypedDataDeviceAction.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.ts"],
4
- "sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\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 { Just, Left, Nothing, Right } from \"purify-ts\";\nimport { assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type SignTypedDataDAError,\n type SignTypedDataDAInput,\n type SignTypedDataDAIntermediateValue,\n type SignTypedDataDAInternalState,\n type SignTypedDataDAOutput,\n} from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { SignEIP712Command } from \"@internal/app-binder/command/SignEIP712Command\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { BuildEIP712ContextTask } from \"@internal/app-binder/task/BuildEIP712ContextTask\";\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n type ProvideEIP712ContextTaskReturnType,\n} from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nexport type MachineDependencies = {\n readonly buildContext: (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n };\n }) => Promise<ProvideEIP712ContextTaskArgs>;\n readonly provideContext: (arg0: {\n input: {\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) => ProvideEIP712ContextTaskReturnType;\n readonly signTypedData: (arg0: {\n input: {\n derivationPath: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n readonly signTypedDataLegacy: (arg0: {\n input: {\n derivationPath: string;\n domainHash: string;\n messageHash: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTypedDataDeviceAction extends XStateDeviceAction<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n > {\n type types = StateMachineTypes<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n >;\n\n const { buildContext, provideContext, signTypedData, signTypedDataLegacy } =\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 buildContext: fromPromise(buildContext),\n provideContext: fromPromise(provideContext),\n signTypedData: fromPromise(signTypedData),\n signTypedDataLegacy: fromPromise(signTypedDataLegacy),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\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 id: \"SignTypedDataDeviceAction\",\n initial: \"OpenAppDeviceAction\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n _internalState: {\n error: null,\n typedDataContext: null,\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<SignTypedDataDAInternalState>({\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: \"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 parser: context.input.parser,\n data: context.input.data,\n }),\n onDone: {\n target: \"ProvideContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n typedDataContext: event.output,\n }),\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"provideContext\",\n src: \"provideContext\",\n input: ({ context }) => ({\n taskArgs: context._internalState.typedDataContext!,\n }),\n onDone: {\n actions: assign({\n _internalState: (_) => {\n if (isSuccessCommandResult(_.event.output)) {\n return _.context._internalState;\n }\n return {\n ..._.context._internalState,\n error: _.event.output.error,\n };\n },\n }),\n target: \"ProvideContextResultCheck\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContextResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"SignTypedData\" },\n { target: \"SignTypedDataLegacy\" },\n ],\n },\n SignTypedData: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"signTypedData\",\n src: \"signTypedData\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\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 SignTypedDataLegacy: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"signTypedDataLegacy\",\n src: \"signTypedDataLegacy\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n domainHash: context._internalState.typedDataContext!.domainHash,\n messageHash: context._internalState.typedDataContext!.messageHash,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\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 SignTypedDataResultCheck: {\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 buildContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n };\n }) =>\n new BuildEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.parser,\n arg0.input.data,\n ).run();\n\n const provideContext = async (arg0: {\n input: {\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) => new ProvideEIP712ContextTask(internalApi, arg0.input.taskArgs).run();\n\n const signTypedData = async (arg0: {\n input: {\n derivationPath: string;\n };\n }): Promise<CommandResult<Signature, EthErrorCodes>> =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Nothing,\n }),\n );\n\n const signTypedDataLegacy = async (arg0: {\n input: {\n derivationPath: string;\n domainHash: string;\n messageHash: string;\n };\n }) =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Just({\n domainHash: arg0.input.domainHash,\n messageHash: arg0.input.messageHash,\n }),\n }),\n );\n\n return {\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n };\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "Just", "Left", "Nothing", "Right", "assign", "fromPromise", "setup", "SignEIP712Command", "ETHEREUM_PLUGINS", "BuildEIP712ContextTask", "ProvideEIP712ContextTask", "SignTypedDataDeviceAction", "internalApi", "buildContext", "provideContext", "signTypedData", "signTypedDataLegacy", "context", "_", "input", "error", "event", "arg0"]
4
+ "sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\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, Nothing, 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 SignTypedDataDAError,\n type SignTypedDataDAInput,\n type SignTypedDataDAIntermediateValue,\n type SignTypedDataDAInternalState,\n type SignTypedDataDAOutput,\n SignTypedDataDAStateStep,\n} from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { GetAddressCommand } from \"@internal/app-binder/command/GetAddressCommand\";\nimport { GetAppConfiguration } from \"@internal/app-binder/command/GetAppConfigurationCommand\";\nimport { SignEIP712Command } from \"@internal/app-binder/command/SignEIP712Command\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport {\n Web3CheckOptInCommand,\n type Web3CheckOptInCommandResponse,\n} from \"@internal/app-binder/command/Web3CheckOptInCommand\";\nimport { BuildEIP712ContextTask } from \"@internal/app-binder/task/BuildEIP712ContextTask\";\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n type ProvideEIP712ContextTaskReturnType,\n} from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { SignTypedDataLegacyTask } from \"@internal/app-binder/task/SignTypedDataLegacyTask\";\nimport { ApplicationChecker } from \"@internal/shared/utils/ApplicationChecker\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\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 buildContext: (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n transactionMapper: TransactionMapperService;\n transactionParser: TransactionParserService;\n from: string;\n };\n }) => Promise<ProvideEIP712ContextTaskArgs>;\n readonly provideContext: (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) => ProvideEIP712ContextTaskReturnType;\n readonly signTypedData: (arg0: {\n input: {\n derivationPath: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n readonly signTypedDataLegacy: (arg0: {\n input: {\n derivationPath: string;\n data: TypedData;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTypedDataDeviceAction extends XStateDeviceAction<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n > {\n type types = StateMachineTypes<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n >;\n\n const {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\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 buildContext: fromPromise(buildContext),\n provideContext: fromPromise(provideContext),\n signTypedData: fromPromise(signTypedData),\n signTypedDataLegacy: fromPromise(signTypedDataLegacy),\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.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 id: \"SignTypedDataDeviceAction\",\n initial: \"InitialState\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n _internalState: {\n error: null,\n appConfig: null,\n from: null,\n typedDataContext: 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: SignTypedDataDAStateStep.OPEN_APP,\n }),\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<SignTypedDataDAInternalState>({\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: SignTypedDataDAStateStep.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: \"GetAddress\",\n guard: \"noInternalError\",\n },\n {\n target: \"Error\",\n },\n ],\n },\n Web3ChecksOptIn: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTypedDataDAStateStep.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: SignTypedDataDAStateStep.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 BuildContext\n after: {\n 0: {\n target: \"GetAddress\",\n },\n },\n },\n GetAddress: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n }),\n invoke: {\n id: \"getAddress\",\n src: \"getAddress\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"BuildContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n from: event.output.data.address,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n },\n },\n },\n BuildContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n }),\n invoke: {\n id: \"buildContext\",\n src: \"buildContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n parser: context.input.parser,\n transactionParser: context.input.transactionParser,\n transactionMapper: context.input.transactionMapper,\n data: context.input.data,\n appConfig: context._internalState.appConfig!,\n derivationPath: context.input.derivationPath,\n from: context._internalState.from!,\n }),\n onDone: {\n target: \"ProvideContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n typedDataContext: event.output,\n }),\n }),\n ],\n },\n onError: {\n target: \"SignTypedDataLegacy\",\n },\n },\n },\n ProvideContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n }),\n invoke: {\n id: \"provideContext\",\n src: \"provideContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n taskArgs: context._internalState.typedDataContext!,\n }),\n onDone: {\n actions: assign({\n _internalState: (_) => {\n if (isSuccessCommandResult(_.event.output)) {\n return _.context._internalState;\n }\n return {\n ..._.context._internalState,\n error: _.event.output.error,\n };\n },\n }),\n target: \"ProvideContextResultCheck\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContextResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"SignTypedData\" },\n { guard: \"notRefusedByUser\", target: \"SignTypedDataLegacy\" },\n { target: \"Error\" },\n ],\n },\n SignTypedData: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n }),\n invoke: {\n id: \"signTypedData\",\n src: \"signTypedData\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\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 SignTypedDataResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { guard: \"notRefusedByUser\", target: \"SignTypedDataLegacy\" },\n { target: \"Error\" },\n ],\n },\n SignTypedDataLegacy: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n }),\n invoke: {\n id: \"signTypedDataLegacy\",\n src: \"signTypedDataLegacy\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n data: context.input.data,\n }),\n onDone: {\n target: \"SignTypedDataLegacyResultCheck\",\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 SignTypedDataLegacyResultCheck: {\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 buildContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n transactionMapper: TransactionMapperService;\n transactionParser: TransactionParserService;\n from: string;\n };\n }) =>\n new BuildEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.parser,\n arg0.input.transactionParser,\n arg0.input.transactionMapper,\n arg0.input.data,\n arg0.input.derivationPath,\n arg0.input.appConfig,\n arg0.input.from,\n ).run();\n\n const provideContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) =>\n new ProvideEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.taskArgs,\n ).run();\n\n const signTypedData = async (arg0: {\n input: {\n derivationPath: string;\n };\n }): Promise<CommandResult<Signature, EthErrorCodes>> =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Nothing,\n }),\n );\n\n const signTypedDataLegacy = async (arg0: {\n input: {\n derivationPath: string;\n data: TypedData;\n };\n }) =>\n new SignTypedDataLegacyTask(\n internalApi,\n arg0.input.data,\n arg0.input.derivationPath,\n ).run();\n\n return {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n };\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["DeviceModelId", "isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "Left", "Nothing", "Right", "and", "assign", "fromPromise", "setup", "SignTypedDataDAStateStep", "GetAddressCommand", "GetAppConfiguration", "SignEIP712Command", "Web3CheckOptInCommand", "BuildEIP712ContextTask", "ProvideEIP712ContextTask", "SignTypedDataLegacyTask", "ApplicationChecker", "SignTypedDataDeviceAction", "internalApi", "getAddress", "getAppConfig", "web3CheckOptIn", "buildContext", "provideContext", "signTypedData", "signTypedDataLegacy", "context", "_", "input", "error", "event", "arg0"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{CommandResultFactory as u,DeviceActionStatus as e,UnknownDAError as p,UnknownDeviceExchangeError as v,UserInteractionRequired as t}from"@ledgerhq/device-management-kit";import{Just as A,Nothing as V}from"purify-ts";import{makeDeviceActionInternalApiMock as l}from"../../../app-binder/device-action/__test-utils__/makeInternalApi";import{setupOpenAppDAMock as m}from"../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock";import{testDeviceActionStates as f}from"../../../app-binder/device-action/__test-utils__/testDeviceActionStates";import{PrimitiveType as k,StructType as T,TypedDataValueField as P}from"../../../typed-data/model/Types";import{SignTypedDataDeviceAction as g}from"./SignTypedDataDeviceAction";jest.mock("@ledgerhq/device-management-kit",()=>({...jest.requireActual("@ledgerhq/device-management-kit"),OpenAppDeviceAction:jest.fn(()=>({makeStateMachine:jest.fn()}))}));describe("SignTypedDataDeviceAction",()=>{const i={domain:{},message:{},primaryType:"TestMessage",types:{}},b={messageHash:"0x8887109c22cd7358af93c04b5397e91b1331e0c389951542e11af4b227a4aa1d",domainHash:"0x06c37168a7db5138defc7866392bb87a741f9b3d104deb5094588ce041cae335",types:{PermitSingle:{details:new T("PermitDetails"),spender:new k("address","address",V),sigDeadline:new k("uint256","uint",A(32))}},domain:[{path:"chainId",type:"uint256",value:new P(Uint8Array.from([137]))}],message:[{path:"details.expiration",type:"uint48",value:new P(Uint8Array.from([19]))}],clearSignContext:A({type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},tokens:{},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}})},d={parse:jest.fn()},o={getContext:jest.fn(),getContexts:jest.fn(),getTypedDataFilters:jest.fn()},s=jest.fn(),c=jest.fn(),x=jest.fn(),D=jest.fn();function y(){return{buildContext:s,provideContext:c,signTypedData:x,signTypedDataLegacy:D}}beforeEach(()=>{jest.resetAllMocks()}),describe("Success case",()=>{it("should call external dependencies with the correct parameters",n=>{m();const a=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});jest.spyOn(a,"extractDependencies").mockReturnValue(y()),s.mockResolvedValueOnce(b),c.mockResolvedValueOnce(u({data:void 0})),x.mockResolvedValueOnce(u({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));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.SignTypedData},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}],{observable:S}=f(a,r,l(),n);S.subscribe({complete:()=>{expect(s).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:o,parser:d,data:i}})),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{taskArgs:b}})),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0"}}))}})}),it("should fallback to legacy signing if the new one fails",n=>{m();const a=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});jest.spyOn(a,"extractDependencies").mockReturnValue(y()),s.mockResolvedValueOnce(b),c.mockResolvedValueOnce(u({error:new v("instruction not supported")})),D.mockResolvedValueOnce(u({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));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.SignTypedData},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];f(a,r,l(),n)})}),describe("error cases",()=>{it("Error if the open app fails",n=>{m(new p("Mocked error"));const a=[{status:e.Pending,intermediateValue:{requiredUserInteraction:t.None}},{status:e.Pending,intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp}},{status:e.Error,error:new p("Mocked error")}],r=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});f(r,a,l(),n)}),it("Error while building context",n=>{m();const a=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});jest.spyOn(a,"extractDependencies").mockReturnValue(y()),s.mockRejectedValueOnce(new p("Error"));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 p("Error"),status:e.Error}];f(a,r,l(),n)}),it("Error thrown while providing context",n=>{m();const a=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});jest.spyOn(a,"extractDependencies").mockReturnValue(y()),s.mockResolvedValueOnce(b),c.mockRejectedValueOnce(new p("Error"));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.SignTypedData},status:e.Pending},{error:new p("Error"),status:e.Error}];f(a,r,l(),n)}),it("Error while signing",n=>{m();const a=new g({input:{derivationPath:"44'/60'/0'/0/0",data:i,contextModule:o,parser:d}});jest.spyOn(a,"extractDependencies").mockReturnValue(y()),s.mockResolvedValueOnce(b),c.mockResolvedValueOnce(u({data:void 0})),x.mockResolvedValueOnce(u({error:new v("Error while signing the typed data")}));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.SignTypedData},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData},status:e.Pending},{error:new v("Error while signing the typed data"),status:e.Error}];f(a,r,l(),n)})})});
1
+ import{CommandResultFactory as r,DeviceActionStatus as e,DeviceModelId as C,DeviceSessionStateType as q,DeviceStatus as h,UnknownDAError as k,UserInteractionRequired as t}from"@ledgerhq/device-management-kit";import{Just as N,Nothing as w}from"purify-ts";import{SignTypedDataDAStateStep as a}from"../../../../api/app-binder/SignTypedDataDeviceActionTypes";import{EthAppCommandErrorFactory as S}from"../../../app-binder/command/utils/ethAppErrors";import{makeDeviceActionInternalApiMock as M}from"../../../app-binder/device-action/__test-utils__/makeInternalApi";import{setupOpenAppDAMock as v}from"../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock";import{testDeviceActionStates as T}from"../../../app-binder/device-action/__test-utils__/testDeviceActionStates";import{PrimitiveType as _,StructType as G,TypedDataValueField as U}from"../../../typed-data/model/Types";import{SignTypedDataDeviceAction as E}from"./SignTypedDataDeviceAction";vi.mock("@ledgerhq/device-management-kit",async d=>({...await d(),OpenAppDeviceAction:vi.fn(()=>({makeStateMachine:vi.fn()}))}));describe("SignTypedDataDeviceAction",()=>{const d={domain:{},message:{},primaryType:"TestMessage",types:{}},P={deviceModelId:C.STAX,derivationPath:"44'/60'/0'/0/0",types:{PermitSingle:{details:new G("PermitDetails"),spender:new _("address","address",w),sigDeadline:new _("uint256","uint",N(32))}},domain:[{path:"chainId",type:"uint256",value:new U(Uint8Array.from([137]))}],message:[{path:"details.expiration",type:"uint48",value:new U(Uint8Array.from([19]))}],clearSignContext:N({type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},trustedNamesAddresses:{},tokens:{},calldatas:{},proxy:void 0,filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}}),calldatasContexts:{}},g="0x8ceb23fd6bc0add59e62ac25578270cff1b9f619",u={parse:vi.fn()},p={extractValue:vi.fn()},l={mapTransactionToSubset:vi.fn()},c={getFieldContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},m=M(),x=vi.fn(),R=vi.fn(),f=vi.fn(),A=vi.fn(),I=vi.fn(),b=vi.fn(),D=vi.fn();function O(){return{getAddress:D,getAppConfig:x,web3CheckOptIn:R,buildContext:f,provideContext:A,signTypedData:I,signTypedDataLegacy:b}}function y(i,s,n){return{blindSigningEnabled:!1,web3ChecksEnabled:s,web3ChecksOptIn:n,version:i}}function V(i,s,n){m.getDeviceSessionState.mockReturnValueOnce({sessionStateType:q.ReadyWithoutSecureChannel,deviceStatus:h.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:i},deviceModelId:C.FLEX,isSecureConnectionAllowed:!1}),x.mockResolvedValue(r({data:y(i,s,n)}))}beforeEach(()=>{vi.resetAllMocks()}),describe("Success case",()=>{it("should call external dependencies with the correct parameters",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({data:void 0})),I.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];T(n,o,m,{onError:s,onDone:()=>{expect(f).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:c,parser:u,transactionParser:p,transactionMapper:l,data:d,appConfig:y("1.15.0",!1,!1),derivationPath:"44'/60'/0'/0/0",from:g}})),expect(A).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:c,taskArgs:P}})),expect(I).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0"}})),i()}})})),it("should be successful whlie skipping OpenApp",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!0}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({data:void 0})),I.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];T(n,o,m,{onError:s,onDone:i})})),it("should fallback to legacy signing if the new one fails",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({error:S({errorCode:"6a80",message:""})})),b.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];T(n,o,m,{onError:s,onDone:i})})),it("should fallback to legacy signing BuildContext fails",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockRejectedValueOnce(new k("Error")),b.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];T(n,o,m,{onError:s,onDone:i})})),it("should not fallback to legacy signing if rejected by the user during streaming",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({error:S({errorCode:"6985",message:""})})),b.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{error:S({errorCode:"6985",message:""}),status:e.Error}];T(n,o,m,{onError:s,onDone:i})})),it("should not fallback to legacy signing if rejected by the user during signing",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({data:void 0})),I.mockResolvedValueOnce(r({error:S({errorCode:"6985",message:"User refused"})}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA},status:e.Pending},{error:S({errorCode:"6985",message:"User refused"}),status:e.Error}];T(n,o,m,{onError:s,onDone:i})}))}),describe("error cases",()=>{it("Error if the open app fails",()=>new Promise((i,s)=>{v(new k("Mocked error"));const n=[{status:e.Pending,intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP}},{status:e.Pending,intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP}},{status:e.Error,error:new k("Mocked error")}],o=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});T(o,n,m,{onError:s,onDone:i})})),it("Error thrown while providing context",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockRejectedValueOnce(new k("Error"));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{error:new k("Error"),status:e.Error}];T(n,o,m,{onError:s,onDone:i})})),it("Error while signing should fallback to legacy signing",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({data:void 0})),I.mockResolvedValueOnce(r({error:S({errorCode:"6a80",message:"Error while signing the typed data"})})),b.mockResolvedValueOnce(r({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY},status:e.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.Completed}];T(n,o,m,{onError:s,onDone:i})})),it("Error if both signing and legacy signing fail",()=>new Promise((i,s)=>{v(),V("1.15.0",!1,!1),D.mockResolvedValueOnce(r({data:{address:g}}));const n=new E({input:{derivationPath:"44'/60'/0'/0/0",data:d,contextModule:c,parser:u,transactionParser:p,transactionMapper:l,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(O()),f.mockResolvedValueOnce(P),A.mockResolvedValueOnce(r({data:void 0})),I.mockResolvedValueOnce(r({error:S({errorCode:"6a80",message:"Error while signing the typed data"})})),b.mockResolvedValueOnce(r({error:S({errorCode:"6a80",message:"Error while signing the typed data with legacy"})}));const o=[{intermediateValue:{requiredUserInteraction:t.None,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.ConfirmOpenApp,step:a.OPEN_APP},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_APP_CONFIG},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.GET_ADDRESS},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.None,step:a.BUILD_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.PROVIDE_CONTEXT},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA},status:e.Pending},{intermediateValue:{requiredUserInteraction:t.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY},status:e.Pending},{error:S({errorCode:"6a80",message:"Error while signing the typed data with legacy"}),status:e.Error}];T(n,o,m,{onError:s,onDone:i})}))})});
2
2
  //# sourceMappingURL=SignTypedDataDeviceAction.test.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.ts"],
4
- "sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionStatus,\n UnknownDAError,\n UnknownDeviceExchangeError,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport { type SignTypedDataDAState } from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\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 ProvideEIP712ContextTaskArgs } from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport {\n PrimitiveType,\n StructType,\n TypedDataValueField,\n} from \"@internal/typed-data/model/Types\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nimport { SignTypedDataDeviceAction } from \"./SignTypedDataDeviceAction\";\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(\"SignTypedDataDeviceAction\", () => {\n const TEST_MESSAGE = {\n domain: {},\n message: {},\n primaryType: \"TestMessage\",\n types: {},\n };\n const TEST_BUILT_CONTEXT: ProvideEIP712ContextTaskArgs = {\n messageHash:\n \"0x8887109c22cd7358af93c04b5397e91b1331e0c389951542e11af4b227a4aa1d\",\n domainHash:\n \"0x06c37168a7db5138defc7866392bb87a741f9b3d104deb5094588ce041cae335\",\n types: {\n PermitSingle: {\n details: new StructType(\"PermitDetails\"),\n spender: new PrimitiveType(\"address\", \"address\", Nothing),\n sigDeadline: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n },\n },\n domain: [\n {\n path: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n ],\n message: [\n {\n path: \"details.expiration\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x13])),\n },\n ],\n clearSignContext: Just({\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 1,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n tokens: {},\n filters: {\n \"details.amount\": {\n displayName: \"Amount allowance\",\n path: \"details.amount\",\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n tokenIndex: 255,\n type: \"amount\",\n },\n },\n }),\n };\n\n const mockParser: TypedDataParserService = {\n parse: jest.fn(),\n };\n const mockContextModule: ContextModule = {\n getContext: jest.fn(),\n getContexts: jest.fn(),\n getTypedDataFilters: jest.fn(),\n };\n const buildContextMock = jest.fn();\n const provideContextMock = jest.fn();\n const signTypedDataMock = jest.fn();\n const signTypedDataLegacyMock = jest.fn();\n function extractDependenciesMock() {\n return {\n buildContext: buildContextMock,\n provideContext: provideContextMock,\n signTypedData: signTypedDataMock,\n signTypedDataLegacy: signTypedDataLegacyMock,\n };\n }\n\n beforeEach(() => {\n jest.resetAllMocks();\n });\n\n describe(\"Success case\", () => {\n it(\"should call external dependencies with the correct parameters\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n // Mock the dependencies to return some sample data\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideContext -> SignTypedData\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\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(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: mockContextModule,\n parser: mockParser,\n data: TEST_MESSAGE,\n },\n }),\n );\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n taskArgs: TEST_BUILT_CONTEXT,\n },\n }),\n );\n expect(signTypedDataMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n },\n });\n });\n\n it(\"should fallback to legacy signing if the new one fails\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n // Mock the providing error\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"instruction not supported\"),\n }),\n );\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n });\n\n describe(\"error cases\", () => {\n it(\"Error if the open app fails\", (done) => {\n setupOpenAppDAMock(new UnknownDAError(\"Mocked error\"));\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n status: DeviceActionStatus.Pending,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n },\n {\n status: DeviceActionStatus.Pending,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n },\n {\n status: DeviceActionStatus.Error,\n error: new UnknownDAError(\"Mocked error\"),\n },\n ];\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n\n it(\"Error while building context\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n // Mock the parsing error\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n buildContextMock.mockRejectedValueOnce(new UnknownDAError(\"Error\"));\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: new UnknownDAError(\"Error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n\n it(\"Error thrown while providing context\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n // Mock the providing error\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockRejectedValueOnce(new UnknownDAError(\"Error\"));\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: new UnknownDAError(\"Error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(\n deviceAction,\n expectedStates,\n makeDeviceActionInternalApiMock(),\n done,\n );\n });\n\n it(\"Error while signing\", (done) => {\n setupOpenAppDAMock();\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule,\n parser: mockParser,\n },\n });\n\n // Mock signing error\n jest\n .spyOn(deviceAction, \"extractDependencies\")\n .mockReturnValue(extractDependenciesMock());\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\n \"Error while signing the typed data\",\n ),\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: new UnknownDeviceExchangeError(\n \"Error while signing the typed data\",\n ),\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", "UnknownDAError", "UnknownDeviceExchangeError", "UserInteractionRequired", "Just", "Nothing", "makeDeviceActionInternalApiMock", "setupOpenAppDAMock", "testDeviceActionStates", "PrimitiveType", "StructType", "TypedDataValueField", "SignTypedDataDeviceAction", "TEST_MESSAGE", "TEST_BUILT_CONTEXT", "mockParser", "mockContextModule", "buildContextMock", "provideContextMock", "signTypedDataMock", "signTypedDataLegacyMock", "extractDependenciesMock", "done", "deviceAction", "expectedStates", "observable"]
4
+ "sourcesContent": ["/* eslint @typescript-eslint/consistent-type-imports: 0 */\nimport { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionStatus,\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n UnknownDAError,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport { type SignTypedDataDAState } from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { SignTypedDataDAStateStep } from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { EthAppCommandErrorFactory } from \"@internal/app-binder/command/utils/ethAppErrors\";\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 ProvideEIP712ContextTaskArgs } from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\nimport {\n PrimitiveType,\n StructType,\n TypedDataValueField,\n} from \"@internal/typed-data/model/Types\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nimport { SignTypedDataDeviceAction } from \"./SignTypedDataDeviceAction\";\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(\"SignTypedDataDeviceAction\", () => {\n const TEST_MESSAGE = {\n domain: {},\n message: {},\n primaryType: \"TestMessage\",\n types: {},\n };\n const TEST_BUILT_CONTEXT: ProvideEIP712ContextTaskArgs = {\n deviceModelId: DeviceModelId.STAX,\n derivationPath: \"44'/60'/0'/0/0\",\n types: {\n PermitSingle: {\n details: new StructType(\"PermitDetails\"),\n spender: new PrimitiveType(\"address\", \"address\", Nothing),\n sigDeadline: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n },\n },\n domain: [\n {\n path: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n ],\n message: [\n {\n path: \"details.expiration\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x13])),\n },\n ],\n clearSignContext: Just({\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 1,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n trustedNamesAddresses: {},\n tokens: {},\n calldatas: {},\n proxy: undefined,\n filters: {\n \"details.amount\": {\n displayName: \"Amount allowance\",\n path: \"details.amount\",\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n tokenIndex: 255,\n type: \"amount\",\n },\n },\n }),\n calldatasContexts: {},\n };\n const FROM = \"0x8ceb23fd6bc0add59e62ac25578270cff1b9f619\";\n\n const mockParser: TypedDataParserService = {\n parse: vi.fn(),\n };\n const mockTransactionParser: TransactionParserService = {\n extractValue: vi.fn(),\n } as unknown as TransactionParserService;\n const mockTransactionMapper: TransactionMapperService = {\n mapTransactionToSubset: vi.fn(),\n };\n const mockContextModule = {\n getFieldContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const apiMock = makeDeviceActionInternalApiMock();\n const getAppConfigMock = vi.fn();\n const web3CheckOptInMock = vi.fn();\n const buildContextMock = vi.fn();\n const provideContextMock = vi.fn();\n const signTypedDataMock = vi.fn();\n const signTypedDataLegacyMock = vi.fn();\n const getAddressMock = vi.fn();\n function extractDependenciesMock() {\n return {\n getAddress: getAddressMock,\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n buildContext: buildContextMock,\n provideContext: provideContextMock,\n signTypedData: signTypedDataMock,\n signTypedDataLegacy: signTypedDataLegacyMock,\n };\n }\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 getAppConfigMock.mockResolvedValue(\n CommandResultFactory({\n data: createAppConfig(version, web3ChecksEnabled, web3ChecksOptIn),\n }),\n );\n }\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"Success case\", () => {\n it(\"should call external dependencies with the correct parameters\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock the dependencies to return some sample data\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideContext -> SignTypedData\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: mockContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n data: TEST_MESSAGE,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n from: FROM,\n },\n }),\n );\n\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: mockContextModule,\n taskArgs: TEST_BUILT_CONTEXT,\n },\n }),\n );\n\n expect(signTypedDataMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n\n resolve();\n },\n });\n }));\n\n it(\"should be successful whlie skipping OpenApp\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: true,\n },\n });\n\n // Mock the dependencies to return some sample data\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> BuildContext -> ProvideContext -> SignTypedData\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"should fallback to legacy signing if the new one fails\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock the providing error\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6a80\",\n message: \"\",\n }),\n }),\n );\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"should fallback to legacy signing BuildContext fails\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock the providing error\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockRejectedValueOnce(new UnknownDAError(\"Error\"));\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"should not fallback to legacy signing if rejected by the user during streaming\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock the providing error\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6985\",\n message: \"\",\n }),\n }),\n );\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: EthAppCommandErrorFactory({\n errorCode: \"6985\",\n message: \"\",\n }),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"should not fallback to legacy signing if rejected by the user during signing\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock user rejection during SignTypedData step\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6985\",\n message: \"User refused\",\n }),\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: EthAppCommandErrorFactory({\n errorCode: \"6985\",\n message: \"User refused\",\n }),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n });\n\n describe(\"error cases\", () => {\n it(\"Error if the open app fails\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock(new UnknownDAError(\"Mocked error\"));\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n status: DeviceActionStatus.Pending,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n },\n {\n status: DeviceActionStatus.Pending,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n },\n {\n status: DeviceActionStatus.Error,\n error: new UnknownDAError(\"Mocked error\"),\n },\n ];\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"Error thrown while providing context\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock the providing error\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockRejectedValueOnce(new UnknownDAError(\"Error\"));\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: new UnknownDAError(\"Error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"Error while signing should fallback to legacy signing\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock signing error that should fallback to legacy\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6a80\",\n message: \"Error while signing the typed data\",\n }),\n }),\n );\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n\n it(\"Error if both signing and legacy signing fail\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: FROM },\n }),\n );\n\n const deviceAction = new SignTypedDataDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n data: TEST_MESSAGE,\n contextModule: mockContextModule as unknown as ContextModule,\n parser: mockParser,\n transactionParser: mockTransactionParser,\n transactionMapper: mockTransactionMapper,\n skipOpenApp: false,\n },\n });\n\n // Mock both signing methods to fail\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n buildContextMock.mockResolvedValueOnce(TEST_BUILT_CONTEXT);\n provideContextMock.mockResolvedValueOnce(\n CommandResultFactory({ data: undefined }),\n );\n signTypedDataMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6a80\",\n message: \"Error while signing the typed data\",\n }),\n }),\n );\n signTypedDataLegacyMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: EthAppCommandErrorFactory({\n errorCode: \"6a80\",\n message: \"Error while signing the typed data with legacy\",\n }),\n }),\n );\n\n const expectedStates: Array<SignTypedDataDAState> = [\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n status: DeviceActionStatus.Pending,\n },\n {\n error: EthAppCommandErrorFactory({\n errorCode: \"6a80\",\n message: \"Error while signing the typed data with legacy\",\n }),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["CommandResultFactory", "DeviceActionStatus", "DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "UnknownDAError", "UserInteractionRequired", "Just", "Nothing", "SignTypedDataDAStateStep", "EthAppCommandErrorFactory", "makeDeviceActionInternalApiMock", "setupOpenAppDAMock", "testDeviceActionStates", "PrimitiveType", "StructType", "TypedDataValueField", "SignTypedDataDeviceAction", "importOriginal", "TEST_MESSAGE", "TEST_BUILT_CONTEXT", "FROM", "mockParser", "mockTransactionParser", "mockTransactionMapper", "mockContextModule", "apiMock", "getAppConfigMock", "web3CheckOptInMock", "buildContextMock", "provideContextMock", "signTypedDataMock", "signTypedDataLegacyMock", "getAddressMock", "extractDependenciesMock", "createAppConfig", "version", "web3ChecksEnabled", "web3ChecksOptIn", "setupAppConfig", "resolve", "reject", "deviceAction", "expectedStates"]
7
7
  }
@@ -0,0 +1,2 @@
1
+ import{isSuccessCommandResult as A,OpenAppDeviceAction as S,UserInteractionRequired as a,XStateDeviceAction as f}from"@ledgerhq/device-management-kit";import{Left as p,Right as u}from"purify-ts";import{assign as r,fromPromise as c,setup as l}from"xstate";import{VerifySafeAddressDAStep as s}from"../../../../api/app-binder/VerifySafeAddressDeviceActionTypes";import{BuildSafeAddressContextTask as y}from"../../../app-binder/task/BuildSafeAddressContextTask";import{ProvideContextTask as x}from"../../../app-binder/task/ProvideContextTask";class I extends f{makeStateMachine(n){const{buildSafeAddressContexts:i,provideContexts:o}=this.extractDependencies(n);return l({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new S({input:{appName:"Ethereum"}}).makeStateMachine(n),buildSafeAddressContexts:c(i),provideContexts:c(o)},guards:{noInternalError:({context:e})=>e._internalState.error===null,skipOpenApp:({context:e})=>!!e.input.options.skipOpenApp},actions:{assignErrorFromEvent:r({_internalState:e=>({...e.context._internalState,error:e.event.error})})}}).createMachine({id:"VerifySafeAddressDeviceAction",initial:"InitialState",context:({input:e})=>({input:e,intermediateValue:{requiredUserInteraction:a.None,step:s.OPEN_APP},_internalState:{error:null,contexts:[]}}),states:{InitialState:{always:[{target:"BuildSafeAddressContexts",guard:"skipOpenApp"},"OpenAppDeviceAction"]},OpenAppDeviceAction:{invoke:{id:"openAppStateMachine",input:{appName:"Ethereum"},src:"openAppStateMachine",onSnapshot:{actions:r({intermediateValue:e=>({...e.event.snapshot.context.intermediateValue,step:s.OPEN_APP})})},onDone:{actions:r({_internalState:e=>e.event.output.caseOf({Right:()=>e.context._internalState,Left:t=>({...e.context._internalState,error:t})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"BuildSafeAddressContexts",guard:"noInternalError"},"Error"]},BuildSafeAddressContexts:{entry:r({intermediateValue:{requiredUserInteraction:a.None,step:s.BUILD_CONTEXTS}}),invoke:{id:"buildSafeAddressContexts",src:"buildSafeAddressContexts",input:({context:e})=>({contextModule:e.input.contextModule,safeContractAddress:e.input.safeContractAddress,options:e.input.options,deviceModelId:n.getDeviceModel().id}),onDone:{target:"ProvideContexts",actions:[r({_internalState:({event:e,context:t})=>({...t._internalState,contexts:e.output.clearSignContexts})})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContexts:{entry:r({intermediateValue:{requiredUserInteraction:a.None,step:s.VERIFY_SAFE_ADDRESS}}),invoke:{id:"provideContexts",src:"provideContexts",input:({context:e})=>({contexts:e._internalState.contexts}),onDone:{target:"ProvideContextsResultCheck",actions:[r({_internalState:({event:e,context:t})=>e.output.isLeft()?{...t._internalState,error:e.output.extract()}:{...t._internalState,error:null}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContextsResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:e})=>e._internalState.error?p(e._internalState.error):u(void 0)})}extractDependencies(n){return{provideContexts:async e=>{for(const t of e.input.contexts){const d=await new x(n,{context:t}).run();if(!A(d))return p(d.error)}return u(void 0)},buildSafeAddressContexts:async e=>new y(n,e.input).run()}}}export{I as VerifySafeAddressDeviceAction};
2
+ //# sourceMappingURL=VerifySafeAddress.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.ts"],
4
+ "sourcesContent": ["import { type ClearSignContextSuccess } from \"@ledgerhq/context-module\";\nimport {\n type DeviceActionStateMachine,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { type Either, Left, Right } from \"purify-ts\";\nimport { assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type VerifySafeAddressDAError,\n type VerifySafeAddressDAInput,\n type VerifySafeAddressDAIntermediateValue,\n type VerifySafeAddressDAInternalState,\n type VerifySafeAddressDAOutput,\n VerifySafeAddressDAStep,\n} from \"@api/app-binder/VerifySafeAddressDeviceActionTypes\";\nimport {\n BuildSafeAddressContextTask,\n type BuildSafeAddressContextTaskArgs,\n type BuildSafeAddressContextTaskResult,\n} from \"@internal/app-binder/task/BuildSafeAddressContextTask\";\nimport { ProvideContextTask } from \"@internal/app-binder/task/ProvideContextTask\";\n\nexport type MachineDependencies = {\n readonly buildSafeAddressContexts: (arg0: {\n input: BuildSafeAddressContextTaskArgs;\n }) => Promise<BuildSafeAddressContextTaskResult>;\n readonly provideContexts: (arg0: {\n input: {\n contexts: ClearSignContextSuccess[];\n };\n }) => Promise<Either<VerifySafeAddressDAError, void>>;\n};\n\nexport class VerifySafeAddressDeviceAction extends XStateDeviceAction<\n VerifySafeAddressDAOutput,\n VerifySafeAddressDAInput,\n VerifySafeAddressDAError,\n VerifySafeAddressDAIntermediateValue,\n VerifySafeAddressDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n VerifySafeAddressDAOutput,\n VerifySafeAddressDAInput,\n VerifySafeAddressDAError,\n VerifySafeAddressDAIntermediateValue,\n VerifySafeAddressDAInternalState\n > {\n type types = StateMachineTypes<\n VerifySafeAddressDAOutput,\n VerifySafeAddressDAInput,\n VerifySafeAddressDAError,\n VerifySafeAddressDAIntermediateValue,\n VerifySafeAddressDAInternalState\n >;\n\n const { buildSafeAddressContexts, 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 buildSafeAddressContexts: fromPromise(buildSafeAddressContexts),\n provideContexts: fromPromise(provideContexts),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\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+VVKNR0gW6IOsoWMfgMdmhHRBHActisFnMMqCmNi2PGiSmC0JjOyZIpVKutINCxZsHZnMkxR5X0qv1qwsVwRVOglcJlcoQEo4ns9pmkQL00mCFgMWJxuuSM3p22JAHEwKRaSSqAAzdC7faHY5nA4wNMbDMYbNQd4OirqAW6CVWDhWPR2fR2Yy+Fu+UwGX1C4zGHoGcPSDuGCx6HTRnWTOMEhNE9gcFMlxRliviMA4HAUHAcRQCUSZ3cAWw4xfTWfQVdKvKdddqDabLbbY/6Pb7IQ4I+sPdR1n+KMtRjWd8VSBdDU4FdL3LdArRtY1KS5D4ykdWtQBqAYO2-MFwyBHRTEjNoYT8Lpv3CKwrG7Zt0VMPRpwSUD9QghZl1TGCK3gjlENOIoULvdCtEQLD-HDMMHAlQjAj7VEdADENg1MYNhQMUwGNxPV43SRdsmg0srygLjSB4qRfH4tCfgfEScPE-CpOIxBVO6HQiLbVUQR8dTYzAmgWOJAB1MAACMDB42BllIHhcwwA4jhOc4OAAd2C0LyUpCKeBvT4a0sjDhKGfxmxDXwMT0KIDF7dpYUono9B7YxbAI4xHGMLymK0hlWMCkKwoyjBN23Xd90PUhjxwM9kp6tLTUijAstQnL+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-EdiqtFfT_HxgOd0TsQMdjlVEIAA */\n id: \"VerifySafeAddressDeviceAction\",\n initial: \"InitialState\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: VerifySafeAddressDAStep.OPEN_APP,\n },\n _internalState: {\n error: null,\n contexts: [],\n },\n };\n },\n states: {\n InitialState: {\n always: [\n {\n target: \"BuildSafeAddressContexts\",\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: VerifySafeAddressDAStep.OPEN_APP,\n }),\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<VerifySafeAddressDAInternalState>(\n {\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n },\n );\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"BuildSafeAddressContexts\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n BuildSafeAddressContexts: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: VerifySafeAddressDAStep.BUILD_CONTEXTS,\n },\n }),\n invoke: {\n id: \"buildSafeAddressContexts\",\n src: \"buildSafeAddressContexts\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n safeContractAddress: context.input.safeContractAddress,\n options: context.input.options,\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 }),\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: VerifySafeAddressDAStep.VERIFY_SAFE_ADDRESS,\n },\n }),\n invoke: {\n id: \"provideContexts\",\n src: \"provideContexts\",\n input: ({ context }) => ({\n contexts: context._internalState\n .contexts as ClearSignContextSuccess[],\n }),\n onDone: {\n target: \"ProvideContextsResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (event.output.isLeft()) {\n return {\n ...context._internalState,\n error: event.output.extract(),\n };\n }\n\n return {\n ...context._internalState,\n error: null,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContextsResultCheck: {\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.error\n ? Left(context._internalState.error)\n : Right(void 0),\n });\n }\n\n extractDependencies(internalApi: InternalApi): MachineDependencies {\n const buildSafeAddressContexts = async (arg0: {\n input: BuildSafeAddressContextTaskArgs;\n }) => new BuildSafeAddressContextTask(internalApi, arg0.input).run();\n\n const provideContexts = async (arg0: {\n input: {\n contexts: ClearSignContextSuccess[];\n };\n }) => {\n for (const context of arg0.input.contexts) {\n const res = await new ProvideContextTask(internalApi, {\n context,\n }).run();\n\n if (!isSuccessCommandResult(res)) {\n return Left(res.error);\n }\n }\n return Right(void 0);\n };\n\n return {\n provideContexts,\n buildSafeAddressContexts,\n };\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["isSuccessCommandResult", "OpenAppDeviceAction", "UserInteractionRequired", "XStateDeviceAction", "Left", "Right", "assign", "fromPromise", "setup", "VerifySafeAddressDAStep", "BuildSafeAddressContextTask", "ProvideContextTask", "VerifySafeAddressDeviceAction", "internalApi", "buildSafeAddressContexts", "provideContexts", "context", "_", "input", "error", "event", "arg0", "res"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{ClearSignContextType as S}from"@ledgerhq/context-module";import{DeviceActionStatus as u,DeviceModelId as n,DeviceSessionStateType as O,DeviceStatus as D,InvalidStatusWordError as h,UserInteractionRequired as M}from"@ledgerhq/device-management-kit";import{Left as b,Right as E}from"purify-ts";import{lastValueFrom as A}from"rxjs";import{VerifySafeAddressDAStep as w}from"../../../../api/app-binder/VerifySafeAddressDeviceActionTypes";import{makeDeviceActionInternalApiMock as R}from"../../../app-binder/device-action/__test-utils__/makeInternalApi";import{setupOpenAppDAMock as p}from"../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock";import{executeUntilStep as k}from"../../../app-binder/device-action/__test-utils__/testDeviceActionUntilStep";import{VerifySafeAddressDeviceAction as v}from"./VerifySafeAddress";vi.mock("@ledgerhq/device-management-kit",async t=>({...await t(),OpenAppDeviceAction:vi.fn(()=>({makeStateMachine:vi.fn()}))}));describe("VerifySafeAddressDeviceAction",()=>{let t;const s={getContexts:vi.fn()},r=vi.fn(),x=vi.fn();function d(){return{buildSafeAddressContexts:r,provideContexts:x}}const a=R(),c="0x1234567890123456789012345678901234567890",i=1,m={type:S.SAFE,payload:"safe_payload"},y={type:S.SIGNER,payload:"signer_payload"};function l(e){a.getDeviceModel.mockReturnValue({id:e}),a.getDeviceSessionState.mockReturnValue({sessionStateType:O.ReadyWithoutSecureChannel,deviceStatus:D.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.15.0"},deviceModelId:e,isSecureConnectionAllowed:!1})}const C=(e,o)=>{if(e[o]?.status!==u.Pending)throw new Error(`Step ${o} is not pending: ${JSON.stringify(e[o])}`);return e[o]};describe("Happy path",()=>{describe("should verify safe address",()=>{beforeEach(()=>{vi.resetAllMocks(),p(),l(n.FLEX),r.mockResolvedValueOnce({clearSignContexts:[m,y]}),x.mockResolvedValueOnce(E(void 0));const e=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable}),it("should open the app",async()=>{const{steps:e}=await k(0,t);expect(C(e,0).intermediateValue.step).toBe(w.OPEN_APP)}),it("should confirm open app",async()=>{const{steps:e}=await k(1,t);expect(C(e,1).intermediateValue.requiredUserInteraction).toBe(M.ConfirmOpenApp)}),it("should build safe address contexts",async()=>{const{steps:e}=await k(2,t);expect(C(e,2).intermediateValue.step).toBe(w.BUILD_CONTEXTS),expect(r).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:s,safeContractAddress:c,options:{chainId:i},deviceModelId:n.FLEX}}))}),it("should provide contexts (verify safe address)",async()=>{const{steps:e}=await k(3,t);expect(C(e,3).intermediateValue.step).toBe(w.VERIFY_SAFE_ADDRESS),expect(x).toHaveBeenCalledWith(expect.objectContaining({input:{contexts:[m,y]}}))}),it("should complete successfully",async()=>{const e=await A(t);expect(e).toEqual({status:u.Completed,output:void 0})})}),describe("should skip open app",()=>{beforeEach(()=>{vi.resetAllMocks(),p(),l(n.FLEX);const e=new v({input:{safeContractAddress:c,options:{chainId:i,skipOpenApp:!0},contextModule:s}});r.mockResolvedValueOnce({clearSignContexts:[m,y]}),x.mockResolvedValueOnce(E(void 0)),vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable}),it("should skip open app and build contexts directly",async()=>{const{steps:e}=await k(0,t);expect(C(e,0).intermediateValue.step).toBe(w.BUILD_CONTEXTS)})}),describe("should work with different device models",()=>{it.each([[n.NANO_S,"Nano S"],[n.NANO_SP,"Nano S Plus"],[n.NANO_X,"Nano X"],[n.FLEX,"Flex"],[n.STAX,"Stax"]])("should verify safe address on %s device",async(e,o)=>{vi.resetAllMocks(),p(),l(e),r.mockResolvedValueOnce({clearSignContexts:[m,y]}),x.mockResolvedValueOnce(E(void 0));const f=new v({input:{safeContractAddress:c,options:{chainId:i,skipOpenApp:!0},contextModule:s}});vi.spyOn(f,"extractDependencies").mockReturnValue(d()),t=f._execute(a).observable;const V=await A(t);expect(V).toEqual({status:u.Completed,output:void 0}),expect(r).toHaveBeenCalledWith(expect.objectContaining({input:expect.objectContaining({deviceModelId:e})}))})}),describe("should work with contexts with certificates",()=>{beforeEach(()=>{vi.resetAllMocks(),p(),l(n.FLEX);const e={type:S.SAFE,payload:"safe_payload",certificate:{keyUsageNumber:1,payload:new Uint8Array([1,2,3])}},o={type:S.SIGNER,payload:"signer_payload",certificate:{keyUsageNumber:2,payload:new Uint8Array([4,5,6])}};r.mockResolvedValueOnce({clearSignContexts:[e,o]}),x.mockResolvedValueOnce(E(void 0));const f=new v({input:{safeContractAddress:c,options:{chainId:i,skipOpenApp:!0},contextModule:s}});vi.spyOn(f,"extractDependencies").mockReturnValue(d()),t=f._execute(a).observable}),it("should handle contexts with certificates",async()=>{const e=await A(t);expect(e).toEqual({status:u.Completed,output:void 0})})})}),describe("Error cases",()=>{beforeEach(()=>{vi.resetAllMocks()}),it("should return an error if the open app throws an error",async()=>{p(new Error("Open app failed")),l(n.FLEX);const e=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable;const o=await A(t);expect(o).toEqual({status:u.Error,error:new Error("Open app failed")})}),it("should return an error if buildSafeAddressContexts throws an error",async()=>{p(),l(n.FLEX),r.mockRejectedValueOnce(new Error("Failed to build contexts"));const e=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable;const o=await A(t);expect(o).toEqual({status:u.Error,error:new Error("Failed to build contexts")})}),it("should return an error if provideContexts returns Left (error)",async()=>{p(),l(n.FLEX),r.mockResolvedValueOnce({clearSignContexts:[m,y]});const e=new h("Failed to provide context");x.mockResolvedValueOnce(b(e));const o=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(o,"extractDependencies").mockReturnValue(d()),t=o._execute(a).observable;const f=await A(t);expect(f).toEqual({status:u.Error,error:e})}),it("should return an error if provideContexts throws an error",async()=>{p(),l(n.FLEX),r.mockResolvedValueOnce({clearSignContexts:[m,y]}),x.mockRejectedValueOnce(new Error("Provide contexts failed"));const e=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable;const o=await A(t);expect(o).toEqual({status:u.Error,error:new Error("Provide contexts failed")})}),it("should return an error when buildSafeAddressContexts returns invalid data",async()=>{p(),l(n.FLEX),r.mockRejectedValueOnce(new Error("Invalid safe address contexts"));const e=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(e,"extractDependencies").mockReturnValue(d()),t=e._execute(a).observable;const o=await A(t);expect(o).toEqual({status:u.Error,error:new Error("Invalid safe address contexts")})}),it("should handle user rejection during provide contexts",async()=>{p(),l(n.FLEX),r.mockResolvedValueOnce({clearSignContexts:[m,y]});const e=new h("User rejected");e.errorCode="6985",x.mockResolvedValueOnce(b(e));const o=new v({input:{safeContractAddress:c,options:{chainId:i},contextModule:s}});vi.spyOn(o,"extractDependencies").mockReturnValue(d()),t=o._execute(a).observable;const f=await A(t);expect(f).toEqual({status:u.Error,error:e})})})});
2
+ //# sourceMappingURL=VerifySafeAddress.test.js.map