@ledgerhq/device-signer-kit-ethereum 1.0.0 → 1.1.0

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 (997) hide show
  1. package/README.md +19 -19
  2. package/lib/cjs/api/SignerEth.js +2 -0
  3. package/lib/cjs/api/SignerEth.js.map +7 -0
  4. package/lib/cjs/api/SignerEthBuilder.js +2 -0
  5. package/lib/cjs/api/SignerEthBuilder.js.map +7 -0
  6. package/lib/cjs/api/SignerEthBuilder.test.js +2 -0
  7. package/lib/cjs/api/SignerEthBuilder.test.js.map +7 -0
  8. package/lib/cjs/api/app-binder/GetAddressCommandTypes.js +2 -3
  9. package/lib/cjs/api/app-binder/GetAddressCommandTypes.js.map +7 -1
  10. package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.js +2 -3
  11. package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.js.map +7 -1
  12. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js +2 -3
  13. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +7 -1
  14. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +2 -3
  15. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +7 -1
  16. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +2 -3
  17. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +7 -1
  18. package/lib/cjs/api/index.js +2 -26
  19. package/lib/cjs/api/index.js.map +7 -1
  20. package/lib/cjs/api/model/Address.js +2 -3
  21. package/lib/cjs/api/model/Address.js.map +7 -1
  22. package/lib/cjs/api/model/AddressOptions.js +2 -3
  23. package/lib/cjs/api/model/AddressOptions.js.map +7 -1
  24. package/lib/cjs/api/model/Signature.js +2 -3
  25. package/lib/cjs/api/model/Signature.js.map +7 -1
  26. package/lib/cjs/api/model/Transaction.js +2 -3
  27. package/lib/cjs/api/model/Transaction.js.map +7 -1
  28. package/lib/cjs/api/model/TransactionOptions.js +2 -3
  29. package/lib/cjs/api/model/TransactionOptions.js.map +7 -1
  30. package/lib/cjs/api/model/TypedData.js +2 -4
  31. package/lib/cjs/api/model/TypedData.js.map +7 -1
  32. package/lib/cjs/index.js +2 -20
  33. package/lib/cjs/index.js.map +7 -1
  34. package/lib/cjs/internal/DefaultSignerEth.js +2 -0
  35. package/lib/cjs/internal/DefaultSignerEth.js.map +7 -0
  36. package/lib/cjs/internal/DefaultSignerEth.test.js +2 -0
  37. package/lib/cjs/internal/DefaultSignerEth.test.js.map +7 -0
  38. package/lib/cjs/internal/address/di/addressModule.js +2 -11
  39. package/lib/cjs/internal/address/di/addressModule.js.map +7 -1
  40. package/lib/cjs/internal/address/di/addressModule.test.js +2 -0
  41. package/lib/cjs/internal/address/di/addressModule.test.js.map +7 -0
  42. package/lib/cjs/internal/address/di/addressTypes.js +2 -7
  43. package/lib/cjs/internal/address/di/addressTypes.js.map +7 -1
  44. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js +2 -38
  45. package/lib/cjs/internal/address/use-case/GetAddressUseCase.js.map +7 -1
  46. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js +2 -0
  47. package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js.map +7 -0
  48. package/lib/cjs/internal/app-binder/EthAppBinder.js +2 -100
  49. package/lib/cjs/internal/app-binder/EthAppBinder.js.map +7 -1
  50. package/lib/cjs/internal/app-binder/EthAppBinder.test.js +2 -0
  51. package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +7 -0
  52. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js +2 -88
  53. package/lib/cjs/internal/app-binder/command/GetAddressCommand.js.map +7 -1
  54. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js +2 -0
  55. package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js.map +7 -0
  56. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +2 -39
  57. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +7 -1
  58. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +2 -0
  59. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +7 -0
  60. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js +2 -0
  61. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js.map +7 -0
  62. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js +2 -0
  63. package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js.map +7 -0
  64. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js +2 -50
  65. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js.map +7 -1
  66. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js +2 -0
  67. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +7 -0
  68. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js +2 -34
  69. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js.map +7 -1
  70. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js +2 -0
  71. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +7 -0
  72. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +2 -0
  73. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +7 -0
  74. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +2 -0
  75. package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +7 -0
  76. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js +2 -0
  77. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +7 -0
  78. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +2 -0
  79. package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +7 -0
  80. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js +2 -0
  81. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js.map +7 -0
  82. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js +2 -0
  83. package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +7 -0
  84. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +2 -69
  85. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +7 -1
  86. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +2 -0
  87. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +7 -0
  88. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +2 -131
  89. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +7 -1
  90. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +2 -0
  91. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +7 -0
  92. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js +2 -51
  93. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +7 -1
  94. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +2 -0
  95. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +7 -0
  96. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js +2 -57
  97. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js.map +7 -1
  98. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js +7 -0
  99. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js.map +7 -0
  100. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js +2 -52
  101. package/lib/cjs/internal/app-binder/command/SetPluginCommand.js.map +7 -1
  102. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js +6 -0
  103. package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js.map +7 -0
  104. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js +2 -69
  105. package/lib/cjs/internal/app-binder/command/SignEIP712Command.js.map +7 -1
  106. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js +2 -0
  107. package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js.map +7 -0
  108. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js +2 -60
  109. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js.map +7 -1
  110. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js +2 -0
  111. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +7 -0
  112. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +2 -59
  113. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +7 -1
  114. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +2 -0
  115. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +7 -0
  116. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js +2 -0
  117. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js.map +7 -0
  118. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js +2 -0
  119. package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js.map +7 -0
  120. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js +2 -0
  121. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js.map +7 -0
  122. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js +2 -0
  123. package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js.map +7 -0
  124. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +2 -161
  125. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +7 -1
  126. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +2 -0
  127. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +7 -0
  128. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +2 -285
  129. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +7 -1
  130. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +2 -0
  131. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +7 -0
  132. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +2 -245
  133. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +7 -1
  134. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +2 -0
  135. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +7 -0
  136. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +2 -18
  137. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +7 -1
  138. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +2 -31
  139. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +7 -1
  140. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +2 -35
  141. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +7 -1
  142. package/lib/cjs/internal/app-binder/di/appBinderModule.js +2 -11
  143. package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +7 -1
  144. package/lib/cjs/internal/app-binder/di/appBinderTypes.js +2 -7
  145. package/lib/cjs/internal/app-binder/di/appBinderTypes.js.map +7 -1
  146. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +2 -72
  147. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +7 -1
  148. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +2 -0
  149. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +7 -0
  150. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +2 -31
  151. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +7 -1
  152. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +2 -0
  153. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +7 -0
  154. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +2 -188
  155. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +7 -1
  156. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +2 -0
  157. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +7 -0
  158. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +2 -112
  159. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +7 -1
  160. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +2 -0
  161. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +7 -0
  162. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +2 -0
  163. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +7 -0
  164. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +2 -0
  165. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +7 -0
  166. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +2 -0
  167. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +7 -0
  168. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +2 -0
  169. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +7 -0
  170. package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js +2 -0
  171. package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js.map +7 -0
  172. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js +2 -42
  173. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js.map +7 -1
  174. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js +2 -0
  175. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +7 -0
  176. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +2 -0
  177. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +7 -0
  178. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +2 -0
  179. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +7 -0
  180. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js +2 -53
  181. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js.map +7 -1
  182. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js +2 -0
  183. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +7 -0
  184. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +2 -53
  185. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +7 -1
  186. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +2 -0
  187. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +7 -0
  188. package/lib/cjs/internal/di.js +2 -27
  189. package/lib/cjs/internal/di.js.map +7 -1
  190. package/lib/cjs/internal/externalTypes.js +2 -9
  191. package/lib/cjs/internal/externalTypes.js.map +7 -1
  192. package/lib/cjs/internal/message/di/messageModule.js +2 -11
  193. package/lib/cjs/internal/message/di/messageModule.js.map +7 -1
  194. package/lib/cjs/internal/message/di/messageModule.test.js +2 -0
  195. package/lib/cjs/internal/message/di/messageModule.test.js.map +7 -0
  196. package/lib/cjs/internal/message/di/messageTypes.js +2 -7
  197. package/lib/cjs/internal/message/di/messageTypes.js.map +7 -1
  198. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +2 -38
  199. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +7 -1
  200. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +2 -0
  201. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +7 -0
  202. package/lib/cjs/internal/shared/utils/PayloadUtils.js +2 -0
  203. package/lib/cjs/internal/shared/utils/PayloadUtils.js.map +7 -0
  204. package/lib/cjs/internal/shared/utils/PayloadUtils.test.js +2 -0
  205. package/lib/cjs/internal/shared/utils/PayloadUtils.test.js.map +7 -0
  206. package/lib/cjs/internal/transaction/di/transactionModule.js +2 -17
  207. package/lib/cjs/internal/transaction/di/transactionModule.js.map +7 -1
  208. package/lib/cjs/internal/transaction/di/transactionModule.test.js +2 -0
  209. package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +7 -0
  210. package/lib/cjs/internal/transaction/di/transactionTypes.js +2 -9
  211. package/lib/cjs/internal/transaction/di/transactionTypes.js.map +7 -1
  212. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js +2 -60
  213. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +7 -1
  214. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js +2 -0
  215. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js.map +7 -0
  216. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js +2 -36
  217. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +7 -1
  218. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js +2 -0
  219. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js.map +7 -0
  220. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +2 -3
  221. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
  222. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +2 -41
  223. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
  224. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
  225. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
  226. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js +2 -3
  227. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
  228. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +2 -0
  229. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
  230. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
  231. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
  232. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js +2 -38
  233. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
  234. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
  235. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
  236. package/lib/cjs/internal/typed-data/di/typedDataModule.js +2 -13
  237. package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +7 -1
  238. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +2 -0
  239. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +7 -0
  240. package/lib/cjs/internal/typed-data/di/typedDataTypes.js +2 -8
  241. package/lib/cjs/internal/typed-data/di/typedDataTypes.js.map +7 -1
  242. package/lib/cjs/internal/typed-data/model/Types.js +2 -64
  243. package/lib/cjs/internal/typed-data/model/Types.js.map +7 -1
  244. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +2 -29
  245. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
  246. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js +2 -101
  247. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
  248. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
  249. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
  250. package/lib/cjs/internal/typed-data/service/TypedDataParser.js +2 -211
  251. package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +7 -1
  252. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +2 -0
  253. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
  254. package/lib/cjs/internal/typed-data/service/TypedDataParserService.js +2 -3
  255. package/lib/cjs/internal/typed-data/service/TypedDataParserService.js.map +7 -1
  256. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -42
  257. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
  258. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
  259. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
  260. package/lib/cjs/package.json +63 -0
  261. package/lib/esm/api/SignerEth.js +1 -0
  262. package/lib/esm/api/SignerEth.js.map +7 -0
  263. package/lib/esm/api/SignerEthBuilder.js +2 -0
  264. package/lib/esm/api/SignerEthBuilder.js.map +7 -0
  265. package/lib/esm/api/SignerEthBuilder.test.js +2 -0
  266. package/lib/esm/api/SignerEthBuilder.test.js.map +7 -0
  267. package/lib/esm/api/app-binder/GetAddressCommandTypes.js +1 -2
  268. package/lib/esm/api/app-binder/GetAddressCommandTypes.js.map +7 -1
  269. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js +1 -2
  270. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js.map +7 -1
  271. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js +1 -2
  272. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +7 -1
  273. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -2
  274. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +7 -1
  275. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -2
  276. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +7 -1
  277. package/lib/esm/api/index.js +2 -10
  278. package/lib/esm/api/index.js.map +7 -1
  279. package/lib/esm/api/model/Address.js +1 -2
  280. package/lib/esm/api/model/Address.js.map +7 -1
  281. package/lib/esm/api/model/AddressOptions.js +1 -2
  282. package/lib/esm/api/model/AddressOptions.js.map +7 -1
  283. package/lib/esm/api/model/Signature.js +1 -2
  284. package/lib/esm/api/model/Signature.js.map +7 -1
  285. package/lib/esm/api/model/Transaction.js +2 -2
  286. package/lib/esm/api/model/Transaction.js.map +7 -1
  287. package/lib/esm/api/model/TransactionOptions.js +1 -2
  288. package/lib/esm/api/model/TransactionOptions.js.map +7 -1
  289. package/lib/esm/api/model/TypedData.js +1 -3
  290. package/lib/esm/api/model/TypedData.js.map +7 -1
  291. package/lib/esm/index.js +2 -4
  292. package/lib/esm/index.js.map +7 -1
  293. package/lib/esm/internal/DefaultSignerEth.js +2 -0
  294. package/lib/esm/internal/DefaultSignerEth.js.map +7 -0
  295. package/lib/esm/internal/DefaultSignerEth.test.js +2 -0
  296. package/lib/esm/internal/DefaultSignerEth.test.js.map +7 -0
  297. package/lib/esm/internal/address/di/addressModule.js +2 -7
  298. package/lib/esm/internal/address/di/addressModule.js.map +7 -1
  299. package/lib/esm/internal/address/di/addressModule.test.js +2 -0
  300. package/lib/esm/internal/address/di/addressModule.test.js.map +7 -0
  301. package/lib/esm/internal/address/di/addressTypes.js +2 -4
  302. package/lib/esm/internal/address/di/addressTypes.js.map +7 -1
  303. package/lib/esm/internal/address/use-case/GetAddressUseCase.js +2 -35
  304. package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +7 -1
  305. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +2 -0
  306. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +7 -0
  307. package/lib/esm/internal/app-binder/EthAppBinder.js +2 -97
  308. package/lib/esm/internal/app-binder/EthAppBinder.js.map +7 -1
  309. package/lib/esm/internal/app-binder/EthAppBinder.test.js +2 -0
  310. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +7 -0
  311. package/lib/esm/internal/app-binder/command/GetAddressCommand.js +2 -84
  312. package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +7 -1
  313. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +2 -0
  314. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +7 -0
  315. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +2 -35
  316. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +7 -1
  317. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +2 -0
  318. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +7 -0
  319. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +2 -0
  320. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +7 -0
  321. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +2 -0
  322. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +7 -0
  323. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +2 -46
  324. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +7 -1
  325. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +2 -0
  326. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +7 -0
  327. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +2 -30
  328. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +7 -1
  329. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +2 -0
  330. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +7 -0
  331. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +2 -0
  332. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +7 -0
  333. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +2 -0
  334. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +7 -0
  335. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +2 -0
  336. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +7 -0
  337. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +2 -0
  338. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +7 -0
  339. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +2 -0
  340. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +7 -0
  341. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +2 -0
  342. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +7 -0
  343. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +2 -65
  344. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +7 -1
  345. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +2 -0
  346. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +7 -0
  347. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +2 -127
  348. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +7 -1
  349. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +2 -0
  350. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +7 -0
  351. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +2 -47
  352. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +7 -1
  353. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +2 -0
  354. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +7 -0
  355. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +2 -52
  356. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +7 -1
  357. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +7 -0
  358. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +7 -0
  359. package/lib/esm/internal/app-binder/command/SetPluginCommand.js +2 -47
  360. package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +7 -1
  361. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +6 -0
  362. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +7 -0
  363. package/lib/esm/internal/app-binder/command/SignEIP712Command.js +2 -65
  364. package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +7 -1
  365. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +2 -0
  366. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +7 -0
  367. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +2 -56
  368. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +7 -1
  369. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +2 -0
  370. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +7 -0
  371. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +2 -55
  372. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +7 -1
  373. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +2 -0
  374. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +7 -0
  375. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +2 -0
  376. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +7 -0
  377. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +2 -0
  378. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +7 -0
  379. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +2 -0
  380. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +7 -0
  381. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +2 -0
  382. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +7 -0
  383. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +2 -157
  384. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +7 -1
  385. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +2 -0
  386. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +7 -0
  387. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +2 -281
  388. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +7 -1
  389. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +2 -0
  390. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +7 -0
  391. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +2 -241
  392. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +7 -1
  393. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +2 -0
  394. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +7 -0
  395. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +2 -15
  396. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +7 -1
  397. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +2 -27
  398. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +7 -1
  399. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +2 -32
  400. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +7 -1
  401. package/lib/esm/internal/app-binder/di/appBinderModule.js +2 -7
  402. package/lib/esm/internal/app-binder/di/appBinderModule.js.map +7 -1
  403. package/lib/esm/internal/app-binder/di/appBinderTypes.js +2 -4
  404. package/lib/esm/internal/app-binder/di/appBinderTypes.js.map +7 -1
  405. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +2 -68
  406. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +7 -1
  407. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +2 -0
  408. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +7 -0
  409. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +2 -27
  410. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +7 -1
  411. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +2 -0
  412. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +7 -0
  413. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +2 -184
  414. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +7 -1
  415. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +2 -0
  416. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +7 -0
  417. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +2 -107
  418. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +7 -1
  419. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +2 -0
  420. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +7 -0
  421. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +2 -0
  422. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +7 -0
  423. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +2 -0
  424. package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +7 -0
  425. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js +2 -0
  426. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +7 -0
  427. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +2 -0
  428. package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +7 -0
  429. package/lib/esm/internal/app-binder/task/SendCommandInChunksTask.js +2 -0
  430. package/lib/esm/internal/app-binder/task/SendCommandInChunksTask.js.map +7 -0
  431. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.js +2 -38
  432. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.js.map +7 -1
  433. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js +2 -0
  434. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +7 -0
  435. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +2 -0
  436. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +7 -0
  437. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +2 -0
  438. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +7 -0
  439. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.js +2 -49
  440. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.js.map +7 -1
  441. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js +2 -0
  442. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +7 -0
  443. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js +2 -49
  444. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js.map +7 -1
  445. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js +2 -0
  446. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js.map +7 -0
  447. package/lib/esm/internal/di.js +2 -23
  448. package/lib/esm/internal/di.js.map +7 -1
  449. package/lib/esm/internal/externalTypes.js +2 -6
  450. package/lib/esm/internal/externalTypes.js.map +7 -1
  451. package/lib/esm/internal/message/di/messageModule.js +2 -7
  452. package/lib/esm/internal/message/di/messageModule.js.map +7 -1
  453. package/lib/esm/internal/message/di/messageModule.test.js +2 -0
  454. package/lib/esm/internal/message/di/messageModule.test.js.map +7 -0
  455. package/lib/esm/internal/message/di/messageTypes.js +2 -4
  456. package/lib/esm/internal/message/di/messageTypes.js.map +7 -1
  457. package/lib/esm/internal/message/use-case/SignMessageUseCase.js +2 -35
  458. package/lib/esm/internal/message/use-case/SignMessageUseCase.js.map +7 -1
  459. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js +2 -0
  460. package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js.map +7 -0
  461. package/lib/esm/internal/shared/utils/PayloadUtils.js +2 -0
  462. package/lib/esm/internal/shared/utils/PayloadUtils.js.map +7 -0
  463. package/lib/esm/internal/shared/utils/PayloadUtils.test.js +2 -0
  464. package/lib/esm/internal/shared/utils/PayloadUtils.test.js.map +7 -0
  465. package/lib/esm/internal/transaction/di/transactionModule.js +2 -13
  466. package/lib/esm/internal/transaction/di/transactionModule.js.map +7 -1
  467. package/lib/esm/internal/transaction/di/transactionModule.test.js +2 -0
  468. package/lib/esm/internal/transaction/di/transactionModule.test.js.map +7 -0
  469. package/lib/esm/internal/transaction/di/transactionTypes.js +2 -6
  470. package/lib/esm/internal/transaction/di/transactionTypes.js.map +7 -1
  471. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js +2 -57
  472. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +7 -1
  473. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js +2 -0
  474. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js.map +7 -0
  475. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js +2 -33
  476. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +7 -1
  477. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js +2 -0
  478. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js.map +7 -0
  479. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +1 -2
  480. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
  481. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +2 -38
  482. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
  483. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
  484. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
  485. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js +1 -2
  486. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
  487. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +2 -0
  488. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
  489. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
  490. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
  491. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js +2 -35
  492. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
  493. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
  494. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
  495. package/lib/esm/internal/typed-data/di/typedDataModule.js +2 -9
  496. package/lib/esm/internal/typed-data/di/typedDataModule.js.map +7 -1
  497. package/lib/esm/internal/typed-data/di/typedDataModule.test.js +2 -0
  498. package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +7 -0
  499. package/lib/esm/internal/typed-data/di/typedDataTypes.js +2 -5
  500. package/lib/esm/internal/typed-data/di/typedDataTypes.js.map +7 -1
  501. package/lib/esm/internal/typed-data/model/Types.js +2 -55
  502. package/lib/esm/internal/typed-data/model/Types.js.map +7 -1
  503. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +2 -26
  504. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
  505. package/lib/esm/internal/typed-data/service/TypedDataEncoder.js +2 -98
  506. package/lib/esm/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
  507. package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
  508. package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
  509. package/lib/esm/internal/typed-data/service/TypedDataParser.js +2 -207
  510. package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +7 -1
  511. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +2 -0
  512. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
  513. package/lib/esm/internal/typed-data/service/TypedDataParserService.js +1 -2
  514. package/lib/esm/internal/typed-data/service/TypedDataParserService.js.map +7 -1
  515. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -39
  516. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
  517. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
  518. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
  519. package/lib/esm/package.json +63 -0
  520. package/lib/types/api/SignerEth.d.ts +15 -0
  521. package/lib/types/api/SignerEth.d.ts.map +1 -0
  522. package/lib/types/api/SignerEthBuilder.d.ts +37 -0
  523. package/lib/types/api/SignerEthBuilder.d.ts.map +1 -0
  524. package/lib/types/api/SignerEthBuilder.test.d.ts +2 -0
  525. package/lib/types/api/SignerEthBuilder.test.d.ts.map +1 -0
  526. package/lib/{cjs → types}/api/app-binder/GetAddressDeviceActionTypes.d.ts +1 -1
  527. package/lib/types/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +1 -0
  528. package/lib/{esm → types}/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +3 -3
  529. package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +1 -0
  530. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +37 -0
  531. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -0
  532. package/lib/{cjs → types}/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +5 -5
  533. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -0
  534. package/lib/{cjs → types}/api/index.d.ts +2 -2
  535. package/lib/{cjs → types}/api/index.d.ts.map +1 -1
  536. package/lib/types/api/model/Address.d.ts +7 -0
  537. package/lib/types/api/model/Address.d.ts.map +1 -0
  538. package/lib/types/api/model/Signature.d.ts +7 -0
  539. package/lib/types/api/model/Signature.d.ts.map +1 -0
  540. package/lib/types/api/model/Transaction.d.ts +14 -0
  541. package/lib/types/api/model/Transaction.d.ts.map +1 -0
  542. package/lib/types/internal/DefaultSignerEth.d.ts +26 -0
  543. package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -0
  544. package/lib/types/internal/DefaultSignerEth.test.d.ts +2 -0
  545. package/lib/types/internal/DefaultSignerEth.test.d.ts.map +1 -0
  546. package/lib/types/internal/address/di/addressModule.test.d.ts +2 -0
  547. package/lib/types/internal/address/di/addressModule.test.d.ts.map +1 -0
  548. package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts +2 -0
  549. package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts.map +1 -0
  550. package/lib/{cjs → types}/internal/app-binder/EthAppBinder.d.ts +6 -4
  551. package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -0
  552. package/lib/types/internal/app-binder/EthAppBinder.test.d.ts +2 -0
  553. package/lib/types/internal/app-binder/EthAppBinder.test.d.ts.map +1 -0
  554. package/lib/{cjs → types}/internal/app-binder/command/GetAddressCommand.d.ts +2 -2
  555. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -0
  556. package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts +2 -0
  557. package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts.map +1 -0
  558. package/lib/{esm → types}/internal/app-binder/command/GetChallengeCommand.d.ts +1 -1
  559. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -0
  560. package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts +2 -0
  561. package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts.map +1 -0
  562. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +18 -0
  563. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -0
  564. package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts +2 -0
  565. package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts.map +1 -0
  566. package/lib/{cjs → types}/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +1 -1
  567. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -0
  568. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts +2 -0
  569. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts.map +1 -0
  570. package/lib/{cjs → types}/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +1 -1
  571. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -0
  572. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts +2 -0
  573. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts.map +1 -0
  574. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +18 -0
  575. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -0
  576. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts +2 -0
  577. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts.map +1 -0
  578. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +18 -0
  579. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -0
  580. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts +2 -0
  581. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts.map +1 -0
  582. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +19 -0
  583. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -0
  584. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts +2 -0
  585. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts.map +1 -0
  586. package/lib/{cjs → types}/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +9 -1
  587. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -0
  588. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts +2 -0
  589. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts.map +1 -0
  590. package/lib/{esm → types}/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +1 -1
  591. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -0
  592. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts +2 -0
  593. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts.map +1 -0
  594. package/lib/{esm → types}/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +1 -1
  595. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -0
  596. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts +2 -0
  597. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts.map +1 -0
  598. package/lib/{esm → types}/internal/app-binder/command/SetExternalPluginCommand.d.ts +1 -1
  599. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -0
  600. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts +2 -0
  601. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts.map +1 -0
  602. package/lib/{cjs → types}/internal/app-binder/command/SetPluginCommand.d.ts +1 -1
  603. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -0
  604. package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts +2 -0
  605. package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts.map +1 -0
  606. package/lib/{esm → types}/internal/app-binder/command/SignEIP712Command.d.ts +2 -2
  607. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -0
  608. package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts +2 -0
  609. package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts.map +1 -0
  610. package/lib/{cjs → types}/internal/app-binder/command/SignPersonalMessageCommand.d.ts +3 -3
  611. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -0
  612. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts +2 -0
  613. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts.map +1 -0
  614. package/lib/{esm → types}/internal/app-binder/command/SignTransactionCommand.d.ts +2 -2
  615. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -0
  616. package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts +2 -0
  617. package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts.map +1 -0
  618. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +12 -0
  619. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -0
  620. package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts +2 -0
  621. package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts.map +1 -0
  622. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +23 -0
  623. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -0
  624. package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts +2 -0
  625. package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts.map +1 -0
  626. package/lib/{esm → types}/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +4 -4
  627. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +1 -0
  628. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts +2 -0
  629. package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts.map +1 -0
  630. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +54 -0
  631. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -0
  632. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts +2 -0
  633. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts.map +1 -0
  634. package/lib/{cjs → types}/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +6 -6
  635. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -0
  636. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts +2 -0
  637. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts.map +1 -0
  638. package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +3 -0
  639. package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
  640. package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +2 -2
  641. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +1 -0
  642. package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
  643. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts +2 -0
  644. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts.map +1 -0
  645. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +27 -0
  646. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +1 -0
  647. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +2 -0
  648. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +1 -0
  649. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +28 -0
  650. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -0
  651. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts +2 -0
  652. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts.map +1 -0
  653. package/lib/{esm → types}/internal/app-binder/task/ProvideTransactionContextTask.d.ts +7 -24
  654. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +1 -0
  655. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +2 -0
  656. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +1 -0
  657. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +38 -0
  658. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +1 -0
  659. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +2 -0
  660. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +1 -0
  661. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +27 -0
  662. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +1 -0
  663. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +2 -0
  664. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +1 -0
  665. package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts +16 -0
  666. package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts.map +1 -0
  667. package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts +2 -0
  668. package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts.map +1 -0
  669. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +14 -0
  670. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -0
  671. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts +2 -0
  672. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts.map +1 -0
  673. package/lib/{esm → types}/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +3 -3
  674. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +1 -0
  675. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts +2 -0
  676. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts.map +1 -0
  677. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +20 -0
  678. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -0
  679. package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts +2 -0
  680. package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts.map +1 -0
  681. package/lib/types/internal/di.d.ts +10 -0
  682. package/lib/types/internal/di.d.ts.map +1 -0
  683. package/lib/{cjs → types}/internal/externalTypes.d.ts +1 -1
  684. package/lib/types/internal/message/di/messageModule.test.d.ts +2 -0
  685. package/lib/types/internal/message/di/messageModule.test.d.ts.map +1 -0
  686. package/lib/{esm → types}/internal/message/use-case/SignMessageUseCase.d.ts +2 -2
  687. package/lib/{cjs → types}/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
  688. package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts +2 -0
  689. package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts.map +1 -0
  690. package/lib/types/internal/shared/utils/PayloadUtils.d.ts +5 -0
  691. package/lib/types/internal/shared/utils/PayloadUtils.d.ts.map +1 -0
  692. package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts +2 -0
  693. package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts.map +1 -0
  694. package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts.map +1 -1
  695. package/lib/types/internal/transaction/di/transactionModule.test.d.ts +2 -0
  696. package/lib/types/internal/transaction/di/transactionModule.test.d.ts.map +1 -0
  697. package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts +1 -0
  698. package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts.map +1 -1
  699. package/lib/{cjs → types}/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +1 -1
  700. package/lib/types/internal/transaction/service/mapper/EthersV5TransactionMapper.test.d.ts +2 -0
  701. package/lib/types/internal/transaction/service/mapper/EthersV5TransactionMapper.test.d.ts.map +1 -0
  702. package/lib/{esm → types}/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +1 -1
  703. package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +1 -0
  704. package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.test.d.ts +2 -0
  705. package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.test.d.ts.map +1 -0
  706. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +7 -0
  707. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +1 -0
  708. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts +2 -0
  709. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts.map +1 -0
  710. package/lib/types/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +18 -0
  711. package/lib/types/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +1 -0
  712. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts +11 -0
  713. package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts.map +1 -0
  714. package/lib/types/internal/transaction/service/parser/TransactionParserService.test.d.ts +2 -0
  715. package/lib/types/internal/transaction/service/parser/TransactionParserService.test.d.ts.map +1 -0
  716. package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts +2 -0
  717. package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts.map +1 -0
  718. package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts +2 -0
  719. package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts.map +1 -0
  720. package/lib/{cjs → types}/internal/typed-data/model/Types.d.ts +1 -1
  721. package/lib/types/internal/typed-data/model/Types.d.ts.map +1 -0
  722. package/lib/{esm → types}/internal/typed-data/service/TypedDataEncoder.d.ts +1 -1
  723. package/lib/{cjs → types}/internal/typed-data/service/TypedDataEncoder.d.ts.map +1 -1
  724. package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts +2 -0
  725. package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts.map +1 -0
  726. package/lib/{esm → types}/internal/typed-data/service/TypedDataParser.d.ts +3 -3
  727. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -0
  728. package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts +2 -0
  729. package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts.map +1 -0
  730. package/lib/{esm → types}/internal/typed-data/service/TypedDataParserService.d.ts +3 -3
  731. package/lib/types/internal/typed-data/service/TypedDataParserService.d.ts.map +1 -0
  732. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts +2 -0
  733. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts.map +1 -0
  734. package/lib/types/tsconfig.prod.tsbuildinfo +1 -0
  735. package/package.json +28 -32
  736. package/lib/cjs/api/KeyringEth.d.ts +0 -15
  737. package/lib/cjs/api/KeyringEth.d.ts.map +0 -1
  738. package/lib/cjs/api/KeyringEth.js +0 -3
  739. package/lib/cjs/api/KeyringEth.js.map +0 -1
  740. package/lib/cjs/api/KeyringEthBuilder.d.ts +0 -38
  741. package/lib/cjs/api/KeyringEthBuilder.d.ts.map +0 -1
  742. package/lib/cjs/api/KeyringEthBuilder.js +0 -49
  743. package/lib/cjs/api/KeyringEthBuilder.js.map +0 -1
  744. package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
  745. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +0 -20
  746. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
  747. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
  748. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
  749. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
  750. package/lib/cjs/api/model/Address.d.ts +0 -7
  751. package/lib/cjs/api/model/Address.d.ts.map +0 -1
  752. package/lib/cjs/api/model/Signature.d.ts +0 -7
  753. package/lib/cjs/api/model/Signature.d.ts.map +0 -1
  754. package/lib/cjs/api/model/Transaction.d.ts +0 -4
  755. package/lib/cjs/api/model/Transaction.d.ts.map +0 -1
  756. package/lib/cjs/internal/DefaultKeyringEth.d.ts +0 -26
  757. package/lib/cjs/internal/DefaultKeyringEth.d.ts.map +0 -1
  758. package/lib/cjs/internal/DefaultKeyringEth.js +0 -36
  759. package/lib/cjs/internal/DefaultKeyringEth.js.map +0 -1
  760. package/lib/cjs/internal/app-binder/EthAppBinder.d.ts.map +0 -1
  761. package/lib/cjs/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
  762. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts +0 -10
  763. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
  764. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
  765. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
  766. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js +0 -41
  767. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
  768. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
  769. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
  770. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
  771. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +0 -25
  772. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
  773. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +0 -30
  774. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
  775. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts +0 -17
  776. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
  777. package/lib/cjs/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
  778. package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts +0 -25
  779. package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
  780. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
  781. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.d.ts +0 -24
  782. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
  783. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +0 -17
  784. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
  785. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
  786. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
  787. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
  788. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
  789. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
  790. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
  791. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  792. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
  793. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
  794. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -57
  795. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  796. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +0 -14
  797. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
  798. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
  799. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
  800. package/lib/cjs/internal/di.d.ts +0 -10
  801. package/lib/cjs/internal/di.d.ts.map +0 -1
  802. package/lib/cjs/internal/message/use-case/SignMessageUseCase.d.ts +0 -8
  803. package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
  804. package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
  805. package/lib/cjs/internal/shared/utils/DerivationPathUtils.js +0 -24
  806. package/lib/cjs/internal/shared/utils/DerivationPathUtils.js.map +0 -1
  807. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +0 -9
  808. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
  809. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
  810. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  811. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
  812. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
  813. package/lib/cjs/internal/typed-data/model/Types.d.ts.map +0 -1
  814. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.d.ts +0 -10
  815. package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts +0 -73
  816. package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
  817. package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts +0 -12
  818. package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
  819. package/lib/esm/api/KeyringEth.d.ts +0 -15
  820. package/lib/esm/api/KeyringEth.d.ts.map +0 -1
  821. package/lib/esm/api/KeyringEth.js +0 -2
  822. package/lib/esm/api/KeyringEth.js.map +0 -1
  823. package/lib/esm/api/KeyringEthBuilder.d.ts +0 -38
  824. package/lib/esm/api/KeyringEthBuilder.d.ts.map +0 -1
  825. package/lib/esm/api/KeyringEthBuilder.js +0 -45
  826. package/lib/esm/api/KeyringEthBuilder.js.map +0 -1
  827. package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts +0 -11
  828. package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -1
  829. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.d.ts +0 -9
  830. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
  831. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
  832. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
  833. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
  834. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +0 -27
  835. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
  836. package/lib/esm/api/index.d.ts +0 -13
  837. package/lib/esm/api/index.d.ts.map +0 -1
  838. package/lib/esm/api/model/Address.d.ts +0 -7
  839. package/lib/esm/api/model/Address.d.ts.map +0 -1
  840. package/lib/esm/api/model/AddressOptions.d.ts +0 -5
  841. package/lib/esm/api/model/AddressOptions.d.ts.map +0 -1
  842. package/lib/esm/api/model/Signature.d.ts +0 -7
  843. package/lib/esm/api/model/Signature.d.ts.map +0 -1
  844. package/lib/esm/api/model/Transaction.d.ts +0 -4
  845. package/lib/esm/api/model/Transaction.d.ts.map +0 -1
  846. package/lib/esm/api/model/TransactionOptions.d.ts +0 -4
  847. package/lib/esm/api/model/TransactionOptions.d.ts.map +0 -1
  848. package/lib/esm/api/model/TypedData.d.ts +0 -18
  849. package/lib/esm/api/model/TypedData.d.ts.map +0 -1
  850. package/lib/esm/index.d.ts +0 -3
  851. package/lib/esm/index.d.ts.map +0 -1
  852. package/lib/esm/internal/DefaultKeyringEth.d.ts +0 -26
  853. package/lib/esm/internal/DefaultKeyringEth.d.ts.map +0 -1
  854. package/lib/esm/internal/DefaultKeyringEth.js +0 -32
  855. package/lib/esm/internal/DefaultKeyringEth.js.map +0 -1
  856. package/lib/esm/internal/address/di/addressModule.d.ts +0 -3
  857. package/lib/esm/internal/address/di/addressModule.d.ts.map +0 -1
  858. package/lib/esm/internal/address/di/addressTypes.d.ts +0 -4
  859. package/lib/esm/internal/address/di/addressTypes.d.ts.map +0 -1
  860. package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts +0 -9
  861. package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -1
  862. package/lib/esm/internal/app-binder/EthAppBinder.d.ts +0 -38
  863. package/lib/esm/internal/app-binder/EthAppBinder.d.ts.map +0 -1
  864. package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts +0 -9
  865. package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
  866. package/lib/esm/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
  867. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
  868. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
  869. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js +0 -37
  870. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
  871. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +0 -15
  872. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
  873. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +0 -14
  874. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
  875. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +0 -41
  876. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
  877. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
  878. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
  879. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
  880. package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts +0 -18
  881. package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
  882. package/lib/esm/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
  883. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts +0 -21
  884. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
  885. package/lib/esm/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
  886. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
  887. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
  888. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
  889. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +0 -31
  890. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
  891. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
  892. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +0 -1
  893. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -2
  894. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +0 -1
  895. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +0 -12
  896. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
  897. package/lib/esm/internal/app-binder/di/appBinderModule.d.ts +0 -3
  898. package/lib/esm/internal/app-binder/di/appBinderModule.d.ts.map +0 -1
  899. package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts +0 -4
  900. package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts.map +0 -1
  901. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -16
  902. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +0 -1
  903. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
  904. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  905. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
  906. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
  907. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  908. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +0 -19
  909. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -1
  910. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
  911. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
  912. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
  913. package/lib/esm/internal/di.d.ts +0 -10
  914. package/lib/esm/internal/di.d.ts.map +0 -1
  915. package/lib/esm/internal/externalTypes.d.ts +0 -6
  916. package/lib/esm/internal/externalTypes.d.ts.map +0 -1
  917. package/lib/esm/internal/message/di/messageModule.d.ts +0 -3
  918. package/lib/esm/internal/message/di/messageModule.d.ts.map +0 -1
  919. package/lib/esm/internal/message/di/messageTypes.d.ts +0 -4
  920. package/lib/esm/internal/message/di/messageTypes.d.ts.map +0 -1
  921. package/lib/esm/internal/message/use-case/SignMessageUseCase.d.ts.map +0 -1
  922. package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
  923. package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
  924. package/lib/esm/internal/shared/utils/DerivationPathUtils.js +0 -20
  925. package/lib/esm/internal/shared/utils/DerivationPathUtils.js.map +0 -1
  926. package/lib/esm/internal/transaction/di/transactionModule.d.ts +0 -3
  927. package/lib/esm/internal/transaction/di/transactionModule.d.ts.map +0 -1
  928. package/lib/esm/internal/transaction/di/transactionTypes.d.ts +0 -6
  929. package/lib/esm/internal/transaction/di/transactionTypes.d.ts.map +0 -1
  930. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -10
  931. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +0 -1
  932. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
  933. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
  934. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  935. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.d.ts +0 -10
  936. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -1
  937. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
  938. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
  939. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts +0 -10
  940. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -1
  941. package/lib/esm/internal/typed-data/di/typedDataModule.d.ts +0 -3
  942. package/lib/esm/internal/typed-data/di/typedDataModule.d.ts.map +0 -1
  943. package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts +0 -5
  944. package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts.map +0 -1
  945. package/lib/esm/internal/typed-data/model/Types.d.ts +0 -41
  946. package/lib/esm/internal/typed-data/model/Types.d.ts.map +0 -1
  947. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -7
  948. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -1
  949. package/lib/esm/internal/typed-data/service/TypedDataEncoder.d.ts.map +0 -1
  950. package/lib/esm/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
  951. package/lib/esm/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
  952. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -11
  953. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -1
  954. /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts +0 -0
  955. /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -0
  956. /package/lib/{cjs → types}/api/model/AddressOptions.d.ts +0 -0
  957. /package/lib/{cjs → types}/api/model/AddressOptions.d.ts.map +0 -0
  958. /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts +0 -0
  959. /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts.map +0 -0
  960. /package/lib/{cjs → types}/api/model/TypedData.d.ts +0 -0
  961. /package/lib/{cjs → types}/api/model/TypedData.d.ts.map +0 -0
  962. /package/lib/{cjs → types}/index.d.ts +0 -0
  963. /package/lib/{cjs → types}/index.d.ts.map +0 -0
  964. /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts +0 -0
  965. /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts.map +0 -0
  966. /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts +0 -0
  967. /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts.map +0 -0
  968. /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts +0 -0
  969. /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -0
  970. /package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -0
  971. /package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +0 -0
  972. /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts +0 -0
  973. /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts.map +0 -0
  974. /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts +0 -0
  975. /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts.map +0 -0
  976. /package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -0
  977. /package/lib/{cjs → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +0 -0
  978. /package/lib/{cjs → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -0
  979. /package/lib/{cjs → types}/internal/externalTypes.d.ts.map +0 -0
  980. /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts +0 -0
  981. /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts.map +0 -0
  982. /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts +0 -0
  983. /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts.map +0 -0
  984. /package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts +0 -0
  985. /package/lib/{cjs → types}/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -0
  986. /package/lib/{cjs → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts +0 -0
  987. /package/lib/{cjs → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -0
  988. /package/lib/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts +0 -0
  989. /package/lib/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -0
  990. /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts +0 -0
  991. /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts.map +0 -0
  992. /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts +0 -0
  993. /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts.map +0 -0
  994. /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -0
  995. /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -0
  996. /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -0
  997. /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -0
@@ -1,184 +1,2 @@
1
- import { VERIFYING_CONTRACT_TOKEN_INDEX, } from "@ledgerhq/context-module";
2
- import { CommandResultFactory, isSuccessCommandResult, } from "@ledgerhq/device-management-kit";
3
- import { Maybe, Nothing } from "purify-ts";
4
- import { ProvideTokenInformationCommand } from "../../app-binder/command/ProvideTokenInformationCommand";
5
- import { Eip712FilterType, SendEIP712FilteringCommand, } from "../../app-binder/command/SendEIP712FilteringCommand";
6
- import { SendEIP712StructDefinitionCommand, StructDefinitionCommand, } from "../../app-binder/command/SendEIP712StructDefinitionCommand";
7
- import { StructImplemType } from "../../app-binder/command/SendEIP712StructImplemCommand";
8
- import { SendEIP712StructImplemTask } from "../../app-binder/task/SendEIP712StructImplemTask";
9
- import { TypedDataValueArray, TypedDataValueRoot, } from "../../typed-data/model/Types";
10
- export class ProvideEIP712ContextTask {
11
- api;
12
- args;
13
- constructor(api, args) {
14
- this.api = api;
15
- this.args = args;
16
- }
17
- async run() {
18
- let result = CommandResultFactory({ data: undefined });
19
- // Provide the structure definitions.
20
- // Should be sent before struct implementations, as described here:
21
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition
22
- // Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:
23
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering
24
- // Therefore it should be normalized on both sides: sorted per keys
25
- const types = Object.entries(this.args.types).sort(([aKey], [bKey]) => aKey.localeCompare(bKey));
26
- for (const [structName, fields] of types) {
27
- result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand({
28
- command: StructDefinitionCommand.Name,
29
- name: structName,
30
- }));
31
- if (!isSuccessCommandResult(result)) {
32
- return result;
33
- }
34
- for (const [fieldName, fieldType] of Object.entries(fields)) {
35
- result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand({
36
- command: StructDefinitionCommand.Field,
37
- name: fieldName,
38
- type: fieldType,
39
- }));
40
- if (!isSuccessCommandResult(result)) {
41
- return result;
42
- }
43
- }
44
- }
45
- if (this.args.clearSignContext.isJust()) {
46
- // Activate the filtering, before sending domain and message implementations, as described here:
47
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation
48
- result = await this.api.sendCommand(new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }));
49
- if (!isSuccessCommandResult(result)) {
50
- return result;
51
- }
52
- }
53
- // Send domain implementation values.
54
- for (const value of this.args.domain) {
55
- await this.getImplementationTask(value).run();
56
- }
57
- if (this.args.clearSignContext.isJust()) {
58
- // Send MessageInformation filter.
59
- // Should be sent between Domain and Message implementations, as described here:
60
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info
61
- result = await this.api.sendCommand(new SendEIP712FilteringCommand({
62
- type: Eip712FilterType.MessageInfo,
63
- displayName: this.args.clearSignContext.extract().messageInfo.displayName,
64
- filtersCount: this.args.clearSignContext.extract().messageInfo.filtersCount,
65
- signature: this.args.clearSignContext.extract().messageInfo.signature,
66
- }));
67
- if (!isSuccessCommandResult(result)) {
68
- return result;
69
- }
70
- }
71
- // Send message implementation values
72
- const tokensIndexes = {};
73
- for (const value of this.args.message) {
74
- // Provide the descriptors of tokens referenced by the message, if any.
75
- // Keep a map of all device indexes for those provided tokens.
76
- const maybeError = await this.provideTokenInformation(value, tokensIndexes);
77
- if (maybeError.isJust()) {
78
- return maybeError.extract();
79
- }
80
- // If there is a filter, it should be sent just before the corresponding implementation:
81
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token
82
- const maybeResult = await this.provideFiltering(value, tokensIndexes);
83
- if (maybeResult.isJust() &&
84
- !isSuccessCommandResult(maybeResult.extract())) {
85
- return maybeResult.extract();
86
- }
87
- // Provide message value implementation
88
- result = await this.getImplementationTask(value).run();
89
- if (!isSuccessCommandResult(result)) {
90
- return result;
91
- }
92
- }
93
- return result;
94
- }
95
- getImplementationTask(value) {
96
- if (value.value instanceof TypedDataValueRoot) {
97
- return new SendEIP712StructImplemTask(this.api, {
98
- type: StructImplemType.ROOT,
99
- value: value.value.root,
100
- });
101
- }
102
- else if (value.value instanceof TypedDataValueArray) {
103
- return new SendEIP712StructImplemTask(this.api, {
104
- type: StructImplemType.ARRAY,
105
- value: value.value.length,
106
- });
107
- }
108
- else {
109
- return new SendEIP712StructImplemTask(this.api, {
110
- type: StructImplemType.FIELD,
111
- value: value.value.data,
112
- });
113
- }
114
- }
115
- async provideTokenInformation(value, tokensIndexes) {
116
- if (this.args.clearSignContext.isJust()) {
117
- const filter = this.args.clearSignContext.extract().filters[value.path];
118
- // Tokens descriptors only needed when a tokenIndex is available in filter.
119
- // It should be sent to the device only 1 time so tokensIndexes has to be checked.
120
- if (filter !== undefined &&
121
- (filter.type === "amount" || filter.type === "token") &&
122
- tokensIndexes[filter.tokenIndex] === undefined) {
123
- const descriptorIndex = filter.tokenIndex;
124
- const tokens = this.args.clearSignContext.extract().tokens;
125
- const token = tokens[descriptorIndex];
126
- if (token === undefined) {
127
- return Nothing;
128
- }
129
- const provideTokenInfoResult = await this.api.sendCommand(new ProvideTokenInformationCommand({ payload: token }));
130
- if (!isSuccessCommandResult(provideTokenInfoResult)) {
131
- return Maybe.of(provideTokenInfoResult);
132
- }
133
- let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;
134
- // The token corresponding to the Verifying Contract of message domain has a special index value, as described here:
135
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value
136
- if (Number(descriptorIndex) === VERIFYING_CONTRACT_TOKEN_INDEX) {
137
- deviceIndex = VERIFYING_CONTRACT_TOKEN_INDEX;
138
- }
139
- // Save the token index in the device slots. That index will be used by later filtering commands.
140
- tokensIndexes[Number(descriptorIndex)] = deviceIndex;
141
- }
142
- }
143
- return Nothing;
144
- }
145
- async provideFiltering(value, tokensIndexes) {
146
- if (this.args.clearSignContext.isJust()) {
147
- const filter = this.args.clearSignContext.extract().filters[value.path];
148
- if (filter === undefined ||
149
- ((filter.type === "amount" || filter.type === "token") &&
150
- tokensIndexes[filter.tokenIndex] === undefined)) {
151
- return Nothing;
152
- }
153
- switch (filter.type) {
154
- case "datetime":
155
- return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
156
- type: Eip712FilterType.Datetime,
157
- displayName: filter.displayName,
158
- signature: filter.signature,
159
- })));
160
- case "raw":
161
- return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
162
- type: Eip712FilterType.Raw,
163
- displayName: filter.displayName,
164
- signature: filter.signature,
165
- })));
166
- case "token":
167
- return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
168
- type: Eip712FilterType.Token,
169
- tokenIndex: tokensIndexes[filter.tokenIndex],
170
- signature: filter.signature,
171
- })));
172
- case "amount":
173
- return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
174
- type: Eip712FilterType.Amount,
175
- displayName: filter.displayName,
176
- tokenIndex: tokensIndexes[filter.tokenIndex],
177
- signature: filter.signature,
178
- })));
179
- }
180
- }
181
- return Nothing;
182
- }
183
- }
184
- //# sourceMappingURL=ProvideEIP712ContextTask.js.map
1
+ import{VERIFYING_CONTRACT_TOKEN_INDEX as x}from"@ledgerhq/context-module";import{CommandResultFactory as w,isSuccessCommandResult as i}from"@ledgerhq/device-management-kit";import{Maybe as g,Nothing as l}from"purify-ts";import{ProvideTokenInformationCommand as S}from"../../app-binder/command/ProvideTokenInformationCommand";import{Eip712FilterType as o,SendEIP712FilteringCommand as m}from"../../app-binder/command/SendEIP712FilteringCommand";import{SendEIP712StructDefinitionCommand as C,StructDefinitionCommand as h}from"../../app-binder/command/SendEIP712StructDefinitionCommand";import{StructImplemType as c}from"../../app-binder/command/SendEIP712StructImplemCommand";import{SendEIP712StructImplemTask as y}from"../../app-binder/task/SendEIP712StructImplemTask";import{TypedDataValueArray as I,TypedDataValueRoot as k}from"../../typed-data/model/Types";const T=5;class J{constructor(e,t){this.api=e;this.args=t}async run(){let e=w({data:void 0});const t=Object.entries(this.args.types).sort(([n],[r])=>n.localeCompare(r));for(const[n,r]of t){if(e=await this.api.sendCommand(new C({command:h.Name,name:n})),!i(e))return e;for(const[s,d]of Object.entries(r))if(e=await this.api.sendCommand(new C({command:h.Field,name:s,type:d})),!i(e))return e}if(this.args.clearSignContext.isJust()&&(e=await this.api.sendCommand(new m({type:o.Activation})),!i(e)))return e;for(const n of this.args.domain)if(e=await this.getImplementationTask(n).run(),!i(e))return e;if(this.args.clearSignContext.isJust()&&(e=await this.api.sendCommand(new m({type:o.MessageInfo,displayName:this.args.clearSignContext.extract().messageInfo.displayName,filtersCount:this.args.clearSignContext.extract().messageInfo.filtersCount,signature:this.args.clearSignContext.extract().messageInfo.signature})),!i(e)))return e;const a={indexes:{},nextIndex:0};for(const n of this.args.message){const r=await this.provideTokenInformation(n,a);if(r.isJust())return r.extract();const s=await this.filterValue(n,a);if(s.isJust()&&!i(s.extract()))return s.extract();if(e=await this.getImplementationTask(n).run(),!i(e))return e;if(this.args.clearSignContext.isJust()&&n.value instanceof I&&n.value.length===0){const p=Object.entries(this.args.clearSignContext.extract().filters).filter(([u,f])=>u.startsWith(`${n.path}.[]`)).map(([u,f])=>f);for(const u of p)if(e=await this.api.sendCommand(new m({type:o.DiscardedPath,path:u.path})),!i(e)||(e=await this.provideFiltering(u,a,!0),!i(e)))return e}}return e}getImplementationTask(e){return e.value instanceof k?new y(this.api,{type:c.ROOT,value:e.value.root}):e.value instanceof I?new y(this.api,{type:c.ARRAY,value:e.value.length}):new y(this.api,{type:c.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 n=a.tokenIndex,s=this.args.clearSignContext.extract().tokens[n];if(s===void 0)return l;const d=await this.api.sendCommand(new S({payload:s}));if(!i(d))return g.of(d);let{tokenIndex:p}=d.data;t.nextIndex=(p+1)%T,Number(n)===x&&(p=x),t.indexes[Number(n)]=p}}return l}async filterValue(e,t){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];return a===void 0?l:g.of(await this.provideFiltering(a,t,!1))}return l}async provideFiltering(e,t,a){switch(e.type){case"datetime":return await this.api.sendCommand(new m({type:o.Datetime,discarded:a,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new m({type:o.Raw,discarded:a,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new m({type:o.Token,discarded:a,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new m({type:o.Amount,discarded:a,displayName:e.displayName,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}))}}sanitizeDeviceIndex(e,t){t.indexes[e]===void 0&&(t.indexes[e]=t.nextIndex,t.nextIndex=(t.nextIndex+1)%T)}}export{J as ProvideEIP712ContextTask};
2
+ //# sourceMappingURL=ProvideEIP712ContextTask.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"ProvideEIP712ContextTask.js","sourceRoot":"","sources":["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.ts"],"names":[],"mappings":"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"}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.ts"],
4
+ "sourcesContent": ["import {\n type TypedDataClearSignContextSuccess,\n type TypedDataFilter,\n type TypedDataTokenIndex,\n VERIFYING_CONTRACT_TOKEN_INDEX,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { Maybe, Nothing } from \"purify-ts\";\n\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\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 { SendEIP712StructImplemTask } from \"@internal/app-binder/task/SendEIP712StructImplemTask\";\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\nexport type ProvideEIP712ContextTaskArgs = {\n types: Record<StructName, Record<FieldName, FieldType>>;\n domain: Array<TypedDataValue>;\n message: Array<TypedDataValue>;\n clearSignContext: Maybe<TypedDataClearSignContextSuccess>;\n};\n\nconst DEVICE_ASSETS_MAX = 5;\n\ntype DeviceAssetIndexes = {\n indexes: Record<TypedDataTokenIndex, number>;\n nextIndex: number;\n};\n\nexport class ProvideEIP712ContextTask {\n constructor(\n private api: InternalApi,\n private args: ProvideEIP712ContextTaskArgs,\n ) {}\n\n async run(): Promise<CommandResult<void>> {\n let result = CommandResultFactory<void, void>({ data: undefined });\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 result = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name: structName,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n for (const [fieldName, fieldType] of Object.entries(fields)) {\n result = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name: fieldName,\n type: fieldType,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n }\n\n if (this.args.clearSignContext.isJust()) {\n // 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 result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n // Send domain implementation values.\n for (const value of this.args.domain) {\n result = await this.getImplementationTask(value).run();\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n if (this.args.clearSignContext.isJust()) {\n // Send MessageInformation filter.\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 result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName:\n this.args.clearSignContext.extract().messageInfo.displayName,\n filtersCount:\n this.args.clearSignContext.extract().messageInfo.filtersCount,\n signature: this.args.clearSignContext.extract().messageInfo.signature,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n // Send message implementation values\n const deviceIndexes: DeviceAssetIndexes = { indexes: {}, nextIndex: 0 };\n for (const value of this.args.message) {\n // Provide the descriptors of tokens referenced by the message, if any.\n // Keep a map of all device indexes for those provided tokens.\n const maybeError = await this.provideTokenInformation(\n value,\n deviceIndexes,\n );\n if (maybeError.isJust()) {\n return maybeError.extract();\n }\n // If there is a filter, it should be sent just before the corresponding implementation:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token\n const maybeResult = await this.filterValue(value, deviceIndexes);\n if (\n maybeResult.isJust() &&\n !isSuccessCommandResult(maybeResult.extract())\n ) {\n return maybeResult.extract();\n }\n // Provide message value implementation\n result = await this.getImplementationTask(value).run();\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n\n // If the value is an empty array, we should discard all 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 result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: filter.path,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n result = await this.provideFiltering(filter, deviceIndexes, true);\n if (!isSuccessCommandResult(result)) {\n return result;\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<CommandErrorResult>> {\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 // Save the token index in the device slots. That index will be used by later filtering commands.\n deviceIndexes.indexes[Number(descriptorIndex)] = deviceIndex;\n }\n }\n return Nothing;\n }\n\n async filterValue(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<void>>> {\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 return Maybe.of(\n await this.provideFiltering(filter, deviceIndexes, false),\n );\n }\n return Nothing;\n }\n\n async provideFiltering(\n filter: TypedDataFilter,\n deviceIndexes: DeviceAssetIndexes,\n discarded: boolean,\n ): Promise<CommandResult<void>> {\n switch (filter.type) {\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 }\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": ["VERIFYING_CONTRACT_TOKEN_INDEX", "CommandResultFactory", "isSuccessCommandResult", "Maybe", "Nothing", "ProvideTokenInformationCommand", "Eip712FilterType", "SendEIP712FilteringCommand", "SendEIP712StructDefinitionCommand", "StructDefinitionCommand", "StructImplemType", "SendEIP712StructImplemTask", "TypedDataValueArray", "TypedDataValueRoot", "DEVICE_ASSETS_MAX", "ProvideEIP712ContextTask", "api", "args", "result", "types", "aKey", "bKey", "structName", "fields", "fieldName", "fieldType", "value", "deviceIndexes", "maybeError", "maybeResult", "discardedFilters", "path", "_", "filter", "descriptorIndex", "token", "provideTokenInfoResult", "deviceIndex", "discarded"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{CommandResultFactory as a,hexaStringToBuffer as v,UnknownDeviceExchangeError as C}from"@ledgerhq/device-management-kit";import{Just as s,Nothing as p}from"purify-ts";import{ProvideTokenInformationCommand as w}from"../../app-binder/command/ProvideTokenInformationCommand";import{Eip712FilterType as c,SendEIP712FilteringCommand as o}from"../../app-binder/command/SendEIP712FilteringCommand";import{SendEIP712StructDefinitionCommand as O,StructDefinitionCommand as h}from"../../app-binder/command/SendEIP712StructDefinitionCommand";import{SendEIP712StructImplemCommand as q,StructImplemType as I}from"../../app-binder/command/SendEIP712StructImplemCommand";import{makeDeviceActionInternalApiMock as N}from"../../app-binder/device-action/__test-utils__/makeInternalApi";import{PrimitiveType as l,StructType as T,TypedDataValueArray as D,TypedDataValueField as i,TypedDataValueRoot as U}from"../../typed-data/model/Types";import{ProvideEIP712ContextTask as r}from"./ProvideEIP712ContextTask";describe("ProvideEIP712ContextTask",()=>{const e=N(),f={EIP712Domain:{name:new l("string","string",p),chainId:new l("uint256","uint",s(32)),verifyingContract:new l("address","address",p)},PermitSingle:{details:new T("PermitDetails"),spender:new l("address","address",p),sigDeadline:new l("uint256","uint",s(32))},PermitDetails:{token:new l("address","address",p),amount:new l("uint160","uint",s(20)),expiration:new l("uint48","uint",s(6)),nonce:new l("uint48","uint",s(6))}},x=[{path:"",type:"",value:new U("EIP712Domain")},{path:"name",type:"string",value:new i(new TextEncoder().encode("Permit2"))},{path:"chainId",type:"uint256",value:new i(Uint8Array.from([137]))},{path:"verifyingContract",type:"address",value:new i(v("0x000000000022d473030f116ddee9f6b43ac78ba3"))}],u=[{path:"",type:"",value:new U("PermitSingle")},{path:"details.token",type:"address",value:new i(v("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"details.amount",type:"uint160",value:new i(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new i(Uint8Array.from([18]))},{path:"details.nonce",type:"uint48",value:new i(Uint8Array.from([0]))},{path:"spender",type:"address",value:new i(v("0xec7be89e9d109e7e3fec59c222cf297125fefda2"))},{path:"sigDeadline",type:"uint256",value:new i(Uint8Array.from([18]))}],m={type:"success",messageInfo:{displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},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"}}},k=new l("address","address",p),A=new l("string","string",p),S=new l("uint256","uint",s(32)),R=new l("uint160","uint",s(20)),g=new l("uint48","uint",s(6)),V=t=>new T(t),y=t=>new O({command:h.Name,name:t}),n=(t,b)=>new O({command:h.Field,name:t,type:b}),E=t=>new q({type:I.ROOT,value:t}),P=t=>new q({type:I.ARRAY,value:t}),d=t=>new q({type:I.FIELD,value:{data:t,isLastChunk:!0}});beforeEach(()=>{jest.resetAllMocks()}),it("Send context with no clear signing context",async()=>{const t={types:f,domain:x,message:u,clearSignContext:p};e.sendCommand.mockResolvedValue(a({data:void 0})),await new r(e,t).run(),expect(e.sendCommand.mock.calls).toHaveLength(24),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(y("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(n("name",A)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(n("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(n("verifyingContract",k)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(y("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(n("token",k)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(n("amount",R)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(n("expiration",g)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(n("nonce",g)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(y("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(n("details",V("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(n("spender",k)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(n("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(E("EIP712Domain")),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(d(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(d(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(d(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(E("PermitSingle")),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(d(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(d(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(d(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(d(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(d(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(d(Uint8Array.from([0,1,18])))}),it("Send context with clear signing",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s(m)};e.sendCommand.mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:{tokenIndex:4}})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:{tokenIndex:5}})),e.sendCommand.mockResolvedValue(a({data:void 0})),await new r(e,t).run(),expect(e.sendCommand.mock.calls).toHaveLength(32),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(y("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(n("name",A)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(n("chainId",S)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(n("verifyingContract",k)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(y("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(n("token",k)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(n("amount",R)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(n("expiration",g)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(n("nonce",g)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(y("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(n("details",V("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(n("spender",k)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(n("sigDeadline",S)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(new o({type:c.Activation})),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(E("EIP712Domain")),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(d(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(d(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(d(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 o({type:c.MessageInfo,displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"})),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(E("PermitSingle")),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(new w({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(new o({type:c.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(d(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 w({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand.mock.calls[24][0]).toStrictEqual(new o({type:c.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand.mock.calls[25][0]).toStrictEqual(d(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[26][0]).toStrictEqual(new o({type:c.Datetime,discarded:!1,displayName:"Approval expire",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b"})),expect(e.sendCommand.mock.calls[27][0]).toStrictEqual(d(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[28][0]).toStrictEqual(d(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[29][0]).toStrictEqual(new o({type:c.Raw,discarded:!1,displayName:"Approve to spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb"})),expect(e.sendCommand.mock.calls[30][0]).toStrictEqual(d(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(d(Uint8Array.from([0,1,18])))}),it("Both tokens unavailable",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s({type:"success",messageInfo:m.messageInfo,filters:m.filters,tokens:{}})};e.sendCommand.mockResolvedValue(a({data:void 0})),await new r(e,t).run(),expect(e.sendCommand).not.toHaveBeenCalledWith(new w({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand).not.toHaveBeenCalledWith(new w({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:1,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("First token unavailable",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s({type:"success",messageInfo:m.messageInfo,filters:m.filters,tokens:{255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"}})};e.sendCommand.mockResolvedValue(a({data:{tokenIndex:4}})),await new r(e,t).run(),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Second token unavailable",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s({type:"success",messageInfo:m.messageInfo,filters:m.filters,tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"}})};e.sendCommand.mockResolvedValue(a({data:{tokenIndex:4}})),await new r(e,t).run(),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new o({type:c.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:0,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Error when providing tokens",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s(m)};e.sendCommand.mockResolvedValueOnce(a({error:new C("error")}));const b=new r(e,t).run();await expect(b).resolves.toStrictEqual(a({error:new C("error")}))}),it("Error when sending struct definitions",async()=>{const t={types:f,domain:x,message:u,clearSignContext:s(m)};e.sendCommand.mockResolvedValueOnce(a({data:{tokenIndex:4}})).mockResolvedValueOnce(a({data:{tokenIndex:5}})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({error:new C("error")}));const b=new r(e,t).run();await expect(b).resolves.toStrictEqual(a({error:new C("error")}))}),it("Error when sending struct implementations",async()=>{const t={types:f,domain:x,message:u,clearSignContext:p};e.sendCommand.mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({data:void 0})).mockResolvedValueOnce(a({error:new C("error")})).mockResolvedValue(a({data:void 0}));const b=new r(e,t).run();await expect(b).resolves.toStrictEqual(a({error:new C("error")}))}),it("Send struct array",async()=>{const t={types:{},domain:[],message:[{path:"spenders",type:"address[]",value:new D(1)},{path:"spenders.[]",type:"address",value:new i(v("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"beneficiaries",type:"address[]",value:new D(0)}],clearSignContext:s({type:"success",messageInfo:{displayName:"Permit2",filtersCount:2,signature:"sig"},tokens:{},filters:{"spenders.[]":{displayName:"Spender",path:"spenders.[]",signature:"sig",type:"raw"},"beneficiaries.[]":{displayName:"Beneficiary",path:"beneficiaries.[]",signature:"sig",type:"raw"}}})};e.sendCommand.mockResolvedValue(a({data:void 0})),await new r(e,t).run(),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(new o({type:c.Activation})),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(new o({type:c.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 o({type:c.Raw,discarded:!1,displayName:"Spender",signature:"sig"})),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(d(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 o({type:c.DiscardedPath,path:"beneficiaries.[]"})),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(new o({type:c.Raw,discarded:!0,displayName:"Beneficiary",signature:"sig"}))})});
2
+ //# sourceMappingURL=ProvideEIP712ContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.test.ts"],
4
+ "sourcesContent": ["import { type TypedDataClearSignContextSuccess } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n hexaStringToBuffer,\n UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\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 {\n SendEIP712StructImplemCommand,\n StructImplemType,\n} from \"@internal/app-binder/command/SendEIP712StructImplemCommand\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport {\n type FieldType,\n PrimitiveType,\n StructType,\n TypedDataValueArray,\n TypedDataValueField,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n} from \"./ProvideEIP712ContextTask\";\n\ndescribe(\"ProvideEIP712ContextTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n\n const TEST_TYPES = {\n EIP712Domain: {\n name: new PrimitiveType(\"string\", \"string\", Nothing),\n chainId: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n verifyingContract: new PrimitiveType(\"address\", \"address\", Nothing),\n },\n PermitSingle: {\n details: new StructType(\"PermitDetails\"),\n spender: new PrimitiveType(\"address\", \"address\", Nothing),\n sigDeadline: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n },\n PermitDetails: {\n token: new PrimitiveType(\"address\", \"address\", Nothing),\n amount: new PrimitiveType(\"uint160\", \"uint\", Just(20)),\n expiration: new PrimitiveType(\"uint48\", \"uint\", Just(6)),\n nonce: new PrimitiveType(\"uint48\", \"uint\", Just(6)),\n },\n };\n const TEST_DOMAIN_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"EIP712Domain\"),\n },\n {\n path: \"name\",\n type: \"string\",\n value: new TypedDataValueField(new TextEncoder().encode(\"Permit2\")),\n },\n {\n path: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n {\n path: \"verifyingContract\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x000000000022d473030f116ddee9f6b43ac78ba3\")!,\n ),\n },\n ];\n const TEST_MESSAGE_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"PermitSingle\"),\n },\n {\n path: \"details.token\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\")!,\n ),\n },\n {\n path: \"details.amount\",\n type: \"uint160\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n {\n path: \"details.expiration\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n {\n path: \"details.nonce\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x00])),\n },\n {\n path: \"spender\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0xec7be89e9d109e7e3fec59c222cf297125fefda2\")!,\n ),\n },\n {\n path: \"sigDeadline\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n ];\n const TEST_CLEAR_SIGN_CONTEXT: TypedDataClearSignContextSuccess = {\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 4,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n tokens: {\n 0: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n 255: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n },\n filters: {\n \"details.amount\": {\n displayName: \"Amount allowance\",\n path: \"details.amount\",\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n tokenIndex: 255,\n type: \"amount\",\n },\n \"details.expiration\": {\n displayName: \"Approval expire\",\n path: \"details.expiration\",\n signature:\n \"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b\",\n type: \"datetime\",\n },\n \"details.token\": {\n displayName: \"Amount allowance\",\n path: \"details.token\",\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n tokenIndex: 0,\n type: \"token\",\n },\n spender: {\n displayName: \"Approve to spender\",\n path: \"spender\",\n signature:\n \"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb\",\n type: \"raw\",\n },\n },\n };\n\n const ADDRESS = new PrimitiveType(\"address\", \"address\", Nothing);\n const STRING = new PrimitiveType(\"string\", \"string\", Nothing);\n const UINT256 = new PrimitiveType(\"uint256\", \"uint\", Just(32));\n const UINT160 = new PrimitiveType(\"uint160\", \"uint\", Just(20));\n const UINT48 = new PrimitiveType(\"uint48\", \"uint\", Just(6));\n const CUSTOM = (name: string) => new StructType(name);\n\n const sendStructDefName = (name: string) =>\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name,\n });\n const sendStructDefField = (name: string, type: FieldType) =>\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name,\n type,\n });\n const sendStructImplRoot = (value: string) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.ROOT,\n value,\n });\n const sendStructImplArray = (value: number) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.ARRAY,\n value,\n });\n const sendStructImplField = (data: Uint8Array) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.FIELD,\n value: {\n data,\n isLastChunk: true,\n },\n });\n\n beforeEach(() => {\n jest.resetAllMocks();\n });\n\n it(\"Send context with no clear signing context\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n };\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand.mock.calls).toHaveLength(24);\n // Send Struct definitions\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n sendStructDefName(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n sendStructDefField(\"name\", STRING),\n );\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructDefField(\"chainId\", UINT256),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n sendStructDefField(\"verifyingContract\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructDefName(\"PermitDetails\"),\n );\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructDefField(\"token\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n sendStructDefField(\"amount\", UINT160),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n sendStructDefField(\"expiration\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[8]![0]).toStrictEqual(\n sendStructDefField(\"nonce\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[9]![0]).toStrictEqual(\n sendStructDefName(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[10]![0]).toStrictEqual(\n sendStructDefField(\"details\", CUSTOM(\"PermitDetails\")),\n );\n expect(apiMock.sendCommand.mock.calls[11]![0]).toStrictEqual(\n sendStructDefField(\"spender\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[12]![0]).toStrictEqual(\n sendStructDefField(\"sigDeadline\", UINT256),\n );\n // Send the domain values\n expect(apiMock.sendCommand.mock.calls[13]![0]).toStrictEqual(\n sendStructImplRoot(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[14]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([0x00, 0x07, 0x50, 0x65, 0x72, 0x6d, 0x69, 0x74, 0x32]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[15]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x89])),\n );\n expect(apiMock.sendCommand.mock.calls[16]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x00, 0x00, 0x00, 0x00, 0x00, 0x22, 0xd4, 0x73, 0x03,\n 0x0f, 0x11, 0x6d, 0xde, 0xe9, 0xf6, 0xb4, 0x3a, 0xc7, 0x8b, 0xa3,\n ]),\n ),\n );\n // Send the message values\n expect(apiMock.sendCommand.mock.calls[17]![0]).toStrictEqual(\n sendStructImplRoot(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[18]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[19]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[20]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[21]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x00])),\n );\n expect(apiMock.sendCommand.mock.calls[22]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0xec, 0x7b, 0xe8, 0x9e, 0x9d, 0x10, 0x9e, 0x7e, 0x3f,\n 0xec, 0x59, 0xc2, 0x22, 0xcf, 0x29, 0x71, 0x25, 0xfe, 0xfd, 0xa2,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[23]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n });\n\n it(\"Send context with clear signing\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 4 } })) // First token provided\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 5 } })); // Second token provided\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand.mock.calls).toHaveLength(32);\n // Send Struct definitions\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n sendStructDefName(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n sendStructDefField(\"name\", STRING),\n );\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructDefField(\"chainId\", UINT256),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n sendStructDefField(\"verifyingContract\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructDefName(\"PermitDetails\"),\n );\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructDefField(\"token\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n sendStructDefField(\"amount\", UINT160),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n sendStructDefField(\"expiration\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[8]![0]).toStrictEqual(\n sendStructDefField(\"nonce\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[9]![0]).toStrictEqual(\n sendStructDefName(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[10]![0]).toStrictEqual(\n sendStructDefField(\"details\", CUSTOM(\"PermitDetails\")),\n );\n expect(apiMock.sendCommand.mock.calls[11]![0]).toStrictEqual(\n sendStructDefField(\"spender\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[12]![0]).toStrictEqual(\n sendStructDefField(\"sigDeadline\", UINT256),\n );\n // Activate the filtering\n expect(apiMock.sendCommand.mock.calls[13]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n // Send the domain values\n expect(apiMock.sendCommand.mock.calls[14]![0]).toStrictEqual(\n sendStructImplRoot(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[15]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([0x00, 0x07, 0x50, 0x65, 0x72, 0x6d, 0x69, 0x74, 0x32]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[16]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x89])),\n );\n expect(apiMock.sendCommand.mock.calls[17]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x00, 0x00, 0x00, 0x00, 0x00, 0x22, 0xd4, 0x73, 0x03,\n 0x0f, 0x11, 0x6d, 0xde, 0xe9, 0xf6, 0xb4, 0x3a, 0xc7, 0x8b, 0xa3,\n ]),\n ),\n );\n // Send the message information filter\n expect(apiMock.sendCommand.mock.calls[18]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: \"Permit2\",\n filtersCount: 4,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n }),\n );\n // Send the message values with corresponding filters\n expect(apiMock.sendCommand.mock.calls[19]![0]).toStrictEqual(\n sendStructImplRoot(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[20]![0]).toStrictEqual(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[21]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 4,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[22]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[23]![0]).toStrictEqual(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[24]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 255,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[25]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[26]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Datetime,\n discarded: false,\n displayName: \"Approval expire\",\n signature:\n \"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[27]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[28]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x00])),\n );\n expect(apiMock.sendCommand.mock.calls[29]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: false,\n displayName: \"Approve to spender\",\n signature:\n \"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[30]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0xec, 0x7b, 0xe8, 0x9e, 0x9d, 0x10, 0x9e, 0x7e, 0x3f,\n 0xec, 0x59, 0xc2, 0x22, 0xcf, 0x29, 0x71, 0x25, 0xfe, 0xfd, 0xa2,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[31]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n });\n\n it(\"Both tokens unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: {},\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).not.toHaveBeenCalledWith(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n }),\n );\n expect(apiMock.sendCommand).not.toHaveBeenCalledWith(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 0,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 1,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"First token unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: { 255: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\" },\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { tokenIndex: 4 } }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 0,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 255,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"Second token unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: { 0: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\" },\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { tokenIndex: 4 } }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 4,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 0,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"Error when providing tokens\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand.mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n // WHEN\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n });\n\n it(\"Error when sending struct definitions\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 4 } }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 5 } }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n // WHEN\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({ error: new UnknownDeviceExchangeError(\"error\") }),\n );\n });\n\n it(\"Error when sending struct implementations\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n };\n // WHEN\n apiMock.sendCommand\n // Struct definitions\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n // Struct implementations\n .mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n )\n .mockResolvedValue(CommandResultFactory({ data: undefined }));\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({ error: new UnknownDeviceExchangeError(\"error\") }),\n );\n });\n\n it(\"Send struct array\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: {},\n domain: [],\n message: [\n // Array containing an element\n {\n path: \"spenders\",\n type: \"address[]\",\n value: new TypedDataValueArray(1),\n },\n {\n path: \"spenders.[]\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\")!,\n ),\n },\n // Empty array\n {\n path: \"beneficiaries\",\n type: \"address[]\",\n value: new TypedDataValueArray(0),\n },\n ],\n clearSignContext: Just({\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 2,\n signature: \"sig\",\n },\n tokens: {},\n filters: {\n \"spenders.[]\": {\n displayName: \"Spender\",\n path: \"spenders.[]\",\n signature: \"sig\",\n type: \"raw\",\n },\n \"beneficiaries.[]\": {\n displayName: \"Beneficiary\",\n path: \"beneficiaries.[]\",\n signature: \"sig\",\n type: \"raw\",\n },\n },\n }),\n };\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n // Activate the filtering\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n // Send the message information filter\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: \"Permit2\",\n filtersCount: 2,\n signature: \"sig\",\n }),\n );\n // Send first array containing 1 element\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructImplArray(1),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: false,\n displayName: \"Spender\",\n signature: \"sig\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n // Send second empty array, with discarded filter\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructImplArray(0),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: \"beneficiaries.[]\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: true,\n displayName: \"Beneficiary\",\n signature: \"sig\",\n }),\n );\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["CommandResultFactory", "hexaStringToBuffer", "UnknownDeviceExchangeError", "Just", "Nothing", "ProvideTokenInformationCommand", "Eip712FilterType", "SendEIP712FilteringCommand", "SendEIP712StructDefinitionCommand", "StructDefinitionCommand", "SendEIP712StructImplemCommand", "StructImplemType", "makeDeviceActionInternalApiMock", "PrimitiveType", "StructType", "TypedDataValueArray", "TypedDataValueField", "TypedDataValueRoot", "ProvideEIP712ContextTask", "apiMock", "TEST_TYPES", "TEST_DOMAIN_VALUES", "TEST_MESSAGE_VALUES", "TEST_CLEAR_SIGN_CONTEXT", "ADDRESS", "STRING", "UINT256", "UINT160", "UINT48", "CUSTOM", "name", "sendStructDefName", "sendStructDefField", "type", "sendStructImplRoot", "value", "sendStructImplArray", "sendStructImplField", "data", "args", "promise"]
7
+ }
@@ -1,107 +1,2 @@
1
- import { ClearSignContextType, } from "@ledgerhq/context-module";
2
- import { APDU_MAX_PAYLOAD, ByteArrayBuilder, CommandResultFactory, hexaStringToBuffer, isSuccessCommandResult, } from "@ledgerhq/device-management-kit";
3
- import { HexaStringEncodeError } from "@ledgerhq/device-management-kit/src/api/apdu/utils/AppBuilderError.js";
4
- import { Just, Nothing } from "purify-ts";
5
- import { PAYLOAD_LENGTH_BYTES, ProvideDomainNameCommand, } from "../../app-binder/command/ProvideDomainNameCommand";
6
- import { ProvideNFTInformationCommand, } from "../../app-binder/command/ProvideNFTInformationCommand";
7
- import { ProvideTokenInformationCommand, } from "../../app-binder/command/ProvideTokenInformationCommand";
8
- import { SetExternalPluginCommand, } from "../../app-binder/command/SetExternalPluginCommand";
9
- import { SetPluginCommand, } from "../../app-binder/command/SetPluginCommand";
10
- /**
11
- * Temporary error type to be used in the `ProvideTransactionContextTask` in order to not forget to handle the error cases.
12
- */
13
- export class ProvideTransactionContextTaskError {
14
- _tag = "ProvideTransactionContextTaskError";
15
- originalError;
16
- constructor(message) {
17
- this.originalError = new Error(message ?? "Unknow error in ProvideTransactionContextTaskError");
18
- }
19
- }
20
- /**
21
- * This task is responsible for providing the transaction context to the device.
22
- * It will send the 5 necessary commands:
23
- * - `SetPluginCommand` (single command)
24
- * - `SetExternalPluginCommand` (single command)
25
- * - `ProvideNFTInformationCommand` (single command)
26
- * - `ProvideTokenInformationCommand` (single command)
27
- * - `ProvideDomainNameCommand` (__mulpitle commands__)
28
- *
29
- * The method `provideDomainNameTask` is dedicated to send the multiple `ProvideDomainNameCommand`.
30
- */
31
- export class ProvideTransactionContextTask {
32
- api;
33
- args;
34
- constructor(api, args) {
35
- this.api = api;
36
- this.args = args;
37
- }
38
- async run() {
39
- for (const context of this.args.clearSignContexts) {
40
- const res = await this.provideContext(context);
41
- if (!isSuccessCommandResult(res)) {
42
- return Just(res);
43
- }
44
- }
45
- return Nothing;
46
- }
47
- /**
48
- * This method will send a command according to the clear sign context type and return the command result if only one command
49
- * is sent, otherwise it will return the result of the `provideDomainNameTask`.
50
- *
51
- * @param context The clear sign context to provide.
52
- * @returns A promise that resolves when the command is sent or result of the `provideDomainNameTask`.
53
- */
54
- async provideContext({ type, payload, }) {
55
- switch (type) {
56
- case ClearSignContextType.PLUGIN: {
57
- return await this.api.sendCommand(new SetPluginCommand({ payload }));
58
- }
59
- case ClearSignContextType.EXTERNAL_PLUGIN: {
60
- return await this.api.sendCommand(new SetExternalPluginCommand({ payload }));
61
- }
62
- case ClearSignContextType.NFT: {
63
- return await this.api.sendCommand(new ProvideNFTInformationCommand({ payload }));
64
- }
65
- case ClearSignContextType.TOKEN: {
66
- return await this.api.sendCommand(new ProvideTokenInformationCommand({ payload }));
67
- }
68
- case ClearSignContextType.DOMAIN_NAME: {
69
- return await this.provideDomainNameTask(payload);
70
- }
71
- default: {
72
- const uncoveredType = type;
73
- throw new ProvideTransactionContextTaskError(`The context type [${uncoveredType}] is not covered`);
74
- }
75
- }
76
- }
77
- /**
78
- * This method is responsible for chunking the domain name if necessary and sending `ProvideDomainNameCommand` to the device.
79
- * It will return the result of the last command sent if all the commands are successful, otherwise it will return the first
80
- * error result encountered.
81
- *
82
- * @param domainName Hexa representation of the domain name.
83
- * @returns A promise that resolves when the command is sent.
84
- */
85
- async provideDomainNameTask(domainName) {
86
- const buffer = hexaStringToBuffer(domainName);
87
- if (buffer === null || buffer.length === 0) {
88
- throw new HexaStringEncodeError("provideDomainNameTask");
89
- }
90
- const data = new ByteArrayBuilder(buffer.length + PAYLOAD_LENGTH_BYTES)
91
- .add16BitUIntToData(buffer.length)
92
- .addBufferToData(buffer)
93
- .build();
94
- let result = CommandResultFactory({ data: undefined });
95
- for (let i = 0; i < data.length; i += APDU_MAX_PAYLOAD) {
96
- result = await this.api.sendCommand(new ProvideDomainNameCommand({
97
- data: data.slice(i, i + APDU_MAX_PAYLOAD),
98
- isFirstChunk: i === 0,
99
- }));
100
- if (!isSuccessCommandResult(result)) {
101
- return result;
102
- }
103
- }
104
- return result;
105
- }
106
- }
107
- //# sourceMappingURL=ProvideTransactionContextTask.js.map
1
+ import{ClearSignContextType as r}from"@ledgerhq/context-module";import{CommandResultFactory as t,InvalidStatusWordError as a,isSuccessCommandResult as s}from"@ledgerhq/device-management-kit";import{Just as i,Nothing as m}from"purify-ts";import{ProvideNFTInformationCommand as d}from"../../app-binder/command/ProvideNFTInformationCommand";import{ProvideTokenInformationCommand as C}from"../../app-binder/command/ProvideTokenInformationCommand";import{ProvideTrustedNameCommand as c}from"../../app-binder/command/ProvideTrustedNameCommand";import{SetExternalPluginCommand as u}from"../../app-binder/command/SetExternalPluginCommand";import{SetPluginCommand as p}from"../../app-binder/command/SetPluginCommand";import{SendPayloadInChunksTask as T}from"./SendPayloadInChunksTask";class g{constructor(o,e){this.api=o;this.args=e}async run(){for(const o of this.args.clearSignContexts){const e=await this.provideContext(o);if(!s(e))return i(e)}return m}async provideContext({type:o,payload:e}){switch(o){case r.PLUGIN:return await this.api.sendCommand(new p({payload:e}));case r.EXTERNAL_PLUGIN:return await this.api.sendCommand(new u({payload:e}));case r.NFT:return await this.api.sendCommand(new d({payload:e}));case r.TOKEN:return await this.api.sendCommand(new C({payload:e}));case r.TRUSTED_NAME:return new T(this.api,{payload:e,commandFactory:n=>new c({data:n.chunkedData,isFirstChunk:n.isFirstChunk})}).run();case r.ENUM:case r.TRANSACTION_FIELD_DESCRIPTION:case r.TRANSACTION_INFO:return t({error:new a("The context type [EXTERNAL_PLUGIN] is not valid here")});default:{const n=o;return t({error:new a(`The context type [${n}] is not covered`)})}}}}export{g as ProvideTransactionContextTask};
2
+ //# sourceMappingURL=ProvideTransactionContextTask.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"ProvideTransactionContextTask.js","sourceRoot":"","sources":["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.ts"],"names":[],"mappings":"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"}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, type Maybe, Nothing } from \"purify-ts\";\n\nimport {\n ProvideNFTInformationCommand,\n type ProvideNFTInformationCommandErrorCodes,\n} from \"@internal/app-binder/command/ProvideNFTInformationCommand\";\nimport {\n ProvideTokenInformationCommand,\n type ProvideTokenInformationCommandResponse,\n} from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport {\n SetExternalPluginCommand,\n type SetExternalPluginCommandErrorCodes,\n} from \"@internal/app-binder/command/SetExternalPluginCommand\";\nimport {\n SetPluginCommand,\n type SetPluginCommandErrorCodes,\n} from \"@internal/app-binder/command/SetPluginCommand\";\n\nimport { SendPayloadInChunksTask } from \"./SendPayloadInChunksTask\";\n\nexport type ProvideTransactionContextTaskArgs = {\n /**\n * The valid clear sign contexts offerred by the `BuildTrancationContextTask`.\n */\n clearSignContexts: ClearSignContextSuccess[];\n};\n\nexport type ProvideTransactionContextTaskErrorCodes =\n | void\n | SetExternalPluginCommandErrorCodes\n | SetPluginCommandErrorCodes\n | ProvideNFTInformationCommandErrorCodes;\n\n/**\n * This task is responsible for providing the transaction context to the device.\n * It will send the 5 necessary commands:\n * - `SetPluginCommand` (single command)\n * - `SetExternalPluginCommand` (single command)\n * - `ProvideNFTInformationCommand` (single command)\n * - `ProvideTokenInformationCommand` (single command)\n * - `ProvideTrustedNameCommand` (__mulpitle commands__)\n *\n * The method `provideTrustedNameTask` is dedicated to send the multiple `ProvideTrustedNameCommand`.\n */\nexport class ProvideTransactionContextTask {\n constructor(\n private api: InternalApi,\n private args: ProvideTransactionContextTaskArgs,\n ) {}\n\n async run(): Promise<\n Maybe<CommandErrorResult<ProvideTransactionContextTaskErrorCodes>>\n > {\n for (const context of this.args.clearSignContexts) {\n const res = await this.provideContext(context);\n if (!isSuccessCommandResult(res)) {\n return Just(res);\n }\n }\n return Nothing;\n }\n\n /**\n * This method will send a command according to the clear sign context type and return the command result if only one command\n * is sent, otherwise it will return the result of the `provideTrustedNameTask`.\n *\n * @param context The clear sign context to provide.\n * @returns A promise that resolves when the command is sent or result of the `provideTrustedNameTask`.\n */\n async provideContext({\n type,\n payload,\n }: ClearSignContextSuccess): Promise<\n CommandResult<\n void | ProvideTokenInformationCommandResponse,\n ProvideTransactionContextTaskErrorCodes\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.TRUSTED_NAME: {\n return new SendPayloadInChunksTask(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 case ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:\n case ClearSignContextType.TRANSACTION_INFO: {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n \"The context type [EXTERNAL_PLUGIN] is not valid here\",\n ),\n });\n }\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": "AAAA,OAEE,wBAAAA,MACK,2BACP,OAGE,wBAAAC,EAEA,0BAAAC,EACA,0BAAAC,MACK,kCACP,OAAS,QAAAC,EAAkB,WAAAC,MAAe,YAE1C,OACE,gCAAAC,MAEK,4DACP,OACE,kCAAAC,MAEK,8DACP,OAAS,6BAAAC,MAAiC,yDAC1C,OACE,4BAAAC,MAEK,wDACP,OACE,oBAAAC,MAEK,gDAEP,OAAS,2BAAAC,MAA+B,4BA0BjC,MAAMC,CAA8B,CACzC,YACUC,EACAC,EACR,CAFQ,SAAAD,EACA,UAAAC,CACP,CAEH,MAAM,KAEJ,CACA,UAAWC,KAAW,KAAK,KAAK,kBAAmB,CACjD,MAAMC,EAAM,MAAM,KAAK,eAAeD,CAAO,EAC7C,GAAI,CAACZ,EAAuBa,CAAG,EAC7B,OAAOZ,EAAKY,CAAG,CAEnB,CACA,OAAOX,CACT,CASA,MAAM,eAAe,CACnB,KAAAY,EACA,QAAAC,CACF,EAKE,CACA,OAAQD,EAAM,CACZ,KAAKjB,EAAqB,OACxB,OAAO,MAAM,KAAK,IAAI,YAAY,IAAIU,EAAiB,CAAE,QAAAQ,CAAQ,CAAC,CAAC,EAErE,KAAKlB,EAAqB,gBACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAIS,EAAyB,CAAE,QAAAS,CAAQ,CAAC,CAC1C,EAEF,KAAKlB,EAAqB,IACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAIM,EAA6B,CAAE,QAAAY,CAAQ,CAAC,CAC9C,EAEF,KAAKlB,EAAqB,MACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAIO,EAA+B,CAAE,QAAAW,CAAQ,CAAC,CAChD,EAEF,KAAKlB,EAAqB,aACxB,OAAO,IAAIW,EAAwB,KAAK,IAAK,CAC3C,QAAAO,EACA,eAAiBJ,GACf,IAAIN,EAA0B,CAC5B,KAAMM,EAAK,YACX,aAAcA,EAAK,YACrB,CAAC,CACL,CAAC,EAAE,IAAI,EAET,KAAKd,EAAqB,KAC1B,KAAKA,EAAqB,8BAC1B,KAAKA,EAAqB,iBACxB,OAAOC,EAAqB,CAC1B,MAAO,IAAIC,EACT,sDACF,CACF,CAAC,EAEH,QAAS,CACP,MAAMiB,EAAuBF,EAC7B,OAAOhB,EAAqB,CAC1B,MAAO,IAAIC,EACT,qBAAqBiB,CAAa,kBACpC,CACF,CAAC,CACH,CACF,CACF,CACF",
6
+ "names": ["ClearSignContextType", "CommandResultFactory", "InvalidStatusWordError", "isSuccessCommandResult", "Just", "Nothing", "ProvideNFTInformationCommand", "ProvideTokenInformationCommand", "ProvideTrustedNameCommand", "SetExternalPluginCommand", "SetPluginCommand", "SendPayloadInChunksTask", "ProvideTransactionContextTask", "api", "args", "context", "res", "type", "payload", "uncoveredType"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{ClearSignContextType as n}from"@ledgerhq/context-module";import{CommandResultFactory as r}from"@ledgerhq/device-management-kit";import{ProvideNFTInformationCommand as c}from"../../app-binder/command/ProvideNFTInformationCommand";import{ProvideTokenInformationCommand as m}from"../../app-binder/command/ProvideTokenInformationCommand";import{SetExternalPluginCommand as l}from"../../app-binder/command/SetExternalPluginCommand";import{SetPluginCommand as p}from"../../app-binder/command/SetPluginCommand";import{makeDeviceActionInternalApiMock as C}from"../../app-binder/device-action/__test-utils__/makeInternalApi";import{ProvideTransactionContextTask as s}from"./ProvideTransactionContextTask";describe("ProvideTransactionContextTask",()=>{const e=C(),d=r({data:void 0}),a=r({data:void 0,error:{}});beforeEach(()=>{jest.resetAllMocks()}),describe("run",()=>{const o={clearSignContexts:[{type:n.PLUGIN,payload:"706c7567696e"},{type:n.EXTERNAL_PLUGIN,payload:"65787465726e616c506c7567696e"},{type:n.NFT,payload:"6e6674"},{type:n.TOKEN,payload:"746f6b656e"}]};afterEach(()=>{jest.restoreAllMocks()}),it("should send relative commands when receiving ClearSignContexts of type not trustedName",async()=>{e.sendCommand.mockResolvedValue(d),await new s(e,o).run(),expect(e.sendCommand).toHaveBeenCalledTimes(4),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.PLUGIN)+1,expect.objectContaining(new p({payload:"706c7567696e"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.EXTERNAL_PLUGIN)+1,expect.objectContaining(new l({payload:"65787465726e616c506c7567696e"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.NFT)+1,expect.objectContaining(new c({payload:"6e6674"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.TOKEN)+1,expect.objectContaining(new m({payload:"746f6b656e"})))}),it("should return the command error result and stop when the command fails",async()=>{e.sendCommand.mockReset(),e.sendCommand.mockResolvedValueOnce(a);const t=await new s(e,o).run();expect(e.sendCommand).toHaveBeenCalledTimes(1),expect(t.isJust()).toBe(!0),expect(t.extract()).toStrictEqual(a)})})});
2
+ //# sourceMappingURL=ProvideTransactionContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.test.ts"],
4
+ "sourcesContent": ["import { ClearSignContextType } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n type UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { ProvideNFTInformationCommand } from \"@internal/app-binder/command/ProvideNFTInformationCommand\";\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { SetExternalPluginCommand } from \"@internal/app-binder/command/SetExternalPluginCommand\";\nimport { SetPluginCommand } from \"@internal/app-binder/command/SetPluginCommand\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\n\nimport {\n ProvideTransactionContextTask,\n type ProvideTransactionContextTaskArgs,\n type ProvideTransactionContextTaskErrorCodes,\n} from \"./ProvideTransactionContextTask\";\n\ndescribe(\"ProvideTransactionContextTask\", () => {\n const api = makeDeviceActionInternalApiMock();\n const successResult = CommandResultFactory<\n void,\n ProvideTransactionContextTaskErrorCodes\n >({\n data: undefined,\n });\n const errorResult = CommandResultFactory<\n void,\n ProvideTransactionContextTaskErrorCodes\n >({\n data: undefined,\n error: {} as UnknownDeviceExchangeError,\n });\n\n beforeEach(() => {\n jest.resetAllMocks();\n });\n\n describe(\"run\", () => {\n const args: ProvideTransactionContextTaskArgs = {\n clearSignContexts: [\n {\n type: ClearSignContextType.PLUGIN,\n payload: \"706c7567696e\", // \"plugin\"\n },\n {\n type: ClearSignContextType.EXTERNAL_PLUGIN,\n payload: \"65787465726e616c506c7567696e\", // \"externalPlugin\"\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"6e6674\", // \"nft\"\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"746f6b656e\", // \"token\"\n },\n ],\n };\n afterEach(() => {\n jest.restoreAllMocks();\n });\n it(\"should send relative commands when receiving ClearSignContexts of type not trustedName\", async () => {\n api.sendCommand.mockResolvedValue(successResult);\n // GIVEN\n const task = new ProvideTransactionContextTask(api, args);\n // WHEN\n await task.run();\n // THEN\n expect(api.sendCommand).toHaveBeenCalledTimes(4);\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n args.clearSignContexts.findIndex(\n (c) => c.type === ClearSignContextType.PLUGIN,\n ) + 1,\n expect.objectContaining(\n new SetPluginCommand({ payload: \"706c7567696e\" }),\n ),\n );\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n args.clearSignContexts.findIndex(\n (c) => c.type === ClearSignContextType.EXTERNAL_PLUGIN,\n ) + 1,\n expect.objectContaining(\n new SetExternalPluginCommand({\n payload: \"65787465726e616c506c7567696e\",\n }),\n ),\n );\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n args.clearSignContexts.findIndex(\n (c) => c.type === ClearSignContextType.NFT,\n ) + 1,\n expect.objectContaining(\n new ProvideNFTInformationCommand({ payload: \"6e6674\" }),\n ),\n );\n expect(api.sendCommand).toHaveBeenNthCalledWith(\n args.clearSignContexts.findIndex(\n (c) => c.type === ClearSignContextType.TOKEN,\n ) + 1,\n expect.objectContaining(\n new ProvideTokenInformationCommand({ payload: \"746f6b656e\" }),\n ),\n );\n });\n it(\"should return the command error result and stop when the command fails\", async () => {\n api.sendCommand.mockReset();\n api.sendCommand.mockResolvedValueOnce(errorResult);\n // GIVEN\n const task = new ProvideTransactionContextTask(api, args);\n // WHEN\n const result = await task.run();\n // THEN\n expect(api.sendCommand).toHaveBeenCalledTimes(1);\n expect(result.isJust()).toBe(true);\n expect(result.extract()).toStrictEqual(errorResult);\n });\n });\n});\n"],
5
+ "mappings": "AAAA,OAAS,wBAAAA,MAA4B,2BACrC,OACE,wBAAAC,MAEK,kCAEP,OAAS,gCAAAC,MAAoC,4DAC7C,OAAS,kCAAAC,MAAsC,8DAC/C,OAAS,4BAAAC,MAAgC,wDACzC,OAAS,oBAAAC,MAAwB,gDACjC,OAAS,mCAAAC,MAAuC,oEAEhD,OACE,iCAAAC,MAGK,kCAEP,SAAS,gCAAiC,IAAM,CAC9C,MAAMC,EAAMF,EAAgC,EACtCG,EAAgBR,EAGpB,CACA,KAAM,MACR,CAAC,EACKS,EAAcT,EAGlB,CACA,KAAM,OACN,MAAO,CAAC,CACV,CAAC,EAED,WAAW,IAAM,CACf,KAAK,cAAc,CACrB,CAAC,EAED,SAAS,MAAO,IAAM,CACpB,MAAMU,EAA0C,CAC9C,kBAAmB,CACjB,CACE,KAAMX,EAAqB,OAC3B,QAAS,cACX,EACA,CACE,KAAMA,EAAqB,gBAC3B,QAAS,8BACX,EACA,CACE,KAAMA,EAAqB,IAC3B,QAAS,QACX,EACA,CACE,KAAMA,EAAqB,MAC3B,QAAS,YACX,CACF,CACF,EACA,UAAU,IAAM,CACd,KAAK,gBAAgB,CACvB,CAAC,EACD,GAAG,yFAA0F,SAAY,CACvGQ,EAAI,YAAY,kBAAkBC,CAAa,EAI/C,MAFa,IAAIF,EAA8BC,EAAKG,CAAI,EAE7C,IAAI,EAEf,OAAOH,EAAI,WAAW,EAAE,sBAAsB,CAAC,EAC/C,OAAOA,EAAI,WAAW,EAAE,wBACtBG,EAAK,kBAAkB,UACpBC,GAAMA,EAAE,OAASZ,EAAqB,MACzC,EAAI,EACJ,OAAO,iBACL,IAAIK,EAAiB,CAAE,QAAS,cAAe,CAAC,CAClD,CACF,EACA,OAAOG,EAAI,WAAW,EAAE,wBACtBG,EAAK,kBAAkB,UACpBC,GAAMA,EAAE,OAASZ,EAAqB,eACzC,EAAI,EACJ,OAAO,iBACL,IAAII,EAAyB,CAC3B,QAAS,8BACX,CAAC,CACH,CACF,EACA,OAAOI,EAAI,WAAW,EAAE,wBACtBG,EAAK,kBAAkB,UACpBC,GAAMA,EAAE,OAASZ,EAAqB,GACzC,EAAI,EACJ,OAAO,iBACL,IAAIE,EAA6B,CAAE,QAAS,QAAS,CAAC,CACxD,CACF,EACA,OAAOM,EAAI,WAAW,EAAE,wBACtBG,EAAK,kBAAkB,UACpBC,GAAMA,EAAE,OAASZ,EAAqB,KACzC,EAAI,EACJ,OAAO,iBACL,IAAIG,EAA+B,CAAE,QAAS,YAAa,CAAC,CAC9D,CACF,CACF,CAAC,EACD,GAAG,yEAA0E,SAAY,CACvFK,EAAI,YAAY,UAAU,EAC1BA,EAAI,YAAY,sBAAsBE,CAAW,EAIjD,MAAMG,EAAS,MAFF,IAAIN,EAA8BC,EAAKG,CAAI,EAE9B,IAAI,EAE9B,OAAOH,EAAI,WAAW,EAAE,sBAAsB,CAAC,EAC/C,OAAOK,EAAO,OAAO,CAAC,EAAE,KAAK,EAAI,EACjC,OAAOA,EAAO,QAAQ,CAAC,EAAE,cAAcH,CAAW,CACpD,CAAC,CACH,CAAC,CACH,CAAC",
6
+ "names": ["ClearSignContextType", "CommandResultFactory", "ProvideNFTInformationCommand", "ProvideTokenInformationCommand", "SetExternalPluginCommand", "SetPluginCommand", "makeDeviceActionInternalApiMock", "ProvideTransactionContextTask", "api", "successResult", "errorResult", "args", "c", "result"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{ClearSignContextType as n}from"@ledgerhq/context-module";import{bufferToHexaString as p,CommandResultFactory as C,InvalidStatusWordError as u,isSuccessCommandResult as i}from"@ledgerhq/device-management-kit";import{Just as s,Nothing as d}from"purify-ts";import{GetChallengeCommand as l}from"../../app-binder/command/GetChallengeCommand";import{ProvideEnumCommand as T}from"../../app-binder/command/ProvideEnumCommand";import{ProvideNFTInformationCommand as f}from"../../app-binder/command/ProvideNFTInformationCommand";import{ProvideTokenInformationCommand as h}from"../../app-binder/command/ProvideTokenInformationCommand";import{ProvideTransactionFieldDescriptionCommand as v}from"../../app-binder/command/ProvideTransactionFieldDescriptionCommand";import{ProvideTrustedNameCommand as y}from"../../app-binder/command/ProvideTrustedNameCommand";import{SendPayloadInChunksTask as m}from"./SendPayloadInChunksTask";class D{constructor(r,t){this.api=r;this.args=t}async run(){const{field:r}=this.args;if(r.reference!==void 0){const e=await this.provideContextReference(r.reference);if(e.isJust())return e}const t=await this.provideContext({...r});return i(t)?d:s(t)}async provideContextReference(r){const t=this.args.transactionParser.extractValue(this.args.serializedTransaction,r.valuePath);if(t.isLeft())return d;for(const e of t.unsafeCoerce()){const c=p(e.slice(Math.max(0,e.length-20)));let a;if(r.type===n.TRUSTED_NAME){const o=await this.api.sendCommand(new l);if(!i(o))return s(o);a=await this.args.contextModule.getContext({type:r.type,chainId:this.args.chainId,address:c,challenge:o.data.challenge,types:r.types,sources:r.sources})}else a=await this.args.contextModule.getContext({type:r.type,chainId:this.args.chainId,address:c});if(a.type!==n.ERROR){const o=await this.provideContext(a);if(!i(o))return s(o)}}return d}async provideContext({type:r,payload:t}){switch(r){case n.NFT:return await this.api.sendCommand(new f({payload:t}));case n.TOKEN:return await this.api.sendCommand(new h({payload:t}));case n.TRUSTED_NAME:return new m(this.api,{payload:t,commandFactory:e=>new y({data:e.chunkedData,isFirstChunk:e.isFirstChunk})}).run();case n.ENUM:return new m(this.api,{payload:t,commandFactory:e=>new T({data:e.chunkedData,isFirstChunk:e.isFirstChunk})}).run();case n.TRANSACTION_FIELD_DESCRIPTION:return new m(this.api,{payload:t,commandFactory:e=>new v({data:e.chunkedData,isFirstChunk:e.isFirstChunk})}).run();case n.TRANSACTION_INFO:case n.PLUGIN:case n.EXTERNAL_PLUGIN:return C({error:new u(`The context type [${r}] is not valid as a transaction field or metadata`)});default:{const e=r;return C({error:new u(`The context type [${e}] is not covered`)})}}}}export{D as ProvideTransactionFieldDescriptionTask};
2
+ //# sourceMappingURL=ProvideTransactionFieldDescriptionTask.js.map