@ledgerhq/device-signer-kit-ethereum 1.0.0 → 1.2.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 (1025) hide show
  1. package/README.md +173 -382
  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/TransactionOptions.js +2 -3
  27. package/lib/cjs/api/model/TransactionOptions.js.map +7 -1
  28. package/lib/cjs/api/model/TransactionType.js +2 -0
  29. package/lib/cjs/api/model/TransactionType.js.map +7 -0
  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/command/utils/ethAppErrors.js +2 -0
  125. package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.js.map +7 -0
  126. package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js +2 -0
  127. package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js.map +7 -0
  128. package/lib/cjs/internal/app-binder/constant/plugins.js +2 -0
  129. package/lib/cjs/internal/app-binder/constant/plugins.js.map +7 -0
  130. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +2 -285
  131. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +7 -1
  132. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +2 -0
  133. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +7 -0
  134. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +2 -245
  135. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +7 -1
  136. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +2 -0
  137. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +7 -0
  138. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +2 -18
  139. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +7 -1
  140. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +2 -31
  141. package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +7 -1
  142. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +2 -35
  143. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +7 -1
  144. package/lib/cjs/internal/app-binder/di/appBinderModule.js +2 -11
  145. package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +7 -1
  146. package/lib/cjs/internal/app-binder/di/appBinderTypes.js +2 -7
  147. package/lib/cjs/internal/app-binder/di/appBinderTypes.js.map +7 -1
  148. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +2 -72
  149. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +7 -1
  150. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +2 -0
  151. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +7 -0
  152. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +2 -31
  153. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +7 -1
  154. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +2 -0
  155. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +7 -0
  156. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +2 -188
  157. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +7 -1
  158. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +2 -0
  159. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +7 -0
  160. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +2 -112
  161. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +7 -1
  162. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +2 -0
  163. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +7 -0
  164. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +2 -0
  165. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +7 -0
  166. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +2 -0
  167. package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +7 -0
  168. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +2 -0
  169. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +7 -0
  170. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +2 -0
  171. package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +7 -0
  172. package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js +2 -0
  173. package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js.map +7 -0
  174. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js +2 -42
  175. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js.map +7 -1
  176. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js +2 -0
  177. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +7 -0
  178. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +2 -0
  179. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +7 -0
  180. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +2 -0
  181. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +7 -0
  182. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js +2 -53
  183. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js.map +7 -1
  184. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js +2 -0
  185. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +7 -0
  186. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +2 -53
  187. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +7 -1
  188. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +2 -0
  189. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +7 -0
  190. package/lib/cjs/internal/di.js +2 -27
  191. package/lib/cjs/internal/di.js.map +7 -1
  192. package/lib/cjs/internal/externalTypes.js +2 -9
  193. package/lib/cjs/internal/externalTypes.js.map +7 -1
  194. package/lib/cjs/internal/message/di/messageModule.js +2 -11
  195. package/lib/cjs/internal/message/di/messageModule.js.map +7 -1
  196. package/lib/cjs/internal/message/di/messageModule.test.js +2 -0
  197. package/lib/cjs/internal/message/di/messageModule.test.js.map +7 -0
  198. package/lib/cjs/internal/message/di/messageTypes.js +2 -7
  199. package/lib/cjs/internal/message/di/messageTypes.js.map +7 -1
  200. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +2 -38
  201. package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +7 -1
  202. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +2 -0
  203. package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +7 -0
  204. package/lib/cjs/internal/shared/utils/PayloadUtils.js +2 -0
  205. package/lib/cjs/internal/shared/utils/PayloadUtils.js.map +7 -0
  206. package/lib/cjs/internal/shared/utils/PayloadUtils.test.js +2 -0
  207. package/lib/cjs/internal/shared/utils/PayloadUtils.test.js.map +7 -0
  208. package/lib/cjs/internal/transaction/di/transactionModule.js +2 -17
  209. package/lib/cjs/internal/transaction/di/transactionModule.js.map +7 -1
  210. package/lib/cjs/internal/transaction/di/transactionModule.test.js +2 -0
  211. package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +7 -0
  212. package/lib/cjs/internal/transaction/di/transactionTypes.js +2 -9
  213. package/lib/cjs/internal/transaction/di/transactionTypes.js.map +7 -1
  214. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js +2 -0
  215. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +7 -0
  216. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +2 -0
  217. package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +7 -0
  218. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +2 -3
  219. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
  220. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +2 -41
  221. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
  222. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
  223. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
  224. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js +2 -3
  225. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
  226. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +2 -0
  227. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
  228. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
  229. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
  230. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js +2 -38
  231. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
  232. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
  233. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
  234. package/lib/cjs/internal/typed-data/di/typedDataModule.js +2 -13
  235. package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +7 -1
  236. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +2 -0
  237. package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +7 -0
  238. package/lib/cjs/internal/typed-data/di/typedDataTypes.js +2 -8
  239. package/lib/cjs/internal/typed-data/di/typedDataTypes.js.map +7 -1
  240. package/lib/cjs/internal/typed-data/model/Types.js +2 -64
  241. package/lib/cjs/internal/typed-data/model/Types.js.map +7 -1
  242. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +2 -29
  243. package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
  244. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js +2 -101
  245. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
  246. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
  247. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
  248. package/lib/cjs/internal/typed-data/service/TypedDataParser.js +2 -211
  249. package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +7 -1
  250. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +2 -0
  251. package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
  252. package/lib/cjs/internal/typed-data/service/TypedDataParserService.js +2 -3
  253. package/lib/cjs/internal/typed-data/service/TypedDataParserService.js.map +7 -1
  254. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -42
  255. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
  256. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
  257. package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
  258. package/lib/cjs/package.json +63 -0
  259. package/lib/esm/api/SignerEth.js +1 -0
  260. package/lib/esm/api/SignerEth.js.map +7 -0
  261. package/lib/esm/api/SignerEthBuilder.js +2 -0
  262. package/lib/esm/api/SignerEthBuilder.js.map +7 -0
  263. package/lib/esm/api/SignerEthBuilder.test.js +2 -0
  264. package/lib/esm/api/SignerEthBuilder.test.js.map +7 -0
  265. package/lib/esm/api/app-binder/GetAddressCommandTypes.js +1 -2
  266. package/lib/esm/api/app-binder/GetAddressCommandTypes.js.map +7 -1
  267. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js +1 -2
  268. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js.map +7 -1
  269. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js +1 -2
  270. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +7 -1
  271. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -2
  272. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +7 -1
  273. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -2
  274. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +7 -1
  275. package/lib/esm/api/index.js +2 -10
  276. package/lib/esm/api/index.js.map +7 -1
  277. package/lib/esm/api/model/Address.js +1 -2
  278. package/lib/esm/api/model/Address.js.map +7 -1
  279. package/lib/esm/api/model/AddressOptions.js +1 -2
  280. package/lib/esm/api/model/AddressOptions.js.map +7 -1
  281. package/lib/esm/api/model/Signature.js +1 -2
  282. package/lib/esm/api/model/Signature.js.map +7 -1
  283. package/lib/esm/api/model/TransactionOptions.js +1 -2
  284. package/lib/esm/api/model/TransactionOptions.js.map +7 -1
  285. package/lib/esm/api/model/TransactionType.js +2 -0
  286. package/lib/esm/api/model/TransactionType.js.map +7 -0
  287. package/lib/esm/api/model/TypedData.js +1 -3
  288. package/lib/esm/api/model/TypedData.js.map +7 -1
  289. package/lib/esm/index.js +2 -4
  290. package/lib/esm/index.js.map +7 -1
  291. package/lib/esm/internal/DefaultSignerEth.js +2 -0
  292. package/lib/esm/internal/DefaultSignerEth.js.map +7 -0
  293. package/lib/esm/internal/DefaultSignerEth.test.js +2 -0
  294. package/lib/esm/internal/DefaultSignerEth.test.js.map +7 -0
  295. package/lib/esm/internal/address/di/addressModule.js +2 -7
  296. package/lib/esm/internal/address/di/addressModule.js.map +7 -1
  297. package/lib/esm/internal/address/di/addressModule.test.js +2 -0
  298. package/lib/esm/internal/address/di/addressModule.test.js.map +7 -0
  299. package/lib/esm/internal/address/di/addressTypes.js +2 -4
  300. package/lib/esm/internal/address/di/addressTypes.js.map +7 -1
  301. package/lib/esm/internal/address/use-case/GetAddressUseCase.js +2 -35
  302. package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +7 -1
  303. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +2 -0
  304. package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +7 -0
  305. package/lib/esm/internal/app-binder/EthAppBinder.js +2 -97
  306. package/lib/esm/internal/app-binder/EthAppBinder.js.map +7 -1
  307. package/lib/esm/internal/app-binder/EthAppBinder.test.js +2 -0
  308. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +7 -0
  309. package/lib/esm/internal/app-binder/command/GetAddressCommand.js +2 -84
  310. package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +7 -1
  311. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +2 -0
  312. package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +7 -0
  313. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +2 -35
  314. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +7 -1
  315. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +2 -0
  316. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +7 -0
  317. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +2 -0
  318. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +7 -0
  319. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +2 -0
  320. package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +7 -0
  321. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +2 -46
  322. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +7 -1
  323. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +2 -0
  324. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +7 -0
  325. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +2 -30
  326. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +7 -1
  327. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +2 -0
  328. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +7 -0
  329. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +2 -0
  330. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +7 -0
  331. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +2 -0
  332. package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +7 -0
  333. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +2 -0
  334. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +7 -0
  335. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +2 -0
  336. package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +7 -0
  337. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +2 -0
  338. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +7 -0
  339. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +2 -0
  340. package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +7 -0
  341. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +2 -65
  342. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +7 -1
  343. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +2 -0
  344. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +7 -0
  345. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +2 -127
  346. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +7 -1
  347. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +2 -0
  348. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +7 -0
  349. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +2 -47
  350. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +7 -1
  351. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +2 -0
  352. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +7 -0
  353. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +2 -52
  354. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +7 -1
  355. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +7 -0
  356. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +7 -0
  357. package/lib/esm/internal/app-binder/command/SetPluginCommand.js +2 -47
  358. package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +7 -1
  359. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +6 -0
  360. package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +7 -0
  361. package/lib/esm/internal/app-binder/command/SignEIP712Command.js +2 -65
  362. package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +7 -1
  363. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +2 -0
  364. package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +7 -0
  365. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +2 -56
  366. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +7 -1
  367. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +2 -0
  368. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +7 -0
  369. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +2 -55
  370. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +7 -1
  371. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +2 -0
  372. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +7 -0
  373. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +2 -0
  374. package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +7 -0
  375. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +2 -0
  376. package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +7 -0
  377. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +2 -0
  378. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +7 -0
  379. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +2 -0
  380. package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +7 -0
  381. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.js +2 -0
  382. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.js.map +7 -0
  383. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js +2 -0
  384. package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js.map +7 -0
  385. package/lib/esm/internal/app-binder/constant/plugins.js +2 -0
  386. package/lib/esm/internal/app-binder/constant/plugins.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/EthersRawTransactionMapper.js +2 -0
  472. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +7 -0
  473. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +2 -0
  474. package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +7 -0
  475. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +1 -2
  476. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
  477. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +2 -38
  478. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
  479. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
  480. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
  481. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js +1 -2
  482. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
  483. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +2 -0
  484. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
  485. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
  486. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
  487. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js +2 -35
  488. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
  489. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
  490. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
  491. package/lib/esm/internal/typed-data/di/typedDataModule.js +2 -9
  492. package/lib/esm/internal/typed-data/di/typedDataModule.js.map +7 -1
  493. package/lib/esm/internal/typed-data/di/typedDataModule.test.js +2 -0
  494. package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +7 -0
  495. package/lib/esm/internal/typed-data/di/typedDataTypes.js +2 -5
  496. package/lib/esm/internal/typed-data/di/typedDataTypes.js.map +7 -1
  497. package/lib/esm/internal/typed-data/model/Types.js +2 -55
  498. package/lib/esm/internal/typed-data/model/Types.js.map +7 -1
  499. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +2 -26
  500. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
  501. package/lib/esm/internal/typed-data/service/TypedDataEncoder.js +2 -98
  502. package/lib/esm/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
  503. package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
  504. package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
  505. package/lib/esm/internal/typed-data/service/TypedDataParser.js +2 -207
  506. package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +7 -1
  507. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +2 -0
  508. package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
  509. package/lib/esm/internal/typed-data/service/TypedDataParserService.js +1 -2
  510. package/lib/esm/internal/typed-data/service/TypedDataParserService.js.map +7 -1
  511. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -39
  512. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
  513. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
  514. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
  515. package/lib/esm/package.json +63 -0
  516. package/lib/types/api/SignerEth.d.ts +14 -0
  517. package/lib/types/api/SignerEth.d.ts.map +1 -0
  518. package/lib/types/api/SignerEthBuilder.d.ts +37 -0
  519. package/lib/types/api/SignerEthBuilder.d.ts.map +1 -0
  520. package/lib/types/api/SignerEthBuilder.test.d.ts +2 -0
  521. package/lib/types/api/SignerEthBuilder.test.d.ts.map +1 -0
  522. package/lib/{esm → types}/api/app-binder/GetAddressDeviceActionTypes.d.ts +3 -2
  523. package/lib/types/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +1 -0
  524. package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +12 -0
  525. package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +1 -0
  526. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +37 -0
  527. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -0
  528. package/lib/{cjs → types}/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +8 -7
  529. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -0
  530. package/lib/{cjs → types}/api/index.d.ts +4 -4
  531. package/lib/types/api/index.d.ts.map +1 -0
  532. package/lib/types/api/model/Address.d.ts +7 -0
  533. package/lib/types/api/model/Address.d.ts.map +1 -0
  534. package/lib/types/api/model/Signature.d.ts +7 -0
  535. package/lib/types/api/model/Signature.d.ts.map +1 -0
  536. package/lib/types/api/model/TransactionType.d.ts +11 -0
  537. package/lib/types/api/model/TransactionType.d.ts.map +1 -0
  538. package/lib/types/internal/DefaultSignerEth.d.ts +25 -0
  539. package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -0
  540. package/lib/types/internal/DefaultSignerEth.test.d.ts +2 -0
  541. package/lib/types/internal/DefaultSignerEth.test.d.ts.map +1 -0
  542. package/lib/types/internal/address/di/addressModule.test.d.ts +2 -0
  543. package/lib/types/internal/address/di/addressModule.test.d.ts.map +1 -0
  544. package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts +2 -0
  545. package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts.map +1 -0
  546. package/lib/{cjs → types}/internal/app-binder/EthAppBinder.d.ts +7 -6
  547. package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -0
  548. package/lib/types/internal/app-binder/EthAppBinder.test.d.ts +2 -0
  549. package/lib/types/internal/app-binder/EthAppBinder.test.d.ts.map +1 -0
  550. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts +11 -0
  551. package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -0
  552. package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts +2 -0
  553. package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts.map +1 -0
  554. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts +12 -0
  555. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -0
  556. package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts +2 -0
  557. package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts.map +1 -0
  558. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +20 -0
  559. package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -0
  560. package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts +2 -0
  561. package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts.map +1 -0
  562. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +16 -0
  563. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -0
  564. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts +2 -0
  565. package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts.map +1 -0
  566. package/lib/{cjs → types}/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +5 -3
  567. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -0
  568. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts +2 -0
  569. package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts.map +1 -0
  570. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +20 -0
  571. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -0
  572. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts +2 -0
  573. package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts.map +1 -0
  574. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +20 -0
  575. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -0
  576. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts +2 -0
  577. package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts.map +1 -0
  578. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +21 -0
  579. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -0
  580. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts +2 -0
  581. package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts.map +1 -0
  582. package/lib/{esm → types}/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +13 -3
  583. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -0
  584. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts +2 -0
  585. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts.map +1 -0
  586. package/lib/{esm → types}/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +5 -3
  587. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -0
  588. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts +2 -0
  589. package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts.map +1 -0
  590. package/lib/{cjs → types}/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +5 -3
  591. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -0
  592. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts +2 -0
  593. package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts.map +1 -0
  594. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts +15 -0
  595. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -0
  596. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts +2 -0
  597. package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts.map +1 -0
  598. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts +16 -0
  599. package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -0
  600. package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts +2 -0
  601. package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts.map +1 -0
  602. package/lib/{cjs → types}/internal/app-binder/command/SignEIP712Command.d.ts +5 -3
  603. package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -0
  604. package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts +2 -0
  605. package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts.map +1 -0
  606. package/lib/{esm → types}/internal/app-binder/command/SignPersonalMessageCommand.d.ts +6 -4
  607. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -0
  608. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts +2 -0
  609. package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts.map +1 -0
  610. package/lib/{cjs → types}/internal/app-binder/command/SignTransactionCommand.d.ts +5 -3
  611. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -0
  612. package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts +2 -0
  613. package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts.map +1 -0
  614. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +14 -0
  615. package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -0
  616. package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts +2 -0
  617. package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts.map +1 -0
  618. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +25 -0
  619. package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -0
  620. package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts +2 -0
  621. package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts.map +1 -0
  622. package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts +8 -0
  623. package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts.map +1 -0
  624. package/lib/types/internal/app-binder/command/utils/ethAppErrors.test.d.ts +2 -0
  625. package/lib/types/internal/app-binder/command/utils/ethAppErrors.test.d.ts.map +1 -0
  626. package/lib/types/internal/app-binder/constant/plugins.d.ts +2 -0
  627. package/lib/types/internal/app-binder/constant/plugins.d.ts.map +1 -0
  628. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +54 -0
  629. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -0
  630. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts +2 -0
  631. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts.map +1 -0
  632. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +39 -0
  633. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -0
  634. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts +2 -0
  635. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts.map +1 -0
  636. package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +4 -0
  637. package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
  638. package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +1 -1
  639. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +15 -0
  640. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +1 -0
  641. package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
  642. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts +2 -0
  643. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts.map +1 -0
  644. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +27 -0
  645. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +1 -0
  646. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +2 -0
  647. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +1 -0
  648. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +35 -0
  649. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -0
  650. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts +2 -0
  651. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts.map +1 -0
  652. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +37 -0
  653. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +1 -0
  654. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +2 -0
  655. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +1 -0
  656. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +80 -0
  657. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +1 -0
  658. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +2 -0
  659. package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +1 -0
  660. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +27 -0
  661. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +1 -0
  662. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +2 -0
  663. package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +1 -0
  664. package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts +17 -0
  665. package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts.map +1 -0
  666. package/lib/{esm → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +2 -1
  667. package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +1 -0
  668. package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts +2 -0
  669. package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts.map +1 -0
  670. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +15 -0
  671. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -0
  672. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts +2 -0
  673. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts.map +1 -0
  674. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +15 -0
  675. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +1 -0
  676. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts +2 -0
  677. package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts.map +1 -0
  678. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +21 -0
  679. package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -0
  680. package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts +2 -0
  681. package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts.map +1 -0
  682. package/lib/types/internal/di.d.ts +10 -0
  683. package/lib/types/internal/di.d.ts.map +1 -0
  684. package/lib/{cjs → types}/internal/externalTypes.d.ts +1 -1
  685. package/lib/types/internal/message/di/messageModule.test.d.ts +2 -0
  686. package/lib/types/internal/message/di/messageModule.test.d.ts.map +1 -0
  687. package/lib/{esm → types}/internal/message/use-case/SignMessageUseCase.d.ts +2 -2
  688. package/lib/{cjs → types}/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
  689. package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts +2 -0
  690. package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts.map +1 -0
  691. package/lib/types/internal/shared/utils/PayloadUtils.d.ts +5 -0
  692. package/lib/types/internal/shared/utils/PayloadUtils.d.ts.map +1 -0
  693. package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts +2 -0
  694. package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts.map +1 -0
  695. package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts.map +1 -1
  696. package/lib/types/internal/transaction/di/transactionModule.test.d.ts +2 -0
  697. package/lib/types/internal/transaction/di/transactionModule.test.d.ts.map +1 -0
  698. package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts +1 -0
  699. package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts.map +1 -1
  700. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts +7 -0
  701. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts.map +1 -0
  702. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts +2 -0
  703. package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts.map +1 -0
  704. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +6 -0
  705. package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +1 -0
  706. package/lib/{esm → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts +1 -2
  707. package/lib/types/internal/transaction/service/mapper/TransactionMapperService.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/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts +1 -2
  717. package/lib/types/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +1 -0
  718. package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts +2 -0
  719. package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts.map +1 -0
  720. package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts +2 -0
  721. package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts.map +1 -0
  722. package/lib/{cjs → types}/internal/typed-data/model/Types.d.ts +1 -1
  723. package/lib/types/internal/typed-data/model/Types.d.ts.map +1 -0
  724. package/lib/{esm → types}/internal/typed-data/service/TypedDataEncoder.d.ts +1 -1
  725. package/lib/{cjs → types}/internal/typed-data/service/TypedDataEncoder.d.ts.map +1 -1
  726. package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts +2 -0
  727. package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts.map +1 -0
  728. package/lib/{esm → types}/internal/typed-data/service/TypedDataParser.d.ts +3 -3
  729. package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -0
  730. package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts +2 -0
  731. package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts.map +1 -0
  732. package/lib/{esm → types}/internal/typed-data/service/TypedDataParserService.d.ts +3 -3
  733. package/lib/types/internal/typed-data/service/TypedDataParserService.d.ts.map +1 -0
  734. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts +2 -0
  735. package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts.map +1 -0
  736. package/lib/types/tsconfig.prod.tsbuildinfo +1 -0
  737. package/package.json +30 -34
  738. package/lib/cjs/api/KeyringEth.d.ts +0 -15
  739. package/lib/cjs/api/KeyringEth.d.ts.map +0 -1
  740. package/lib/cjs/api/KeyringEth.js +0 -3
  741. package/lib/cjs/api/KeyringEth.js.map +0 -1
  742. package/lib/cjs/api/KeyringEthBuilder.d.ts +0 -38
  743. package/lib/cjs/api/KeyringEthBuilder.d.ts.map +0 -1
  744. package/lib/cjs/api/KeyringEthBuilder.js +0 -49
  745. package/lib/cjs/api/KeyringEthBuilder.js.map +0 -1
  746. package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.d.ts +0 -9
  747. package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
  748. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +0 -20
  749. package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
  750. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
  751. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
  752. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
  753. package/lib/cjs/api/index.d.ts.map +0 -1
  754. package/lib/cjs/api/model/Address.d.ts +0 -7
  755. package/lib/cjs/api/model/Address.d.ts.map +0 -1
  756. package/lib/cjs/api/model/Signature.d.ts +0 -7
  757. package/lib/cjs/api/model/Signature.d.ts.map +0 -1
  758. package/lib/cjs/api/model/Transaction.d.ts +0 -4
  759. package/lib/cjs/api/model/Transaction.d.ts.map +0 -1
  760. package/lib/cjs/api/model/Transaction.js +0 -3
  761. package/lib/cjs/api/model/Transaction.js.map +0 -1
  762. package/lib/cjs/internal/DefaultKeyringEth.d.ts +0 -26
  763. package/lib/cjs/internal/DefaultKeyringEth.d.ts.map +0 -1
  764. package/lib/cjs/internal/DefaultKeyringEth.js +0 -36
  765. package/lib/cjs/internal/DefaultKeyringEth.js.map +0 -1
  766. package/lib/cjs/internal/app-binder/EthAppBinder.d.ts.map +0 -1
  767. package/lib/cjs/internal/app-binder/command/GetAddressCommand.d.ts +0 -9
  768. package/lib/cjs/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
  769. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts +0 -10
  770. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
  771. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
  772. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
  773. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js +0 -41
  774. package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
  775. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +0 -15
  776. package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
  777. package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
  778. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +0 -41
  779. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
  780. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +0 -25
  781. package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
  782. package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
  783. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts +0 -17
  784. package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
  785. package/lib/cjs/internal/app-binder/command/SetPluginCommand.d.ts +0 -18
  786. package/lib/cjs/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
  787. package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
  788. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts +0 -21
  789. package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
  790. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
  791. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +0 -17
  792. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
  793. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -161
  794. package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +0 -1
  795. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
  796. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
  797. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +0 -31
  798. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
  799. package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
  800. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +0 -12
  801. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
  802. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
  803. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  804. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
  805. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
  806. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -57
  807. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  808. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +0 -19
  809. package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -1
  810. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +0 -14
  811. package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
  812. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
  813. package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
  814. package/lib/cjs/internal/di.d.ts +0 -10
  815. package/lib/cjs/internal/di.d.ts.map +0 -1
  816. package/lib/cjs/internal/message/use-case/SignMessageUseCase.d.ts +0 -8
  817. package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
  818. package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
  819. package/lib/cjs/internal/shared/utils/DerivationPathUtils.js +0 -24
  820. package/lib/cjs/internal/shared/utils/DerivationPathUtils.js.map +0 -1
  821. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -10
  822. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +0 -1
  823. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js +0 -60
  824. package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +0 -1
  825. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +0 -9
  826. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
  827. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js +0 -36
  828. package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +0 -1
  829. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
  830. package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  831. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.d.ts +0 -10
  832. package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -1
  833. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
  834. package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
  835. package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -1
  836. package/lib/cjs/internal/typed-data/model/Types.d.ts.map +0 -1
  837. package/lib/cjs/internal/typed-data/service/TypedDataEncoder.d.ts +0 -10
  838. package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts +0 -73
  839. package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
  840. package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts +0 -12
  841. package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
  842. package/lib/esm/api/KeyringEth.d.ts +0 -15
  843. package/lib/esm/api/KeyringEth.d.ts.map +0 -1
  844. package/lib/esm/api/KeyringEth.js +0 -2
  845. package/lib/esm/api/KeyringEth.js.map +0 -1
  846. package/lib/esm/api/KeyringEthBuilder.d.ts +0 -38
  847. package/lib/esm/api/KeyringEthBuilder.d.ts.map +0 -1
  848. package/lib/esm/api/KeyringEthBuilder.js +0 -45
  849. package/lib/esm/api/KeyringEthBuilder.js.map +0 -1
  850. package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts +0 -11
  851. package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -1
  852. package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
  853. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +0 -20
  854. package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
  855. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
  856. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
  857. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +0 -27
  858. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
  859. package/lib/esm/api/index.d.ts +0 -13
  860. package/lib/esm/api/index.d.ts.map +0 -1
  861. package/lib/esm/api/model/Address.d.ts +0 -7
  862. package/lib/esm/api/model/Address.d.ts.map +0 -1
  863. package/lib/esm/api/model/AddressOptions.d.ts +0 -5
  864. package/lib/esm/api/model/AddressOptions.d.ts.map +0 -1
  865. package/lib/esm/api/model/Signature.d.ts +0 -7
  866. package/lib/esm/api/model/Signature.d.ts.map +0 -1
  867. package/lib/esm/api/model/Transaction.d.ts +0 -4
  868. package/lib/esm/api/model/Transaction.d.ts.map +0 -1
  869. package/lib/esm/api/model/Transaction.js +0 -2
  870. package/lib/esm/api/model/Transaction.js.map +0 -1
  871. package/lib/esm/api/model/TransactionOptions.d.ts +0 -4
  872. package/lib/esm/api/model/TransactionOptions.d.ts.map +0 -1
  873. package/lib/esm/api/model/TypedData.d.ts +0 -18
  874. package/lib/esm/api/model/TypedData.d.ts.map +0 -1
  875. package/lib/esm/index.d.ts +0 -3
  876. package/lib/esm/index.d.ts.map +0 -1
  877. package/lib/esm/internal/DefaultKeyringEth.d.ts +0 -26
  878. package/lib/esm/internal/DefaultKeyringEth.d.ts.map +0 -1
  879. package/lib/esm/internal/DefaultKeyringEth.js +0 -32
  880. package/lib/esm/internal/DefaultKeyringEth.js.map +0 -1
  881. package/lib/esm/internal/address/di/addressModule.d.ts +0 -3
  882. package/lib/esm/internal/address/di/addressModule.d.ts.map +0 -1
  883. package/lib/esm/internal/address/di/addressTypes.d.ts +0 -4
  884. package/lib/esm/internal/address/di/addressTypes.d.ts.map +0 -1
  885. package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts +0 -9
  886. package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -1
  887. package/lib/esm/internal/app-binder/EthAppBinder.d.ts +0 -38
  888. package/lib/esm/internal/app-binder/EthAppBinder.d.ts.map +0 -1
  889. package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts +0 -9
  890. package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
  891. package/lib/esm/internal/app-binder/command/GetChallengeCommand.d.ts +0 -10
  892. package/lib/esm/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
  893. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
  894. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
  895. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js +0 -37
  896. package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
  897. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +0 -15
  898. package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
  899. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +0 -14
  900. package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
  901. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
  902. package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
  903. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +0 -30
  904. package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
  905. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.d.ts +0 -17
  906. package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
  907. package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts +0 -18
  908. package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
  909. package/lib/esm/internal/app-binder/command/SignEIP712Command.d.ts +0 -25
  910. package/lib/esm/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
  911. package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
  912. package/lib/esm/internal/app-binder/command/SignTransactionCommand.d.ts +0 -24
  913. package/lib/esm/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
  914. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +0 -17
  915. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
  916. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -157
  917. package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +0 -1
  918. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
  919. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
  920. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +0 -31
  921. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
  922. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
  923. package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +0 -1
  924. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -2
  925. package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +0 -1
  926. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +0 -12
  927. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
  928. package/lib/esm/internal/app-binder/di/appBinderModule.d.ts +0 -3
  929. package/lib/esm/internal/app-binder/di/appBinderModule.d.ts.map +0 -1
  930. package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts +0 -4
  931. package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts.map +0 -1
  932. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -16
  933. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +0 -1
  934. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
  935. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  936. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
  937. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
  938. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -57
  939. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  940. package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -1
  941. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +0 -14
  942. package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
  943. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
  944. package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
  945. package/lib/esm/internal/di.d.ts +0 -10
  946. package/lib/esm/internal/di.d.ts.map +0 -1
  947. package/lib/esm/internal/externalTypes.d.ts +0 -6
  948. package/lib/esm/internal/externalTypes.d.ts.map +0 -1
  949. package/lib/esm/internal/message/di/messageModule.d.ts +0 -3
  950. package/lib/esm/internal/message/di/messageModule.d.ts.map +0 -1
  951. package/lib/esm/internal/message/di/messageTypes.d.ts +0 -4
  952. package/lib/esm/internal/message/di/messageTypes.d.ts.map +0 -1
  953. package/lib/esm/internal/message/use-case/SignMessageUseCase.d.ts.map +0 -1
  954. package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
  955. package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
  956. package/lib/esm/internal/shared/utils/DerivationPathUtils.js +0 -20
  957. package/lib/esm/internal/shared/utils/DerivationPathUtils.js.map +0 -1
  958. package/lib/esm/internal/transaction/di/transactionModule.d.ts +0 -3
  959. package/lib/esm/internal/transaction/di/transactionModule.d.ts.map +0 -1
  960. package/lib/esm/internal/transaction/di/transactionTypes.d.ts +0 -6
  961. package/lib/esm/internal/transaction/di/transactionTypes.d.ts.map +0 -1
  962. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -10
  963. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +0 -1
  964. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js +0 -57
  965. package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +0 -1
  966. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +0 -9
  967. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
  968. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js +0 -33
  969. package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +0 -1
  970. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
  971. package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
  972. package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -1
  973. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
  974. package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
  975. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts +0 -10
  976. package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -1
  977. package/lib/esm/internal/typed-data/di/typedDataModule.d.ts +0 -3
  978. package/lib/esm/internal/typed-data/di/typedDataModule.d.ts.map +0 -1
  979. package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts +0 -5
  980. package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts.map +0 -1
  981. package/lib/esm/internal/typed-data/model/Types.d.ts +0 -41
  982. package/lib/esm/internal/typed-data/model/Types.d.ts.map +0 -1
  983. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -7
  984. package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -1
  985. package/lib/esm/internal/typed-data/service/TypedDataEncoder.d.ts.map +0 -1
  986. package/lib/esm/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
  987. package/lib/esm/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
  988. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -11
  989. package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -1
  990. /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts +0 -0
  991. /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -0
  992. /package/lib/{cjs → types}/api/model/AddressOptions.d.ts +0 -0
  993. /package/lib/{cjs → types}/api/model/AddressOptions.d.ts.map +0 -0
  994. /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts +0 -0
  995. /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts.map +0 -0
  996. /package/lib/{cjs → types}/api/model/TypedData.d.ts +0 -0
  997. /package/lib/{cjs → types}/api/model/TypedData.d.ts.map +0 -0
  998. /package/lib/{cjs → types}/index.d.ts +0 -0
  999. /package/lib/{cjs → types}/index.d.ts.map +0 -0
  1000. /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts +0 -0
  1001. /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts.map +0 -0
  1002. /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts +0 -0
  1003. /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts.map +0 -0
  1004. /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts +0 -0
  1005. /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -0
  1006. /package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -0
  1007. /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts +0 -0
  1008. /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts.map +0 -0
  1009. /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts +0 -0
  1010. /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts.map +0 -0
  1011. /package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -0
  1012. /package/lib/{cjs → types}/internal/externalTypes.d.ts.map +0 -0
  1013. /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts +0 -0
  1014. /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts.map +0 -0
  1015. /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts +0 -0
  1016. /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts.map +0 -0
  1017. /package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts +0 -0
  1018. /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts +0 -0
  1019. /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts.map +0 -0
  1020. /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts +0 -0
  1021. /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts.map +0 -0
  1022. /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -0
  1023. /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -0
  1024. /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -0
  1025. /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -0
@@ -1 +1,7 @@
1
- {"version":3,"file":"appBinderTypes.js","sourceRoot":"","sources":["../../../../../src/internal/app-binder/di/appBinderTypes.ts"],"names":[],"mappings":";;;AAAa,QAAA,cAAc,GAAG;IAC5B,UAAU,EAAE,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC;CACpC,CAAC"}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/di/appBinderTypes.ts"],
4
+ "sourcesContent": ["export const appBinderTypes = {\n AppBinding: Symbol.for(\"AppBinder\"),\n};\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,oBAAAE,IAAA,eAAAC,EAAAH,GAAO,MAAME,EAAiB,CAC5B,WAAY,OAAO,IAAI,WAAW,CACpC",
6
+ "names": ["appBinderTypes_exports", "__export", "appBinderTypes", "__toCommonJS"]
7
+ }
@@ -1,72 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BuildEIP712ContextTask = exports.ZERO_ADDRESS = void 0;
4
- const device_management_kit_1 = require("@ledgerhq/device-management-kit");
5
- const purify_ts_1 = require("purify-ts");
6
- const Types_1 = require("../../typed-data/model/Types");
7
- exports.ZERO_ADDRESS = "0x0000000000000000000000000000000000000000";
8
- class BuildEIP712ContextTask {
9
- api;
10
- contextModule;
11
- parser;
12
- data;
13
- constructor(api, contextModule, parser, data) {
14
- this.api = api;
15
- this.contextModule = contextModule;
16
- this.parser = parser;
17
- this.data = data;
18
- }
19
- async run() {
20
- // Parse the message types and values
21
- const parsed = this.parser.parse(this.data);
22
- if (parsed.isLeft()) {
23
- throw parsed.extract();
24
- }
25
- const { types, domain, message } = parsed.unsafeCoerce();
26
- // Get clear signing context, if any
27
- let clearSignContext = purify_ts_1.Nothing;
28
- const version = this.getClearSignVersion();
29
- if (version.isJust()) {
30
- const verifyingContract = this.data.domain.verifyingContract?.toLowerCase() || exports.ZERO_ADDRESS;
31
- const chainId = this.data.domain.chainId || 0;
32
- const fieldsValues = message
33
- .filter((v) => v.value instanceof Types_1.TypedDataValueField)
34
- .map((v) => ({
35
- path: v.path,
36
- value: v.value.data,
37
- }));
38
- const filters = await this.contextModule.getTypedDataFilters({
39
- verifyingContract,
40
- chainId,
41
- version: version.extract(),
42
- schema: this.data.types,
43
- fieldsValues,
44
- });
45
- if (filters.type === "success") {
46
- clearSignContext = (0, purify_ts_1.Just)(filters);
47
- }
48
- }
49
- // Return the args for provide context task
50
- const provideTaskArgs = {
51
- types,
52
- domain,
53
- message,
54
- clearSignContext,
55
- };
56
- return provideTaskArgs;
57
- }
58
- getClearSignVersion() {
59
- const deviceState = this.api.getDeviceSessionState();
60
- if (deviceState.sessionStateType === device_management_kit_1.DeviceSessionStateType.Connected) {
61
- return purify_ts_1.Nothing;
62
- }
63
- if (deviceState.currentApp.name !== "Ethereum") {
64
- return purify_ts_1.Nothing;
65
- }
66
- // TODO add currentAppVersion to session state
67
- // const shouldUseV2Filters = semver.gte(deviceState.currentAppVersion!, "1.11.1-0");
68
- return (0, purify_ts_1.Just)("v2");
69
- }
70
- }
71
- exports.BuildEIP712ContextTask = BuildEIP712ContextTask;
72
- //# sourceMappingURL=BuildEIP712ContextTask.js.map
1
+ "use strict";var p=Object.defineProperty;var P=Object.getOwnPropertyDescriptor;var A=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var I=(e,t)=>{for(var a in t)p(e,a,{get:t[a],enumerable:!0})},F=(e,t,a,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of A(t))!E.call(e,s)&&s!==a&&p(e,s,{get:()=>t[s],enumerable:!(i=P(t,s))||i.enumerable});return e};var M=e=>F(p({},"__esModule",{value:!0}),e);var k={};I(k,{BuildEIP712ContextTask:()=>V,ZERO_ADDRESS:()=>f});module.exports=M(k);var l=require("@ledgerhq/device-management-kit"),d=require("ethers"),r=require("purify-ts"),u=require("semver"),v=require("../../typed-data/model/Types");const f="0x0000000000000000000000000000000000000000";class V{constructor(t,a,i,s){this.api=t;this.contextModule=a;this.parser=i;this.data=s}async run(){const t=d.TypedDataEncoder.hashDomain(this.data.domain);if(!this.data.types[this.data.primaryType])throw new Error(`Primary type "${this.data.primaryType}" is not defined in the types.`);const a=this.data.types,{EIP712Domain:i,...s}=a,T=d.TypedDataEncoder.hashStruct(this.data.primaryType,s,this.data.message),n=this.parser.parse(this.data);if(n.isLeft())throw n.extract();const{types:g,domain:C,message:c}=n.unsafeCoerce();let y=r.Nothing;const m=this.getClearSignVersion();if(m.isJust()){const D=this.data.domain.verifyingContract?.toLowerCase()||f,S=this.data.domain.chainId||0,x=c.filter(o=>o.value instanceof v.TypedDataValueField).map(o=>({path:o.path,value:o.value.data})),h=await this.contextModule.getTypedDataFilters({verifyingContract:D,chainId:S,version:m.extract(),schema:this.data.types,fieldsValues:x});h.type==="success"&&(y=(0,r.Just)(h))}return{types:g,domain:C,message:c,clearSignContext:y,domainHash:t,messageHash:T}}getClearSignVersion(){const t=this.api.getDeviceSessionState();return t.sessionStateType===l.DeviceSessionStateType.Connected?r.Nothing:t.currentApp.name!=="Ethereum"?r.Nothing:(0,u.gte)(t.currentApp.version,"1.12.0")?(0,r.Just)("v2"):(0,r.Just)("v1")}}0&&(module.exports={BuildEIP712ContextTask,ZERO_ADDRESS});
2
+ //# sourceMappingURL=BuildEIP712ContextTask.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"BuildEIP712ContextTask.js","sourceRoot":"","sources":["../../../../../src/internal/app-binder/task/BuildEIP712ContextTask.ts"],"names":[],"mappings":";;;AAIA,2EAGyC;AACzC,yCAAiD;AAIjD,4DAAuE;AAG1D,QAAA,YAAY,GAAG,4CAA4C,CAAC;AAEzE,MAAa,sBAAsB;IAEvB;IACA;IACA;IACA;IAJV,YACU,GAAgB,EAChB,aAA4B,EAC5B,MAA8B,EAC9B,IAAe;QAHf,QAAG,GAAH,GAAG,CAAa;QAChB,kBAAa,GAAb,aAAa,CAAe;QAC5B,WAAM,GAAN,MAAM,CAAwB;QAC9B,SAAI,GAAJ,IAAI,CAAW;IACtB,CAAC;IAEJ,KAAK,CAAC,GAAG;QACP,qCAAqC;QACrC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;YACpB,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;QACzB,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAEzD,oCAAoC;QACpC,IAAI,gBAAgB,GAA4C,mBAAO,CAAC;QACxE,MAAM,OAAO,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3C,IAAI,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;YACrB,MAAM,iBAAiB,GACrB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,WAAW,EAAE,IAAI,oBAAY,CAAC;YACpE,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC;YAC9C,MAAM,YAAY,GAAG,OAAO;iBACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,YAAY,2BAAmB,CAAC;iBACrD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACX,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,KAAK,EAAG,CAAC,CAAC,KAA6B,CAAC,IAAI;aAC7C,CAAC,CAAC,CAAC;YACN,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC;gBAC3D,iBAAiB;gBACjB,OAAO;gBACP,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE;gBAC1B,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK;gBACvB,YAAY;aACb,CAAC,CAAC;YACH,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBAC/B,gBAAgB,GAAG,IAAA,gBAAI,EAAC,OAAO,CAAC,CAAC;YACnC,CAAC;QACH,CAAC;QAED,2CAA2C;QAC3C,MAAM,eAAe,GAAiC;YACpD,KAAK;YACL,MAAM;YACN,OAAO;YACP,gBAAgB;SACjB,CAAC;QACF,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,mBAAmB;QACzB,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,qBAAqB,EAAE,CAAC;QACrD,IAAI,WAAW,CAAC,gBAAgB,KAAK,8CAAsB,CAAC,SAAS,EAAE,CAAC;YACtE,OAAO,mBAAO,CAAC;QACjB,CAAC;QACD,IAAI,WAAW,CAAC,UAAU,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;YAC/C,OAAO,mBAAO,CAAC;QACjB,CAAC;QACD,8CAA8C;QAC9C,qFAAqF;QACrF,OAAO,IAAA,gBAAI,EAAC,IAAI,CAAC,CAAC;IACpB,CAAC;CACF;AA/DD,wDA+DC"}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildEIP712ContextTask.ts"],
4
+ "sourcesContent": ["import {\n type ContextModule,\n type TypedDataClearSignContextSuccess,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceSessionStateType,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { TypedDataEncoder, type TypedDataField } from \"ethers\";\nimport { Just, type Maybe, Nothing } from \"purify-ts\";\nimport { gte } from \"semver\";\n\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { type ProvideEIP712ContextTaskArgs } from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { TypedDataValueField } from \"@internal/typed-data/model/Types\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nexport const ZERO_ADDRESS = \"0x0000000000000000000000000000000000000000\";\n\nexport class BuildEIP712ContextTask {\n constructor(\n private api: InternalApi,\n private contextModule: ContextModule,\n private parser: TypedDataParserService,\n private data: TypedData,\n ) {}\n\n async run(): Promise<ProvideEIP712ContextTaskArgs> {\n // Legacy blind signing context\n const domainHash = TypedDataEncoder.hashDomain(this.data.domain);\n\n if (!this.data.types[this.data.primaryType]) {\n throw new Error(\n `Primary type \"${this.data.primaryType}\" is not defined in the types.`,\n );\n }\n\n const typesRecord: Record<string, TypedDataField[]> = this.data.types;\n const { EIP712Domain, ...rest } = typesRecord;\n const messageHash = TypedDataEncoder.hashStruct(\n this.data.primaryType,\n rest,\n this.data.message,\n );\n\n // Clear signing context\n // Parse the message types and values\n const parsed = this.parser.parse(this.data);\n if (parsed.isLeft()) {\n throw parsed.extract();\n }\n const { types, domain, message } = parsed.unsafeCoerce();\n\n // Get clear signing context, if any\n let clearSignContext: Maybe<TypedDataClearSignContextSuccess> = Nothing;\n const version = this.getClearSignVersion();\n if (version.isJust()) {\n const verifyingContract =\n this.data.domain.verifyingContract?.toLowerCase() || ZERO_ADDRESS;\n const chainId = this.data.domain.chainId || 0;\n const fieldsValues = message\n .filter((v) => v.value instanceof TypedDataValueField)\n .map((v) => ({\n path: v.path,\n value: (v.value as TypedDataValueField).data,\n }));\n const filters = await this.contextModule.getTypedDataFilters({\n verifyingContract,\n chainId,\n version: version.extract(),\n schema: this.data.types,\n fieldsValues,\n });\n if (filters.type === \"success\") {\n clearSignContext = Just(filters);\n }\n }\n\n // Return the args for provide context task\n const provideTaskArgs: ProvideEIP712ContextTaskArgs = {\n types,\n domain,\n message,\n clearSignContext,\n domainHash,\n messageHash,\n };\n return provideTaskArgs;\n }\n\n private getClearSignVersion(): Maybe<\"v1\" | \"v2\"> {\n const deviceState = this.api.getDeviceSessionState();\n if (deviceState.sessionStateType === DeviceSessionStateType.Connected) {\n return Nothing;\n }\n if (deviceState.currentApp.name !== \"Ethereum\") {\n return Nothing;\n }\n // EIP712 v2 (amount & datetime filters) supported since 1.11.0:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#1110-1\n // But some issues were still present until 1.12.0 among which:\n // * V2 descriptor with missing token not supported by the app\n // * Empty arrays with filters not correctly handled\n // * Trusted name filters not yet released\n // Therefore it's safer and easier to use V1 filters before 1.12.0:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#1120\n const shouldUseV2Filters = gte(deviceState.currentApp.version, \"1.12.0\");\n return shouldUseV2Filters ? Just(\"v2\") : Just(\"v1\");\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,4BAAAE,EAAA,iBAAAC,IAAA,eAAAC,EAAAJ,GAIA,IAAAK,EAGO,2CACPC,EAAsD,kBACtDC,EAA0C,qBAC1CC,EAAoB,kBAIpBC,EAAoC,4CAG7B,MAAMN,EAAe,6CAErB,MAAMD,CAAuB,CAClC,YACUQ,EACAC,EACAC,EACAC,EACR,CAJQ,SAAAH,EACA,mBAAAC,EACA,YAAAC,EACA,UAAAC,CACP,CAEH,MAAM,KAA6C,CAEjD,MAAMC,EAAa,mBAAiB,WAAW,KAAK,KAAK,MAAM,EAE/D,GAAI,CAAC,KAAK,KAAK,MAAM,KAAK,KAAK,WAAW,EACxC,MAAM,IAAI,MACR,iBAAiB,KAAK,KAAK,WAAW,gCACxC,EAGF,MAAMC,EAAgD,KAAK,KAAK,MAC1D,CAAE,aAAAC,EAAc,GAAGC,CAAK,EAAIF,EAC5BG,EAAc,mBAAiB,WACnC,KAAK,KAAK,YACVD,EACA,KAAK,KAAK,OACZ,EAIME,EAAS,KAAK,OAAO,MAAM,KAAK,IAAI,EAC1C,GAAIA,EAAO,OAAO,EAChB,MAAMA,EAAO,QAAQ,EAEvB,KAAM,CAAE,MAAAC,EAAO,OAAAC,EAAQ,QAAAC,CAAQ,EAAIH,EAAO,aAAa,EAGvD,IAAII,EAA4D,UAChE,MAAMC,EAAU,KAAK,oBAAoB,EACzC,GAAIA,EAAQ,OAAO,EAAG,CACpB,MAAMC,EACJ,KAAK,KAAK,OAAO,mBAAmB,YAAY,GAAKtB,EACjDuB,EAAU,KAAK,KAAK,OAAO,SAAW,EACtCC,EAAeL,EAClB,OAAQM,GAAMA,EAAE,iBAAiB,qBAAmB,EACpD,IAAKA,IAAO,CACX,KAAMA,EAAE,KACR,MAAQA,EAAE,MAA8B,IAC1C,EAAE,EACEC,EAAU,MAAM,KAAK,cAAc,oBAAoB,CAC3D,kBAAAJ,EACA,QAAAC,EACA,QAASF,EAAQ,QAAQ,EACzB,OAAQ,KAAK,KAAK,MAClB,aAAAG,CACF,CAAC,EACGE,EAAQ,OAAS,YACnBN,KAAmB,QAAKM,CAAO,EAEnC,CAWA,MARsD,CACpD,MAAAT,EACA,OAAAC,EACA,QAAAC,EACA,iBAAAC,EACA,WAAAT,EACA,YAAAI,CACF,CAEF,CAEQ,qBAA0C,CAChD,MAAMY,EAAc,KAAK,IAAI,sBAAsB,EACnD,OAAIA,EAAY,mBAAqB,yBAAuB,UACnD,UAELA,EAAY,WAAW,OAAS,WAC3B,aAUkB,OAAIA,EAAY,WAAW,QAAS,QAAQ,KAC3C,QAAK,IAAI,KAAI,QAAK,IAAI,CACpD,CACF",
6
+ "names": ["BuildEIP712ContextTask_exports", "__export", "BuildEIP712ContextTask", "ZERO_ADDRESS", "__toCommonJS", "import_device_management_kit", "import_ethers", "import_purify_ts", "import_semver", "import_Types", "api", "contextModule", "parser", "data", "domainHash", "typesRecord", "EIP712Domain", "rest", "messageHash", "parsed", "types", "domain", "message", "clearSignContext", "version", "verifyingContract", "chainId", "fieldsValues", "v", "filters", "deviceState"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var a=require("@ledgerhq/device-management-kit"),e=require("purify-ts"),f=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),t=require("../../typed-data/model/Types"),u=require("./BuildEIP712ContextTask");describe("BuildEIP712ContextTask",()=>{const o=(0,f.makeDeviceActionInternalApiMock)(),i={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},n={parse:vi.fn()},c={domain:{name:"Permit2",chainId:137,verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3"},primaryType:"PermitSingle",message:{details:{token:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",amount:"69420000000000000000",expiration:"1718184249",nonce:"0"},spender:"0xec7be89e9d109e7e3fec59c222cf297125fefda2",sigDeadline:"1715594049"},types:{PermitSingle:[{name:"details",type:"PermitDetails"},{name:"spender",type:"address"},{name:"sigDeadline",type:"uint256"}],PermitDetails:[{name:"token",type:"address"},{name:"amount",type:"uint"},{name:"expiration",type:"uint"},{name:"nonce",type:"uint"}]}},d={PermitSingle:{details:new t.StructType("PermitDetails"),spender:new t.PrimitiveType("address","address",e.Nothing),sigDeadline:new t.PrimitiveType("uint256","uint",(0,e.Just)(32))},PermitDetails:{token:new t.PrimitiveType("address","address",e.Nothing),amount:new t.PrimitiveType("uint160","uint",(0,e.Just)(20)),expiration:new t.PrimitiveType("uint48","uint",(0,e.Just)(6)),nonce:new t.PrimitiveType("uint48","uint",(0,e.Just)(6))}},p=[{path:"",type:"",value:new t.TypedDataValueRoot("EIP712Domain")},{path:"chainId",type:"uint256",value:new t.TypedDataValueField(Uint8Array.from([137]))}],l=[{path:"",type:"",value:new t.TypedDataValueRoot("PermitSingle")},{path:"details.amount",type:"uint160",value:new t.TypedDataValueField(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new t.TypedDataValueField(Uint8Array.from([19]))}],m={type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},tokens:{},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}};beforeEach(()=>{vi.resetAllMocks()}),it("Build context with clear signing context not supported by the device",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,c);n.parse.mockReturnValueOnce((0,e.Right)({types:d,domain:p,message:l})),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:a.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:a.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Bitcoin",version:"1.0"},deviceModelId:a.DeviceModelId.FLEX});const r=await s.run();expect(r).toStrictEqual({types:d,domain:p,message:l,clearSignContext:e.Nothing,domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"})}),it("Build context with no clear signing context",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,c);n.parse.mockReturnValueOnce((0,e.Right)({types:d,domain:p,message:l})),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:a.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:a.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:a.DeviceModelId.FLEX}),i.getTypedDataFilters.mockResolvedValueOnce({type:"error",error:new Error("no filter")});const r=await s.run();expect(r).toStrictEqual({types:d,domain:p,message:l,clearSignContext:e.Nothing,domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"})}),it("Build context with clear signing context",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,c);n.parse.mockReturnValueOnce((0,e.Right)({types:d,domain:p,message:l})),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:a.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:a.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:a.DeviceModelId.FLEX}),i.getTypedDataFilters.mockResolvedValueOnce(m);const r=await s.run();expect(r).toStrictEqual({types:d,domain:p,message:l,clearSignContext:(0,e.Just)(m),domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"}),expect(n.parse).toHaveBeenCalledWith(c),expect(i.getTypedDataFilters).toHaveBeenCalledWith({verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3",chainId:137,version:"v2",schema:c.types,fieldsValues:[{path:"details.amount",value:Uint8Array.from([18])},{path:"details.expiration",value:Uint8Array.from([19])}]})}),it("Build context with clear signing context V1",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,c);n.parse.mockReturnValueOnce((0,e.Right)({types:d,domain:p,message:l})),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:a.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:a.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.11.0"},deviceModelId:a.DeviceModelId.FLEX}),i.getTypedDataFilters.mockResolvedValueOnce(m),await s.run(),expect(i.getTypedDataFilters).toHaveBeenCalledWith({verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3",chainId:137,version:"v1",schema:c.types,fieldsValues:[{path:"details.amount",value:Uint8Array.from([18])},{path:"details.expiration",value:Uint8Array.from([19])}]})}),it("Should throw error if no primary type",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,{...c,primaryType:""});n.parse.mockReturnValueOnce((0,e.Right)({types:d,domain:p,message:l}));try{await s.run()}catch(r){expect(r).toBeInstanceOf(Error),expect(r.message).toBe('Primary type "" is not defined in the types.')}}),it("Should throw an error if parsing fails",async()=>{const s=new u.BuildEIP712ContextTask(o,i,n,c);n.parse.mockReturnValueOnce((0,e.Left)(new Error("Parsing error")));try{await s.run()}catch(r){expect(r).toBeInstanceOf(Error),expect(r.message).toBe("Parsing error")}})});
2
+ //# sourceMappingURL=BuildEIP712ContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildEIP712ContextTask.test.ts"],
4
+ "sourcesContent": ["import { type TypedDataClearSignContextSuccess } from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Left, Nothing, Right } from \"purify-ts\";\n\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport {\n PrimitiveType,\n StructType,\n TypedDataValueField,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport { BuildEIP712ContextTask } from \"./BuildEIP712ContextTask\";\n\ndescribe(\"BuildEIP712ContextTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n const contextMouleMock = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const parserMock = {\n parse: vi.fn(),\n };\n\n const TEST_DATA = {\n domain: {\n name: \"Permit2\",\n chainId: 137,\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n },\n primaryType: \"PermitSingle\",\n message: {\n details: {\n token: \"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n amount: \"69420000000000000000\",\n expiration: \"1718184249\",\n nonce: \"0\",\n },\n spender: \"0xec7be89e9d109e7e3fec59c222cf297125fefda2\",\n sigDeadline: \"1715594049\",\n },\n types: {\n PermitSingle: [\n {\n name: \"details\",\n type: \"PermitDetails\",\n },\n {\n name: \"spender\",\n type: \"address\",\n },\n {\n name: \"sigDeadline\",\n type: \"uint256\",\n },\n ],\n PermitDetails: [\n { name: \"token\", type: \"address\" },\n { name: \"amount\", type: \"uint\" },\n { name: \"expiration\", type: \"uint\" },\n { name: \"nonce\", type: \"uint\" },\n ],\n },\n };\n\n const TEST_TYPES = {\n PermitSingle: {\n details: new StructType(\"PermitDetails\"),\n spender: new PrimitiveType(\"address\", \"address\", Nothing),\n sigDeadline: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n },\n 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: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n ];\n const TEST_MESSAGE_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"PermitSingle\"),\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([0x13])),\n },\n ];\n const TEST_CLEAR_SIGN_CONTEXT: TypedDataClearSignContextSuccess = {\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 1,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n tokens: {},\n filters: {\n \"details.amount\": {\n displayName: \"Amount allowance\",\n path: \"details.amount\",\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n tokenIndex: 255,\n type: \"amount\",\n },\n },\n };\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n it(\"Build context with clear signing context not supported by the device\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Bitcoin\", version: \"1.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n });\n\n it(\"Build context with no clear signing context\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce({\n type: \"error\",\n error: new Error(\"no filter\"),\n });\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n });\n\n it(\"Build context with clear signing context\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce(\n TEST_CLEAR_SIGN_CONTEXT,\n );\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n expect(parserMock.parse).toHaveBeenCalledWith(TEST_DATA);\n expect(contextMouleMock.getTypedDataFilters).toHaveBeenCalledWith({\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n chainId: 137,\n version: \"v2\",\n schema: TEST_DATA[\"types\"],\n fieldsValues: [\n {\n path: \"details.amount\",\n value: Uint8Array.from([0x12]),\n },\n {\n path: \"details.expiration\",\n value: Uint8Array.from([0x13]),\n },\n ],\n });\n });\n\n it(\"Build context with clear signing context V1\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.11.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce(\n TEST_CLEAR_SIGN_CONTEXT,\n );\n // WHEN\n await task.run();\n // THEN\n expect(contextMouleMock.getTypedDataFilters).toHaveBeenCalledWith({\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n chainId: 137,\n version: \"v1\",\n schema: TEST_DATA[\"types\"],\n fieldsValues: [\n {\n path: \"details.amount\",\n value: Uint8Array.from([0x12]),\n },\n {\n path: \"details.expiration\",\n value: Uint8Array.from([0x13]),\n },\n ],\n });\n });\n\n it(\"Should throw error if no primary type\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n {\n ...TEST_DATA,\n primaryType: \"\",\n },\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n // WHEN\n try {\n await task.run();\n } catch (e) {\n // THEN\n expect(e).toBeInstanceOf(Error);\n // @ts-expect-error\n expect(e.message).toBe('Primary type \"\" is not defined in the types.');\n }\n });\n\n it(\"Should throw an error if parsing fails\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(Left(new Error(\"Parsing error\")));\n // WHEN\n try {\n await task.run();\n } catch (e) {\n // THEN\n expect(e).toBeInstanceOf(Error);\n // @ts-expect-error\n expect(e.message).toBe(\"Parsing error\");\n }\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_device_management_kit", "import_purify_ts", "import_makeInternalApi", "import_Types", "import_BuildEIP712ContextTask", "apiMock", "contextMouleMock", "parserMock", "TEST_DATA", "TEST_TYPES", "TEST_DOMAIN_VALUES", "TEST_MESSAGE_VALUES", "TEST_CLEAR_SIGN_CONTEXT", "task", "builtContext", "e"]
7
+ }
@@ -1,31 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BuildTransactionContextTask = void 0;
4
- class BuildTransactionContextTask {
5
- args;
6
- constructor(args) {
7
- this.args = args;
8
- }
9
- async run() {
10
- const { contextModule, mapper, transaction, options, challenge } = this.args;
11
- const parsed = mapper.mapTransactionToSubset(transaction);
12
- parsed.ifLeft((err) => {
13
- throw err;
14
- });
15
- const { subset, serializedTransaction } = parsed.unsafeCoerce();
16
- const clearSignContexts = await contextModule.getContexts({
17
- challenge,
18
- domain: options.domain,
19
- ...subset,
20
- });
21
- // TODO: for now we ignore the error contexts
22
- // as we consider that they are warnings and not blocking
23
- const clearSignContextsSuccess = clearSignContexts.filter((context) => context.type !== "error");
24
- return {
25
- clearSignContexts: clearSignContextsSuccess,
26
- serializedTransaction,
27
- };
28
- }
29
- }
30
- exports.BuildTransactionContextTask = BuildTransactionContextTask;
31
- //# sourceMappingURL=BuildTransactionContextTask.js.map
1
+ "use strict";var d=Object.defineProperty;var A=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var M=Object.prototype.hasOwnProperty;var h=(n,e)=>{for(var o in e)d(n,o,{get:e[o],enumerable:!0})},O=(n,e,o,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of E(e))!M.call(n,a)&&a!==o&&d(n,a,{get:()=>e[a],enumerable:!(s=A(e,a))||s.enumerable});return n};var R=n=>O(d({},"__esModule",{value:!0}),n);var D={};h(D,{BuildTransactionContextTask:()=>v});module.exports=R(D);var r=require("@ledgerhq/context-module"),c=require("@ledgerhq/device-management-kit"),S=require("semver"),f=require("../../app-binder/constant/plugins");class v{constructor(e,o){this.api=e;this.args=o}async run(){const{contextModule:e,mapper:o,transaction:s,options:a,challenge:m}=this.args,y=this.api.getDeviceSessionState(),C=o.mapTransactionToSubset(s);C.ifLeft(t=>{throw t});const{subset:T,serializedTransaction:x,type:g}=C.unsafeCoerce(),u=await e.getContexts({challenge:m??void 0,domain:a.domain,deviceModelId:y.deviceModelId,...T}),p=u.filter(t=>t.type!==r.ClearSignContextType.ERROR&&t.type!==r.ClearSignContextType.ENUM),I=u.filter(t=>t.type===r.ClearSignContextType.ENUM);let l=[];const i=p.find(t=>t.type===r.ClearSignContextType.TRANSACTION_INFO);if(i&&!i.certificate)throw new Error("Transaction info certificate is missing");if(!this.supportsGenericParser(y)||i===void 0)l=p.filter(t=>t.type!==r.ClearSignContextType.TRANSACTION_INFO&&t.type!==r.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION);else{const t=p.filter(N=>N.type===r.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION);l={transactionInfo:i.payload,transactionInfoCertificate:i.certificate,transactionFields:t,transactionEnums:I}}return{clearSignContexts:l,serializedTransaction:x,chainId:T.chainId,transactionType:g}}supportsGenericParser(e){if(e.sessionStateType===c.DeviceSessionStateType.Connected)return!1;if(e.currentApp.name!=="Ethereum"&&!f.ETHEREUM_PLUGINS.includes(e.currentApp.name))throw new Error("Unsupported app");return e.deviceModelId===c.DeviceModelId.NANO_S?!1:(0,S.gte)(e.currentApp.version,"1.15.0")}}0&&(module.exports={BuildTransactionContextTask});
2
+ //# sourceMappingURL=BuildTransactionContextTask.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"BuildTransactionContextTask.js","sourceRoot":"","sources":["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.ts"],"names":[],"mappings":";;;AAsBA,MAAa,2BAA2B;IACT;IAA7B,YAA6B,IAAqC;QAArC,SAAI,GAAJ,IAAI,CAAiC;IAAG,CAAC;IAEtE,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,GAC9D,IAAI,CAAC,IAAI,CAAC;QACZ,MAAM,MAAM,GAAG,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,CAAC;QAC1D,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACpB,MAAM,GAAG,CAAC;QACZ,CAAC,CAAC,CAAC;QACH,MAAM,EAAE,MAAM,EAAE,qBAAqB,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAEhE,MAAM,iBAAiB,GAAG,MAAM,aAAa,CAAC,WAAW,CAAC;YACxD,SAAS;YACT,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,GAAG,MAAM;SACV,CAAC,CAAC;QAEH,6CAA6C;QAC7C,yDAAyD;QACzD,MAAM,wBAAwB,GAC5B,iBAAiB,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;QAElE,OAAO;YACL,iBAAiB,EAAE,wBAAwB;YAC3C,qBAAqB;SACtB,CAAC;IACJ,CAAC;CACF;AA5BD,kEA4BC"}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextSuccess,\n type ClearSignContextSuccessType,\n ClearSignContextType,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n type DeviceSessionState,\n DeviceSessionStateType,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { gte } from \"semver\";\n\nimport { type TransactionOptions } from \"@api/model/TransactionOptions\";\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nimport { type GenericContext } from \"./ProvideTransactionGenericContextTask\";\n\nexport type BuildTransactionTaskResult = {\n readonly clearSignContexts: ClearSignContextSuccess[] | GenericContext;\n readonly serializedTransaction: Uint8Array;\n readonly chainId: number;\n readonly transactionType: TransactionType;\n};\n\nexport type BuildTransactionContextTaskArgs = {\n readonly contextModule: ContextModule;\n readonly mapper: TransactionMapperService;\n readonly transaction: Uint8Array;\n readonly options: TransactionOptions;\n readonly challenge: string | null;\n};\n\nexport class BuildTransactionContextTask {\n constructor(\n private readonly api: InternalApi,\n private readonly args: BuildTransactionContextTaskArgs,\n ) {}\n\n async run(): Promise<BuildTransactionTaskResult> {\n const { contextModule, mapper, transaction, options, challenge } =\n this.args;\n const deviceState = this.api.getDeviceSessionState();\n\n const parsed = mapper.mapTransactionToSubset(transaction);\n parsed.ifLeft((err) => {\n throw err;\n });\n const { subset, serializedTransaction, type } = parsed.unsafeCoerce();\n\n const clearSignContexts = await contextModule.getContexts({\n challenge: challenge ?? undefined,\n domain: options.domain,\n deviceModelId: deviceState.deviceModelId,\n ...subset,\n });\n\n // NOTE: we need to filter out the ENUM and ERROR types\n // ENUM are handled differently\n // ERROR are not handled at all for now\n const clearSignContextsSuccess: ClearSignContextSuccess<\n Exclude<ClearSignContextSuccessType, ClearSignContextType.ENUM>\n >[] = clearSignContexts.filter(\n (context) =>\n context.type !== ClearSignContextType.ERROR &&\n context.type !== ClearSignContextType.ENUM,\n );\n\n // Retrieve all ENUM contexts\n const transactionEnums: ClearSignContextSuccess<ClearSignContextType.ENUM>[] =\n clearSignContexts.filter(\n (context) => context.type === ClearSignContextType.ENUM,\n );\n\n let filteredContexts: ClearSignContextSuccess[] | GenericContext = [];\n const transactionInfo = clearSignContextsSuccess.find(\n (ctx) => ctx.type === ClearSignContextType.TRANSACTION_INFO,\n );\n\n if (transactionInfo && !transactionInfo.certificate) {\n throw new Error(\"Transaction info certificate is missing\");\n }\n\n // If the device does not support the generic parser,\n // we need to filter out the transaction info and transaction field description\n // as they are not supported by the device\n if (\n !this.supportsGenericParser(deviceState) ||\n transactionInfo === undefined\n ) {\n filteredContexts = clearSignContextsSuccess.filter(\n (ctx) =>\n ctx.type !== ClearSignContextType.TRANSACTION_INFO &&\n ctx.type !== ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n );\n } else {\n const transactionFields = clearSignContextsSuccess.filter(\n (ctx) =>\n ctx.type === ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n );\n filteredContexts = {\n transactionInfo: transactionInfo.payload,\n transactionInfoCertificate: transactionInfo.certificate!,\n transactionFields,\n transactionEnums,\n };\n }\n\n return {\n clearSignContexts: filteredContexts,\n serializedTransaction,\n chainId: subset.chainId,\n transactionType: type,\n };\n }\n\n private supportsGenericParser(deviceState: DeviceSessionState): boolean {\n if (deviceState.sessionStateType === DeviceSessionStateType.Connected) {\n return false;\n }\n\n if (\n deviceState.currentApp.name !== \"Ethereum\" &&\n !ETHEREUM_PLUGINS.includes(deviceState.currentApp.name)\n ) {\n // Sanity check, should never happen as open app is called before this task\n throw new Error(\"Unsupported app\");\n }\n\n if (deviceState.deviceModelId === DeviceModelId.NANO_S) {\n return false;\n }\n return gte(deviceState.currentApp.version, \"1.15.0\");\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,iCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAKO,oCACPC,EAKO,2CACPC,EAAoB,kBAIpBC,EAAiC,iDAoB1B,MAAML,CAA4B,CACvC,YACmBM,EACAC,EACjB,CAFiB,SAAAD,EACA,UAAAC,CAChB,CAEH,MAAM,KAA2C,CAC/C,KAAM,CAAE,cAAAC,EAAe,OAAAC,EAAQ,YAAAC,EAAa,QAAAC,EAAS,UAAAC,CAAU,EAC7D,KAAK,KACDC,EAAc,KAAK,IAAI,sBAAsB,EAE7CC,EAASL,EAAO,uBAAuBC,CAAW,EACxDI,EAAO,OAAQC,GAAQ,CACrB,MAAMA,CACR,CAAC,EACD,KAAM,CAAE,OAAAC,EAAQ,sBAAAC,EAAuB,KAAAC,CAAK,EAAIJ,EAAO,aAAa,EAE9DK,EAAoB,MAAMX,EAAc,YAAY,CACxD,UAAWI,GAAa,OACxB,OAAQD,EAAQ,OAChB,cAAeE,EAAY,cAC3B,GAAGG,CACL,CAAC,EAKKI,EAEAD,EAAkB,OACrBE,GACCA,EAAQ,OAAS,uBAAqB,OACtCA,EAAQ,OAAS,uBAAqB,IAC1C,EAGMC,EACJH,EAAkB,OACfE,GAAYA,EAAQ,OAAS,uBAAqB,IACrD,EAEF,IAAIE,EAA+D,CAAC,EACpE,MAAMC,EAAkBJ,EAAyB,KAC9CK,GAAQA,EAAI,OAAS,uBAAqB,gBAC7C,EAEA,GAAID,GAAmB,CAACA,EAAgB,YACtC,MAAM,IAAI,MAAM,yCAAyC,EAM3D,GACE,CAAC,KAAK,sBAAsBX,CAAW,GACvCW,IAAoB,OAEpBD,EAAmBH,EAAyB,OACzCK,GACCA,EAAI,OAAS,uBAAqB,kBAClCA,EAAI,OAAS,uBAAqB,6BACtC,MACK,CACL,MAAMC,EAAoBN,EAAyB,OAChDK,GACCA,EAAI,OAAS,uBAAqB,6BACtC,EACAF,EAAmB,CACjB,gBAAiBC,EAAgB,QACjC,2BAA4BA,EAAgB,YAC5C,kBAAAE,EACA,iBAAAJ,CACF,CACF,CAEA,MAAO,CACL,kBAAmBC,EACnB,sBAAAN,EACA,QAASD,EAAO,QAChB,gBAAiBE,CACnB,CACF,CAEQ,sBAAsBL,EAA0C,CACtE,GAAIA,EAAY,mBAAqB,yBAAuB,UAC1D,MAAO,GAGT,GACEA,EAAY,WAAW,OAAS,YAChC,CAAC,mBAAiB,SAASA,EAAY,WAAW,IAAI,EAGtD,MAAM,IAAI,MAAM,iBAAiB,EAGnC,OAAIA,EAAY,gBAAkB,gBAAc,OACvC,MAEF,OAAIA,EAAY,WAAW,QAAS,QAAQ,CACrD,CACF",
6
+ "names": ["BuildTransactionContextTask_exports", "__export", "BuildTransactionContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_semver", "import_plugins", "api", "args", "contextModule", "mapper", "transaction", "options", "challenge", "deviceState", "parsed", "err", "subset", "serializedTransaction", "type", "clearSignContexts", "clearSignContextsSuccess", "context", "transactionEnums", "filteredContexts", "transactionInfo", "ctx", "transactionFields"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var a=require("@ledgerhq/context-module"),e=require("@ledgerhq/device-management-kit"),T=require("ethers"),l=require("purify-ts"),S=require("../../app-binder/constant/plugins"),C=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),u=require("./BuildTransactionContextTask");describe("BuildTransactionContextTask",()=>{const p={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},r={mapTransactionToSubset:vi.fn()},x={domain:"domain-name.eth"},y=(0,e.hexaStringToBuffer)(T.Transaction.from({chainId:1n,nonce:0,data:"0x"}).unsignedSerialized),c={keyUsageNumber:1,payload:new Uint8Array([1,2,3])};let d;const o=(0,C.makeDeviceActionInternalApiMock)();beforeEach(()=>{vi.resetAllMocks(),d={contextModule:p,mapper:r,transaction:y,options:x,challenge:"challenge"}}),it("should build the transaction context without clear sign contexts",async()=>{const n=new Uint8Array([1,2,3]),t=[],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:t,serializedTransaction:n,chainId:1,transactionType:0})}),it("should build the transaction context with clear sign contexts",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.NFT,payload:"payload-2"}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:t,serializedTransaction:n,chainId:1,transactionType:2})}),it("should build the transaction context with generic-parser context",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-1",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:a.ClearSignContextType.ENUM,payload:"payload-3",id:1,value:2,certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.15.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:{transactionInfo:"payload-1",transactionInfoCertificate:c,transactionFields:[t[1],t[3]],transactionEnums:[t[2]]},serializedTransaction:n,chainId:1,transactionType:2})}),it("should build the transaction context with generic-parser context and a plugin instead of Ethereum app",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-1",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:a.ClearSignContextType.ENUM,payload:"payload-3",id:1,value:2,certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:S.ETHEREUM_PLUGINS[0],version:"1.15.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:{transactionInfo:"payload-1",transactionInfoCertificate:c,transactionFields:[t[1],t[3]],transactionEnums:[t[2]]},serializedTransaction:n,chainId:1,transactionType:2})}),it("should call the mapper with the transaction",async()=>{const n=new Uint8Array([1,2,3]),t=[],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX}),await new u.BuildTransactionContextTask(o,d).run(),expect(r.mapTransactionToSubset).toHaveBeenCalledWith(y)}),it("should call the context module with the correct parameters",async()=>{const n=new Uint8Array([1,2,3]),t=[],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX}),await new u.BuildTransactionContextTask(o,d).run(),expect(p.getContexts).toHaveBeenCalledWith({deviceModelId:e.DeviceModelId.FLEX,challenge:"challenge",domain:"domain-name.eth",...s.subset})}),it("should throw an error if the mapper returns an error",async()=>{const n=new Error("error");r.mapTransactionToSubset.mockReturnValueOnce((0,l.Left)(n)),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const t=new u.BuildTransactionContextTask(o,d);await expect(t.run()).rejects.toThrow(n)}),it("should exclude error contexts from the result",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.ERROR,error:new Error("error")},{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.ERROR,error:new Error("error")},{type:a.ClearSignContextType.NFT,payload:"payload-2"}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:[t[1],t[3]],serializedTransaction:n,chainId:1,transactionType:0})}),it("should exclude generic-parser contexts from the result on old apps",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"transaction_info",certificate:c},{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"transaction_field"},{type:a.ClearSignContextType.NFT,payload:"payload-2"},{type:a.ClearSignContextType.ENUM,payload:"enum",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:[t[1],t[3]],serializedTransaction:n,chainId:1,transactionType:0})}),it("should exclude generic-parser contexts from the result if no transaction_info was found",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"transaction_field"},{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.ENUM,payload:"enum",id:1,value:2},{type:a.ClearSignContextType.NFT,payload:"payload-2"}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:0};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:[t[1],t[3]],serializedTransaction:n,chainId:1,transactionType:0})}),it("should exclude legacy contexts from the result for generic-parser transactions",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-2",certificate:c},{type:a.ClearSignContextType.EXTERNAL_PLUGIN,payload:"payload-3"},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"},{type:a.ClearSignContextType.ENUM,payload:"payload-5",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.15.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,d).run();expect(i).toEqual({clearSignContexts:{transactionInfo:"payload-2",transactionInfoCertificate:c,transactionFields:[t[3]],transactionEnums:[t[4]]},serializedTransaction:n,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with a nano s device",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-2",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:a.ClearSignContextType.ENUM,payload:"payload-4",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:e.DeviceModelId.NANO_S});const i=await new u.BuildTransactionContextTask(o,{...d,challenge:null}).run();expect(i).toEqual({clearSignContexts:[t[0]],serializedTransaction:n,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with an old app version",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-2",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:a.ClearSignContextType.ENUM,payload:"payload-4",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,{...d,challenge:null}).run();expect(i).toEqual({clearSignContexts:[t[0]],serializedTransaction:n,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with a non ready device",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TOKEN,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-2",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:a.ClearSignContextType.ENUM,payload:"payload-4",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.Connected,deviceStatus:e.DeviceStatus.NOT_CONNECTED,deviceModelId:e.DeviceModelId.FLEX});const i=await new u.BuildTransactionContextTask(o,{...d,challenge:null}).run();expect(i).toEqual({clearSignContexts:[t[0]],serializedTransaction:n,chainId:1,transactionType:2})}),it("should throw an error if the app is not ethereum compatible",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-1",certificate:c},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:a.ClearSignContextType.ENUM,payload:"payload-3",id:1,value:2,certificate:c}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Not Ethereum Compatible",version:"1.14.0"},deviceModelId:e.DeviceModelId.FLEX});const i=new u.BuildTransactionContextTask(o,d);await expect(i.run()).rejects.toThrow("Unsupported app")}),it("should return an error if the transaction info certificate is missing",async()=>{const n=new Uint8Array([1,2,3]),t=[{type:a.ClearSignContextType.TRANSACTION_INFO,payload:"payload-1"},{type:a.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:a.ClearSignContextType.ENUM,payload:"payload-3",id:1,value:2}],s={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:n,type:2};r.mapTransactionToSubset.mockReturnValueOnce((0,l.Right)(s)),p.getContexts.mockResolvedValueOnce(t),o.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:e.DeviceModelId.FLEX});const i=new u.BuildTransactionContextTask(o,d);await expect(i.run()).rejects.toThrow("Transaction info certificate is missing")})});
2
+ //# sourceMappingURL=BuildTransactionContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.test.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContext,\n ClearSignContextType,\n type PkiCertificate,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n} from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { type TransactionMapperResult } from \"@internal/transaction/service/mapper/model/TransactionMapperResult\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nimport {\n BuildTransactionContextTask,\n type BuildTransactionContextTaskArgs,\n} from \"./BuildTransactionContextTask\";\n\ndescribe(\"BuildTransactionContextTask\", () => {\n const contextModuleMock = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const mapperMock = {\n mapTransactionToSubset: vi.fn(),\n };\n const defaultOptions = {\n domain: \"domain-name.eth\",\n };\n const defaultTransaction: Uint8Array = hexaStringToBuffer(\n Transaction.from({\n chainId: 1n,\n nonce: 0,\n data: \"0x\",\n }).unsignedSerialized,\n )!;\n const defaultCertificate: PkiCertificate = {\n keyUsageNumber: 1,\n payload: new Uint8Array([0x01, 0x02, 0x03]),\n };\n\n let defaultArgs: BuildTransactionContextTaskArgs;\n const apiMock = makeDeviceActionInternalApiMock();\n\n beforeEach(() => {\n vi.resetAllMocks();\n\n defaultArgs = {\n contextModule: contextModuleMock,\n mapper: mapperMock as unknown as TransactionMapperService,\n transaction: defaultTransaction,\n options: defaultOptions,\n challenge: \"challenge\",\n };\n });\n\n it(\"should build the transaction context without clear sign contexts\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts,\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should build the transaction context with clear sign contexts\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts,\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should build the transaction context with generic-parser context\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[1], clearSignContexts[3]],\n transactionEnums: [clearSignContexts[2]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should build the transaction context with generic-parser context and a plugin instead of Ethereum app\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: ETHEREUM_PLUGINS[0]!, version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[1], clearSignContexts[3]],\n transactionEnums: [clearSignContexts[2]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should call the mapper with the transaction\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n await new BuildTransactionContextTask(apiMock, defaultArgs).run();\n\n // THEN\n expect(mapperMock.mapTransactionToSubset).toHaveBeenCalledWith(\n defaultTransaction,\n );\n });\n\n it(\"should call the context module with the correct parameters\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n await new BuildTransactionContextTask(apiMock, defaultArgs).run();\n\n // THEN\n expect(contextModuleMock.getContexts).toHaveBeenCalledWith({\n deviceModelId: DeviceModelId.FLEX,\n challenge: \"challenge\",\n domain: \"domain-name.eth\",\n ...mapperResult.subset,\n });\n });\n\n it(\"should throw an error if the mapper returns an error\", async () => {\n // GIVEN\n const error = new Error(\"error\");\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Left(error));\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(error);\n });\n\n it(\"should exclude error contexts from the result\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.ERROR,\n error: new Error(\"error\"),\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.ERROR,\n error: new Error(\"error\"),\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude generic-parser contexts from the result on old apps\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"transaction_info\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"transaction_field\",\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"enum\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude generic-parser contexts from the result if no transaction_info was found\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"transaction_field\",\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"enum\",\n id: 1,\n value: 2,\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude legacy contexts from the result for generic-parser transactions\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.EXTERNAL_PLUGIN,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-5\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-2\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[3]],\n transactionEnums: [clearSignContexts[4]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with a nano s device\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.NANO_S,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with an old app version\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with a non ready device\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.Connected,\n deviceStatus: DeviceStatus.NOT_CONNECTED,\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should throw an error if the app is not ethereum compatible\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Not Ethereum Compatible\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Unsupported app\");\n });\n\n it(\"should return an error if the transaction info certificate is missing\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\n \"Transaction info certificate is missing\",\n );\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_device_management_kit", "import_ethers", "import_purify_ts", "import_plugins", "import_makeInternalApi", "import_BuildTransactionContextTask", "contextModuleMock", "mapperMock", "defaultOptions", "defaultTransaction", "defaultCertificate", "defaultArgs", "apiMock", "serializedTransaction", "clearSignContexts", "mapperResult", "result", "error", "task"]
7
+ }
@@ -1,188 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ProvideEIP712ContextTask = void 0;
4
- const context_module_1 = require("@ledgerhq/context-module");
5
- const device_management_kit_1 = require("@ledgerhq/device-management-kit");
6
- const purify_ts_1 = require("purify-ts");
7
- const ProvideTokenInformationCommand_1 = require("../../app-binder/command/ProvideTokenInformationCommand");
8
- const SendEIP712FilteringCommand_1 = require("../../app-binder/command/SendEIP712FilteringCommand");
9
- const SendEIP712StructDefinitionCommand_1 = require("../../app-binder/command/SendEIP712StructDefinitionCommand");
10
- const SendEIP712StructImplemCommand_1 = require("../../app-binder/command/SendEIP712StructImplemCommand");
11
- const SendEIP712StructImplemTask_1 = require("../../app-binder/task/SendEIP712StructImplemTask");
12
- const Types_1 = require("../../typed-data/model/Types");
13
- class ProvideEIP712ContextTask {
14
- api;
15
- args;
16
- constructor(api, args) {
17
- this.api = api;
18
- this.args = args;
19
- }
20
- async run() {
21
- let result = (0, device_management_kit_1.CommandResultFactory)({ data: undefined });
22
- // Provide the structure definitions.
23
- // Should be sent before struct implementations, as described here:
24
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition
25
- // Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:
26
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering
27
- // Therefore it should be normalized on both sides: sorted per keys
28
- const types = Object.entries(this.args.types).sort(([aKey], [bKey]) => aKey.localeCompare(bKey));
29
- for (const [structName, fields] of types) {
30
- result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand_1.SendEIP712StructDefinitionCommand({
31
- command: SendEIP712StructDefinitionCommand_1.StructDefinitionCommand.Name,
32
- name: structName,
33
- }));
34
- if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
35
- return result;
36
- }
37
- for (const [fieldName, fieldType] of Object.entries(fields)) {
38
- result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand_1.SendEIP712StructDefinitionCommand({
39
- command: SendEIP712StructDefinitionCommand_1.StructDefinitionCommand.Field,
40
- name: fieldName,
41
- type: fieldType,
42
- }));
43
- if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
44
- return result;
45
- }
46
- }
47
- }
48
- if (this.args.clearSignContext.isJust()) {
49
- // Activate the filtering, before sending domain and message implementations, as described here:
50
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation
51
- result = await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({ type: SendEIP712FilteringCommand_1.Eip712FilterType.Activation }));
52
- if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
53
- return result;
54
- }
55
- }
56
- // Send domain implementation values.
57
- for (const value of this.args.domain) {
58
- await this.getImplementationTask(value).run();
59
- }
60
- if (this.args.clearSignContext.isJust()) {
61
- // Send MessageInformation filter.
62
- // Should be sent between Domain and Message implementations, as described here:
63
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info
64
- result = await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
65
- type: SendEIP712FilteringCommand_1.Eip712FilterType.MessageInfo,
66
- displayName: this.args.clearSignContext.extract().messageInfo.displayName,
67
- filtersCount: this.args.clearSignContext.extract().messageInfo.filtersCount,
68
- signature: this.args.clearSignContext.extract().messageInfo.signature,
69
- }));
70
- if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
71
- return result;
72
- }
73
- }
74
- // Send message implementation values
75
- const tokensIndexes = {};
76
- for (const value of this.args.message) {
77
- // Provide the descriptors of tokens referenced by the message, if any.
78
- // Keep a map of all device indexes for those provided tokens.
79
- const maybeError = await this.provideTokenInformation(value, tokensIndexes);
80
- if (maybeError.isJust()) {
81
- return maybeError.extract();
82
- }
83
- // If there is a filter, it should be sent just before the corresponding implementation:
84
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token
85
- const maybeResult = await this.provideFiltering(value, tokensIndexes);
86
- if (maybeResult.isJust() &&
87
- !(0, device_management_kit_1.isSuccessCommandResult)(maybeResult.extract())) {
88
- return maybeResult.extract();
89
- }
90
- // Provide message value implementation
91
- result = await this.getImplementationTask(value).run();
92
- if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
93
- return result;
94
- }
95
- }
96
- return result;
97
- }
98
- getImplementationTask(value) {
99
- if (value.value instanceof Types_1.TypedDataValueRoot) {
100
- return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
101
- type: SendEIP712StructImplemCommand_1.StructImplemType.ROOT,
102
- value: value.value.root,
103
- });
104
- }
105
- else if (value.value instanceof Types_1.TypedDataValueArray) {
106
- return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
107
- type: SendEIP712StructImplemCommand_1.StructImplemType.ARRAY,
108
- value: value.value.length,
109
- });
110
- }
111
- else {
112
- return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
113
- type: SendEIP712StructImplemCommand_1.StructImplemType.FIELD,
114
- value: value.value.data,
115
- });
116
- }
117
- }
118
- async provideTokenInformation(value, tokensIndexes) {
119
- if (this.args.clearSignContext.isJust()) {
120
- const filter = this.args.clearSignContext.extract().filters[value.path];
121
- // Tokens descriptors only needed when a tokenIndex is available in filter.
122
- // It should be sent to the device only 1 time so tokensIndexes has to be checked.
123
- if (filter !== undefined &&
124
- (filter.type === "amount" || filter.type === "token") &&
125
- tokensIndexes[filter.tokenIndex] === undefined) {
126
- const descriptorIndex = filter.tokenIndex;
127
- const tokens = this.args.clearSignContext.extract().tokens;
128
- const token = tokens[descriptorIndex];
129
- if (token === undefined) {
130
- return purify_ts_1.Nothing;
131
- }
132
- const provideTokenInfoResult = await this.api.sendCommand(new ProvideTokenInformationCommand_1.ProvideTokenInformationCommand({ payload: token }));
133
- if (!(0, device_management_kit_1.isSuccessCommandResult)(provideTokenInfoResult)) {
134
- return purify_ts_1.Maybe.of(provideTokenInfoResult);
135
- }
136
- let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;
137
- // The token corresponding to the Verifying Contract of message domain has a special index value, as described here:
138
- // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value
139
- if (Number(descriptorIndex) === context_module_1.VERIFYING_CONTRACT_TOKEN_INDEX) {
140
- deviceIndex = context_module_1.VERIFYING_CONTRACT_TOKEN_INDEX;
141
- }
142
- // Save the token index in the device slots. That index will be used by later filtering commands.
143
- tokensIndexes[Number(descriptorIndex)] = deviceIndex;
144
- }
145
- }
146
- return purify_ts_1.Nothing;
147
- }
148
- async provideFiltering(value, tokensIndexes) {
149
- if (this.args.clearSignContext.isJust()) {
150
- const filter = this.args.clearSignContext.extract().filters[value.path];
151
- if (filter === undefined ||
152
- ((filter.type === "amount" || filter.type === "token") &&
153
- tokensIndexes[filter.tokenIndex] === undefined)) {
154
- return purify_ts_1.Nothing;
155
- }
156
- switch (filter.type) {
157
- case "datetime":
158
- return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
159
- type: SendEIP712FilteringCommand_1.Eip712FilterType.Datetime,
160
- displayName: filter.displayName,
161
- signature: filter.signature,
162
- })));
163
- case "raw":
164
- return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
165
- type: SendEIP712FilteringCommand_1.Eip712FilterType.Raw,
166
- displayName: filter.displayName,
167
- signature: filter.signature,
168
- })));
169
- case "token":
170
- return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
171
- type: SendEIP712FilteringCommand_1.Eip712FilterType.Token,
172
- tokenIndex: tokensIndexes[filter.tokenIndex],
173
- signature: filter.signature,
174
- })));
175
- case "amount":
176
- return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
177
- type: SendEIP712FilteringCommand_1.Eip712FilterType.Amount,
178
- displayName: filter.displayName,
179
- tokenIndex: tokensIndexes[filter.tokenIndex],
180
- signature: filter.signature,
181
- })));
182
- }
183
- }
184
- return purify_ts_1.Nothing;
185
- }
186
- }
187
- exports.ProvideEIP712ContextTask = ProvideEIP712ContextTask;
188
- //# sourceMappingURL=ProvideEIP712ContextTask.js.map
1
+ "use strict";var I=Object.defineProperty;var v=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var R=Object.prototype.hasOwnProperty;var D=(d,e)=>{for(var n in e)I(d,n,{get:e[n],enumerable:!0})},A=(d,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of w(e))!R.call(d,t)&&t!==n&&I(d,t,{get:()=>e[t],enumerable:!(a=v(e,t))||a.enumerable});return d};var N=d=>A(I({},"__esModule",{value:!0}),d);var F={};D(F,{ProvideEIP712ContextTask:()=>P});module.exports=N(F);var h=require("@ledgerhq/context-module"),s=require("@ledgerhq/device-management-kit"),l=require("purify-ts"),k=require("../../app-binder/command/ProvideTokenInformationCommand"),i=require("../../app-binder/command/SendEIP712FilteringCommand"),c=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),f=require("../../app-binder/command/SendEIP712StructImplemCommand"),g=require("../../app-binder/task/SendEIP712StructImplemTask"),y=require("../../typed-data/model/Types");const S=5;class P{constructor(e,n){this.api=e;this.args=n}async run(){const e=(0,s.CommandResultFactory)({data:void 0}),n=Object.entries(this.args.types).sort(([t],[o])=>t.localeCompare(o));for(const[t,o]of n){const r=await this.api.sendCommand(new c.SendEIP712StructDefinitionCommand({command:c.StructDefinitionCommand.Name,name:t}));if(!(0,s.isSuccessCommandResult)(r))return r;for(const[p,m]of Object.entries(o)){const x=await this.api.sendCommand(new c.SendEIP712StructDefinitionCommand({command:c.StructDefinitionCommand.Field,name:p,type:m}));if(!(0,s.isSuccessCommandResult)(x))return x}}if(this.args.clearSignContext.isJust()){const t=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Activation}));if(!(0,s.isSuccessCommandResult)(t))return t}for(const t of this.args.domain){const r=await this.getImplementationTask(t).run();if(!(0,s.isSuccessCommandResult)(r))return r}if(this.args.clearSignContext.isJust()){const t=this.args.clearSignContext.extract(),o=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.MessageInfo,displayName:t.messageInfo.displayName,filtersCount:t.messageInfo.filtersCount,signature:t.messageInfo.signature}));if(!(0,s.isSuccessCommandResult)(o))return o}const a={indexes:{},nextIndex:0};for(const t of this.args.message){const o=await this.provideTokenInformation(t,a);if(o.isJust())return o.extract();const r=await this.filterValue(t,a);if(r.isJust()&&!(0,s.isSuccessCommandResult)(r.extract()))return r.extract();const m=await this.getImplementationTask(t).run();if(!(0,s.isSuccessCommandResult)(m))return m;if(this.args.clearSignContext.isJust()&&t.value instanceof y.TypedDataValueArray&&t.value.length===0){const E=Object.entries(this.args.clearSignContext.extract().filters).filter(([u])=>u.startsWith(`${t.path}.[]`)).map(([,u])=>u);for(const u of E){const C=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.DiscardedPath,path:u.path}));if(!(0,s.isSuccessCommandResult)(C))return C;const T=await this.provideFiltering(u,a,!0);if(!(0,s.isSuccessCommandResult)(T))return T}}}return e}getImplementationTask(e){return e.value instanceof y.TypedDataValueRoot?new g.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.ROOT,value:e.value.root}):e.value instanceof y.TypedDataValueArray?new g.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.ARRAY,value:e.value.length}):new g.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.FIELD,value:e.value.data})}async provideTokenInformation(e,n){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a!==void 0&&(a.type==="amount"||a.type==="token")&&n.indexes[a.tokenIndex]===void 0){const t=a.tokenIndex,r=this.args.clearSignContext.extract().tokens[t];if(r===void 0)return l.Nothing;const p=await this.api.sendCommand(new k.ProvideTokenInformationCommand({payload:r}));if(!(0,s.isSuccessCommandResult)(p))return l.Maybe.of(p);let{tokenIndex:m}=p.data;n.nextIndex=(m+1)%S,Number(t)===h.VERIFYING_CONTRACT_TOKEN_INDEX&&(m=h.VERIFYING_CONTRACT_TOKEN_INDEX),n.indexes[Number(t)]=m}}return l.Nothing}async filterValue(e,n){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a===void 0)return l.Nothing;const t=await this.provideFiltering(a,n,!1);return l.Maybe.of(t)}return l.Nothing}async provideFiltering(e,n,a){switch(e.type){case"datetime":return await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Datetime,discarded:a,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Raw,discarded:a,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,n),await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Token,discarded:a,tokenIndex:n.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,n),await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Amount,discarded:a,displayName:e.displayName,tokenIndex:n.indexes[e.tokenIndex],signature:e.signature}));default:return(0,s.CommandResultFactory)({error:new s.InvalidStatusWordError("ProvideEIP712ContextTask/provideFiltering - Unhandled filter type")})}}sanitizeDeviceIndex(e,n){n.indexes[e]===void 0&&(n.indexes[e]=n.nextIndex,n.nextIndex=(n.nextIndex+1)%S)}}0&&(module.exports={ProvideEIP712ContextTask});
2
+ //# sourceMappingURL=ProvideEIP712ContextTask.js.map