@ledgerhq/device-signer-kit-ethereum 0.0.0-signer-eth-plugin-fix-20250331141239 → 0.0.0-solana-signer-20251204160729

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 (839) hide show
  1. package/README.md +112 -1
  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/SignDelegationAuthorizationTypes.js +2 -0
  9. package/lib/cjs/api/app-binder/SignDelegationAuthorizationTypes.js.map +7 -0
  10. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  11. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
  12. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
  13. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
  14. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  15. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  16. package/lib/cjs/api/index.js +1 -1
  17. package/lib/cjs/api/index.js.map +3 -3
  18. package/lib/cjs/api/model/AddressOptions.js +1 -1
  19. package/lib/cjs/api/model/AddressOptions.js.map +1 -1
  20. package/lib/cjs/api/model/ClearSigningType.js +2 -0
  21. package/lib/cjs/api/model/ClearSigningType.js.map +7 -0
  22. package/lib/cjs/api/model/MessageOptions.js +2 -0
  23. package/lib/cjs/api/model/MessageOptions.js.map +7 -0
  24. package/lib/cjs/api/model/SafeAddressOptions.js +2 -0
  25. package/lib/cjs/api/model/SafeAddressOptions.js.map +7 -0
  26. package/lib/cjs/api/model/TransactionOptions.js +1 -1
  27. package/lib/cjs/api/model/TransactionOptions.js.map +1 -1
  28. package/lib/cjs/api/model/TypedDataOptions.js +2 -0
  29. package/lib/cjs/api/model/TypedDataOptions.js.map +7 -0
  30. package/lib/cjs/internal/DefaultSignerEth.js +1 -1
  31. package/lib/cjs/internal/DefaultSignerEth.js.map +3 -3
  32. package/lib/cjs/internal/DefaultSignerEth.test.js +1 -1
  33. package/lib/cjs/internal/DefaultSignerEth.test.js.map +3 -3
  34. package/lib/cjs/internal/address/di/addressModule.js +1 -1
  35. package/lib/cjs/internal/address/di/addressModule.js.map +3 -3
  36. package/lib/cjs/internal/address/di/addressModule.test.js +1 -1
  37. package/lib/cjs/internal/address/di/addressModule.test.js.map +2 -2
  38. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js +1 -1
  39. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js.map +2 -2
  40. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js +1 -1
  41. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
  42. package/lib/cjs/internal/app-binder/EthAppBinder.js +1 -1
  43. package/lib/cjs/internal/app-binder/EthAppBinder.js.map +3 -3
  44. package/lib/cjs/internal/app-binder/EthAppBinder.test.js +1 -1
  45. package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +3 -3
  46. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js +1 -1
  47. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js.map +2 -2
  48. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js +1 -1
  49. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
  50. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
  51. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
  52. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
  53. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
  54. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +1 -1
  55. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  56. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  57. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  58. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js +1 -1
  59. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
  60. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
  61. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
  62. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
  63. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
  64. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
  65. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
  66. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  67. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  68. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  69. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  70. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
  71. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
  72. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
  73. package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
  74. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  75. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  76. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  77. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  78. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
  79. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
  80. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
  81. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
  82. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
  83. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
  84. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
  85. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
  86. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
  87. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
  88. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
  89. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
  90. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
  91. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
  92. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
  93. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
  94. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js +1 -1
  95. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +2 -2
  96. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +1 -1
  97. package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +3 -3
  98. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  99. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  100. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  101. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  102. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
  103. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
  104. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
  105. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
  106. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
  107. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
  108. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
  109. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
  110. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
  111. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
  112. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
  113. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
  114. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js +1 -1
  115. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js.map +2 -2
  116. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js +2 -2
  117. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
  118. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
  119. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
  120. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
  121. package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
  122. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js +1 -1
  123. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js.map +3 -3
  124. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js +1 -1
  125. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
  126. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
  127. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
  128. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
  129. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
  130. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +1 -1
  131. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
  132. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  133. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  134. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js +1 -1
  135. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
  136. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
  137. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
  138. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js +1 -1
  139. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
  140. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
  141. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
  142. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js +1 -1
  143. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js.map +2 -2
  144. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js +1 -1
  145. package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +3 -3
  146. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  147. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  148. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  149. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  150. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  151. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
  152. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  153. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  154. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  155. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  156. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  157. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  158. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
  159. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
  160. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  161. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  162. package/lib/cjs/internal/app-binder/di/appBinderModule.js +1 -1
  163. package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +3 -3
  164. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js +2 -0
  165. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  166. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  167. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  168. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  169. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  170. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  171. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  172. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  173. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  174. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  175. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  176. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  177. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  178. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  179. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  180. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  181. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  182. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  183. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  184. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  185. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  186. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  187. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  188. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js +2 -0
  189. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  190. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  191. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  192. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js +2 -0
  193. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  194. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  195. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  196. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  197. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  198. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  199. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  200. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  201. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  202. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  203. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  204. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  205. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  206. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  207. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  208. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
  209. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
  210. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
  211. package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
  212. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +1 -1
  213. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
  214. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
  215. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
  216. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
  217. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
  218. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
  219. package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
  220. package/lib/cjs/internal/di.js +1 -1
  221. package/lib/cjs/internal/di.js.map +3 -3
  222. package/lib/cjs/internal/eip7702/di/eip7702Module.js +2 -0
  223. package/lib/cjs/internal/eip7702/di/eip7702Module.js.map +7 -0
  224. package/lib/cjs/internal/eip7702/di/eip7702Module.test.js +2 -0
  225. package/lib/cjs/internal/eip7702/di/eip7702Module.test.js.map +7 -0
  226. package/lib/cjs/internal/eip7702/di/eip7702Types.js +2 -0
  227. package/lib/cjs/internal/eip7702/di/eip7702Types.js.map +7 -0
  228. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
  229. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
  230. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
  231. package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
  232. package/lib/cjs/internal/message/di/messageModule.js +1 -1
  233. package/lib/cjs/internal/message/di/messageModule.js.map +3 -3
  234. package/lib/cjs/internal/message/di/messageModule.test.js +1 -1
  235. package/lib/cjs/internal/message/di/messageModule.test.js.map +2 -2
  236. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +1 -1
  237. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +3 -3
  238. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +1 -1
  239. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
  240. package/lib/cjs/internal/safe/di/safeModule.js +2 -0
  241. package/lib/cjs/internal/safe/di/safeModule.js.map +7 -0
  242. package/lib/cjs/internal/safe/di/safeModule.test.js +2 -0
  243. package/lib/cjs/internal/safe/di/safeModule.test.js.map +7 -0
  244. package/lib/cjs/internal/safe/di/safeTypes.js +2 -0
  245. package/lib/cjs/internal/safe/di/safeTypes.js.map +7 -0
  246. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  247. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  248. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  249. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  250. package/lib/cjs/internal/shared/utils/ApplicationChecker.js +1 -1
  251. package/lib/cjs/internal/shared/utils/ApplicationChecker.js.map +3 -3
  252. package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js +1 -1
  253. package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js.map +2 -2
  254. package/lib/cjs/internal/transaction/di/transactionModule.js +1 -1
  255. package/lib/cjs/internal/transaction/di/transactionModule.js.map +3 -3
  256. package/lib/cjs/internal/transaction/di/transactionModule.test.js +1 -1
  257. package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +2 -2
  258. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
  259. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
  260. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
  261. package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
  262. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +1 -1
  263. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +3 -3
  264. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +1 -1
  265. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
  266. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  267. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
  268. package/lib/cjs/internal/typed-data/di/typedDataModule.js +1 -1
  269. package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +3 -3
  270. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +1 -1
  271. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +2 -2
  272. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
  273. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
  274. package/lib/cjs/internal/typed-data/service/TypedDataParser.js +1 -1
  275. package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +3 -3
  276. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +1 -1
  277. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
  278. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
  279. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
  280. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
  281. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
  282. package/lib/cjs/package.json +43 -40
  283. package/lib/esm/api/SignerEthBuilder.js +1 -1
  284. package/lib/esm/api/SignerEthBuilder.js.map +3 -3
  285. package/lib/esm/api/SignerEthBuilder.test.js +1 -1
  286. package/lib/esm/api/SignerEthBuilder.test.js.map +3 -3
  287. package/lib/esm/api/app-binder/SignDelegationAuthorizationTypes.js +1 -0
  288. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  289. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
  290. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
  291. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
  292. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  293. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  294. package/lib/esm/api/index.js +1 -1
  295. package/lib/esm/api/index.js.map +2 -2
  296. package/lib/esm/api/model/ClearSigningType.js +2 -0
  297. package/lib/esm/api/model/ClearSigningType.js.map +7 -0
  298. package/lib/esm/api/model/MessageOptions.js +1 -0
  299. package/lib/esm/api/model/MessageOptions.js.map +7 -0
  300. package/lib/esm/api/model/SafeAddressOptions.js +1 -0
  301. package/lib/esm/api/model/SafeAddressOptions.js.map +7 -0
  302. package/lib/esm/api/model/TypedDataOptions.js +1 -0
  303. package/lib/esm/api/model/TypedDataOptions.js.map +7 -0
  304. package/lib/esm/internal/DefaultSignerEth.js +1 -1
  305. package/lib/esm/internal/DefaultSignerEth.js.map +3 -3
  306. package/lib/esm/internal/DefaultSignerEth.test.js +1 -1
  307. package/lib/esm/internal/DefaultSignerEth.test.js.map +3 -3
  308. package/lib/esm/internal/address/di/addressModule.js +1 -1
  309. package/lib/esm/internal/address/di/addressModule.js.map +3 -3
  310. package/lib/esm/internal/address/di/addressModule.test.js +1 -1
  311. package/lib/esm/internal/address/di/addressModule.test.js.map +2 -2
  312. package/lib/esm/internal/address/use-case/GetAddressUseCase.js +1 -1
  313. package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +2 -2
  314. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +1 -1
  315. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
  316. package/lib/esm/internal/app-binder/EthAppBinder.js +1 -1
  317. package/lib/esm/internal/app-binder/EthAppBinder.js.map +3 -3
  318. package/lib/esm/internal/app-binder/EthAppBinder.test.js +1 -1
  319. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +3 -3
  320. package/lib/esm/internal/app-binder/command/GetAddressCommand.js +1 -1
  321. package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +2 -2
  322. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +1 -1
  323. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
  324. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
  325. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
  326. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
  327. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
  328. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +1 -1
  329. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  330. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  331. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  332. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +1 -1
  333. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
  334. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
  335. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
  336. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
  337. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
  338. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
  339. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
  340. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  341. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  342. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  343. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  344. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
  345. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
  346. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
  347. package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
  348. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  349. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  350. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  351. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  352. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
  353. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
  354. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
  355. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
  356. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
  357. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
  358. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
  359. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
  360. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
  361. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
  362. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
  363. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
  364. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
  365. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
  366. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
  367. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
  368. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js +1 -1
  369. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +2 -2
  370. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +1 -1
  371. package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +3 -3
  372. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  373. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  374. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  375. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  376. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
  377. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
  378. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
  379. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
  380. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
  381. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
  382. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
  383. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
  384. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
  385. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
  386. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
  387. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
  388. package/lib/esm/internal/app-binder/command/SetPluginCommand.js +1 -1
  389. package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +2 -2
  390. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +2 -2
  391. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
  392. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
  393. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
  394. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
  395. package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
  396. package/lib/esm/internal/app-binder/command/SignEIP712Command.js +1 -1
  397. package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +2 -2
  398. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +1 -1
  399. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
  400. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
  401. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
  402. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
  403. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
  404. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +1 -1
  405. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
  406. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  407. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  408. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +1 -1
  409. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
  410. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
  411. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
  412. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +1 -1
  413. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
  414. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
  415. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
  416. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js +1 -1
  417. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js.map +2 -2
  418. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js +1 -1
  419. package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +3 -3
  420. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  421. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  422. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  423. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  424. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  425. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
  426. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  427. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  428. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  429. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  430. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  431. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  432. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
  433. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
  434. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  435. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  436. package/lib/esm/internal/app-binder/di/appBinderModule.js +1 -1
  437. package/lib/esm/internal/app-binder/di/appBinderModule.js.map +3 -3
  438. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js +2 -0
  439. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  440. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  441. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  442. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  443. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  444. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  445. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  446. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  447. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  448. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  449. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  450. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  451. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  452. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  453. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  454. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  455. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  456. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  457. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  458. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  459. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  460. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  461. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  462. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js +2 -0
  463. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  464. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  465. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  466. package/lib/esm/internal/app-binder/task/ProvideContextTask.js +2 -0
  467. package/lib/esm/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  468. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  469. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  470. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  471. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  472. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  473. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  474. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  475. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  476. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  477. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  478. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  479. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  480. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  481. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  482. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
  483. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
  484. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
  485. package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
  486. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js +1 -1
  487. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
  488. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
  489. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
  490. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
  491. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
  492. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
  493. package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
  494. package/lib/esm/internal/di.js +1 -1
  495. package/lib/esm/internal/di.js.map +3 -3
  496. package/lib/esm/internal/eip7702/di/eip7702Module.js +2 -0
  497. package/lib/esm/internal/eip7702/di/eip7702Module.js.map +7 -0
  498. package/lib/esm/internal/eip7702/di/eip7702Module.test.js +2 -0
  499. package/lib/esm/internal/eip7702/di/eip7702Module.test.js.map +7 -0
  500. package/lib/esm/internal/eip7702/di/eip7702Types.js +2 -0
  501. package/lib/esm/internal/eip7702/di/eip7702Types.js.map +7 -0
  502. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
  503. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
  504. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
  505. package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
  506. package/lib/esm/internal/message/di/messageModule.js +1 -1
  507. package/lib/esm/internal/message/di/messageModule.js.map +3 -3
  508. package/lib/esm/internal/message/di/messageModule.test.js +1 -1
  509. package/lib/esm/internal/message/di/messageModule.test.js.map +2 -2
  510. package/lib/esm/internal/message/use-case/SignMessageUseCase.js +1 -1
  511. package/lib/esm/internal/message/use-case/SignMessageUseCase.js.map +3 -3
  512. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js +1 -1
  513. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
  514. package/lib/esm/internal/safe/di/safeModule.js +2 -0
  515. package/lib/esm/internal/safe/di/safeModule.js.map +7 -0
  516. package/lib/esm/internal/safe/di/safeModule.test.js +2 -0
  517. package/lib/esm/internal/safe/di/safeModule.test.js.map +7 -0
  518. package/lib/esm/internal/safe/di/safeTypes.js +2 -0
  519. package/lib/esm/internal/safe/di/safeTypes.js.map +7 -0
  520. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  521. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  522. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  523. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  524. package/lib/esm/internal/shared/utils/ApplicationChecker.js +1 -1
  525. package/lib/esm/internal/shared/utils/ApplicationChecker.js.map +3 -3
  526. package/lib/esm/internal/shared/utils/ApplicationChecker.test.js +1 -1
  527. package/lib/esm/internal/shared/utils/ApplicationChecker.test.js.map +2 -2
  528. package/lib/esm/internal/transaction/di/transactionModule.js +1 -1
  529. package/lib/esm/internal/transaction/di/transactionModule.js.map +3 -3
  530. package/lib/esm/internal/transaction/di/transactionModule.test.js +1 -1
  531. package/lib/esm/internal/transaction/di/transactionModule.test.js.map +2 -2
  532. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
  533. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
  534. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
  535. package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
  536. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +0 -1
  537. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +4 -4
  538. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +1 -1
  539. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
  540. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  541. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
  542. package/lib/esm/internal/typed-data/di/typedDataModule.js +1 -1
  543. package/lib/esm/internal/typed-data/di/typedDataModule.js.map +3 -3
  544. package/lib/esm/internal/typed-data/di/typedDataModule.test.js +1 -1
  545. package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +2 -2
  546. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
  547. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
  548. package/lib/esm/internal/typed-data/service/TypedDataParser.js +1 -1
  549. package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +3 -3
  550. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +1 -1
  551. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
  552. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
  553. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
  554. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
  555. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
  556. package/lib/esm/package.json +43 -40
  557. package/lib/types/api/SignerEth.d.ts +11 -4
  558. package/lib/types/api/SignerEth.d.ts.map +1 -1
  559. package/lib/types/api/SignerEthBuilder.d.ts +4 -2
  560. package/lib/types/api/SignerEthBuilder.d.ts.map +1 -1
  561. package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts +19 -0
  562. package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts.map +1 -0
  563. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +18 -12
  564. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
  565. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +13 -1
  566. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -1
  567. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts +30 -0
  568. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts.map +1 -0
  569. package/lib/types/api/index.d.ts +5 -4
  570. package/lib/types/api/index.d.ts.map +1 -1
  571. package/lib/types/api/model/AddressOptions.d.ts +1 -0
  572. package/lib/types/api/model/AddressOptions.d.ts.map +1 -1
  573. package/lib/types/api/model/ClearSigningType.d.ts +5 -0
  574. package/lib/types/api/model/ClearSigningType.d.ts.map +1 -0
  575. package/lib/types/api/model/MessageOptions.d.ts +4 -0
  576. package/lib/types/api/model/MessageOptions.d.ts.map +1 -0
  577. package/lib/types/api/model/SafeAddressOptions.d.ts +5 -0
  578. package/lib/types/api/model/SafeAddressOptions.d.ts.map +1 -0
  579. package/lib/types/api/model/TransactionOptions.d.ts +1 -0
  580. package/lib/types/api/model/TransactionOptions.d.ts.map +1 -1
  581. package/lib/types/api/model/TypedDataOptions.d.ts +4 -0
  582. package/lib/types/api/model/TypedDataOptions.d.ts.map +1 -0
  583. package/lib/types/internal/DefaultSignerEth.d.ts +10 -3
  584. package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -1
  585. package/lib/types/internal/address/di/addressModule.d.ts.map +1 -1
  586. package/lib/types/internal/address/use-case/GetAddressUseCase.d.ts.map +1 -1
  587. package/lib/types/internal/app-binder/EthAppBinder.d.ts +19 -3
  588. package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -1
  589. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts +1 -0
  590. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -1
  591. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts +1 -0
  592. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts.map +1 -1
  593. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts +1 -0
  594. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -1
  595. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +1 -0
  596. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -1
  597. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +1 -0
  598. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -1
  599. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts +29 -0
  600. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts.map +1 -0
  601. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts +2 -0
  602. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts.map +1 -0
  603. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts +21 -0
  604. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts.map +1 -0
  605. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts +2 -0
  606. package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts.map +1 -0
  607. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts +35 -0
  608. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts.map +1 -0
  609. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts +2 -0
  610. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts.map +1 -0
  611. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +1 -0
  612. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -1
  613. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +1 -0
  614. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -1
  615. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +1 -0
  616. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -1
  617. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +1 -0
  618. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -1
  619. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts +1 -0
  620. package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts.map +1 -1
  621. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +30 -1
  622. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -1
  623. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +1 -0
  624. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -1
  625. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +1 -0
  626. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -1
  627. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts +1 -0
  628. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -1
  629. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts +1 -0
  630. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -1
  631. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts +30 -0
  632. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts.map +1 -0
  633. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts +2 -0
  634. package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts.map +1 -0
  635. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts +1 -0
  636. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -1
  637. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts +1 -0
  638. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -1
  639. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts +1 -0
  640. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -1
  641. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +1 -0
  642. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -1
  643. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +1 -0
  644. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -1
  645. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts +1 -0
  646. package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts.map +1 -1
  647. package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts.map +1 -1
  648. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +19 -36
  649. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -1
  650. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +10 -2
  651. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -1
  652. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts +20 -0
  653. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts.map +1 -0
  654. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts +2 -0
  655. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts.map +1 -0
  656. package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
  657. package/lib/types/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +1 -1
  658. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts +6 -0
  659. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts.map +1 -0
  660. package/lib/types/internal/app-binder/di/appBinderModule.d.ts.map +1 -1
  661. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts +47 -0
  662. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts.map +1 -0
  663. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts +2 -0
  664. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts.map +1 -0
  665. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts +10 -3
  666. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
  667. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts +39 -0
  668. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts.map +1 -0
  669. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts +2 -0
  670. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts.map +1 -0
  671. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts +19 -0
  672. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts.map +1 -0
  673. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts +2 -0
  674. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts.map +1 -0
  675. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts +28 -0
  676. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts.map +1 -0
  677. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts +2 -0
  678. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts.map +1 -0
  679. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts +21 -0
  680. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts.map +1 -0
  681. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts +2 -0
  682. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts.map +1 -0
  683. package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts +17 -0
  684. package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts.map +1 -0
  685. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts +2 -0
  686. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts.map +1 -0
  687. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts +22 -0
  688. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts.map +1 -0
  689. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts +2 -0
  690. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts.map +1 -0
  691. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +16 -7
  692. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -1
  693. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts +36 -0
  694. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts.map +1 -0
  695. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts +2 -0
  696. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts.map +1 -0
  697. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +2 -2
  698. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -1
  699. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts +18 -0
  700. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts.map +1 -0
  701. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts +2 -0
  702. package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts.map +1 -0
  703. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +2 -1
  704. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -1
  705. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts +12 -0
  706. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts.map +1 -0
  707. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts +2 -0
  708. package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts.map +1 -0
  709. package/lib/types/internal/di.d.ts.map +1 -1
  710. package/lib/types/internal/eip7702/di/eip7702Module.d.ts +3 -0
  711. package/lib/types/internal/eip7702/di/eip7702Module.d.ts.map +1 -0
  712. package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts +2 -0
  713. package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts.map +1 -0
  714. package/lib/types/internal/eip7702/di/eip7702Types.d.ts +4 -0
  715. package/lib/types/internal/eip7702/di/eip7702Types.d.ts.map +1 -0
  716. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts +8 -0
  717. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts.map +1 -0
  718. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts +2 -0
  719. package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts.map +1 -0
  720. package/lib/types/internal/message/di/messageModule.d.ts.map +1 -1
  721. package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts +2 -1
  722. package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
  723. package/lib/types/internal/safe/di/safeModule.d.ts +3 -0
  724. package/lib/types/internal/safe/di/safeModule.d.ts.map +1 -0
  725. package/lib/types/internal/safe/di/safeModule.test.d.ts +2 -0
  726. package/lib/types/internal/safe/di/safeModule.test.d.ts.map +1 -0
  727. package/lib/types/internal/safe/di/safeTypes.d.ts +4 -0
  728. package/lib/types/internal/safe/di/safeTypes.d.ts.map +1 -0
  729. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts +9 -0
  730. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts.map +1 -0
  731. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts +2 -0
  732. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts.map +1 -0
  733. package/lib/types/internal/shared/utils/ApplicationChecker.d.ts.map +1 -1
  734. package/lib/types/internal/transaction/di/transactionModule.d.ts.map +1 -1
  735. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts +8 -0
  736. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts.map +1 -0
  737. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts +2 -0
  738. package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts.map +1 -0
  739. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts +4 -7
  740. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +1 -1
  741. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts +2 -2
  742. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts.map +1 -1
  743. package/lib/types/internal/typed-data/di/typedDataModule.d.ts.map +1 -1
  744. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts +4 -2
  745. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -1
  746. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +2 -1
  747. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +1 -1
  748. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  749. package/package.json +41 -38
  750. package/lib/cjs/internal/app-binder/constant/plugins.js +0 -2
  751. package/lib/cjs/internal/app-binder/constant/plugins.js.map +0 -7
  752. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  753. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  754. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  755. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  756. package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.js +0 -2
  757. package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.js.map +0 -7
  758. package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.test.js +0 -2
  759. package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.test.js.map +0 -7
  760. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  761. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  762. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  763. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  764. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
  765. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
  766. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
  767. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
  768. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
  769. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
  770. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
  771. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
  772. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
  773. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
  774. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
  775. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
  776. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +0 -2
  777. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +0 -7
  778. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
  779. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
  780. package/lib/esm/internal/app-binder/constant/plugins.js +0 -2
  781. package/lib/esm/internal/app-binder/constant/plugins.js.map +0 -7
  782. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  783. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  784. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  785. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  786. package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.js +0 -2
  787. package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.js.map +0 -7
  788. package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.test.js +0 -2
  789. package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.test.js.map +0 -7
  790. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  791. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  792. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  793. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  794. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
  795. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
  796. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
  797. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
  798. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
  799. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
  800. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
  801. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
  802. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
  803. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
  804. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
  805. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
  806. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +0 -1
  807. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
  808. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
  809. package/lib/types/internal/app-binder/constant/plugins.d.ts +0 -2
  810. package/lib/types/internal/app-binder/constant/plugins.d.ts.map +0 -1
  811. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -32
  812. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  813. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +0 -2
  814. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +0 -1
  815. package/lib/types/internal/app-binder/task/GetWeb3CheckTask.d.ts +0 -30
  816. package/lib/types/internal/app-binder/task/GetWeb3CheckTask.d.ts.map +0 -1
  817. package/lib/types/internal/app-binder/task/GetWeb3CheckTask.test.d.ts +0 -2
  818. package/lib/types/internal/app-binder/task/GetWeb3CheckTask.test.d.ts.map +0 -1
  819. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -38
  820. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  821. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +0 -2
  822. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +0 -1
  823. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +0 -80
  824. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +0 -1
  825. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +0 -2
  826. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +0 -1
  827. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +0 -28
  828. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +0 -1
  829. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +0 -2
  830. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +0 -1
  831. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts +0 -7
  832. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts.map +0 -1
  833. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts +0 -2
  834. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts.map +0 -1
  835. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -6
  836. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  837. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts +0 -2
  838. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts.map +0 -1
  839. /package/lib/esm/{internal/transaction/service/mapper/TransactionMapper.js.map → api/app-binder/SignDelegationAuthorizationTypes.js.map} +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideContextTask.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n LoadCertificateCommand,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { ProvideEnumCommand } from \"@internal/app-binder/command/ProvideEnumCommand\";\nimport {\n NetworkConfigurationType,\n ProvideNetworkConfigurationCommand,\n} from \"@internal/app-binder/command/ProvideNetworkConfigurationCommand\";\nimport { ProvideNFTInformationCommand } from \"@internal/app-binder/command/ProvideNFTInformationCommand\";\nimport { ProvideProxyInfoCommand } from \"@internal/app-binder/command/ProvideProxyInfoCommand\";\nimport {\n ProvideSafeAccountCommand,\n ProvideSafeAccountCommandType,\n} from \"@internal/app-binder/command/ProvideSafeAccountCommand\";\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTransactionFieldDescriptionCommand } from \"@internal/app-binder/command/ProvideTransactionFieldDescriptionCommand\";\nimport { ProvideTransactionInformationCommand } from \"@internal/app-binder/command/ProvideTransactionInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport { ProvideWeb3CheckCommand } from \"@internal/app-binder/command/ProvideWeb3CheckCommand\";\nimport { SetExternalPluginCommand } from \"@internal/app-binder/command/SetExternalPluginCommand\";\nimport { SetPluginCommand } from \"@internal/app-binder/command/SetPluginCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\n\nimport {\n SendPayloadInChunksTask,\n type SendPayloadInChunksTaskArgs,\n} from \"./SendPayloadInChunksTask\";\n\nexport type ProvideContextTaskArgs = {\n /**\n * The clear sign context to provide.\n */\n context: ClearSignContextSuccess;\n};\n\nexport type ProvideContextTaskResult = CommandResult<unknown, EthErrorCodes>;\n\n/**\n * This task is responsible for providing a single context to the device.\n */\nexport class ProvideContextTask {\n constructor(\n private _api: InternalApi,\n private _args: ProvideContextTaskArgs,\n private _sendPayloadInChunksTaskFactory = (\n api: InternalApi,\n args: SendPayloadInChunksTaskArgs<unknown>,\n ) => new SendPayloadInChunksTask(api, args),\n ) {}\n\n async run(): Promise<ProvideContextTaskResult> {\n const { type, payload, certificate } = this._args.context;\n\n // if a certificate is provided, we load it before sending the command\n if (certificate) {\n await this._api.sendCommand(\n new LoadCertificateCommand({\n keyUsage: certificate.keyUsageNumber,\n certificate: certificate.payload,\n }),\n );\n }\n\n switch (type) {\n case ClearSignContextType.PLUGIN: {\n return await this._api.sendCommand(new SetPluginCommand({ payload }));\n }\n case ClearSignContextType.EXTERNAL_PLUGIN: {\n return await this._api.sendCommand(\n new SetExternalPluginCommand({ payload }),\n );\n }\n case ClearSignContextType.NFT: {\n return await this._api.sendCommand(\n new ProvideNFTInformationCommand({ payload }),\n );\n }\n case ClearSignContextType.TOKEN: {\n return await this._api.sendCommand(\n new ProvideTokenInformationCommand({ payload }),\n );\n }\n case ClearSignContextType.TRANSACTION_INFO: {\n const transactionInfoResult =\n await this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideTransactionInformationCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n\n return transactionInfoResult;\n }\n case ClearSignContextType.TRUSTED_NAME: {\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideTrustedNameCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n }\n case ClearSignContextType.ENUM:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideEnumCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n case ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideTransactionFieldDescriptionCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n case ClearSignContextType.TRANSACTION_CHECK:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideWeb3CheckCommand({\n payload: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n case ClearSignContextType.PROXY_INFO:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideProxyInfoCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n case ClearSignContextType.DYNAMIC_NETWORK:\n // Dynamic network configuration uses the existing ProvideNetworkConfiguration command\n // but is provided as part of the context flow\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideNetworkConfigurationCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n configurationType: NetworkConfigurationType.CONFIGURATION,\n }),\n }).run();\n case ClearSignContextType.DYNAMIC_NETWORK_ICON: {\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideNetworkConfigurationCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n configurationType: NetworkConfigurationType.ICON,\n }),\n withPayloadLength: false,\n }).run();\n }\n case ClearSignContextType.SAFE:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideSafeAccountCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n type: ProvideSafeAccountCommandType.SAFE_DESCRIPTOR,\n }),\n }).run();\n case ClearSignContextType.SIGNER:\n return this._sendPayloadInChunksTaskFactory(this._api, {\n payload,\n commandFactory: (args) =>\n new ProvideSafeAccountCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n type: ProvideSafeAccountCommandType.SIGNER_DESCRIPTOR,\n }),\n }).run();\n default: {\n const uncoveredType: never = type;\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n `The context type [${uncoveredType}] is not covered`,\n ),\n });\n }\n }\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["ProvideContextTask_exports", "__export", "ProvideContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_ProvideEnumCommand", "import_ProvideNetworkConfigurationCommand", "import_ProvideNFTInformationCommand", "import_ProvideProxyInfoCommand", "import_ProvideSafeAccountCommand", "import_ProvideTokenInformationCommand", "import_ProvideTransactionFieldDescriptionCommand", "import_ProvideTransactionInformationCommand", "import_ProvideTrustedNameCommand", "import_ProvideWeb3CheckCommand", "import_SetExternalPluginCommand", "import_SetPluginCommand", "import_SendPayloadInChunksTask", "_api", "_args", "_sendPayloadInChunksTaskFactory", "api", "args", "type", "payload", "certificate", "uncoveredType"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var a=require("@ledgerhq/context-module"),m=require("@ledgerhq/device-management-kit"),h=require("../../app-binder/command/ProvideEnumCommand"),y=require("../../app-binder/command/ProvideNetworkConfigurationCommand"),f=require("../../app-binder/command/ProvideNFTInformationCommand"),v=require("../../app-binder/command/ProvideProxyInfoCommand"),u=require("../../app-binder/command/ProvideSafeAccountCommand"),x=require("../../app-binder/command/ProvideTokenInformationCommand"),g=require("../../app-binder/command/ProvideTransactionFieldDescriptionCommand"),T=require("../../app-binder/command/ProvideTransactionInformationCommand"),w=require("../../app-binder/command/ProvideTrustedNameCommand"),A=require("../../app-binder/command/ProvideWeb3CheckCommand"),I=require("../../app-binder/command/SetExternalPluginCommand"),E=require("../../app-binder/command/SetPluginCommand"),P=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),d=require("./ProvideContextTask"),N=require("./SendPayloadInChunksTask");describe("ProvideContextTask",()=>{const e=(0,P.makeDeviceActionInternalApiMock)(),n=(0,m.CommandResultFactory)({data:void 0}),k=(0,m.CommandResultFactory)({data:void 0,error:{}});beforeEach(()=>{vi.resetAllMocks()}),describe("run",()=>{const r=vi.fn(),s=vi.fn();beforeEach(()=>{vi.clearAllMocks(),s.mockImplementation((t,c)=>({run:()=>r(t,c)}))}),describe("contexts with sendCommand",()=>{it.each([[a.ClearSignContextType.PLUGIN,E.SetPluginCommand],[a.ClearSignContextType.EXTERNAL_PLUGIN,I.SetExternalPluginCommand],[a.ClearSignContextType.NFT,f.ProvideNFTInformationCommand],[a.ClearSignContextType.TOKEN,x.ProvideTokenInformationCommand]])("should provide context by calling sendCommand for a %s context",async(t,c)=>{const o={context:{type:t,payload:"payload"}};e.sendCommand.mockResolvedValue(n);const i=await new d.ProvideContextTask(e,o,s).run();expect(i).toEqual(n),expect(e.sendCommand).toHaveBeenCalledTimes(1),expect(e.sendCommand).toHaveBeenCalledWith(expect.any(c))})}),describe("contexts with sendPayloadInChunksTask",()=>{it.each([[a.ClearSignContextType.TRANSACTION_INFO,T.ProvideTransactionInformationCommand],[a.ClearSignContextType.TRUSTED_NAME,w.ProvideTrustedNameCommand],[a.ClearSignContextType.ENUM,h.ProvideEnumCommand],[a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,g.ProvideTransactionFieldDescriptionCommand],[a.ClearSignContextType.TRANSACTION_CHECK,A.ProvideWeb3CheckCommand],[a.ClearSignContextType.PROXY_INFO,v.ProvideProxyInfoCommand]])("should provide context by calling sendPayloadInChunksTask for a %s context",async(t,c)=>{const o={context:{type:t,payload:"payload"}};r.mockResolvedValue(n);const i=await new d.ProvideContextTask(e,o,s).run();expect(i).toEqual(n),expect(r).toHaveBeenCalledTimes(1),expect(r).toHaveBeenCalledWith(e,{payload:"payload",commandFactory:expect.any(Function)});const l=s.mock.calls[0][1].commandFactory,F={chunkedData:new Uint8Array([1,2,3]),isFirstChunk:!0},R=l(F);expect(R).toBeInstanceOf(c)}),it("should provide context for DYNAMIC_NETWORK with correct configuration type",async()=>{const t={context:{type:a.ClearSignContextType.DYNAMIC_NETWORK,payload:"payload"}};r.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(r).toHaveBeenCalledTimes(1);const i=s.mock.calls[0][1].commandFactory,p={chunkedData:new Uint8Array([1,2,3]),isFirstChunk:!0},l=i(p);expect(l).toBeInstanceOf(y.ProvideNetworkConfigurationCommand),expect(l.args.configurationType).toBe(y.NetworkConfigurationType.CONFIGURATION)}),it("should provide context for DYNAMIC_NETWORK_ICON with correct configuration type and withPayloadLength",async()=>{const t={context:{type:a.ClearSignContextType.DYNAMIC_NETWORK_ICON,payload:"payload"}};r.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(r).toHaveBeenCalledTimes(1),expect(r).toHaveBeenCalledWith(e,{payload:"payload",commandFactory:expect.any(Function),withPayloadLength:!1});const i=s.mock.calls[0][1].commandFactory,p={chunkedData:new Uint8Array([1,2,3]),isFirstChunk:!0},l=i(p);expect(l).toBeInstanceOf(y.ProvideNetworkConfigurationCommand),expect(l.args.configurationType).toBe(y.NetworkConfigurationType.ICON)}),it("should provide context for SAFE with correct type",async()=>{const t={context:{type:a.ClearSignContextType.SAFE,payload:"payload"}};r.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(r).toHaveBeenCalledTimes(1);const i=s.mock.calls[0][1].commandFactory,p={chunkedData:new Uint8Array([1,2,3]),isFirstChunk:!0},l=i(p);expect(l).toBeInstanceOf(u.ProvideSafeAccountCommand),expect(l.args.type).toBe(u.ProvideSafeAccountCommandType.SAFE_DESCRIPTOR)}),it("should provide context for SIGNER with correct type",async()=>{const t={context:{type:a.ClearSignContextType.SIGNER,payload:"payload"}};r.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(r).toHaveBeenCalledTimes(1);const i=s.mock.calls[0][1].commandFactory,p={chunkedData:new Uint8Array([1,2,3]),isFirstChunk:!0},l=i(p);expect(l).toBeInstanceOf(u.ProvideSafeAccountCommand),expect(l.args.type).toBe(u.ProvideSafeAccountCommandType.SIGNER_DESCRIPTOR)})}),describe("with certificate",()=>{it("should load certificate before providing context when certificate is present",async()=>{const t={context:{type:a.ClearSignContextType.TOKEN,payload:"payload",certificate:{keyUsageNumber:1,payload:new Uint8Array([1,2,3])}}};e.sendCommand.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(e.sendCommand).toHaveBeenCalledTimes(2),expect(e.sendCommand).toHaveBeenNthCalledWith(1,expect.any(m.LoadCertificateCommand)),expect(e.sendCommand).toHaveBeenNthCalledWith(2,expect.any(x.ProvideTokenInformationCommand))}),it("should load certificate with sendPayloadInChunksTask context",async()=>{const t={context:{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload",certificate:{keyUsageNumber:2,payload:new Uint8Array([4,5,6])}}};e.sendCommand.mockResolvedValue(n),r.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(e.sendCommand).toHaveBeenCalledTimes(1),expect(e.sendCommand).toHaveBeenCalledWith(expect.any(m.LoadCertificateCommand)),expect(r).toHaveBeenCalledTimes(1)}),it("should not load certificate when not present",async()=>{const t={context:{type:a.ClearSignContextType.TOKEN,payload:"payload"}};e.sendCommand.mockResolvedValue(n);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(n),expect(e.sendCommand).toHaveBeenCalledTimes(1),expect(e.sendCommand).toHaveBeenCalledWith(expect.any(x.ProvideTokenInformationCommand))})}),describe("error handling",()=>{it("should return error when sendCommand fails",async()=>{const t={context:{type:a.ClearSignContextType.NFT,payload:"payload"}};e.sendCommand.mockResolvedValue(k);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(k)}),it("should return error when sendPayloadInChunksTask fails",async()=>{const t={context:{type:a.ClearSignContextType.TRUSTED_NAME,payload:"payload"}};r.mockResolvedValue(k);const o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual(k)}),it("should return error for unsupported context type",async()=>{const t={context:{type:"unsupported",payload:"payload"}},o=await new d.ProvideContextTask(e,t,s).run();expect(o).toEqual((0,m.CommandResultFactory)({error:new m.InvalidStatusWordError("The context type [unsupported] is not covered")}))})}),describe("factory",()=>{it("should have a default sendPayloadInChunksTaskFactory",()=>{const t={context:{type:a.ClearSignContextType.TOKEN,payload:"payload"}},c=new d.ProvideContextTask(e,t);expect(c._sendPayloadInChunksTaskFactory).toBeDefined();const o=c._sendPayloadInChunksTaskFactory(e,{payload:"payload",commandFactory:()=>new T.ProvideTransactionInformationCommand({data:new Uint8Array,isFirstChunk:!0})});expect(o).toBeInstanceOf(N.SendPayloadInChunksTask)})})})});
2
+ //# sourceMappingURL=ProvideContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideContextTask.test.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n LoadCertificateCommand,\n type UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { ProvideEnumCommand } from \"@internal/app-binder/command/ProvideEnumCommand\";\nimport {\n NetworkConfigurationType,\n ProvideNetworkConfigurationCommand,\n} from \"@internal/app-binder/command/ProvideNetworkConfigurationCommand\";\nimport { ProvideNFTInformationCommand } from \"@internal/app-binder/command/ProvideNFTInformationCommand\";\nimport { ProvideProxyInfoCommand } from \"@internal/app-binder/command/ProvideProxyInfoCommand\";\nimport {\n ProvideSafeAccountCommand,\n ProvideSafeAccountCommandType,\n} from \"@internal/app-binder/command/ProvideSafeAccountCommand\";\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTransactionFieldDescriptionCommand } from \"@internal/app-binder/command/ProvideTransactionFieldDescriptionCommand\";\nimport { ProvideTransactionInformationCommand } from \"@internal/app-binder/command/ProvideTransactionInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport { ProvideWeb3CheckCommand } from \"@internal/app-binder/command/ProvideWeb3CheckCommand\";\nimport { SetExternalPluginCommand } from \"@internal/app-binder/command/SetExternalPluginCommand\";\nimport { SetPluginCommand } from \"@internal/app-binder/command/SetPluginCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\n\nimport {\n ProvideContextTask,\n type ProvideContextTaskArgs,\n} from \"./ProvideContextTask\";\nimport {\n SendPayloadInChunksTask,\n type SendPayloadInChunksTaskArgs,\n} from \"./SendPayloadInChunksTask\";\n\ndescribe(\"ProvideContextTask\", () => {\n const api = makeDeviceActionInternalApiMock();\n const successResult = CommandResultFactory<void, EthErrorCodes>({\n data: undefined,\n });\n const errorResult = CommandResultFactory<void, EthErrorCodes>({\n data: undefined,\n error: {} as UnknownDeviceExchangeError,\n });\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"run\", () => {\n const sendPayloadInChunksRunMock = vi.fn();\n const sendPayloadInChunksTaskMockFactory = vi.fn();\n\n beforeEach(() => {\n vi.clearAllMocks();\n sendPayloadInChunksTaskMockFactory.mockImplementation(\n (a: InternalApi, args: SendPayloadInChunksTaskArgs<unknown>) =>\n ({\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n run: () => sendPayloadInChunksRunMock(a, args),\n }) as unknown as SendPayloadInChunksTask<unknown>,\n );\n });\n\n describe(\"contexts with sendCommand\", () => {\n it.each([\n [ClearSignContextType.PLUGIN, SetPluginCommand],\n [ClearSignContextType.EXTERNAL_PLUGIN, SetExternalPluginCommand],\n [ClearSignContextType.NFT, ProvideNFTInformationCommand],\n [ClearSignContextType.TOKEN, ProvideTokenInformationCommand],\n ] as const)(\n \"should provide context by calling sendCommand for a %s context\",\n async (contextType, commandClass) => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: contextType,\n payload: \"payload\",\n },\n };\n api.sendCommand.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(api.sendCommand).toHaveBeenCalledTimes(1);\n expect(api.sendCommand).toHaveBeenCalledWith(\n expect.any(commandClass),\n );\n },\n );\n });\n\n describe(\"contexts with sendPayloadInChunksTask\", () => {\n it.each([\n [\n ClearSignContextType.TRANSACTION_INFO,\n ProvideTransactionInformationCommand,\n ],\n [ClearSignContextType.TRUSTED_NAME, ProvideTrustedNameCommand],\n [ClearSignContextType.ENUM, ProvideEnumCommand],\n [\n ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n ProvideTransactionFieldDescriptionCommand,\n ],\n [ClearSignContextType.TRANSACTION_CHECK, ProvideWeb3CheckCommand],\n [ClearSignContextType.PROXY_INFO, ProvideProxyInfoCommand],\n ] as const)(\n \"should provide context by calling sendPayloadInChunksTask for a %s context\",\n async (contextType, commandClass) => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: contextType,\n payload: \"payload\",\n } as ClearSignContextSuccess<typeof contextType>,\n };\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledWith(api, {\n payload: \"payload\",\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n commandFactory: expect.any(Function),\n });\n\n // Test that the commandFactory returns the correct command class\n const factoryCall = sendPayloadInChunksTaskMockFactory.mock.calls[0]!;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n const commandFactory = factoryCall[1].commandFactory;\n const mockArgs = {\n chunkedData: new Uint8Array([1, 2, 3]),\n isFirstChunk: true,\n };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call\n const command = commandFactory(mockArgs);\n expect(command).toBeInstanceOf(commandClass);\n },\n );\n\n it(\"should provide context for DYNAMIC_NETWORK with correct configuration type\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.DYNAMIC_NETWORK,\n payload: \"payload\",\n },\n };\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n\n // Test that the commandFactory returns ProvideNetworkConfigurationCommand with CONFIGURATION type\n const factoryCall = sendPayloadInChunksTaskMockFactory.mock.calls[0]!;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n const commandFactory = factoryCall[1].commandFactory;\n const mockArgs = {\n chunkedData: new Uint8Array([1, 2, 3]),\n isFirstChunk: true,\n };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call\n const command = commandFactory(mockArgs);\n expect(command).toBeInstanceOf(ProvideNetworkConfigurationCommand);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n expect(command.args.configurationType).toBe(\n NetworkConfigurationType.CONFIGURATION,\n );\n });\n\n it(\"should provide context for DYNAMIC_NETWORK_ICON with correct configuration type and withPayloadLength\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.DYNAMIC_NETWORK_ICON,\n payload: \"payload\",\n },\n };\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledWith(api, {\n payload: \"payload\",\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n commandFactory: expect.any(Function),\n withPayloadLength: false,\n });\n\n // Test that the commandFactory returns ProvideNetworkConfigurationCommand with ICON type\n const factoryCall = sendPayloadInChunksTaskMockFactory.mock.calls[0]!;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n const commandFactory = factoryCall[1].commandFactory;\n const mockArgs = {\n chunkedData: new Uint8Array([1, 2, 3]),\n isFirstChunk: true,\n };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call\n const command = commandFactory(mockArgs);\n expect(command).toBeInstanceOf(ProvideNetworkConfigurationCommand);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n expect(command.args.configurationType).toBe(\n NetworkConfigurationType.ICON,\n );\n });\n\n it(\"should provide context for SAFE with correct type\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.SAFE,\n payload: \"payload\",\n },\n };\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n\n // Test that the commandFactory returns ProvideSafeAccountCommand with SAFE_DESCRIPTOR type\n const factoryCall = sendPayloadInChunksTaskMockFactory.mock.calls[0]!;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n const commandFactory = factoryCall[1].commandFactory;\n const mockArgs = {\n chunkedData: new Uint8Array([1, 2, 3]),\n isFirstChunk: true,\n };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call\n const command = commandFactory(mockArgs);\n expect(command).toBeInstanceOf(ProvideSafeAccountCommand);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n expect(command.args.type).toBe(\n ProvideSafeAccountCommandType.SAFE_DESCRIPTOR,\n );\n });\n\n it(\"should provide context for SIGNER with correct type\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.SIGNER,\n payload: \"payload\",\n },\n };\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n\n // Test that the commandFactory returns ProvideSafeAccountCommand with SIGNER_DESCRIPTOR type\n const factoryCall = sendPayloadInChunksTaskMockFactory.mock.calls[0]!;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n const commandFactory = factoryCall[1].commandFactory;\n const mockArgs = {\n chunkedData: new Uint8Array([1, 2, 3]),\n isFirstChunk: true,\n };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call\n const command = commandFactory(mockArgs);\n expect(command).toBeInstanceOf(ProvideSafeAccountCommand);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n expect(command.args.type).toBe(\n ProvideSafeAccountCommandType.SIGNER_DESCRIPTOR,\n );\n });\n });\n\n describe(\"with certificate\", () => {\n it(\"should load certificate before providing context when certificate is present\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.TOKEN,\n payload: \"payload\",\n certificate: {\n keyUsageNumber: 1,\n payload: new Uint8Array([1, 2, 3]),\n },\n },\n };\n api.sendCommand.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(api.sendCommand).toHaveBeenCalledTimes(2);\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n 1,\n expect.any(LoadCertificateCommand),\n );\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n 2,\n expect.any(ProvideTokenInformationCommand),\n );\n });\n\n it(\"should load certificate with sendPayloadInChunksTask context\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload\",\n certificate: {\n keyUsageNumber: 2,\n payload: new Uint8Array([4, 5, 6]),\n },\n },\n };\n api.sendCommand.mockResolvedValue(successResult);\n sendPayloadInChunksRunMock.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(api.sendCommand).toHaveBeenCalledTimes(1);\n expect(api.sendCommand).toHaveBeenCalledWith(\n expect.any(LoadCertificateCommand),\n );\n expect(sendPayloadInChunksRunMock).toHaveBeenCalledTimes(1);\n });\n\n it(\"should not load certificate when not present\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.TOKEN,\n payload: \"payload\",\n },\n };\n api.sendCommand.mockResolvedValue(successResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(successResult);\n expect(api.sendCommand).toHaveBeenCalledTimes(1);\n expect(api.sendCommand).toHaveBeenCalledWith(\n expect.any(ProvideTokenInformationCommand),\n );\n });\n });\n\n describe(\"error handling\", () => {\n it(\"should return error when sendCommand fails\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.NFT,\n payload: \"payload\",\n },\n };\n api.sendCommand.mockResolvedValue(errorResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(errorResult);\n });\n\n it(\"should return error when sendPayloadInChunksTask fails\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.TRUSTED_NAME,\n payload: \"payload\",\n },\n };\n sendPayloadInChunksRunMock.mockResolvedValue(errorResult);\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(errorResult);\n });\n\n it(\"should return error for unsupported context type\", async () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: \"unsupported\" as unknown as ClearSignContextType.TOKEN,\n payload: \"payload\",\n },\n };\n\n // WHEN\n const task = new ProvideContextTask(\n api,\n args,\n sendPayloadInChunksTaskMockFactory,\n );\n const result = await task.run();\n\n // THEN\n expect(result).toEqual(\n CommandResultFactory({\n error: new InvalidStatusWordError(\n `The context type [unsupported] is not covered`,\n ),\n }),\n );\n });\n });\n\n describe(\"factory\", () => {\n it(\"should have a default sendPayloadInChunksTaskFactory\", () => {\n // GIVEN\n const args: ProvideContextTaskArgs = {\n context: {\n type: ClearSignContextType.TOKEN,\n payload: \"payload\",\n },\n };\n\n // WHEN\n const task = new ProvideContextTask(api, args);\n\n // THEN\n expect(task[\"_sendPayloadInChunksTaskFactory\"]).toBeDefined();\n const sendPayloadInChunksTask = task[\"_sendPayloadInChunksTaskFactory\"](\n api,\n {\n payload: \"payload\",\n commandFactory: () =>\n new ProvideTransactionInformationCommand({\n data: new Uint8Array(),\n isFirstChunk: true,\n }),\n },\n );\n expect(sendPayloadInChunksTask).toBeInstanceOf(SendPayloadInChunksTask);\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_device_management_kit", "import_ProvideEnumCommand", "import_ProvideNetworkConfigurationCommand", "import_ProvideNFTInformationCommand", "import_ProvideProxyInfoCommand", "import_ProvideSafeAccountCommand", "import_ProvideTokenInformationCommand", "import_ProvideTransactionFieldDescriptionCommand", "import_ProvideTransactionInformationCommand", "import_ProvideTrustedNameCommand", "import_ProvideWeb3CheckCommand", "import_SetExternalPluginCommand", "import_SetPluginCommand", "import_makeInternalApi", "import_ProvideContextTask", "import_SendPayloadInChunksTask", "api", "successResult", "errorResult", "sendPayloadInChunksRunMock", "sendPayloadInChunksTaskMockFactory", "a", "args", "contextType", "commandClass", "result", "commandFactory", "mockArgs", "command", "task", "sendPayloadInChunksTask"]
7
+ }
@@ -1,2 +1,2 @@
1
- "use strict";var g=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var F=Object.prototype.hasOwnProperty;var M=(u,e)=>{for(var a in e)g(u,a,{get:e[a],enumerable:!0})},V=(u,e,a,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of P(e))!F.call(u,t)&&t!==a&&g(u,t,{get:()=>e[t],enumerable:!(n=b(e,t))||n.enumerable});return u};var J=u=>V(g({},"__esModule",{value:!0}),u);var O={};M(O,{ProvideEIP712ContextTask:()=>_});module.exports=J(O);var x=require("@ledgerhq/context-module"),T=require("@ledgerhq/context-module"),s=require("@ledgerhq/device-management-kit"),d=require("purify-ts"),E=require("../../app-binder/command/GetChallengeCommand"),v=require("../../app-binder/command/ProvideTokenInformationCommand"),N=require("../../app-binder/command/ProvideTrustedNameCommand"),R=require("../../app-binder/command/ProvideWeb3CheckCommand"),r=require("../../app-binder/command/SendEIP712FilteringCommand"),l=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),h=require("../../app-binder/command/SendEIP712StructImplemCommand"),C=require("../../app-binder/task/SendEIP712StructImplemTask"),A=require("../../typed-data/model/Types"),f=require("../../typed-data/model/Types"),I=require("./SendPayloadInChunksTask");const w=5;class _{constructor(e,a,n){this.api=e;this.contextModule=a;this.args=n;for(const t of this.args.domain)if(t.path==="chainId"&&t.value instanceof A.TypedDataValueField){const i=BigInt((0,s.bufferToHexaString)(t.value.data));i<=Number.MAX_SAFE_INTEGER&&(this.chainId=(0,d.Just)(Number(i)));break}}chainId=d.Nothing;async run(){this.args.web3Check&&(this.args.web3Check.certificate&&await this.api.sendCommand(new s.LoadCertificateCommand({keyUsage:this.args.web3Check.certificate.keyUsageNumber,certificate:this.args.web3Check.certificate.payload})),await new I.SendPayloadInChunksTask(this.api,{payload:this.args.web3Check.payload,commandFactory:t=>new R.ProvideWeb3CheckCommand({payload:t.chunkedData,isFirstChunk:t.isFirstChunk})}).run());const e=(0,s.CommandResultFactory)({data:void 0}),a=Object.entries(this.args.types).sort(([t],[i])=>t.localeCompare(i));for(const[t,i]of a){const o=await this.api.sendCommand(new l.SendEIP712StructDefinitionCommand({command:l.StructDefinitionCommand.Name,name:t}));if(!(0,s.isSuccessCommandResult)(o))return o;for(const[m,c]of Object.entries(i)){const y=await this.api.sendCommand(new l.SendEIP712StructDefinitionCommand({command:l.StructDefinitionCommand.Field,name:m,type:c}));if(!(0,s.isSuccessCommandResult)(y))return y}}if(this.args.clearSignContext.isJust()){const t=await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.Activation}));if(!(0,s.isSuccessCommandResult)(t))return t}for(const t of this.args.domain){const o=await this.getImplementationTask(t).run();if(!(0,s.isSuccessCommandResult)(o))return o}if(this.args.clearSignContext.isJust()){const t=this.args.clearSignContext.extract(),i=await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.MessageInfo,displayName:t.messageInfo.displayName,filtersCount:t.messageInfo.filtersCount,signature:t.messageInfo.signature}));if(!(0,s.isSuccessCommandResult)(i))return i}const n={indexes:{},nextIndex:0};for(const t of this.args.message){const i=await this.provideTokenInformation(t,n);if(i.isJust())return i.extract();const o=await this.provideTrustedName(t);if(o.isJust())return o.extract();const m=await this.filterValue(t,n);if(m.isJust()&&!(0,s.isSuccessCommandResult)(m.extract()))return m.extract();const y=await this.getImplementationTask(t).run();if(!(0,s.isSuccessCommandResult)(y))return y;if(this.args.clearSignContext.isJust()&&t.value instanceof f.TypedDataValueArray&&t.value.length===0){const D=Object.entries(this.args.clearSignContext.extract().filters).filter(([p])=>p.startsWith(`${t.path}.[]`)).map(([,p])=>p);for(const p of D){const k=await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.DiscardedPath,path:p.path}));if(!(0,s.isSuccessCommandResult)(k))return k;const S=await this.provideFiltering(p,n,!0);if(!(0,s.isSuccessCommandResult)(S))return S}}}return e}getImplementationTask(e){return e.value instanceof f.TypedDataValueRoot?new C.SendEIP712StructImplemTask(this.api,{type:h.StructImplemType.ROOT,value:e.value.root}):e.value instanceof f.TypedDataValueArray?new C.SendEIP712StructImplemTask(this.api,{type:h.StructImplemType.ARRAY,value:e.value.length}):new C.SendEIP712StructImplemTask(this.api,{type:h.StructImplemType.FIELD,value:e.value.data})}async provideTokenInformation(e,a){if(this.args.clearSignContext.isJust()){const n=this.args.clearSignContext.extract().filters[e.path];if(n!==void 0&&(n.type==="amount"||n.type==="token")&&a.indexes[n.tokenIndex]===void 0){const t=n.tokenIndex,o=this.args.clearSignContext.extract().tokens[t];if(o===void 0)return d.Nothing;const m=await this.api.sendCommand(new v.ProvideTokenInformationCommand({payload:o}));if(!(0,s.isSuccessCommandResult)(m))return d.Maybe.of(m);let{tokenIndex:c}=m.data;a.nextIndex=(c+1)%w,Number(t)===x.VERIFYING_CONTRACT_TOKEN_INDEX&&(c=x.VERIFYING_CONTRACT_TOKEN_INDEX),a.indexes[Number(t)]=c}}return d.Nothing}async provideTrustedName(e){if(this.args.clearSignContext.isJust()&&this.chainId.isJust()){const a=this.args.clearSignContext.extract(),n=a.filters[e.path],t=a.trustedNamesAddresses[e.path];if(n!==void 0&&n.type==="trusted-name"&&t!==void 0){const i=await this.api.sendCommand(new E.GetChallengeCommand);if(!(0,s.isSuccessCommandResult)(i))return(0,d.Just)(i);const o=await this.contextModule.getContext({type:T.ClearSignContextType.TRUSTED_NAME,chainId:this.chainId.extract(),address:t,challenge:i.data.challenge,types:n.types,sources:n.sources});if(o.type===T.ClearSignContextType.TRUSTED_NAME){o.certificate&&await this.api.sendCommand(new s.LoadCertificateCommand({keyUsage:o.certificate.keyUsageNumber,certificate:o.certificate.payload}));const m=await new I.SendPayloadInChunksTask(this.api,{payload:o.payload,commandFactory:c=>new N.ProvideTrustedNameCommand({data:c.chunkedData,isFirstChunk:c.isFirstChunk})}).run();if(!(0,s.isSuccessCommandResult)(m))return(0,d.Just)(m)}}}return d.Nothing}async filterValue(e,a){if(this.args.clearSignContext.isJust()){const n=this.args.clearSignContext.extract().filters[e.path];if(n===void 0)return d.Nothing;const t=await this.provideFiltering(n,a,!1);return d.Maybe.of(t)}return d.Nothing}async provideFiltering(e,a,n){switch(e.type){case"trusted-name":return await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.TrustedName,discarded:n,displayName:e.displayName,typesAndSourcesPayload:e.typesAndSourcesPayload,signature:e.signature}));case"datetime":return await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.Datetime,discarded:n,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.Raw,discarded:n,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,a),await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.Token,discarded:n,tokenIndex:a.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,a),await this.api.sendCommand(new r.SendEIP712FilteringCommand({type:r.Eip712FilterType.Amount,discarded:n,displayName:e.displayName,tokenIndex:a.indexes[e.tokenIndex],signature:e.signature}));default:return(0,s.CommandResultFactory)({error:new s.InvalidStatusWordError("ProvideEIP712ContextTask/provideFiltering - Unhandled filter type")})}}sanitizeDeviceIndex(e,a){a.indexes[e]===void 0&&(a.indexes[e]=a.nextIndex,a.nextIndex=(a.nextIndex+1)%w)}}0&&(module.exports={ProvideEIP712ContextTask});
1
+ "use strict";var T=Object.defineProperty;var M=Object.getOwnPropertyDescriptor;var O=Object.getOwnPropertyNames;var _=Object.prototype.hasOwnProperty;var V=(p,e)=>{for(var t in e)T(p,t,{get:e[t],enumerable:!0})},U=(p,e,t,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of O(e))!_.call(p,i)&&i!==t&&T(p,i,{get:()=>e[i],enumerable:!(a=M(e,i))||a.enumerable});return p};var J=p=>U(T({},"__esModule",{value:!0}),p);var G={};V(G,{ProvideEIP712ContextTask:()=>W});module.exports=J(G);var u=require("@ledgerhq/context-module"),l=require("@ledgerhq/context-module"),o=require("@ledgerhq/device-management-kit"),d=require("purify-ts"),F=require("../../app-binder/command/GetChallengeCommand"),N=require("../../app-binder/command/ProvideProxyInfoCommand"),P=require("../../app-binder/command/ProvideTokenInformationCommand"),E=require("../../app-binder/command/ProvideTrustedNameCommand"),R=require("../../app-binder/command/ProvideWeb3CheckCommand"),n=require("../../app-binder/command/SendEIP712FilteringCommand"),h=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),x=require("../../app-binder/command/SendEIP712StructImplemCommand"),f=require("../../app-binder/task/SendEIP712StructImplemTask"),A=require("../../typed-data/model/Types"),g=require("../../typed-data/model/Types"),D=require("./ProvideTransactionContextsTask"),I=require("./SendPayloadInChunksTask");const k=5;class W{constructor(e,t,a,i=s=>new D.ProvideTransactionContextsTask(this.api,s)){this.api=e;this.contextModule=t;this.args=a;this.provideContextFactory=i;for(const s of this.args.domain)if(s.path==="chainId"&&s.value instanceof A.TypedDataValueField){const r=BigInt((0,o.bufferToHexaString)(s.value.data));r<=Number.MAX_SAFE_INTEGER&&(this.chainId=(0,d.Just)(Number(r)));break}}chainId=d.Nothing;calldataMetadatas={};async run(){this.args.transactionChecks&&await this.provideContext(this.args.transactionChecks);const e=this.args.clearSignContext.extract()?.proxy;e!==void 0&&await this.provideContext(e);const t=(0,o.CommandResultFactory)({data:void 0}),a=Object.entries(this.args.types).sort(([s],[r])=>s.localeCompare(r));for(const[s,r]of a){const c=await this.api.sendCommand(new h.SendEIP712StructDefinitionCommand({command:h.StructDefinitionCommand.Name,name:s}));if(!(0,o.isSuccessCommandResult)(c))return c;for(const[m,w]of Object.entries(r)){const y=await this.api.sendCommand(new h.SendEIP712StructDefinitionCommand({command:h.StructDefinitionCommand.Field,name:m,type:w}));if(!(0,o.isSuccessCommandResult)(y))return y}}if(this.args.clearSignContext.isJust()){const s=await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.Activation}));if(!(0,o.isSuccessCommandResult)(s))return s}for(const s of this.args.domain){const c=await this.getImplementationTask(s).run();if(!(0,o.isSuccessCommandResult)(c))return c}if(this.args.clearSignContext.isJust()){const s=this.args.clearSignContext.extract(),r=await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.MessageInfo,displayName:s.messageInfo.displayName,filtersCount:s.messageInfo.filtersCount,signature:s.messageInfo.signature}));if(!(0,o.isSuccessCommandResult)(r))return r}const i={indexes:{},nextIndex:0};for(const s of this.args.message){const r=await this.provideTokenInformation(s,i);if(r.isJust())return r.extract();const c=await this.provideTrustedName(s);if(c.isJust())return c.extract();const m=await this.filterValue(s,i);if(m.isJust()&&!(0,o.isSuccessCommandResult)(m.extract()))return m.extract();const y=await this.getImplementationTask(s).run();if(!(0,o.isSuccessCommandResult)(y))return y;if(await this.tryProvideTransactionContext(),this.args.clearSignContext.isJust()&&s.value instanceof g.TypedDataValueArray&&s.value.length===0){const b=Object.entries(this.args.clearSignContext.extract().filters).filter(([C])=>C.startsWith(`${s.path}.[]`)).map(([,C])=>C);for(const C of b){const v=await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.DiscardedPath,path:C.path}));if(!(0,o.isSuccessCommandResult)(v))return v;const S=await this.provideFiltering(C,i,!0);if(!(0,o.isSuccessCommandResult)(S))return S}}}return t}async provideContext({type:e,payload:t,certificate:a}){switch(a&&await this.api.sendCommand(new o.LoadCertificateCommand({keyUsage:a.keyUsageNumber,certificate:a.payload})),e){case l.ClearSignContextType.TRANSACTION_CHECK:await new I.SendPayloadInChunksTask(this.api,{payload:t,commandFactory:i=>new R.ProvideWeb3CheckCommand({payload:i.chunkedData,isFirstChunk:i.isFirstChunk})}).run();break;case l.ClearSignContextType.PROXY_INFO:await new I.SendPayloadInChunksTask(this.api,{payload:t,commandFactory:i=>new N.ProvideProxyInfoCommand({data:i.chunkedData,isFirstChunk:i.isFirstChunk})}).run();break;case l.ClearSignContextType.TOKEN:case l.ClearSignContextType.NFT:case l.ClearSignContextType.TRUSTED_NAME:case l.ClearSignContextType.PLUGIN:case l.ClearSignContextType.EXTERNAL_PLUGIN:case l.ClearSignContextType.ENUM:case l.ClearSignContextType.TRANSACTION_INFO:case l.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:case l.ClearSignContextType.DYNAMIC_NETWORK:case l.ClearSignContextType.DYNAMIC_NETWORK_ICON:case l.ClearSignContextType.SAFE:case l.ClearSignContextType.SIGNER:throw new Error(`Context type ${e} not supported in EIP712 messages`);default:{const i=e;throw new Error(`Unhandled context type ${i}`)}}}getImplementationTask(e){return e.value instanceof g.TypedDataValueRoot?new f.SendEIP712StructImplemTask(this.api,{type:x.StructImplemType.ROOT,value:e.value.root}):e.value instanceof g.TypedDataValueArray?new f.SendEIP712StructImplemTask(this.api,{type:x.StructImplemType.ARRAY,value:e.value.length}):new f.SendEIP712StructImplemTask(this.api,{type:x.StructImplemType.FIELD,value:e.value.data})}async provideTokenInformation(e,t){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a!==void 0&&(a.type==="amount"||a.type==="token")&&t.indexes[a.tokenIndex]===void 0){const i=a.tokenIndex,r=this.args.clearSignContext.extract().tokens[i];if(r===void 0)return d.Nothing;const c=await this.api.sendCommand(new P.ProvideTokenInformationCommand({payload:r}));if(!(0,o.isSuccessCommandResult)(c))return d.Maybe.of(c);let{tokenIndex:m}=c.data;t.nextIndex=(m+1)%k,Number(i)===u.VERIFYING_CONTRACT_TOKEN_INDEX&&(m=u.VERIFYING_CONTRACT_TOKEN_INDEX),t.indexes[Number(i)]=m}}return d.Nothing}async provideTrustedName(e){if(this.args.clearSignContext.isJust()&&this.chainId.isJust()){const t=this.args.clearSignContext.extract(),a=t.filters[e.path],i=t.trustedNamesAddresses[e.path];if(a!==void 0&&a.type==="trusted-name"&&i!==void 0){const s=await this.api.sendCommand(new F.GetChallengeCommand);if(!(0,o.isSuccessCommandResult)(s))return(0,d.Just)(s);const r=await this.contextModule.getFieldContext({chainId:this.chainId.extract(),address:i,challenge:s.data.challenge,types:a.types,sources:a.sources,deviceModelId:this.args.deviceModelId},l.ClearSignContextType.TRUSTED_NAME);if(r.type===l.ClearSignContextType.TRUSTED_NAME){r.certificate&&await this.api.sendCommand(new o.LoadCertificateCommand({keyUsage:r.certificate.keyUsageNumber,certificate:r.certificate.payload}));const c=await new I.SendPayloadInChunksTask(this.api,{payload:r.payload,commandFactory:m=>new E.ProvideTrustedNameCommand({data:m.chunkedData,isFirstChunk:m.isFirstChunk})}).run();if(!(0,o.isSuccessCommandResult)(c))return(0,d.Just)(c)}}}return d.Nothing}async filterValue(e,t){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a===void 0)return d.Nothing;const i=await this.provideFiltering(a,t,!1);return d.Maybe.of(i)}return d.Nothing}async provideFiltering(e,t,a){switch(e.type){case"trusted-name":return await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.TrustedName,discarded:a,displayName:e.displayName,typesAndSourcesPayload:e.typesAndSourcesPayload,signature:e.signature}));case"datetime":return await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.Datetime,discarded:a,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.Raw,discarded:a,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.Token,discarded:a,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.Amount,discarded:a,displayName:e.displayName,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}));case"calldata-value":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataValue,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));case"calldata-callee":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataCallee,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));case"calldata-spender":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataSpender,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));case"calldata-chain-id":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataChainId,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));case"calldata-selector":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataSelector,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));case"calldata-amount":return await this.provideCalldataInfos(e.calldataIndex),await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataAmount,discarded:a,calldataIndex:e.calldataIndex,signature:e.signature}));default:{const i=e;throw new Error(`ProvideEIP712ContextTask/provideFiltering - Unhandled filter ${i}`)}}}async provideCalldataInfos(e){if(this.args.clearSignContext.isJust()){if(this.calldataMetadatas[e]!==void 0)return this.calldataMetadatas[e].remainingFilters--,d.Nothing;const t=this.args.clearSignContext.extract().calldatas[e];if(t===void 0)return d.Nothing;const i=[t.filter.valueFlag,t.filter.calleeFlag===u.TypedDataCalldataParamPresence.Present,t.filter.chainIdFlag,t.filter.selectorFlag,t.filter.amountFlag,t.filter.spenderFlag===u.TypedDataCalldataParamPresence.Present].filter(s=>s).length;return this.calldataMetadatas[e]={remainingFilters:i-1,contexts:this.args.calldatasContexts[e]},d.Maybe.of(await this.api.sendCommand(new n.SendEIP712FilteringCommand({type:n.Eip712FilterType.CalldataInfo,discarded:!1,calldataIndex:e,valueFlag:t.filter.valueFlag,calleeFlag:this.mapCalldataPresence(t.filter.calleeFlag),chainIdFlag:t.filter.chainIdFlag,selectorFlag:t.filter.selectorFlag,amountFlag:t.filter.amountFlag,spenderFlag:this.mapCalldataPresence(t.filter.spenderFlag),signature:t.filter.signature})))}return d.Nothing}async tryProvideTransactionContext(){for(const e in this.calldataMetadatas){const t=this.calldataMetadatas[e];t.remainingFilters===0&&(t.contexts!==void 0&&await this.provideContextFactory({contexts:t.contexts,derivationPath:this.args.derivationPath}).run(),delete this.calldataMetadatas[e])}}mapCalldataPresence(e){switch(e){case u.TypedDataCalldataParamPresence.None:return n.CalldataParamPresence.None;case u.TypedDataCalldataParamPresence.Present:return n.CalldataParamPresence.Present;case u.TypedDataCalldataParamPresence.VerifyingContract:return n.CalldataParamPresence.VerifyingContract;default:{const t=e;throw new Error(`Unhandled presence ${t}`)}}}sanitizeDeviceIndex(e,t){t.indexes[e]===void 0&&(t.indexes[e]=t.nextIndex,t.nextIndex=(t.nextIndex+1)%k)}}0&&(module.exports={ProvideEIP712ContextTask});
2
2
  //# sourceMappingURL=ProvideEIP712ContextTask.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.ts"],
4
- "sourcesContent": ["import {\n type ContextModule,\n type TypedDataClearSignContextSuccess,\n type TypedDataFilter,\n type TypedDataTokenIndex,\n VERIFYING_CONTRACT_TOKEN_INDEX,\n} from \"@ledgerhq/context-module\";\nimport {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport type {\n CommandResult,\n InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport {\n bufferToHexaString,\n CommandResultFactory,\n InvalidStatusWordError,\n isSuccessCommandResult,\n LoadCertificateCommand,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Maybe, Nothing } from \"purify-ts\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport { ProvideWeb3CheckCommand } from \"@internal/app-binder/command/ProvideWeb3CheckCommand\";\nimport {\n Eip712FilterType,\n SendEIP712FilteringCommand,\n} from \"@internal/app-binder/command/SendEIP712FilteringCommand\";\nimport {\n SendEIP712StructDefinitionCommand,\n StructDefinitionCommand,\n} from \"@internal/app-binder/command/SendEIP712StructDefinitionCommand\";\nimport { StructImplemType } from \"@internal/app-binder/command/SendEIP712StructImplemCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport { SendEIP712StructImplemTask } from \"@internal/app-binder/task/SendEIP712StructImplemTask\";\nimport { TypedDataValueField } from \"@internal/typed-data/model/Types\";\nimport {\n type FieldName,\n type FieldType,\n type StructName,\n type TypedDataValue,\n TypedDataValueArray,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport { SendPayloadInChunksTask } from \"./SendPayloadInChunksTask\";\n\ntype AllSuccessTypes = void | { tokenIndex: number };\n\nexport type ProvideEIP712ContextTaskReturnType = Promise<\n CommandResult<AllSuccessTypes, EthErrorCodes>\n>;\n\nexport type ProvideEIP712ContextTaskArgs = {\n types: Record<StructName, Record<FieldName, FieldType>>;\n domain: Array<TypedDataValue>;\n message: Array<TypedDataValue>;\n clearSignContext: Maybe<TypedDataClearSignContextSuccess>;\n domainHash: string;\n messageHash: string;\n web3Check: ClearSignContextSuccess<ClearSignContextType.WEB3_CHECK> | null;\n};\n\nconst DEVICE_ASSETS_MAX = 5;\n\ntype DeviceAssetIndexes = {\n indexes: Record<TypedDataTokenIndex, number>;\n nextIndex: number;\n};\n\nexport class ProvideEIP712ContextTask {\n private chainId: Maybe<number> = Nothing;\n\n constructor(\n private api: InternalApi,\n private contextModule: ContextModule,\n private args: ProvideEIP712ContextTaskArgs,\n ) {\n for (const domainValue of this.args.domain) {\n if (\n domainValue.path === \"chainId\" &&\n domainValue.value instanceof TypedDataValueField\n ) {\n const val = BigInt(bufferToHexaString(domainValue.value.data));\n if (val <= Number.MAX_SAFE_INTEGER) {\n this.chainId = Just(Number(val));\n }\n break;\n }\n }\n }\n\n async run(): ProvideEIP712ContextTaskReturnType {\n // Send message simulation first\n if (this.args.web3Check) {\n if (this.args.web3Check.certificate) {\n await this.api.sendCommand(\n new LoadCertificateCommand({\n keyUsage: this.args.web3Check.certificate.keyUsageNumber,\n certificate: this.args.web3Check.certificate.payload,\n }),\n );\n }\n await new SendPayloadInChunksTask(this.api, {\n payload: this.args.web3Check.payload,\n commandFactory: (args) =>\n new ProvideWeb3CheckCommand({\n payload: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n }\n\n const result: CommandResult<AllSuccessTypes, EthErrorCodes> =\n CommandResultFactory<AllSuccessTypes, EthErrorCodes>({ data: undefined });\n\n // Provide the structure definitions.\n // Should be sent before struct implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition\n // Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering\n // Therefore it should be normalized on both sides: sorted per keys\n const types = Object.entries(this.args.types).sort(([aKey], [bKey]) =>\n aKey.localeCompare(bKey),\n );\n for (const [structName, fields] of types) {\n const structNameResult = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name: structName,\n }),\n );\n if (!isSuccessCommandResult(structNameResult)) {\n return structNameResult;\n }\n\n for (const [fieldName, fieldType] of Object.entries(fields)) {\n const fieldResult = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name: fieldName,\n type: fieldType,\n }),\n );\n if (!isSuccessCommandResult(fieldResult)) {\n return fieldResult;\n }\n }\n }\n\n // possibly activate the filtering, before sending domain and message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation\n if (this.args.clearSignContext.isJust()) {\n const activationResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n if (!isSuccessCommandResult(activationResult)) {\n return activationResult;\n }\n }\n\n // send domain implementation values.\n for (const value of this.args.domain) {\n const domainImplTask = this.getImplementationTask(value);\n const domainImplResult = await domainImplTask.run();\n if (!isSuccessCommandResult(domainImplResult)) {\n return domainImplResult;\n }\n }\n\n // possibly send MessageInformation filter (between Domain and Message)\n // should be sent between Domain and Message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info\n if (this.args.clearSignContext.isJust()) {\n const clearSignContext = this.args.clearSignContext.extract();\n const messageInfoFilterResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: clearSignContext.messageInfo.displayName,\n filtersCount: clearSignContext.messageInfo.filtersCount,\n signature: clearSignContext.messageInfo.signature,\n }),\n );\n if (!isSuccessCommandResult(messageInfoFilterResult)) {\n return messageInfoFilterResult;\n }\n }\n\n // send message implementation values\n const deviceIndexes: DeviceAssetIndexes = { indexes: {}, nextIndex: 0 };\n for (const value of this.args.message) {\n // 5.1 Provide token descriptors, if any\n // Keep a map of all device indexes for those provided tokens.\n const maybeTokenError = await this.provideTokenInformation(\n value,\n deviceIndexes,\n );\n if (maybeTokenError.isJust()) {\n return maybeTokenError.extract();\n }\n\n // Provide trusted name descriptors, if any\n const maybeNameError = await this.provideTrustedName(value);\n if (maybeNameError.isJust()) {\n return maybeNameError.extract();\n }\n\n // if there's a filter, send it\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token\n const maybeFilterResult = await this.filterValue(value, deviceIndexes);\n if (\n maybeFilterResult.isJust() &&\n !isSuccessCommandResult(maybeFilterResult.extract())\n ) {\n return maybeFilterResult.extract();\n }\n\n // provide message value implementation\n const messageImplTask = this.getImplementationTask(value);\n const messageImplResult = await messageImplTask.run();\n if (!isSuccessCommandResult(messageImplResult)) {\n return messageImplResult;\n }\n\n // if the value is an empty array, discard sub-filters since\n // there will be no according sub-values in the message\n if (\n this.args.clearSignContext.isJust() &&\n value.value instanceof TypedDataValueArray &&\n value.value.length === 0\n ) {\n const filters = Object.entries(\n this.args.clearSignContext.extract().filters,\n );\n const discardedFilters = filters\n .filter(([path]) => path.startsWith(`${value.path}.[]`))\n .map(([, filter]) => filter);\n for (const filter of discardedFilters) {\n const discardedPathResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: filter.path,\n }),\n );\n if (!isSuccessCommandResult(discardedPathResult)) {\n return discardedPathResult;\n }\n\n const provideFilteringResult = await this.provideFiltering(\n filter,\n deviceIndexes,\n true,\n );\n if (!isSuccessCommandResult(provideFilteringResult)) {\n return provideFilteringResult;\n }\n }\n }\n }\n\n return result;\n }\n\n getImplementationTask(value: TypedDataValue): SendEIP712StructImplemTask {\n if (value.value instanceof TypedDataValueRoot) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ROOT,\n value: value.value.root,\n });\n } else if (value.value instanceof TypedDataValueArray) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ARRAY,\n value: value.value.length,\n });\n } else {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.FIELD,\n value: value.value.data,\n });\n }\n }\n\n async provideTokenInformation(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n // tokens descriptors only needed when a tokenIndex is available in filter.\n // it should be sent to the device only 1 time so deviceIndexes has to be checked.\n if (\n filter !== undefined &&\n (filter.type === \"amount\" || filter.type === \"token\") &&\n deviceIndexes.indexes[filter.tokenIndex] === undefined\n ) {\n const descriptorIndex = filter.tokenIndex;\n const tokens = this.args.clearSignContext.extract().tokens;\n const token = tokens[descriptorIndex];\n if (token === undefined) {\n return Nothing;\n }\n\n const provideTokenInfoResult = await this.api.sendCommand(\n new ProvideTokenInformationCommand({ payload: token }),\n );\n if (!isSuccessCommandResult(provideTokenInfoResult)) {\n return Maybe.of(provideTokenInfoResult);\n }\n let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;\n deviceIndexes.nextIndex = (deviceIndex + 1) % DEVICE_ASSETS_MAX;\n\n // the token corresponding to the Verifying Contract of message domain has a special index value, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value\n if (Number(descriptorIndex) === VERIFYING_CONTRACT_TOKEN_INDEX) {\n deviceIndex = VERIFYING_CONTRACT_TOKEN_INDEX;\n }\n\n deviceIndexes.indexes[Number(descriptorIndex)] = deviceIndex;\n }\n }\n return Nothing;\n }\n\n private async provideTrustedName(\n value: TypedDataValue,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust() && this.chainId.isJust()) {\n const context = this.args.clearSignContext.extract();\n const filter = context.filters[value.path];\n const address = context.trustedNamesAddresses[value.path];\n if (\n filter !== undefined &&\n filter.type === \"trusted-name\" &&\n address !== undefined\n ) {\n const getChallengeResult = await this.api.sendCommand(\n new GetChallengeCommand(),\n );\n if (!isSuccessCommandResult(getChallengeResult)) {\n return Just(getChallengeResult);\n }\n\n const context = await this.contextModule.getContext({\n type: ClearSignContextType.TRUSTED_NAME,\n chainId: this.chainId.extract(),\n address,\n challenge: getChallengeResult.data.challenge,\n types: filter.types,\n sources: filter.sources,\n });\n if (context.type === ClearSignContextType.TRUSTED_NAME) {\n if (context.certificate) {\n await this.api.sendCommand(\n new LoadCertificateCommand({\n keyUsage: context.certificate.keyUsageNumber,\n certificate: context.certificate.payload,\n }),\n );\n }\n const provideNameResult = await new SendPayloadInChunksTask(\n this.api,\n {\n payload: context.payload,\n commandFactory: (args) =>\n new ProvideTrustedNameCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n },\n ).run();\n if (!isSuccessCommandResult(provideNameResult)) {\n return Just(provideNameResult);\n }\n }\n }\n }\n return Nothing;\n }\n\n async filterValue(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n if (filter === undefined) {\n return Nothing;\n }\n // provide the filter\n const filteringResult = await this.provideFiltering(\n filter,\n deviceIndexes,\n false,\n );\n return Maybe.of(filteringResult);\n }\n return Nothing;\n }\n\n async provideFiltering(\n filter: TypedDataFilter,\n deviceIndexes: DeviceAssetIndexes,\n discarded: boolean,\n ): Promise<CommandResult<AllSuccessTypes, EthErrorCodes>> {\n switch (filter.type) {\n case \"trusted-name\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.TrustedName,\n discarded,\n displayName: filter.displayName,\n typesAndSourcesPayload: filter.typesAndSourcesPayload,\n signature: filter.signature,\n }),\n );\n case \"datetime\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Datetime,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"raw\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"token\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n case \"amount\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded,\n displayName: filter.displayName,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n default:\n return CommandResultFactory<AllSuccessTypes, EthErrorCodes>({\n error: new InvalidStatusWordError(\n \"ProvideEIP712ContextTask/provideFiltering - Unhandled filter type\",\n ),\n });\n }\n }\n\n private sanitizeDeviceIndex(\n descriptorIndex: number,\n deviceIndexes: DeviceAssetIndexes,\n ) {\n // If a token is missing, the device will replace it with a placeholder and use the next available index\n if (deviceIndexes.indexes[descriptorIndex] === undefined) {\n deviceIndexes.indexes[descriptorIndex] = deviceIndexes.nextIndex;\n deviceIndexes.nextIndex =\n (deviceIndexes.nextIndex + 1) % DEVICE_ASSETS_MAX;\n }\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["ProvideEIP712ContextTask_exports", "__export", "ProvideEIP712ContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_purify_ts", "import_GetChallengeCommand", "import_ProvideTokenInformationCommand", "import_ProvideTrustedNameCommand", "import_ProvideWeb3CheckCommand", "import_SendEIP712FilteringCommand", "import_SendEIP712StructDefinitionCommand", "import_SendEIP712StructImplemCommand", "import_SendEIP712StructImplemTask", "import_Types", "import_SendPayloadInChunksTask", "DEVICE_ASSETS_MAX", "api", "contextModule", "args", "domainValue", "val", "result", "types", "aKey", "bKey", "structName", "fields", "structNameResult", "fieldName", "fieldType", "fieldResult", "activationResult", "value", "domainImplResult", "clearSignContext", "messageInfoFilterResult", "deviceIndexes", "maybeTokenError", "maybeNameError", "maybeFilterResult", "messageImplResult", "discardedFilters", "path", "filter", "discardedPathResult", "provideFilteringResult", "descriptorIndex", "token", "provideTokenInfoResult", "deviceIndex", "context", "address", "getChallengeResult", "provideNameResult", "filteringResult", "discarded"]
4
+ "sourcesContent": ["import {\n type ContextModule,\n type TypedDataCalldataIndex,\n TypedDataCalldataParamPresence,\n type TypedDataClearSignContextSuccess,\n type TypedDataFilter,\n type TypedDataTokenIndex,\n VERIFYING_CONTRACT_TOKEN_INDEX,\n} from \"@ledgerhq/context-module\";\nimport {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport type {\n CommandResult,\n DeviceModelId,\n InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport {\n bufferToHexaString,\n CommandResultFactory,\n isSuccessCommandResult,\n LoadCertificateCommand,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Maybe, Nothing } from \"purify-ts\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { ProvideProxyInfoCommand } from \"@internal/app-binder/command/ProvideProxyInfoCommand\";\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport { ProvideWeb3CheckCommand } from \"@internal/app-binder/command/ProvideWeb3CheckCommand\";\nimport {\n CalldataParamPresence,\n Eip712FilterType,\n SendEIP712FilteringCommand,\n} from \"@internal/app-binder/command/SendEIP712FilteringCommand\";\nimport {\n SendEIP712StructDefinitionCommand,\n StructDefinitionCommand,\n} from \"@internal/app-binder/command/SendEIP712StructDefinitionCommand\";\nimport { StructImplemType } from \"@internal/app-binder/command/SendEIP712StructImplemCommand\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport { type ContextWithSubContexts } from \"@internal/app-binder/task/BuildFullContextsTask\";\nimport { SendEIP712StructImplemTask } from \"@internal/app-binder/task/SendEIP712StructImplemTask\";\nimport { TypedDataValueField } from \"@internal/typed-data/model/Types\";\nimport {\n type FieldName,\n type FieldType,\n type StructName,\n type TypedDataValue,\n TypedDataValueArray,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport {\n ProvideTransactionContextsTask,\n type ProvideTransactionContextsTaskArgs,\n} from \"./ProvideTransactionContextsTask\";\nimport { SendPayloadInChunksTask } from \"./SendPayloadInChunksTask\";\n\ntype AllSuccessTypes = void | { tokenIndex: number };\n\nexport type ProvideEIP712ContextTaskReturnType = Promise<\n CommandResult<AllSuccessTypes, EthErrorCodes>\n>;\n\nexport type ProvideEIP712ContextTaskArgs = {\n deviceModelId: DeviceModelId;\n derivationPath: string;\n types: Record<StructName, Record<FieldName, FieldType>>;\n domain: Array<TypedDataValue>;\n message: Array<TypedDataValue>;\n clearSignContext: Maybe<TypedDataClearSignContextSuccess>;\n calldatasContexts: Record<TypedDataCalldataIndex, ContextWithSubContexts[]>;\n transactionChecks?: ClearSignContextSuccess;\n};\n\nconst DEVICE_ASSETS_MAX = 5;\n\ntype DeviceAssetIndexes = {\n indexes: Record<TypedDataTokenIndex, number>;\n nextIndex: number;\n};\n\ntype CalldataFiltersMetadata = {\n remainingFilters: number;\n contexts?: ContextWithSubContexts[];\n};\n\nexport class ProvideEIP712ContextTask {\n private chainId: Maybe<number> = Nothing;\n private calldataMetadatas: Record<\n TypedDataCalldataIndex,\n CalldataFiltersMetadata\n > = {};\n\n constructor(\n private api: InternalApi,\n private contextModule: ContextModule,\n private args: ProvideEIP712ContextTaskArgs,\n private readonly provideContextFactory = (\n args: ProvideTransactionContextsTaskArgs,\n ) => new ProvideTransactionContextsTask(this.api, args),\n ) {\n for (const domainValue of this.args.domain) {\n if (\n domainValue.path === \"chainId\" &&\n domainValue.value instanceof TypedDataValueField\n ) {\n const val = BigInt(bufferToHexaString(domainValue.value.data));\n if (val <= Number.MAX_SAFE_INTEGER) {\n this.chainId = Just(Number(val));\n }\n break;\n }\n }\n }\n\n async run(): ProvideEIP712ContextTaskReturnType {\n // Provide the transaction checks first if any\n if (this.args.transactionChecks) {\n await this.provideContext(this.args.transactionChecks);\n }\n\n // Send proxy descriptor first if required\n const proxyContext:\n | ClearSignContextSuccess<ClearSignContextType.PROXY_INFO>\n | undefined = this.args.clearSignContext.extract()?.proxy;\n if (proxyContext !== undefined) {\n await this.provideContext(proxyContext);\n }\n\n const result: CommandResult<AllSuccessTypes, EthErrorCodes> =\n CommandResultFactory<AllSuccessTypes, EthErrorCodes>({ data: undefined });\n\n // Provide the structure definitions.\n // Should be sent before struct implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition\n // Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering\n // Therefore it should be normalized on both sides: sorted per keys\n const types = Object.entries(this.args.types).sort(([aKey], [bKey]) =>\n aKey.localeCompare(bKey),\n );\n for (const [structName, fields] of types) {\n const structNameResult = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name: structName,\n }),\n );\n if (!isSuccessCommandResult(structNameResult)) {\n return structNameResult;\n }\n\n for (const [fieldName, fieldType] of Object.entries(fields)) {\n const fieldResult = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name: fieldName,\n type: fieldType,\n }),\n );\n if (!isSuccessCommandResult(fieldResult)) {\n return fieldResult;\n }\n }\n }\n\n // possibly activate the filtering, before sending domain and message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation\n if (this.args.clearSignContext.isJust()) {\n const activationResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n if (!isSuccessCommandResult(activationResult)) {\n return activationResult;\n }\n }\n\n // send domain implementation values.\n for (const value of this.args.domain) {\n const domainImplTask = this.getImplementationTask(value);\n const domainImplResult = await domainImplTask.run();\n if (!isSuccessCommandResult(domainImplResult)) {\n return domainImplResult;\n }\n }\n\n // possibly send MessageInformation filter (between Domain and Message)\n // should be sent between Domain and Message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info\n if (this.args.clearSignContext.isJust()) {\n const clearSignContext = this.args.clearSignContext.extract();\n const messageInfoFilterResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: clearSignContext.messageInfo.displayName,\n filtersCount: clearSignContext.messageInfo.filtersCount,\n signature: clearSignContext.messageInfo.signature,\n }),\n );\n if (!isSuccessCommandResult(messageInfoFilterResult)) {\n return messageInfoFilterResult;\n }\n }\n\n // send message implementation values\n const deviceIndexes: DeviceAssetIndexes = { indexes: {}, nextIndex: 0 };\n for (const value of this.args.message) {\n // 5.1 Provide token descriptors, if any\n // Keep a map of all device indexes for those provided tokens.\n const maybeTokenError = await this.provideTokenInformation(\n value,\n deviceIndexes,\n );\n if (maybeTokenError.isJust()) {\n return maybeTokenError.extract();\n }\n\n // Provide trusted name descriptors, if any\n const maybeNameError = await this.provideTrustedName(value);\n if (maybeNameError.isJust()) {\n return maybeNameError.extract();\n }\n\n // if there's a filter, send it\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token\n const maybeFilterResult = await this.filterValue(value, deviceIndexes);\n if (\n maybeFilterResult.isJust() &&\n !isSuccessCommandResult(maybeFilterResult.extract())\n ) {\n return maybeFilterResult.extract();\n }\n\n // provide message value implementation\n const messageImplTask = this.getImplementationTask(value);\n const messageImplResult = await messageImplTask.run();\n if (!isSuccessCommandResult(messageImplResult)) {\n return messageImplResult;\n }\n\n // if a transaction was embedded in that value, provide the related clear sign context\n await this.tryProvideTransactionContext();\n\n // if the value is an empty array, discard sub-filters since\n // there will be no according sub-values in the message\n if (\n this.args.clearSignContext.isJust() &&\n value.value instanceof TypedDataValueArray &&\n value.value.length === 0\n ) {\n const filters = Object.entries(\n this.args.clearSignContext.extract().filters,\n );\n const discardedFilters = filters\n .filter(([path]) => path.startsWith(`${value.path}.[]`))\n .map(([, filter]) => filter);\n for (const filter of discardedFilters) {\n const discardedPathResult = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: filter.path,\n }),\n );\n if (!isSuccessCommandResult(discardedPathResult)) {\n return discardedPathResult;\n }\n\n const provideFilteringResult = await this.provideFiltering(\n filter,\n deviceIndexes,\n true,\n );\n if (!isSuccessCommandResult(provideFilteringResult)) {\n return provideFilteringResult;\n }\n }\n }\n }\n\n return result;\n }\n\n async provideContext({\n type,\n payload,\n certificate,\n }: ClearSignContextSuccess) {\n // if a certificate is provided, we load it before sending the command\n if (certificate) {\n await this.api.sendCommand(\n new LoadCertificateCommand({\n keyUsage: certificate.keyUsageNumber,\n certificate: certificate.payload,\n }),\n );\n }\n\n switch (type) {\n case ClearSignContextType.TRANSACTION_CHECK:\n await new SendPayloadInChunksTask(this.api, {\n payload,\n commandFactory: (args) =>\n new ProvideWeb3CheckCommand({\n payload: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n break;\n case ClearSignContextType.PROXY_INFO:\n await new SendPayloadInChunksTask(this.api, {\n payload,\n commandFactory: (args) =>\n new ProvideProxyInfoCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n break;\n case ClearSignContextType.TOKEN:\n case ClearSignContextType.NFT:\n case ClearSignContextType.TRUSTED_NAME:\n case ClearSignContextType.PLUGIN:\n case ClearSignContextType.EXTERNAL_PLUGIN:\n case ClearSignContextType.ENUM:\n case ClearSignContextType.TRANSACTION_INFO:\n case ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:\n case ClearSignContextType.DYNAMIC_NETWORK:\n case ClearSignContextType.DYNAMIC_NETWORK_ICON:\n case ClearSignContextType.SAFE:\n case ClearSignContextType.SIGNER:\n throw new Error(\n `Context type ${type} not supported in EIP712 messages`,\n );\n default: {\n const uncoveredType: never = type;\n throw new Error(`Unhandled context type ${uncoveredType}`);\n }\n }\n }\n\n getImplementationTask(value: TypedDataValue): SendEIP712StructImplemTask {\n if (value.value instanceof TypedDataValueRoot) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ROOT,\n value: value.value.root,\n });\n } else if (value.value instanceof TypedDataValueArray) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ARRAY,\n value: value.value.length,\n });\n } else {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.FIELD,\n value: value.value.data,\n });\n }\n }\n\n async provideTokenInformation(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n // tokens descriptors only needed when a tokenIndex is available in filter.\n // it should be sent to the device only 1 time so deviceIndexes has to be checked.\n if (\n filter !== undefined &&\n (filter.type === \"amount\" || filter.type === \"token\") &&\n deviceIndexes.indexes[filter.tokenIndex] === undefined\n ) {\n const descriptorIndex = filter.tokenIndex;\n const tokens = this.args.clearSignContext.extract().tokens;\n const token = tokens[descriptorIndex];\n if (token === undefined) {\n return Nothing;\n }\n\n const provideTokenInfoResult = await this.api.sendCommand(\n new ProvideTokenInformationCommand({ payload: token }),\n );\n if (!isSuccessCommandResult(provideTokenInfoResult)) {\n return Maybe.of(provideTokenInfoResult);\n }\n let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;\n deviceIndexes.nextIndex = (deviceIndex + 1) % DEVICE_ASSETS_MAX;\n\n // the token corresponding to the Verifying Contract of message domain has a special index value, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value\n if (Number(descriptorIndex) === VERIFYING_CONTRACT_TOKEN_INDEX) {\n deviceIndex = VERIFYING_CONTRACT_TOKEN_INDEX;\n }\n\n deviceIndexes.indexes[Number(descriptorIndex)] = deviceIndex;\n }\n }\n return Nothing;\n }\n\n private async provideTrustedName(\n value: TypedDataValue,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust() && this.chainId.isJust()) {\n const context = this.args.clearSignContext.extract();\n const filter = context.filters[value.path];\n const address = context.trustedNamesAddresses[value.path];\n if (\n filter !== undefined &&\n filter.type === \"trusted-name\" &&\n address !== undefined\n ) {\n const getChallengeResult = await this.api.sendCommand(\n new GetChallengeCommand(),\n );\n if (!isSuccessCommandResult(getChallengeResult)) {\n return Just(getChallengeResult);\n }\n\n const context = await this.contextModule.getFieldContext(\n {\n chainId: this.chainId.extract(),\n address,\n challenge: getChallengeResult.data.challenge,\n types: filter.types,\n sources: filter.sources,\n deviceModelId: this.args.deviceModelId,\n },\n ClearSignContextType.TRUSTED_NAME,\n );\n if (context.type === ClearSignContextType.TRUSTED_NAME) {\n if (context.certificate) {\n await this.api.sendCommand(\n new LoadCertificateCommand({\n keyUsage: context.certificate.keyUsageNumber,\n certificate: context.certificate.payload,\n }),\n );\n }\n const provideNameResult = await new SendPayloadInChunksTask(\n this.api,\n {\n payload: context.payload,\n commandFactory: (args) =>\n new ProvideTrustedNameCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n },\n ).run();\n if (!isSuccessCommandResult(provideNameResult)) {\n return Just(provideNameResult);\n }\n }\n }\n }\n return Nothing;\n }\n\n async filterValue(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n if (filter === undefined) {\n return Nothing;\n }\n // provide the filter\n const filteringResult = await this.provideFiltering(\n filter,\n deviceIndexes,\n false,\n );\n return Maybe.of(filteringResult);\n }\n return Nothing;\n }\n\n async provideFiltering(\n filter: TypedDataFilter,\n deviceIndexes: DeviceAssetIndexes,\n discarded: boolean,\n ): Promise<CommandResult<AllSuccessTypes, EthErrorCodes>> {\n switch (filter.type) {\n case \"trusted-name\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.TrustedName,\n discarded,\n displayName: filter.displayName,\n typesAndSourcesPayload: filter.typesAndSourcesPayload,\n signature: filter.signature,\n }),\n );\n case \"datetime\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Datetime,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"raw\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"token\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n case \"amount\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded,\n displayName: filter.displayName,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n case \"calldata-value\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataValue,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n case \"calldata-callee\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataCallee,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n case \"calldata-spender\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataSpender,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n case \"calldata-chain-id\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataChainId,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n case \"calldata-selector\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataSelector,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n case \"calldata-amount\":\n await this.provideCalldataInfos(filter.calldataIndex);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataAmount,\n discarded,\n calldataIndex: filter.calldataIndex,\n signature: filter.signature,\n }),\n );\n default: {\n const unhandledType: never = filter;\n throw new Error(\n `ProvideEIP712ContextTask/provideFiltering - Unhandled filter ${unhandledType}`,\n );\n }\n }\n }\n\n private async provideCalldataInfos(\n calldataIndex: number,\n ): Promise<Maybe<CommandResult<AllSuccessTypes, EthErrorCodes>>> {\n if (this.args.clearSignContext.isJust()) {\n // ensure the calldata info was not already provided to the device\n if (this.calldataMetadatas[calldataIndex] !== undefined) {\n // If already provided, update the remaining filters count\n this.calldataMetadatas[calldataIndex]!.remainingFilters--;\n return Nothing;\n }\n\n // get the calldata infos\n const calldataInfos =\n this.args.clearSignContext.extract().calldatas[calldataIndex];\n if (calldataInfos === undefined) {\n return Nothing;\n }\n\n // Initialize the expected filters count\n const filtersPresence = [\n calldataInfos.filter.valueFlag,\n calldataInfos.filter.calleeFlag ===\n TypedDataCalldataParamPresence.Present,\n calldataInfos.filter.chainIdFlag,\n calldataInfos.filter.selectorFlag,\n calldataInfos.filter.amountFlag,\n calldataInfos.filter.spenderFlag ===\n TypedDataCalldataParamPresence.Present,\n ];\n const filtersCount = filtersPresence.filter((f) => f).length;\n this.calldataMetadatas[calldataIndex] = {\n remainingFilters: filtersCount - 1, // Minus 1 since a filter is already being sent\n contexts: this.args.calldatasContexts[calldataIndex],\n };\n\n // provide the transaction infos filter\n return Maybe.of(\n await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.CalldataInfo,\n discarded: false,\n calldataIndex: calldataIndex,\n valueFlag: calldataInfos.filter.valueFlag,\n calleeFlag: this.mapCalldataPresence(\n calldataInfos.filter.calleeFlag,\n ),\n chainIdFlag: calldataInfos.filter.chainIdFlag,\n selectorFlag: calldataInfos.filter.selectorFlag,\n amountFlag: calldataInfos.filter.amountFlag,\n spenderFlag: this.mapCalldataPresence(\n calldataInfos.filter.spenderFlag,\n ),\n signature: calldataInfos.filter.signature,\n }),\n ),\n );\n }\n return Nothing;\n }\n\n private async tryProvideTransactionContext() {\n for (const calldataIndex in this.calldataMetadatas) {\n const metadata = this.calldataMetadatas[calldataIndex]!;\n if (metadata.remainingFilters === 0) {\n // All the filters and implementations were sent for that TX,\n // the related clear sign contexts should now be provided\n if (metadata.contexts !== undefined) {\n await this.provideContextFactory({\n contexts: metadata.contexts,\n derivationPath: this.args.derivationPath,\n }).run();\n }\n delete this.calldataMetadatas[calldataIndex];\n }\n }\n }\n\n private mapCalldataPresence(\n presence: TypedDataCalldataParamPresence,\n ): CalldataParamPresence {\n switch (presence) {\n case TypedDataCalldataParamPresence.None:\n return CalldataParamPresence.None;\n case TypedDataCalldataParamPresence.Present:\n return CalldataParamPresence.Present;\n case TypedDataCalldataParamPresence.VerifyingContract:\n return CalldataParamPresence.VerifyingContract;\n default: {\n const unhandledPresence: never = presence;\n throw new Error(`Unhandled presence ${unhandledPresence}`);\n }\n }\n }\n\n private sanitizeDeviceIndex(\n descriptorIndex: number,\n deviceIndexes: DeviceAssetIndexes,\n ) {\n // If a token is missing, the device will replace it with a placeholder and use the next available index\n if (deviceIndexes.indexes[descriptorIndex] === undefined) {\n deviceIndexes.indexes[descriptorIndex] = deviceIndexes.nextIndex;\n deviceIndexes.nextIndex =\n (deviceIndexes.nextIndex + 1) % DEVICE_ASSETS_MAX;\n }\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,8BAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAQO,oCACPA,EAGO,oCAMPC,EAKO,2CACPC,EAAqC,qBAErCC,EAAoC,4DACpCC,EAAwC,gEACxCC,EAA+C,uEAC/CC,EAA0C,kEAC1CC,EAAwC,gEACxCC,EAIO,mEACPC,EAGO,0EACPC,EAAiC,sEAGjCC,EAA2C,gEAC3CC,EAAoC,4CACpCA,EAOO,4CAEPC,EAGO,4CACPC,EAAwC,qCAmBxC,MAAMC,EAAoB,EAYnB,MAAMjB,CAAyB,CAOpC,YACUkB,EACAC,EACAC,EACSC,EACfD,GACG,IAAI,iCAA+B,KAAK,IAAKA,CAAI,EACtD,CANQ,SAAAF,EACA,mBAAAC,EACA,UAAAC,EACS,2BAAAC,EAIjB,UAAWC,KAAe,KAAK,KAAK,OAClC,GACEA,EAAY,OAAS,WACrBA,EAAY,iBAAiB,sBAC7B,CACA,MAAMC,EAAM,UAAO,sBAAmBD,EAAY,MAAM,IAAI,CAAC,EACzDC,GAAO,OAAO,mBAChB,KAAK,WAAU,QAAK,OAAOA,CAAG,CAAC,GAEjC,KACF,CAEJ,CA1BQ,QAAyB,UACzB,kBAGJ,CAAC,EAwBL,MAAM,KAA0C,CAE1C,KAAK,KAAK,mBACZ,MAAM,KAAK,eAAe,KAAK,KAAK,iBAAiB,EAIvD,MAAMC,EAEU,KAAK,KAAK,iBAAiB,QAAQ,GAAG,MAClDA,IAAiB,QACnB,MAAM,KAAK,eAAeA,CAAY,EAGxC,MAAMC,KACJ,wBAAqD,CAAE,KAAM,MAAU,CAAC,EAQpEC,EAAQ,OAAO,QAAQ,KAAK,KAAK,KAAK,EAAE,KAAK,CAAC,CAACC,CAAI,EAAG,CAACC,CAAI,IAC/DD,EAAK,cAAcC,CAAI,CACzB,EACA,SAAW,CAACC,EAAYC,CAAM,IAAKJ,EAAO,CACxC,MAAMK,EAAmB,MAAM,KAAK,IAAI,YACtC,IAAI,oCAAkC,CACpC,QAAS,0BAAwB,KACjC,KAAMF,CACR,CAAC,CACH,EACA,GAAI,IAAC,0BAAuBE,CAAgB,EAC1C,OAAOA,EAGT,SAAW,CAACC,EAAWC,CAAS,IAAK,OAAO,QAAQH,CAAM,EAAG,CAC3D,MAAMI,EAAc,MAAM,KAAK,IAAI,YACjC,IAAI,oCAAkC,CACpC,QAAS,0BAAwB,MACjC,KAAMF,EACN,KAAMC,CACR,CAAC,CACH,EACA,GAAI,IAAC,0BAAuBC,CAAW,EACrC,OAAOA,CAEX,CACF,CAIA,GAAI,KAAK,KAAK,iBAAiB,OAAO,EAAG,CACvC,MAAMC,EAAmB,MAAM,KAAK,IAAI,YACtC,IAAI,6BAA2B,CAAE,KAAM,mBAAiB,UAAW,CAAC,CACtE,EACA,GAAI,IAAC,0BAAuBA,CAAgB,EAC1C,OAAOA,CAEX,CAGA,UAAWC,KAAS,KAAK,KAAK,OAAQ,CAEpC,MAAMC,EAAmB,MADF,KAAK,sBAAsBD,CAAK,EACT,IAAI,EAClD,GAAI,IAAC,0BAAuBC,CAAgB,EAC1C,OAAOA,CAEX,CAKA,GAAI,KAAK,KAAK,iBAAiB,OAAO,EAAG,CACvC,MAAMC,EAAmB,KAAK,KAAK,iBAAiB,QAAQ,EACtDC,EAA0B,MAAM,KAAK,IAAI,YAC7C,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,YACvB,YAAaD,EAAiB,YAAY,YAC1C,aAAcA,EAAiB,YAAY,aAC3C,UAAWA,EAAiB,YAAY,SAC1C,CAAC,CACH,EACA,GAAI,IAAC,0BAAuBC,CAAuB,EACjD,OAAOA,CAEX,CAGA,MAAMC,EAAoC,CAAE,QAAS,CAAC,EAAG,UAAW,CAAE,EACtE,UAAWJ,KAAS,KAAK,KAAK,QAAS,CAGrC,MAAMK,EAAkB,MAAM,KAAK,wBACjCL,EACAI,CACF,EACA,GAAIC,EAAgB,OAAO,EACzB,OAAOA,EAAgB,QAAQ,EAIjC,MAAMC,EAAiB,MAAM,KAAK,mBAAmBN,CAAK,EAC1D,GAAIM,EAAe,OAAO,EACxB,OAAOA,EAAe,QAAQ,EAKhC,MAAMC,EAAoB,MAAM,KAAK,YAAYP,EAAOI,CAAa,EACrE,GACEG,EAAkB,OAAO,GACzB,IAAC,0BAAuBA,EAAkB,QAAQ,CAAC,EAEnD,OAAOA,EAAkB,QAAQ,EAKnC,MAAMC,EAAoB,MADF,KAAK,sBAAsBR,CAAK,EACR,IAAI,EACpD,GAAI,IAAC,0BAAuBQ,CAAiB,EAC3C,OAAOA,EAQT,GAJA,MAAM,KAAK,6BAA6B,EAKtC,KAAK,KAAK,iBAAiB,OAAO,GAClCR,EAAM,iBAAiB,uBACvBA,EAAM,MAAM,SAAW,EACvB,CAIA,MAAMS,EAHU,OAAO,QACrB,KAAK,KAAK,iBAAiB,QAAQ,EAAE,OACvC,EAEG,OAAO,CAAC,CAACC,CAAI,IAAMA,EAAK,WAAW,GAAGV,EAAM,IAAI,KAAK,CAAC,EACtD,IAAI,CAAC,CAAC,CAAEW,CAAM,IAAMA,CAAM,EAC7B,UAAWA,KAAUF,EAAkB,CACrC,MAAMG,EAAsB,MAAM,KAAK,IAAI,YACzC,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,cACvB,KAAMD,EAAO,IACf,CAAC,CACH,EACA,GAAI,IAAC,0BAAuBC,CAAmB,EAC7C,OAAOA,EAGT,MAAMC,EAAyB,MAAM,KAAK,iBACxCF,EACAP,EACA,EACF,EACA,GAAI,IAAC,0BAAuBS,CAAsB,EAChD,OAAOA,CAEX,CACF,CACF,CAEA,OAAOxB,CACT,CAEA,MAAM,eAAe,CACnB,KAAAyB,EACA,QAAAC,EACA,YAAAC,CACF,EAA4B,CAW1B,OATIA,GACF,MAAM,KAAK,IAAI,YACb,IAAI,yBAAuB,CACzB,SAAUA,EAAY,eACtB,YAAaA,EAAY,OAC3B,CAAC,CACH,EAGMF,EAAM,CACZ,KAAK,uBAAqB,kBACxB,MAAM,IAAI,0BAAwB,KAAK,IAAK,CAC1C,QAAAC,EACA,eAAiB/B,GACf,IAAI,0BAAwB,CAC1B,QAASA,EAAK,YACd,aAAcA,EAAK,YACrB,CAAC,CACL,CAAC,EAAE,IAAI,EACP,MACF,KAAK,uBAAqB,WACxB,MAAM,IAAI,0BAAwB,KAAK,IAAK,CAC1C,QAAA+B,EACA,eAAiB/B,GACf,IAAI,0BAAwB,CAC1B,KAAMA,EAAK,YACX,aAAcA,EAAK,YACrB,CAAC,CACL,CAAC,EAAE,IAAI,EACP,MACF,KAAK,uBAAqB,MAC1B,KAAK,uBAAqB,IAC1B,KAAK,uBAAqB,aAC1B,KAAK,uBAAqB,OAC1B,KAAK,uBAAqB,gBAC1B,KAAK,uBAAqB,KAC1B,KAAK,uBAAqB,iBAC1B,KAAK,uBAAqB,8BAC1B,KAAK,uBAAqB,gBAC1B,KAAK,uBAAqB,qBAC1B,KAAK,uBAAqB,KAC1B,KAAK,uBAAqB,OACxB,MAAM,IAAI,MACR,gBAAgB8B,CAAI,mCACtB,EACF,QAAS,CACP,MAAMG,EAAuBH,EAC7B,MAAM,IAAI,MAAM,0BAA0BG,CAAa,EAAE,CAC3D,CACF,CACF,CAEA,sBAAsBjB,EAAmD,CACvE,OAAIA,EAAM,iBAAiB,qBAClB,IAAI,6BAA2B,KAAK,IAAK,CAC9C,KAAM,mBAAiB,KACvB,MAAOA,EAAM,MAAM,IACrB,CAAC,EACQA,EAAM,iBAAiB,sBACzB,IAAI,6BAA2B,KAAK,IAAK,CAC9C,KAAM,mBAAiB,MACvB,MAAOA,EAAM,MAAM,MACrB,CAAC,EAEM,IAAI,6BAA2B,KAAK,IAAK,CAC9C,KAAM,mBAAiB,MACvB,MAAOA,EAAM,MAAM,IACrB,CAAC,CAEL,CAEA,MAAM,wBACJA,EACAI,EAC+D,CAC/D,GAAI,KAAK,KAAK,iBAAiB,OAAO,EAAG,CACvC,MAAMO,EAAS,KAAK,KAAK,iBAAiB,QAAQ,EAAE,QAAQX,EAAM,IAAI,EAGtE,GACEW,IAAW,SACVA,EAAO,OAAS,UAAYA,EAAO,OAAS,UAC7CP,EAAc,QAAQO,EAAO,UAAU,IAAM,OAC7C,CACA,MAAMO,EAAkBP,EAAO,WAEzBQ,EADS,KAAK,KAAK,iBAAiB,QAAQ,EAAE,OAC/BD,CAAe,EACpC,GAAIC,IAAU,OACZ,OAAO,UAGT,MAAMC,EAAyB,MAAM,KAAK,IAAI,YAC5C,IAAI,iCAA+B,CAAE,QAASD,CAAM,CAAC,CACvD,EACA,GAAI,IAAC,0BAAuBC,CAAsB,EAChD,OAAO,QAAM,GAAGA,CAAsB,EAExC,GAAI,CAAE,WAAYC,CAAY,EAAID,EAAuB,KACzDhB,EAAc,WAAaiB,EAAc,GAAKxC,EAI1C,OAAOqC,CAAe,IAAM,mCAC9BG,EAAc,kCAGhBjB,EAAc,QAAQ,OAAOc,CAAe,CAAC,EAAIG,CACnD,CACF,CACA,OAAO,SACT,CAEA,MAAc,mBACZrB,EAC+D,CAC/D,GAAI,KAAK,KAAK,iBAAiB,OAAO,GAAK,KAAK,QAAQ,OAAO,EAAG,CAChE,MAAMsB,EAAU,KAAK,KAAK,iBAAiB,QAAQ,EAC7CX,EAASW,EAAQ,QAAQtB,EAAM,IAAI,EACnCuB,EAAUD,EAAQ,sBAAsBtB,EAAM,IAAI,EACxD,GACEW,IAAW,QACXA,EAAO,OAAS,gBAChBY,IAAY,OACZ,CACA,MAAMC,EAAqB,MAAM,KAAK,IAAI,YACxC,IAAI,qBACN,EACA,GAAI,IAAC,0BAAuBA,CAAkB,EAC5C,SAAO,QAAKA,CAAkB,EAGhC,MAAMF,EAAU,MAAM,KAAK,cAAc,gBACvC,CACE,QAAS,KAAK,QAAQ,QAAQ,EAC9B,QAAAC,EACA,UAAWC,EAAmB,KAAK,UACnC,MAAOb,EAAO,MACd,QAASA,EAAO,QAChB,cAAe,KAAK,KAAK,aAC3B,EACA,uBAAqB,YACvB,EACA,GAAIW,EAAQ,OAAS,uBAAqB,aAAc,CAClDA,EAAQ,aACV,MAAM,KAAK,IAAI,YACb,IAAI,yBAAuB,CACzB,SAAUA,EAAQ,YAAY,eAC9B,YAAaA,EAAQ,YAAY,OACnC,CAAC,CACH,EAEF,MAAMG,EAAoB,MAAM,IAAI,0BAClC,KAAK,IACL,CACE,QAASH,EAAQ,QACjB,eAAiBtC,GACf,IAAI,4BAA0B,CAC5B,KAAMA,EAAK,YACX,aAAcA,EAAK,YACrB,CAAC,CACL,CACF,EAAE,IAAI,EACN,GAAI,IAAC,0BAAuByC,CAAiB,EAC3C,SAAO,QAAKA,CAAiB,CAEjC,CACF,CACF,CACA,OAAO,SACT,CAEA,MAAM,YACJzB,EACAI,EAC+D,CAC/D,GAAI,KAAK,KAAK,iBAAiB,OAAO,EAAG,CACvC,MAAMO,EAAS,KAAK,KAAK,iBAAiB,QAAQ,EAAE,QAAQX,EAAM,IAAI,EACtE,GAAIW,IAAW,OACb,OAAO,UAGT,MAAMe,EAAkB,MAAM,KAAK,iBACjCf,EACAP,EACA,EACF,EACA,OAAO,QAAM,GAAGsB,CAAe,CACjC,CACA,OAAO,SACT,CAEA,MAAM,iBACJf,EACAP,EACAuB,EACwD,CACxD,OAAQhB,EAAO,KAAM,CACnB,IAAK,eACH,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,YACvB,UAAAgB,EACA,YAAahB,EAAO,YACpB,uBAAwBA,EAAO,uBAC/B,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,WACH,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,SACvB,UAAAgB,EACA,YAAahB,EAAO,YACpB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,MACH,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,IACvB,UAAAgB,EACA,YAAahB,EAAO,YACpB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,QACH,YAAK,oBAAoBA,EAAO,WAAYP,CAAa,EAClD,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,MACvB,UAAAuB,EACA,WAAYvB,EAAc,QAAQO,EAAO,UAAU,EACnD,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,SACH,YAAK,oBAAoBA,EAAO,WAAYP,CAAa,EAClD,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,OACvB,UAAAuB,EACA,YAAahB,EAAO,YACpB,WAAYP,EAAc,QAAQO,EAAO,UAAU,EACnD,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,iBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,cACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,kBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,eACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,mBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,gBACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,oBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,gBACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,oBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,iBACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,IAAK,kBACH,aAAM,KAAK,qBAAqBA,EAAO,aAAa,EAC7C,MAAM,KAAK,IAAI,YACpB,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,eACvB,UAAAgB,EACA,cAAehB,EAAO,cACtB,UAAWA,EAAO,SACpB,CAAC,CACH,EACF,QAAS,CACP,MAAMiB,EAAuBjB,EAC7B,MAAM,IAAI,MACR,gEAAgEiB,CAAa,EAC/E,CACF,CACF,CACF,CAEA,MAAc,qBACZC,EAC+D,CAC/D,GAAI,KAAK,KAAK,iBAAiB,OAAO,EAAG,CAEvC,GAAI,KAAK,kBAAkBA,CAAa,IAAM,OAE5C,YAAK,kBAAkBA,CAAa,EAAG,mBAChC,UAIT,MAAMC,EACJ,KAAK,KAAK,iBAAiB,QAAQ,EAAE,UAAUD,CAAa,EAC9D,GAAIC,IAAkB,OACpB,OAAO,UAcT,MAAMC,EAVkB,CACtBD,EAAc,OAAO,UACrBA,EAAc,OAAO,aACnB,iCAA+B,QACjCA,EAAc,OAAO,YACrBA,EAAc,OAAO,aACrBA,EAAc,OAAO,WACrBA,EAAc,OAAO,cACnB,iCAA+B,OACnC,EACqC,OAAQE,GAAMA,CAAC,EAAE,OACtD,YAAK,kBAAkBH,CAAa,EAAI,CACtC,iBAAkBE,EAAe,EACjC,SAAU,KAAK,KAAK,kBAAkBF,CAAa,CACrD,EAGO,QAAM,GACX,MAAM,KAAK,IAAI,YACb,IAAI,6BAA2B,CAC7B,KAAM,mBAAiB,aACvB,UAAW,GACX,cAAeA,EACf,UAAWC,EAAc,OAAO,UAChC,WAAY,KAAK,oBACfA,EAAc,OAAO,UACvB,EACA,YAAaA,EAAc,OAAO,YAClC,aAAcA,EAAc,OAAO,aACnC,WAAYA,EAAc,OAAO,WACjC,YAAa,KAAK,oBAChBA,EAAc,OAAO,WACvB,EACA,UAAWA,EAAc,OAAO,SAClC,CAAC,CACH,CACF,CACF,CACA,OAAO,SACT,CAEA,MAAc,8BAA+B,CAC3C,UAAWD,KAAiB,KAAK,kBAAmB,CAClD,MAAMI,EAAW,KAAK,kBAAkBJ,CAAa,EACjDI,EAAS,mBAAqB,IAG5BA,EAAS,WAAa,QACxB,MAAM,KAAK,sBAAsB,CAC/B,SAAUA,EAAS,SACnB,eAAgB,KAAK,KAAK,cAC5B,CAAC,EAAE,IAAI,EAET,OAAO,KAAK,kBAAkBJ,CAAa,EAE/C,CACF,CAEQ,oBACNK,EACuB,CACvB,OAAQA,EAAU,CAChB,KAAK,iCAA+B,KAClC,OAAO,wBAAsB,KAC/B,KAAK,iCAA+B,QAClC,OAAO,wBAAsB,QAC/B,KAAK,iCAA+B,kBAClC,OAAO,wBAAsB,kBAC/B,QAAS,CACP,MAAMC,EAA2BD,EACjC,MAAM,IAAI,MAAM,sBAAsBC,CAAiB,EAAE,CAC3D,CACF,CACF,CAEQ,oBACNjB,EACAd,EACA,CAEIA,EAAc,QAAQc,CAAe,IAAM,SAC7Cd,EAAc,QAAQc,CAAe,EAAId,EAAc,UACvDA,EAAc,WACXA,EAAc,UAAY,GAAKvB,EAEtC,CACF",
6
+ "names": ["ProvideEIP712ContextTask_exports", "__export", "ProvideEIP712ContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_purify_ts", "import_GetChallengeCommand", "import_ProvideProxyInfoCommand", "import_ProvideTokenInformationCommand", "import_ProvideTrustedNameCommand", "import_ProvideWeb3CheckCommand", "import_SendEIP712FilteringCommand", "import_SendEIP712StructDefinitionCommand", "import_SendEIP712StructImplemCommand", "import_SendEIP712StructImplemTask", "import_Types", "import_ProvideTransactionContextsTask", "import_SendPayloadInChunksTask", "DEVICE_ASSETS_MAX", "api", "contextModule", "args", "provideContextFactory", "domainValue", "val", "proxyContext", "result", "types", "aKey", "bKey", "structName", "fields", "structNameResult", "fieldName", "fieldType", "fieldResult", "activationResult", "value", "domainImplResult", "clearSignContext", "messageInfoFilterResult", "deviceIndexes", "maybeTokenError", "maybeNameError", "maybeFilterResult", "messageImplResult", "discardedFilters", "path", "filter", "discardedPathResult", "provideFilteringResult", "type", "payload", "certificate", "uncoveredType", "descriptorIndex", "token", "provideTokenInfoResult", "deviceIndex", "context", "address", "getChallengeResult", "provideNameResult", "filteringResult", "discarded", "unhandledType", "calldataIndex", "calldataInfos", "filtersCount", "f", "metadata", "presence", "unhandledPresence"]
7
7
  }
@@ -1,2 +1,2 @@
1
- "use strict";var b=require("@ledgerhq/context-module"),a=require("@ledgerhq/device-management-kit"),c=require("purify-ts"),E=require("../../app-binder/command/GetChallengeCommand"),g=require("../../app-binder/command/ProvideTokenInformationCommand"),h=require("../../app-binder/command/ProvideWeb3CheckCommand"),t=require("../../app-binder/command/SendEIP712FilteringCommand"),y=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),p=require("../../app-binder/command/SendEIP712StructImplemCommand"),q=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),d=require("../../typed-data/model/Types"),i=require("./ProvideEIP712ContextTask");describe("ProvideEIP712ContextTask",()=>{const e=(0,q.makeDeviceActionInternalApiMock)(),l={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn(),getWeb3Checks:vi.fn()},m={EIP712Domain:{name:new d.PrimitiveType("string","string",c.Nothing),chainId:new d.PrimitiveType("uint256","uint",(0,c.Just)(32)),verifyingContract:new d.PrimitiveType("address","address",c.Nothing)},PermitSingle:{details:new d.StructType("PermitDetails"),spender:new d.PrimitiveType("address","address",c.Nothing),sigDeadline:new d.PrimitiveType("uint256","uint",(0,c.Just)(32))},PermitDetails:{token:new d.PrimitiveType("address","address",c.Nothing),amount:new d.PrimitiveType("uint160","uint",(0,c.Just)(20)),expiration:new d.PrimitiveType("uint48","uint",(0,c.Just)(6)),nonce:new d.PrimitiveType("uint48","uint",(0,c.Just)(6))}},r=[{path:"",type:"",value:new d.TypedDataValueRoot("EIP712Domain")},{path:"name",type:"string",value:new d.TypedDataValueField(new TextEncoder().encode("Permit2"))},{path:"chainId",type:"uint256",value:new d.TypedDataValueField(Uint8Array.from([137]))},{path:"verifyingContract",type:"address",value:new d.TypedDataValueField((0,a.hexaStringToBuffer)("0x000000000022d473030f116ddee9f6b43ac78ba3"))}],f=[{path:"",type:"",value:new d.TypedDataValueRoot("PermitSingle")},{path:"details.token",type:"address",value:new d.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"details.amount",type:"uint160",value:new d.TypedDataValueField(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new d.TypedDataValueField(Uint8Array.from([18]))},{path:"details.nonce",type:"uint48",value:new d.TypedDataValueField(Uint8Array.from([0]))},{path:"spender",type:"address",value:new d.TypedDataValueField((0,a.hexaStringToBuffer)("0xec7be89e9d109e7e3fec59c222cf297125fefda2"))},{path:"sigDeadline",type:"uint256",value:new d.TypedDataValueField(Uint8Array.from([18]))}],x={type:"success",messageInfo:{displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},trustedNamesAddresses:{},tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"},"details.expiration":{displayName:"Approval expire",path:"details.expiration",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b",type:"datetime"},"details.token":{displayName:"Amount allowance",path:"details.token",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733",tokenIndex:0,type:"token"},spender:{displayName:"Approve to spender",path:"spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb",type:"raw"}}},C=new d.PrimitiveType("address","address",c.Nothing),A=new d.PrimitiveType("string","string",c.Nothing),S=new d.PrimitiveType("uint256","uint",(0,c.Just)(32)),I=new d.PrimitiveType("uint160","uint",(0,c.Just)(20)),w=new d.PrimitiveType("uint48","uint",(0,c.Just)(6)),R=n=>new d.StructType(n),k=n=>new y.SendEIP712StructDefinitionCommand({command:y.StructDefinitionCommand.Name,name:n}),o=(n,u)=>new y.SendEIP712StructDefinitionCommand({command:y.StructDefinitionCommand.Field,name:n,type:u}),v=n=>new p.SendEIP712StructImplemCommand({type:p.StructImplemType.ROOT,value:n}),P=n=>new p.SendEIP712StructImplemCommand({type:p.StructImplemType.ARRAY,value:n}),s=n=>new p.SendEIP712StructImplemCommand({type:p.StructImplemType.FIELD,value:{data:n,isLastChunk:!0}});beforeEach(()=>{vi.resetAllMocks()}),it("Send context with no clear signing context",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:c.Nothing,domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand.mock.calls).toHaveLength(24),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(k("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",A)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",C)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(k("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",C)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",I)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",w)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",w)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(k("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",R("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",C)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(v("EIP712Domain")),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(v("PermitSingle")),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Send context with clear signing",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)(x),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})),e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand.mock.calls).toHaveLength(32),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(k("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",A)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",C)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(k("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",C)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",I)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",w)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",w)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(k("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",R("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",C)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(v("EIP712Domain")),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"})),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(v("PermitSingle")),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(new g.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(new g.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand.mock.calls[24][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand.mock.calls[25][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[26][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Datetime,discarded:!1,displayName:"Approval expire",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b"})),expect(e.sendCommand.mock.calls[27][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[28][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[29][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Approve to spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb"})),expect(e.sendCommand.mock.calls[30][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[31][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Both tokens unavailable",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:x.messageInfo,filters:x.filters,trustedNamesAddresses:{},tokens:{}}),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand).not.toHaveBeenCalledWith(new g.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand).not.toHaveBeenCalledWith(new g.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:1,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("First token unavailable",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:x.messageInfo,filters:x.filters,trustedNamesAddresses:{},tokens:{255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"}}),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Second token unavailable",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:x.messageInfo,filters:x.filters,trustedNamesAddresses:{},tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"}}),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:0,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Filter with trusted name",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:x.messageInfo,filters:{"details.token":{displayName:"Amount allowance",path:"details.token",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733",types:["contract"],sources:["local","ens"],typesAndSourcesPayload:"010203010002",type:"trusted-name"}},trustedNamesAddresses:{"details.token":"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"},tokens:{}}),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{challenge:"0x42"}})),l.getContext.mockResolvedValue({type:b.ClearSignContextType.TRUSTED_NAME,payload:"0x01020304"}),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand).toHaveBeenCalledWith(new E.GetChallengeCommand),expect(l.getContext).toHaveBeenCalledWith({type:b.ClearSignContextType.TRUSTED_NAME,chainId:137,address:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",types:["contract"],sources:["local","ens"],challenge:"0x42"}),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.TrustedName,discarded:!1,displayName:"Amount allowance",typesAndSourcesPayload:"010203010002",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"}))}),it("Filter with trusted name and certificate",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:x.messageInfo,filters:{"details.token":{displayName:"Amount allowance",path:"details.token",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733",types:["contract"],sources:["local","ens"],typesAndSourcesPayload:"010203010002",type:"trusted-name"}},trustedNamesAddresses:{"details.token":"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"},tokens:{}}),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{challenge:"0x42"}})),l.getContext.mockResolvedValue({type:b.ClearSignContextType.TRUSTED_NAME,certificate:{keyUsageNumber:7,payload:new Uint8Array(3).fill(42)},payload:"0x01020304"}),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand).toHaveBeenCalledWith(new E.GetChallengeCommand),expect(l.getContext).toHaveBeenCalledWith({type:b.ClearSignContextType.TRUSTED_NAME,chainId:137,address:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",types:["contract"],sources:["local","ens"],challenge:"0x42"}),expect(e.sendCommand).toHaveBeenCalledWith(new a.LoadCertificateCommand({keyUsage:7,certificate:new Uint8Array(3).fill(42)})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.TrustedName,discarded:!1,displayName:"Amount allowance",typesAndSourcesPayload:"010203010002",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"}))}),it("Provide Web3Check",async()=>{const u={web3Check:{type:b.ClearSignContextType.WEB3_CHECK,payload:"0x010203"},types:m,domain:r,message:f,clearSignContext:c.Nothing,domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,u).run(),expect(e.sendCommand).toHaveBeenCalledWith(new h.ProvideWeb3CheckCommand({payload:(0,a.hexaStringToBuffer)("0x0003010203"),isFirstChunk:!0}))}),it("Provide Web3Check and certificate",async()=>{const n={type:b.ClearSignContextType.WEB3_CHECK,certificate:{keyUsageNumber:3,payload:new Uint8Array(3).fill(42)},payload:"0x010203"},u={web3Check:n,types:m,domain:r,message:f,clearSignContext:c.Nothing,domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,u).run(),expect(e.sendCommand).toHaveBeenCalledWith(new a.LoadCertificateCommand({keyUsage:3,certificate:n.certificate.payload})),expect(e.sendCommand).toHaveBeenCalledWith(new h.ProvideWeb3CheckCommand({payload:(0,a.hexaStringToBuffer)("0x0003010203"),isFirstChunk:!0}))}),it("Error when providing tokens",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)(x),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new i.ProvideEIP712ContextTask(e,l,n).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct definitions",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:(0,c.Just)(x),domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new i.ProvideEIP712ContextTask(e,l,n).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct implementations",async()=>{const n={web3Check:null,types:m,domain:r,message:f,clearSignContext:c.Nothing,domainHash:"0x",messageHash:"0x"};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")})).mockResolvedValue((0,a.CommandResultFactory)({data:void 0}));const u=new i.ProvideEIP712ContextTask(e,l,n).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Send struct array",async()=>{const n={web3Check:null,domainHash:"0x",messageHash:"0x",types:{},domain:[],message:[{path:"spenders",type:"address[]",value:new d.TypedDataValueArray(1)},{path:"spenders.[]",type:"address",value:new d.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"beneficiaries",type:"address[]",value:new d.TypedDataValueArray(0)}],clearSignContext:(0,c.Just)({type:"success",messageInfo:{displayName:"Permit2",filtersCount:2,signature:"sig"},trustedNamesAddresses:{},tokens:{},filters:{"spenders.[]":{displayName:"Spender",path:"spenders.[]",signature:"sig",type:"raw"},"beneficiaries.[]":{displayName:"Beneficiary",path:"beneficiaries.[]",signature:"sig",type:"raw"}}})};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,l,n).run(),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:2,signature:"sig"})),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(P(1)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Spender",signature:"sig"})),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(P(0)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.DiscardedPath,path:"beneficiaries.[]"})),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!0,displayName:"Beneficiary",signature:"sig"}))})});
1
+ "use strict";var p=require("@ledgerhq/context-module"),a=require("@ledgerhq/device-management-kit"),c=require("purify-ts"),T=require("../../app-binder/command/ProvideProxyInfoCommand"),v=require("../../app-binder/command/ProvideTokenInformationCommand"),t=require("../../app-binder/command/SendEIP712FilteringCommand"),g=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),C=require("../../app-binder/command/SendEIP712StructImplemCommand"),R=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),n=require("../../typed-data/model/Types"),i=require("./ProvideEIP712ContextTask");describe("ProvideEIP712ContextTask",()=>{const e=(0,R.makeDeviceActionInternalApiMock)(),l=vi.fn(),r={getFieldContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn(),getSolanaContext:vi.fn()},f={EIP712Domain:{name:new n.PrimitiveType("string","string",c.Nothing),chainId:new n.PrimitiveType("uint256","uint",(0,c.Just)(32)),verifyingContract:new n.PrimitiveType("address","address",c.Nothing)},PermitSingle:{details:new n.StructType("PermitDetails"),spender:new n.PrimitiveType("address","address",c.Nothing),sigDeadline:new n.PrimitiveType("uint256","uint",(0,c.Just)(32))},PermitDetails:{token:new n.PrimitiveType("address","address",c.Nothing),amount:new n.PrimitiveType("uint160","uint",(0,c.Just)(20)),expiration:new n.PrimitiveType("uint48","uint",(0,c.Just)(6)),nonce:new n.PrimitiveType("uint48","uint",(0,c.Just)(6))}},m=[{path:"",type:"",value:new n.TypedDataValueRoot("EIP712Domain")},{path:"name",type:"string",value:new n.TypedDataValueField(new TextEncoder().encode("Permit2"))},{path:"chainId",type:"uint256",value:new n.TypedDataValueField(Uint8Array.from([137]))},{path:"verifyingContract",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x000000000022d473030f116ddee9f6b43ac78ba3"))}],x=[{path:"",type:"",value:new n.TypedDataValueRoot("PermitSingle")},{path:"details.token",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"details.amount",type:"uint160",value:new n.TypedDataValueField(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new n.TypedDataValueField(Uint8Array.from([18]))},{path:"details.nonce",type:"uint48",value:new n.TypedDataValueField(Uint8Array.from([0]))},{path:"spender",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0xec7be89e9d109e7e3fec59c222cf297125fefda2"))},{path:"sigDeadline",type:"uint256",value:new n.TypedDataValueField(Uint8Array.from([18]))}],b={type:"success",messageInfo:{displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},trustedNamesAddresses:{},calldatas:{},proxy:void 0,tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"},"details.expiration":{displayName:"Approval expire",path:"details.expiration",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b",type:"datetime"},"details.token":{displayName:"Amount allowance",path:"details.token",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733",tokenIndex:0,type:"token"},spender:{displayName:"Approve to spender",path:"spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb",type:"raw"}}},y=new n.PrimitiveType("address","address",c.Nothing),E=new n.PrimitiveType("string","string",c.Nothing),S=new n.PrimitiveType("uint256","uint",(0,c.Just)(32)),h=new n.PrimitiveType("uint160","uint",(0,c.Just)(20)),w=new n.PrimitiveType("uint48","uint",(0,c.Just)(6)),A=d=>new n.StructType(d),k=d=>new g.SendEIP712StructDefinitionCommand({command:g.StructDefinitionCommand.Name,name:d}),o=(d,u)=>new g.SendEIP712StructDefinitionCommand({command:g.StructDefinitionCommand.Field,name:d,type:u}),I=d=>new C.SendEIP712StructImplemCommand({type:C.StructImplemType.ROOT,value:d}),P=d=>new C.SendEIP712StructImplemCommand({type:C.StructImplemType.ARRAY,value:d}),s=d=>new C.SendEIP712StructImplemCommand({type:C.StructImplemType.FIELD,value:{data:d,isLastChunk:!0}});beforeEach(()=>{vi.resetAllMocks(),l.mockReturnValue({run:async()=>{}})}),it("Send context with no clear signing context",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:c.Nothing,calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand.mock.calls).toHaveLength(24),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(k("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",E)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",y)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(k("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",y)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",h)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",w)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",w)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(k("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",A("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",y)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(I("EIP712Domain")),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(I("PermitSingle")),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Send context with transaction check",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:c.Nothing,calldatasContexts:{},transactionChecks:{type:p.ClearSignContextType.TRANSACTION_CHECK,payload:"transactionCheck",certificate:{keyUsageNumber:1,payload:new Uint8Array([1,2,3])}}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand.mock.calls).toHaveLength(25)}),it("Send context with clear signing",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)(b),calldatasContexts:{}};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})),e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand.mock.calls).toHaveLength(32),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(k("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",E)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",y)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(k("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",y)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",h)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",w)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",w)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(k("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",A("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",y)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(I("EIP712Domain")),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"})),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(I("PermitSingle")),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(new v.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(new v.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand.mock.calls[24][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand.mock.calls[25][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[26][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Datetime,discarded:!1,displayName:"Approval expire",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b"})),expect(e.sendCommand.mock.calls[27][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[28][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[29][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Approve to spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb"})),expect(e.sendCommand.mock.calls[30][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[31][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Both tokens unavailable",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)({type:"success",messageInfo:b.messageInfo,filters:b.filters,trustedNamesAddresses:{},calldatas:{},proxy:void 0,tokens:{}}),calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand).not.toHaveBeenCalledWith(new v.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand).not.toHaveBeenCalledWith(new v.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:1,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Provide calldata filters",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)({type:"success",messageInfo:b.messageInfo,filters:{"details.amount":{displayName:"Value",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:0,type:"calldata-value"},"details.expiration":{displayName:"Callee",path:"details.expiration",signature:"304502201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:0,type:"calldata-callee"},spender:{displayName:"Spender",path:"spender",signature:"304602201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:0,type:"calldata-spender"},"details.token":{displayName:"Chain ID",path:"details.token",signature:"304702201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:0,type:"calldata-chain-id"},"details.nonce":{displayName:"Chain ID",path:"details.nonce",signature:"304802201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:1,type:"calldata-selector"},sigDeadline:{displayName:"Amount",path:"sigDeadline",signature:"304902201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",calldataIndex:1,type:"calldata-amount"}},trustedNamesAddresses:{},calldatas:{0:{filter:{calldataIndex:0,displayName:"Transaction",valueFlag:!0,calleeFlag:p.TypedDataCalldataParamPresence.Present,chainIdFlag:!1,selectorFlag:!1,amountFlag:!0,spenderFlag:p.TypedDataCalldataParamPresence.VerifyingContract,signature:"3045022100d8496ab69152efeef6a923a3ebd225334ad65dcb985814994243be7bc09bf27e02206314835816908dd6d51d3cbb0f9465d91d7ddc9104b34dd6c4247f65c551836e"},subset:{chainId:4660,data:"0x6a76120200000000000000000000000023f8abfc2824c397ccb3da89ae772984107ddb99",from:"0x8ceb23fd6bc0add59e62ac25578270cff1b9f619",selector:"0x778899aa",to:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",value:4200000000000000n}},1:{filter:{calldataIndex:1,displayName:"Transaction",valueFlag:!0,calleeFlag:p.TypedDataCalldataParamPresence.Present,chainIdFlag:!1,selectorFlag:!1,amountFlag:!0,spenderFlag:p.TypedDataCalldataParamPresence.VerifyingContract,signature:"3045932100d8496ab69152efeef6a923a3ebd225334ad65dcb985814994243be7bc09bf27e02206314835816908dd6d51d3cbb0f9465d91d7ddc9104b34dd6c4247f65c551836e"},subset:{chainId:4661,data:"0x6a76120200000000000000000000000023f8abfc2824c397ccb3da89ae772984107ddb99",from:"0x8ceb23fd6bc0add59e62ac25578270cff1b9f619",selector:"0x778899aa",to:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",value:4300000000000000n}}},proxy:void 0,tokens:{}}),calldatasContexts:{0:[]}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(l).toHaveBeenCalledTimes(1),expect(l).toHaveBeenCalledWith({contexts:[],derivationPath:"44'/60'/0'/0/0"}),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataInfo,discarded:!1,calldataIndex:0,valueFlag:!0,calleeFlag:t.CalldataParamPresence.Present,chainIdFlag:!1,selectorFlag:!1,amountFlag:!0,spenderFlag:t.CalldataParamPresence.VerifyingContract,signature:"3045022100d8496ab69152efeef6a923a3ebd225334ad65dcb985814994243be7bc09bf27e02206314835816908dd6d51d3cbb0f9465d91d7ddc9104b34dd6c4247f65c551836e"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataValue,discarded:!1,calldataIndex:0,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataCallee,discarded:!1,calldataIndex:0,signature:"304502201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataSpender,discarded:!1,calldataIndex:0,signature:"304602201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataChainId,discarded:!1,calldataIndex:0,signature:"304702201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataInfo,discarded:!1,calldataIndex:1,valueFlag:!0,calleeFlag:t.CalldataParamPresence.Present,chainIdFlag:!1,selectorFlag:!1,amountFlag:!0,spenderFlag:t.CalldataParamPresence.VerifyingContract,signature:"3045932100d8496ab69152efeef6a923a3ebd225334ad65dcb985814994243be7bc09bf27e02206314835816908dd6d51d3cbb0f9465d91d7ddc9104b34dd6c4247f65c551836e"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataSelector,discarded:!1,calldataIndex:1,signature:"304802201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.CalldataAmount,discarded:!1,calldataIndex:1,signature:"304902201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("First token unavailable",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)({type:"success",messageInfo:b.messageInfo,filters:b.filters,trustedNamesAddresses:{},calldatas:{},proxy:void 0,tokens:{255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"}}),calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Second token unavailable",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)({type:"success",messageInfo:b.messageInfo,filters:b.filters,trustedNamesAddresses:{},calldatas:{},proxy:void 0,tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"}}),calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:0,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Provide proxy",async()=>{const d={type:p.ClearSignContextType.PROXY_INFO,payload:"0x010203"},u={...b,proxy:d},q={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)(u),calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new i.ProvideEIP712ContextTask(e,r,q,l).run(),expect(e.sendCommand).toHaveBeenCalledWith(new T.ProvideProxyInfoCommand({data:(0,a.hexaStringToBuffer)("0x0003010203"),isFirstChunk:!0}))}),it("Error when providing tokens",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)(b),calldatasContexts:{}};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new i.ProvideEIP712ContextTask(e,r,d,l).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct definitions",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:(0,c.Just)(b),calldatasContexts:{}};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new i.ProvideEIP712ContextTask(e,r,d,l).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct implementations",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:f,domain:m,message:x,clearSignContext:c.Nothing,calldatasContexts:{}};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")})).mockResolvedValue((0,a.CommandResultFactory)({data:void 0}));const u=new i.ProvideEIP712ContextTask(e,r,d,l).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Send struct array",async()=>{const d={deviceModelId:a.DeviceModelId.STAX,derivationPath:"44'/60'/0'/0/0",types:{},domain:[],message:[{path:"spenders",type:"address[]",value:new n.TypedDataValueArray(1)},{path:"spenders.[]",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"beneficiaries",type:"address[]",value:new n.TypedDataValueArray(0)}],clearSignContext:(0,c.Just)({type:"success",messageInfo:{displayName:"Permit2",filtersCount:2,signature:"sig"},trustedNamesAddresses:{},calldatas:{},proxy:void 0,tokens:{},filters:{"spenders.[]":{displayName:"Spender",path:"spenders.[]",signature:"sig",type:"raw"},"beneficiaries.[]":{displayName:"Beneficiary",path:"beneficiaries.[]",signature:"sig",type:"raw"}}}),calldatasContexts:{}};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new i.ProvideEIP712ContextTask(e,r,d,l).run(),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:2,signature:"sig"})),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(P(1)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Spender",signature:"sig"})),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(P(0)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.DiscardedPath,path:"beneficiaries.[]"})),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!0,displayName:"Beneficiary",signature:"sig"}))})});
2
2
  //# sourceMappingURL=ProvideEIP712ContextTask.test.js.map