@ledgerhq/context-module 0.0.0-legacy-speculos-datasource-20250821095840 → 0.0.0-lifi-with-logger-20251208144248

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 (871) hide show
  1. package/lib/cjs/package.json +38 -34
  2. package/lib/cjs/src/ContextModule.js +1 -1
  3. package/lib/cjs/src/ContextModule.js.map +1 -1
  4. package/lib/cjs/src/ContextModuleBuilder.js +1 -1
  5. package/lib/cjs/src/ContextModuleBuilder.js.map +3 -3
  6. package/lib/cjs/src/ContextModuleBuilder.test.js +1 -1
  7. package/lib/cjs/src/ContextModuleBuilder.test.js.map +3 -3
  8. package/lib/cjs/src/DefaultContextModule.js +1 -1
  9. package/lib/cjs/src/DefaultContextModule.js.map +3 -3
  10. package/lib/cjs/src/DefaultContextModule.test.js +1 -1
  11. package/lib/cjs/src/DefaultContextModule.test.js.map +3 -3
  12. package/lib/cjs/src/calldata/data/CalldataDescriptorDataSource.js +2 -0
  13. package/lib/cjs/src/calldata/data/CalldataDescriptorDataSource.js.map +7 -0
  14. package/lib/cjs/src/calldata/data/HttpCalldataDescriptorDataSource.js +2 -0
  15. package/lib/cjs/src/calldata/data/HttpCalldataDescriptorDataSource.js.map +7 -0
  16. package/lib/cjs/src/calldata/data/HttpCalldataDescriptorDataSource.test.js +2 -0
  17. package/lib/cjs/src/calldata/data/HttpCalldataDescriptorDataSource.test.js.map +7 -0
  18. package/lib/cjs/src/calldata/data/dto/CalldataDto.js +2 -0
  19. package/lib/cjs/src/calldata/data/dto/CalldataDto.js.map +7 -0
  20. package/lib/cjs/src/calldata/di/calldataModuleFactory.js +2 -0
  21. package/lib/cjs/src/calldata/di/calldataModuleFactory.js.map +7 -0
  22. package/lib/cjs/src/calldata/di/calldataTypes.js +2 -0
  23. package/lib/cjs/src/calldata/di/calldataTypes.js.map +7 -0
  24. package/lib/cjs/src/calldata/domain/CalldataContextLoader.js +2 -0
  25. package/lib/cjs/src/calldata/domain/CalldataContextLoader.js.map +7 -0
  26. package/lib/cjs/src/calldata/domain/CalldataContextLoader.test.js +2 -0
  27. package/lib/cjs/src/calldata/domain/CalldataContextLoader.test.js.map +7 -0
  28. package/lib/cjs/src/config/model/ContextModuleConfig.js +1 -1
  29. package/lib/cjs/src/config/model/ContextModuleConfig.js.map +1 -1
  30. package/lib/cjs/src/di.js +1 -1
  31. package/lib/cjs/src/di.js.map +3 -3
  32. package/lib/cjs/src/dynamic-network/data/DynamicNetworkDataSource.js +2 -0
  33. package/lib/cjs/src/dynamic-network/data/DynamicNetworkDataSource.js.map +7 -0
  34. package/lib/cjs/src/dynamic-network/data/HttpDynamicNetworkDataSource.js +2 -0
  35. package/lib/cjs/src/dynamic-network/data/HttpDynamicNetworkDataSource.js.map +7 -0
  36. package/lib/cjs/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.js +2 -0
  37. package/lib/cjs/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.js.map +7 -0
  38. package/lib/cjs/src/dynamic-network/data/dto/DynamicNetworkApiResponseDto.js +2 -0
  39. package/lib/cjs/src/dynamic-network/data/dto/DynamicNetworkApiResponseDto.js.map +7 -0
  40. package/lib/cjs/src/dynamic-network/di/dynamicNetworkModuleFactory.js +2 -0
  41. package/lib/cjs/src/dynamic-network/di/dynamicNetworkModuleFactory.js.map +7 -0
  42. package/lib/cjs/src/dynamic-network/di/dynamicNetworkTypes.js +2 -0
  43. package/lib/cjs/src/dynamic-network/di/dynamicNetworkTypes.js.map +7 -0
  44. package/lib/cjs/src/dynamic-network/domain/DynamicNetworkContextLoader.js +2 -0
  45. package/lib/cjs/src/dynamic-network/domain/DynamicNetworkContextLoader.js.map +7 -0
  46. package/lib/cjs/src/dynamic-network/domain/DynamicNetworkContextLoader.test.js +2 -0
  47. package/lib/cjs/src/dynamic-network/domain/DynamicNetworkContextLoader.test.js.map +7 -0
  48. package/lib/cjs/src/dynamic-network/model/DynamicNetworkConfiguration.js +2 -0
  49. package/lib/cjs/src/dynamic-network/model/DynamicNetworkConfiguration.js.map +7 -0
  50. package/lib/cjs/src/external-plugin/domain/ExternalPluginContextLoader.js +1 -1
  51. package/lib/cjs/src/external-plugin/domain/ExternalPluginContextLoader.js.map +3 -3
  52. package/lib/cjs/src/external-plugin/domain/ExternalPluginContextLoader.test.js +1 -1
  53. package/lib/cjs/src/external-plugin/domain/ExternalPluginContextLoader.test.js.map +3 -3
  54. package/lib/cjs/src/index.js +1 -1
  55. package/lib/cjs/src/index.js.map +2 -2
  56. package/lib/cjs/src/nft/data/HttpNftDataSource.js +1 -1
  57. package/lib/cjs/src/nft/data/HttpNftDataSource.js.map +2 -2
  58. package/lib/cjs/src/nft/data/HttpNftDataSource.test.js +1 -1
  59. package/lib/cjs/src/nft/data/HttpNftDataSource.test.js.map +2 -2
  60. package/lib/cjs/src/nft/di/nftModuleFactory.js +1 -1
  61. package/lib/cjs/src/nft/di/nftModuleFactory.js.map +3 -3
  62. package/lib/cjs/src/nft/di/nftTypes.js +1 -1
  63. package/lib/cjs/src/nft/di/nftTypes.js.map +2 -2
  64. package/lib/cjs/src/nft/domain/NftContextFieldLoader.js +2 -0
  65. package/lib/cjs/src/nft/domain/NftContextFieldLoader.js.map +7 -0
  66. package/lib/cjs/src/nft/domain/NftContextFieldLoader.test.js +2 -0
  67. package/lib/cjs/src/nft/domain/NftContextFieldLoader.test.js.map +7 -0
  68. package/lib/cjs/src/nft/domain/NftContextLoader.js +1 -1
  69. package/lib/cjs/src/nft/domain/NftContextLoader.js.map +3 -3
  70. package/lib/cjs/src/nft/domain/NftContextLoader.test.js +1 -1
  71. package/lib/cjs/src/nft/domain/NftContextLoader.test.js.map +3 -3
  72. package/lib/cjs/src/pki/domain/DefaultPkiCertificateLoader.js +1 -1
  73. package/lib/cjs/src/pki/domain/DefaultPkiCertificateLoader.js.map +3 -3
  74. package/lib/cjs/src/pki/domain/DefaultPkiCertificateLoader.test.js +1 -1
  75. package/lib/cjs/src/pki/domain/DefaultPkiCertificateLoader.test.js.map +3 -3
  76. package/lib/cjs/src/pki/model/KeyUsage.js +1 -1
  77. package/lib/cjs/src/pki/model/KeyUsage.js.map +2 -2
  78. package/lib/cjs/src/pki/model/PkiCertificateInfo.js +1 -1
  79. package/lib/cjs/src/pki/model/PkiCertificateInfo.js.map +1 -1
  80. package/lib/cjs/src/proxy/data/HttpProxyDataSource.js +2 -0
  81. package/lib/cjs/src/proxy/data/HttpProxyDataSource.js.map +7 -0
  82. package/lib/cjs/src/proxy/data/HttpProxyDataSource.test.js +2 -0
  83. package/lib/cjs/src/proxy/data/HttpProxyDataSource.test.js.map +7 -0
  84. package/lib/cjs/src/proxy/data/HttpSafeProxyDataSource.js +2 -0
  85. package/lib/cjs/src/proxy/data/HttpSafeProxyDataSource.js.map +7 -0
  86. package/lib/cjs/src/proxy/data/HttpSafeProxyDataSource.test.js +2 -0
  87. package/lib/cjs/src/proxy/data/HttpSafeProxyDataSource.test.js.map +7 -0
  88. package/lib/cjs/src/proxy/data/ProxyDataSource.js +2 -0
  89. package/lib/cjs/src/proxy/data/ProxyDataSource.js.map +7 -0
  90. package/lib/cjs/src/proxy/data/dto/ProxyDelegateCallDto.js +2 -0
  91. package/lib/cjs/src/proxy/data/dto/ProxyDelegateCallDto.js.map +7 -0
  92. package/lib/cjs/src/{transaction → proxy}/data/dto/ProxyImplementationAddressDto.js.map +1 -1
  93. package/lib/cjs/src/proxy/data/dto/SafeProxyImplementationAddressDto.js +2 -0
  94. package/lib/cjs/src/proxy/data/dto/SafeProxyImplementationAddressDto.js.map +7 -0
  95. package/lib/cjs/src/proxy/di/proxyModuleFactory.js +2 -0
  96. package/lib/cjs/src/proxy/di/proxyModuleFactory.js.map +7 -0
  97. package/lib/cjs/src/proxy/di/proxyModuleFactory.test.js +2 -0
  98. package/lib/cjs/src/proxy/di/proxyModuleFactory.test.js.map +7 -0
  99. package/lib/cjs/src/proxy/di/proxyTypes.js +2 -0
  100. package/lib/cjs/src/proxy/di/proxyTypes.js.map +7 -0
  101. package/lib/cjs/src/proxy/domain/ProxyContextFieldLoader.js +2 -0
  102. package/lib/cjs/src/proxy/domain/ProxyContextFieldLoader.js.map +7 -0
  103. package/lib/cjs/src/proxy/domain/ProxyContextFieldLoader.test.js +2 -0
  104. package/lib/cjs/src/proxy/domain/ProxyContextFieldLoader.test.js.map +7 -0
  105. package/lib/cjs/src/proxy/model/ProxyDelegateCall.js +2 -0
  106. package/lib/cjs/src/proxy/model/ProxyDelegateCall.js.map +7 -0
  107. package/lib/cjs/src/safe/data/HttpSafeAccountDataSource.js +2 -0
  108. package/lib/cjs/src/safe/data/HttpSafeAccountDataSource.js.map +7 -0
  109. package/lib/cjs/src/safe/data/HttpSafeAccountDataSource.test.js +2 -0
  110. package/lib/cjs/src/safe/data/HttpSafeAccountDataSource.test.js.map +7 -0
  111. package/lib/cjs/src/safe/data/SafeAccountDataSource.js +2 -0
  112. package/lib/cjs/src/safe/data/SafeAccountDataSource.js.map +7 -0
  113. package/lib/cjs/src/safe/data/dto/SafeAccountDto.js +2 -0
  114. package/lib/cjs/src/safe/data/dto/SafeAccountDto.js.map +7 -0
  115. package/lib/cjs/src/safe/di/safeModuleFactory.js +2 -0
  116. package/lib/cjs/src/safe/di/safeModuleFactory.js.map +7 -0
  117. package/lib/cjs/src/safe/di/safeModuleFactory.test.js +2 -0
  118. package/lib/cjs/src/safe/di/safeModuleFactory.test.js.map +7 -0
  119. package/lib/cjs/src/safe/di/safeTypes.js +2 -0
  120. package/lib/cjs/src/safe/di/safeTypes.js.map +7 -0
  121. package/lib/cjs/src/safe/domain/SafeAddressLoader.js +2 -0
  122. package/lib/cjs/src/safe/domain/SafeAddressLoader.js.map +7 -0
  123. package/lib/cjs/src/safe/domain/SafeAddressLoader.test.js +2 -0
  124. package/lib/cjs/src/safe/domain/SafeAddressLoader.test.js.map +7 -0
  125. package/lib/cjs/src/shared/domain/ContextFieldLoader.js +2 -0
  126. package/lib/cjs/src/shared/domain/ContextFieldLoader.js.map +7 -0
  127. package/lib/cjs/src/shared/domain/ContextLoader.js +1 -1
  128. package/lib/cjs/src/shared/domain/ContextLoader.js.map +1 -1
  129. package/lib/cjs/src/shared/model/ClearSignContext.js +1 -1
  130. package/lib/cjs/src/shared/model/ClearSignContext.js.map +3 -3
  131. package/lib/cjs/src/shared/model/SolanaContextTypes.js +2 -0
  132. package/lib/cjs/src/shared/model/SolanaContextTypes.js.map +7 -0
  133. package/lib/cjs/src/shared/model/SolanaTransactionContext.js +1 -1
  134. package/lib/cjs/src/shared/model/SolanaTransactionContext.js.map +1 -1
  135. package/lib/cjs/src/shared/model/TransactionSubset.js +1 -1
  136. package/lib/cjs/src/shared/model/TransactionSubset.js.map +1 -1
  137. package/lib/cjs/src/shared/model/TypedDataClearSignContext.js +1 -1
  138. package/lib/cjs/src/shared/model/TypedDataClearSignContext.js.map +3 -3
  139. package/lib/cjs/src/shared/model/TypedDataContext.js +1 -1
  140. package/lib/cjs/src/shared/model/TypedDataContext.js.map +1 -1
  141. package/lib/cjs/src/shared/utils/KeyUsageMapper.js +1 -1
  142. package/lib/cjs/src/shared/utils/KeyUsageMapper.js.map +2 -2
  143. package/lib/cjs/src/shared/utils/KeyUsageMapper.test.js +1 -1
  144. package/lib/cjs/src/shared/utils/KeyUsageMapper.test.js.map +2 -2
  145. package/lib/cjs/src/solana/data/HttpSolanaOwnerInfoDataSource.js +1 -1
  146. package/lib/cjs/src/solana/data/HttpSolanaOwnerInfoDataSource.js.map +3 -3
  147. package/lib/cjs/src/solana/data/HttpSolanaOwnerInfoDataSource.test.js +1 -1
  148. package/lib/cjs/src/solana/data/HttpSolanaOwnerInfoDataSource.test.js.map +2 -2
  149. package/lib/cjs/src/solana/data/SolanaDataSource.js +1 -1
  150. package/lib/cjs/src/solana/data/SolanaDataSource.js.map +1 -1
  151. package/lib/cjs/src/solana/domain/DefaultSolanaContextLoader.js +1 -1
  152. package/lib/cjs/src/solana/domain/DefaultSolanaContextLoader.js.map +3 -3
  153. package/lib/cjs/src/solana/domain/DefaultSolanaContextLoader.test.js +1 -1
  154. package/lib/cjs/src/solana/domain/DefaultSolanaContextLoader.test.js.map +3 -3
  155. package/lib/cjs/src/solana/domain/solanaContextTypes.js +1 -1
  156. package/lib/cjs/src/solana/domain/solanaContextTypes.js.map +1 -1
  157. package/lib/cjs/src/solanaLifi/data/HttpSolanaLifiDataSource.js +2 -0
  158. package/lib/cjs/src/solanaLifi/data/HttpSolanaLifiDataSource.js.map +7 -0
  159. package/lib/cjs/src/solanaLifi/data/HttpSolanaLifiDataSource.test.js +2 -0
  160. package/lib/cjs/src/solanaLifi/data/HttpSolanaLifiDataSource.test.js.map +7 -0
  161. package/lib/cjs/src/solanaLifi/data/SolanaLifiDataSource.js +2 -0
  162. package/lib/cjs/src/solanaLifi/data/SolanaLifiDataSource.js.map +7 -0
  163. package/lib/cjs/src/solanaLifi/di/lifiModuleFactory.js +2 -0
  164. package/lib/cjs/src/solanaLifi/di/lifiModuleFactory.js.map +7 -0
  165. package/lib/cjs/src/solanaLifi/di/solanaLifiTypes.js +2 -0
  166. package/lib/cjs/src/solanaLifi/di/solanaLifiTypes.js.map +7 -0
  167. package/lib/cjs/src/solanaLifi/domain/SolanaLifiContextLoader.js +2 -0
  168. package/lib/cjs/src/solanaLifi/domain/SolanaLifiContextLoader.js.map +7 -0
  169. package/lib/cjs/src/solanaLifi/domain/SolanaLifiContextLoader.test.js +2 -0
  170. package/lib/cjs/src/solanaLifi/domain/SolanaLifiContextLoader.test.js.map +7 -0
  171. package/lib/cjs/src/solanaToken/data/HttpSolanaTokenDataSource.js +2 -0
  172. package/lib/cjs/src/solanaToken/data/HttpSolanaTokenDataSource.js.map +7 -0
  173. package/lib/cjs/src/solanaToken/data/HttpSolanaTokenDataSource.test.js +7 -0
  174. package/lib/cjs/src/solanaToken/data/HttpSolanaTokenDataSource.test.js.map +7 -0
  175. package/lib/cjs/src/solanaToken/data/SolanaTokenDataSource.js +2 -0
  176. package/lib/cjs/src/solanaToken/data/SolanaTokenDataSource.js.map +7 -0
  177. package/lib/cjs/src/solanaToken/di/solanaTokenTypes.js +2 -0
  178. package/lib/cjs/src/solanaToken/di/solanaTokenTypes.js.map +7 -0
  179. package/lib/cjs/src/solanaToken/di/tokenModuleFactory.js +2 -0
  180. package/lib/cjs/src/solanaToken/di/tokenModuleFactory.js.map +7 -0
  181. package/lib/cjs/src/solanaToken/domain/SolanaTokenContextLoader.js +2 -0
  182. package/lib/cjs/src/solanaToken/domain/SolanaTokenContextLoader.js.map +7 -0
  183. package/lib/cjs/src/solanaToken/domain/SolanaTokenContextLoader.test.js +2 -0
  184. package/lib/cjs/src/solanaToken/domain/SolanaTokenContextLoader.test.js.map +7 -0
  185. package/lib/cjs/src/token/data/HttpTokenDataSource.js +1 -1
  186. package/lib/cjs/src/token/data/HttpTokenDataSource.js.map +2 -2
  187. package/lib/cjs/src/token/data/HttpTokenDataSource.test.js +1 -1
  188. package/lib/cjs/src/token/data/HttpTokenDataSource.test.js.map +2 -2
  189. package/lib/cjs/src/token/di/tokenModuleFactory.js +1 -1
  190. package/lib/cjs/src/token/di/tokenModuleFactory.js.map +3 -3
  191. package/lib/cjs/src/token/di/tokenTypes.js +1 -1
  192. package/lib/cjs/src/token/di/tokenTypes.js.map +2 -2
  193. package/lib/cjs/src/token/domain/TokenContextFieldLoader.js +2 -0
  194. package/lib/cjs/src/token/domain/TokenContextFieldLoader.js.map +7 -0
  195. package/lib/cjs/src/token/domain/TokenContextFieldLoader.test.js +2 -0
  196. package/lib/cjs/src/token/domain/TokenContextFieldLoader.test.js.map +7 -0
  197. package/lib/cjs/src/token/domain/TokenContextLoader.js +1 -1
  198. package/lib/cjs/src/token/domain/TokenContextLoader.js.map +3 -3
  199. package/lib/cjs/src/token/domain/TokenContextLoader.test.js +1 -1
  200. package/lib/cjs/src/token/domain/TokenContextLoader.test.js.map +3 -3
  201. package/lib/cjs/src/transaction-check/data/HttpTransactionCheckDataSource.js +2 -0
  202. package/lib/cjs/src/transaction-check/data/HttpTransactionCheckDataSource.js.map +7 -0
  203. package/lib/cjs/src/transaction-check/data/HttpTransactionCheckDataSource.test.js +2 -0
  204. package/lib/cjs/src/transaction-check/data/HttpTransactionCheckDataSource.test.js.map +7 -0
  205. package/lib/cjs/src/transaction-check/data/HttpTypedDataCheckDataSource.js +2 -0
  206. package/lib/cjs/src/transaction-check/data/HttpTypedDataCheckDataSource.js.map +7 -0
  207. package/lib/cjs/src/transaction-check/data/HttpTypedDataCheckDataSource.test.js +2 -0
  208. package/lib/cjs/src/transaction-check/data/HttpTypedDataCheckDataSource.test.js.map +7 -0
  209. package/lib/cjs/src/transaction-check/data/TransactionCheckDataSource.js +2 -0
  210. package/lib/cjs/src/transaction-check/data/TransactionCheckDataSource.js.map +7 -0
  211. package/lib/cjs/src/transaction-check/data/TypedDataCheckDataSource.js +2 -0
  212. package/lib/cjs/src/transaction-check/data/TypedDataCheckDataSource.js.map +7 -0
  213. package/lib/cjs/src/transaction-check/data/dto/TransactionCheckDto.js +2 -0
  214. package/lib/cjs/src/transaction-check/data/dto/TransactionCheckDto.js.map +7 -0
  215. package/lib/cjs/src/transaction-check/data/dto/TypedDataCheckDto.js +2 -0
  216. package/lib/cjs/src/transaction-check/data/dto/TypedDataCheckDto.js.map +7 -0
  217. package/lib/cjs/src/transaction-check/di/transactionCheckModuleFactory.js +2 -0
  218. package/lib/cjs/src/transaction-check/di/transactionCheckModuleFactory.js.map +7 -0
  219. package/lib/cjs/src/transaction-check/di/transactionCheckTypes.js +2 -0
  220. package/lib/cjs/src/transaction-check/di/transactionCheckTypes.js.map +7 -0
  221. package/lib/cjs/src/transaction-check/domain/TransactionCheckContextLoader.js +2 -0
  222. package/lib/cjs/src/transaction-check/domain/TransactionCheckContextLoader.js.map +7 -0
  223. package/lib/cjs/src/transaction-check/domain/TransactionCheckContextLoader.test.js +2 -0
  224. package/lib/cjs/src/transaction-check/domain/TransactionCheckContextLoader.test.js.map +7 -0
  225. package/lib/cjs/src/transaction-check/domain/TypedDataCheckContextLoader.js +2 -0
  226. package/lib/cjs/src/transaction-check/domain/TypedDataCheckContextLoader.js.map +7 -0
  227. package/lib/cjs/src/transaction-check/domain/TypedDataCheckContextLoader.test.js +2 -0
  228. package/lib/cjs/src/transaction-check/domain/TypedDataCheckContextLoader.test.js.map +7 -0
  229. package/lib/cjs/src/trusted-name/data/HttpTrustedNameDataSource.js +1 -1
  230. package/lib/cjs/src/trusted-name/data/HttpTrustedNameDataSource.js.map +3 -3
  231. package/lib/cjs/src/trusted-name/data/HttpTrustedNameDataSource.test.js +1 -1
  232. package/lib/cjs/src/trusted-name/data/HttpTrustedNameDataSource.test.js.map +2 -2
  233. package/lib/cjs/src/trusted-name/data/TrustedNameDataSource.js +1 -1
  234. package/lib/cjs/src/trusted-name/data/TrustedNameDataSource.js.map +1 -1
  235. package/lib/cjs/src/trusted-name/data/TrustedNameDto.js +1 -1
  236. package/lib/cjs/src/trusted-name/data/TrustedNameDto.js.map +1 -1
  237. package/lib/cjs/src/trusted-name/di/trustedNameModuleFactory.js +1 -1
  238. package/lib/cjs/src/trusted-name/di/trustedNameModuleFactory.js.map +3 -3
  239. package/lib/cjs/src/trusted-name/di/trustedNameTypes.js +1 -1
  240. package/lib/cjs/src/trusted-name/di/trustedNameTypes.js.map +2 -2
  241. package/lib/cjs/src/trusted-name/domain/TrustedNameContextFieldLoader.js +2 -0
  242. package/lib/cjs/src/trusted-name/domain/TrustedNameContextFieldLoader.js.map +7 -0
  243. package/lib/cjs/src/trusted-name/domain/TrustedNameContextFieldLoader.test.js +2 -0
  244. package/lib/cjs/src/trusted-name/domain/TrustedNameContextFieldLoader.test.js.map +7 -0
  245. package/lib/cjs/src/trusted-name/domain/TrustedNameContextLoader.js +1 -1
  246. package/lib/cjs/src/trusted-name/domain/TrustedNameContextLoader.js.map +3 -3
  247. package/lib/cjs/src/trusted-name/domain/TrustedNameContextLoader.test.js +1 -1
  248. package/lib/cjs/src/trusted-name/domain/TrustedNameContextLoader.test.js.map +3 -3
  249. package/lib/cjs/src/typed-data/data/FiltersDto.js +1 -1
  250. package/lib/cjs/src/typed-data/data/FiltersDto.js.map +1 -1
  251. package/lib/cjs/src/typed-data/data/HttpTypedDataDataSource.js +1 -1
  252. package/lib/cjs/src/typed-data/data/HttpTypedDataDataSource.js.map +3 -3
  253. package/lib/cjs/src/typed-data/data/HttpTypedDataDataSource.test.js +1 -1
  254. package/lib/cjs/src/typed-data/data/HttpTypedDataDataSource.test.js.map +3 -3
  255. package/lib/cjs/src/typed-data/data/TypedDataDataSource.js +1 -1
  256. package/lib/cjs/src/typed-data/data/TypedDataDataSource.js.map +1 -1
  257. package/lib/cjs/src/typed-data/domain/DefaultTypedDataContextLoader.js +1 -1
  258. package/lib/cjs/src/typed-data/domain/DefaultTypedDataContextLoader.js.map +3 -3
  259. package/lib/cjs/src/typed-data/domain/DefaultTypedDataContextLoader.test.js +1 -1
  260. package/lib/cjs/src/typed-data/domain/DefaultTypedDataContextLoader.test.js.map +3 -3
  261. package/lib/cjs/src/uniswap/constants/uniswap.js +1 -1
  262. package/lib/cjs/src/uniswap/constants/uniswap.js.map +3 -3
  263. package/lib/cjs/src/uniswap/domain/UniswapContextLoader.js +1 -1
  264. package/lib/cjs/src/uniswap/domain/UniswapContextLoader.js.map +3 -3
  265. package/lib/cjs/src/uniswap/domain/UniswapContextLoader.test.js +1 -1
  266. package/lib/cjs/src/uniswap/domain/UniswapContextLoader.test.js.map +3 -3
  267. package/lib/esm/package.json +38 -34
  268. package/lib/esm/src/ContextModuleBuilder.js +1 -1
  269. package/lib/esm/src/ContextModuleBuilder.js.map +3 -3
  270. package/lib/esm/src/ContextModuleBuilder.test.js +1 -1
  271. package/lib/esm/src/ContextModuleBuilder.test.js.map +3 -3
  272. package/lib/esm/src/DefaultContextModule.js +1 -1
  273. package/lib/esm/src/DefaultContextModule.js.map +3 -3
  274. package/lib/esm/src/DefaultContextModule.test.js +1 -1
  275. package/lib/esm/src/DefaultContextModule.test.js.map +3 -3
  276. package/lib/esm/src/calldata/data/CalldataDescriptorDataSource.js +1 -0
  277. package/lib/esm/src/calldata/data/HttpCalldataDescriptorDataSource.js +2 -0
  278. package/lib/esm/src/calldata/data/HttpCalldataDescriptorDataSource.js.map +7 -0
  279. package/lib/esm/src/calldata/data/HttpCalldataDescriptorDataSource.test.js +2 -0
  280. package/lib/esm/src/calldata/data/HttpCalldataDescriptorDataSource.test.js.map +7 -0
  281. package/lib/esm/src/calldata/di/calldataModuleFactory.js +2 -0
  282. package/lib/esm/src/calldata/di/calldataModuleFactory.js.map +7 -0
  283. package/lib/esm/src/calldata/di/calldataTypes.js +2 -0
  284. package/lib/esm/src/calldata/di/calldataTypes.js.map +7 -0
  285. package/lib/esm/src/calldata/domain/CalldataContextLoader.js +2 -0
  286. package/lib/esm/src/calldata/domain/CalldataContextLoader.js.map +7 -0
  287. package/lib/esm/src/calldata/domain/CalldataContextLoader.test.js +2 -0
  288. package/lib/esm/src/calldata/domain/CalldataContextLoader.test.js.map +7 -0
  289. package/lib/esm/src/di.js +1 -1
  290. package/lib/esm/src/di.js.map +3 -3
  291. package/lib/esm/src/dynamic-network/data/DynamicNetworkDataSource.js +1 -0
  292. package/lib/esm/src/dynamic-network/data/HttpDynamicNetworkDataSource.js +2 -0
  293. package/lib/esm/src/dynamic-network/data/HttpDynamicNetworkDataSource.js.map +7 -0
  294. package/lib/esm/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.js +2 -0
  295. package/lib/esm/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.js.map +7 -0
  296. package/lib/esm/src/dynamic-network/data/dto/DynamicNetworkApiResponseDto.js +1 -0
  297. package/lib/esm/src/dynamic-network/di/dynamicNetworkModuleFactory.js +2 -0
  298. package/lib/esm/src/dynamic-network/di/dynamicNetworkModuleFactory.js.map +7 -0
  299. package/lib/esm/src/dynamic-network/di/dynamicNetworkTypes.js +2 -0
  300. package/lib/esm/src/dynamic-network/di/dynamicNetworkTypes.js.map +7 -0
  301. package/lib/esm/src/dynamic-network/domain/DynamicNetworkContextLoader.js +2 -0
  302. package/lib/esm/src/dynamic-network/domain/DynamicNetworkContextLoader.js.map +7 -0
  303. package/lib/esm/src/dynamic-network/domain/DynamicNetworkContextLoader.test.js +2 -0
  304. package/lib/esm/src/dynamic-network/domain/DynamicNetworkContextLoader.test.js.map +7 -0
  305. package/lib/esm/src/dynamic-network/model/DynamicNetworkConfiguration.js +1 -0
  306. package/lib/esm/src/external-plugin/domain/ExternalPluginContextLoader.js +1 -1
  307. package/lib/esm/src/external-plugin/domain/ExternalPluginContextLoader.js.map +3 -3
  308. package/lib/esm/src/external-plugin/domain/ExternalPluginContextLoader.test.js +1 -1
  309. package/lib/esm/src/external-plugin/domain/ExternalPluginContextLoader.test.js.map +3 -3
  310. package/lib/esm/src/index.js +1 -1
  311. package/lib/esm/src/index.js.map +2 -2
  312. package/lib/esm/src/nft/data/HttpNftDataSource.js +1 -1
  313. package/lib/esm/src/nft/data/HttpNftDataSource.js.map +2 -2
  314. package/lib/esm/src/nft/data/HttpNftDataSource.test.js +1 -1
  315. package/lib/esm/src/nft/data/HttpNftDataSource.test.js.map +2 -2
  316. package/lib/esm/src/nft/di/nftModuleFactory.js +1 -1
  317. package/lib/esm/src/nft/di/nftModuleFactory.js.map +3 -3
  318. package/lib/esm/src/nft/di/nftTypes.js +1 -1
  319. package/lib/esm/src/nft/di/nftTypes.js.map +2 -2
  320. package/lib/esm/src/nft/domain/NftContextFieldLoader.js +2 -0
  321. package/lib/esm/src/nft/domain/NftContextFieldLoader.js.map +7 -0
  322. package/lib/esm/src/nft/domain/NftContextFieldLoader.test.js +2 -0
  323. package/lib/esm/src/nft/domain/NftContextFieldLoader.test.js.map +7 -0
  324. package/lib/esm/src/nft/domain/NftContextLoader.js +1 -1
  325. package/lib/esm/src/nft/domain/NftContextLoader.js.map +3 -3
  326. package/lib/esm/src/nft/domain/NftContextLoader.test.js +1 -1
  327. package/lib/esm/src/nft/domain/NftContextLoader.test.js.map +3 -3
  328. package/lib/esm/src/pki/domain/DefaultPkiCertificateLoader.js +1 -1
  329. package/lib/esm/src/pki/domain/DefaultPkiCertificateLoader.js.map +3 -3
  330. package/lib/esm/src/pki/domain/DefaultPkiCertificateLoader.test.js +1 -1
  331. package/lib/esm/src/pki/domain/DefaultPkiCertificateLoader.test.js.map +3 -3
  332. package/lib/esm/src/pki/model/KeyUsage.js +1 -1
  333. package/lib/esm/src/pki/model/KeyUsage.js.map +2 -2
  334. package/lib/esm/src/proxy/data/HttpProxyDataSource.js +2 -0
  335. package/lib/esm/src/proxy/data/HttpProxyDataSource.js.map +7 -0
  336. package/lib/esm/src/proxy/data/HttpProxyDataSource.test.js +2 -0
  337. package/lib/esm/src/proxy/data/HttpProxyDataSource.test.js.map +7 -0
  338. package/lib/esm/src/proxy/data/HttpSafeProxyDataSource.js +2 -0
  339. package/lib/esm/src/proxy/data/HttpSafeProxyDataSource.js.map +7 -0
  340. package/lib/esm/src/proxy/data/HttpSafeProxyDataSource.test.js +2 -0
  341. package/lib/esm/src/proxy/data/HttpSafeProxyDataSource.test.js.map +7 -0
  342. package/lib/esm/src/proxy/data/ProxyDataSource.js +1 -0
  343. package/lib/esm/src/proxy/data/dto/SafeProxyImplementationAddressDto.js +1 -0
  344. package/lib/esm/src/proxy/di/proxyModuleFactory.js +2 -0
  345. package/lib/esm/src/proxy/di/proxyModuleFactory.js.map +7 -0
  346. package/lib/esm/src/proxy/di/proxyModuleFactory.test.js +2 -0
  347. package/lib/esm/src/proxy/di/proxyModuleFactory.test.js.map +7 -0
  348. package/lib/esm/src/proxy/di/proxyTypes.js +2 -0
  349. package/lib/esm/src/proxy/di/proxyTypes.js.map +7 -0
  350. package/lib/esm/src/proxy/domain/ProxyContextFieldLoader.js +2 -0
  351. package/lib/esm/src/proxy/domain/ProxyContextFieldLoader.js.map +7 -0
  352. package/lib/esm/src/proxy/domain/ProxyContextFieldLoader.test.js +2 -0
  353. package/lib/esm/src/proxy/domain/ProxyContextFieldLoader.test.js.map +7 -0
  354. package/lib/esm/src/safe/data/HttpSafeAccountDataSource.js +2 -0
  355. package/lib/esm/src/safe/data/HttpSafeAccountDataSource.js.map +7 -0
  356. package/lib/esm/src/safe/data/HttpSafeAccountDataSource.test.js +2 -0
  357. package/lib/esm/src/safe/data/HttpSafeAccountDataSource.test.js.map +7 -0
  358. package/lib/esm/src/safe/data/SafeAccountDataSource.js +1 -0
  359. package/lib/esm/src/safe/data/dto/SafeAccountDto.js +1 -0
  360. package/lib/esm/src/safe/data/dto/SafeAccountDto.js.map +7 -0
  361. package/lib/esm/src/safe/di/safeModuleFactory.js +2 -0
  362. package/lib/esm/src/safe/di/safeModuleFactory.js.map +7 -0
  363. package/lib/esm/src/safe/di/safeModuleFactory.test.js +2 -0
  364. package/lib/esm/src/safe/di/safeModuleFactory.test.js.map +7 -0
  365. package/lib/esm/src/safe/di/safeTypes.js +2 -0
  366. package/lib/esm/src/safe/di/safeTypes.js.map +7 -0
  367. package/lib/esm/src/safe/domain/SafeAddressLoader.js +2 -0
  368. package/lib/esm/src/safe/domain/SafeAddressLoader.js.map +7 -0
  369. package/lib/esm/src/safe/domain/SafeAddressLoader.test.js +2 -0
  370. package/lib/esm/src/safe/domain/SafeAddressLoader.test.js.map +7 -0
  371. package/lib/esm/src/shared/domain/ContextFieldLoader.js +1 -0
  372. package/lib/esm/src/shared/domain/ContextFieldLoader.js.map +7 -0
  373. package/lib/esm/src/shared/model/ClearSignContext.js +1 -1
  374. package/lib/esm/src/shared/model/ClearSignContext.js.map +3 -3
  375. package/lib/esm/src/shared/model/SolanaContextTypes.js +2 -0
  376. package/lib/esm/src/shared/model/SolanaContextTypes.js.map +7 -0
  377. package/lib/esm/src/shared/model/TypedDataClearSignContext.js +1 -1
  378. package/lib/esm/src/shared/model/TypedDataClearSignContext.js.map +3 -3
  379. package/lib/esm/src/shared/utils/KeyUsageMapper.js +1 -1
  380. package/lib/esm/src/shared/utils/KeyUsageMapper.js.map +2 -2
  381. package/lib/esm/src/shared/utils/KeyUsageMapper.test.js +1 -1
  382. package/lib/esm/src/shared/utils/KeyUsageMapper.test.js.map +2 -2
  383. package/lib/esm/src/solana/data/HttpSolanaOwnerInfoDataSource.js +1 -1
  384. package/lib/esm/src/solana/data/HttpSolanaOwnerInfoDataSource.js.map +3 -3
  385. package/lib/esm/src/solana/data/HttpSolanaOwnerInfoDataSource.test.js +1 -1
  386. package/lib/esm/src/solana/data/HttpSolanaOwnerInfoDataSource.test.js.map +2 -2
  387. package/lib/esm/src/solana/domain/DefaultSolanaContextLoader.js +1 -1
  388. package/lib/esm/src/solana/domain/DefaultSolanaContextLoader.js.map +3 -3
  389. package/lib/esm/src/solana/domain/DefaultSolanaContextLoader.test.js +1 -1
  390. package/lib/esm/src/solana/domain/DefaultSolanaContextLoader.test.js.map +3 -3
  391. package/lib/esm/src/solanaLifi/data/HttpSolanaLifiDataSource.js +2 -0
  392. package/lib/esm/src/solanaLifi/data/HttpSolanaLifiDataSource.js.map +7 -0
  393. package/lib/esm/src/solanaLifi/data/HttpSolanaLifiDataSource.test.js +2 -0
  394. package/lib/esm/src/solanaLifi/data/HttpSolanaLifiDataSource.test.js.map +7 -0
  395. package/lib/esm/src/solanaLifi/data/SolanaLifiDataSource.js +1 -0
  396. package/lib/esm/src/solanaLifi/data/SolanaLifiDataSource.js.map +7 -0
  397. package/lib/esm/src/solanaLifi/di/lifiModuleFactory.js +2 -0
  398. package/lib/esm/src/solanaLifi/di/lifiModuleFactory.js.map +7 -0
  399. package/lib/esm/src/solanaLifi/di/solanaLifiTypes.js +2 -0
  400. package/lib/esm/src/solanaLifi/di/solanaLifiTypes.js.map +7 -0
  401. package/lib/esm/src/solanaLifi/domain/SolanaLifiContextLoader.js +2 -0
  402. package/lib/esm/src/solanaLifi/domain/SolanaLifiContextLoader.js.map +7 -0
  403. package/lib/esm/src/solanaLifi/domain/SolanaLifiContextLoader.test.js +2 -0
  404. package/lib/esm/src/solanaLifi/domain/SolanaLifiContextLoader.test.js.map +7 -0
  405. package/lib/esm/src/solanaToken/data/HttpSolanaTokenDataSource.js +2 -0
  406. package/lib/esm/src/solanaToken/data/HttpSolanaTokenDataSource.js.map +7 -0
  407. package/lib/esm/src/solanaToken/data/HttpSolanaTokenDataSource.test.js +7 -0
  408. package/lib/esm/src/solanaToken/data/HttpSolanaTokenDataSource.test.js.map +7 -0
  409. package/lib/esm/src/solanaToken/data/SolanaTokenDataSource.js +1 -0
  410. package/lib/esm/src/solanaToken/data/SolanaTokenDataSource.js.map +7 -0
  411. package/lib/esm/src/solanaToken/di/solanaTokenTypes.js +2 -0
  412. package/lib/esm/src/solanaToken/di/solanaTokenTypes.js.map +7 -0
  413. package/lib/esm/src/solanaToken/di/tokenModuleFactory.js +2 -0
  414. package/lib/esm/src/solanaToken/di/tokenModuleFactory.js.map +7 -0
  415. package/lib/esm/src/solanaToken/domain/SolanaTokenContextLoader.js +2 -0
  416. package/lib/esm/src/solanaToken/domain/SolanaTokenContextLoader.js.map +7 -0
  417. package/lib/esm/src/solanaToken/domain/SolanaTokenContextLoader.test.js +2 -0
  418. package/lib/esm/src/solanaToken/domain/SolanaTokenContextLoader.test.js.map +7 -0
  419. package/lib/esm/src/token/data/HttpTokenDataSource.js +1 -1
  420. package/lib/esm/src/token/data/HttpTokenDataSource.js.map +2 -2
  421. package/lib/esm/src/token/data/HttpTokenDataSource.test.js +1 -1
  422. package/lib/esm/src/token/data/HttpTokenDataSource.test.js.map +2 -2
  423. package/lib/esm/src/token/di/tokenModuleFactory.js +1 -1
  424. package/lib/esm/src/token/di/tokenModuleFactory.js.map +3 -3
  425. package/lib/esm/src/token/di/tokenTypes.js +1 -1
  426. package/lib/esm/src/token/di/tokenTypes.js.map +2 -2
  427. package/lib/esm/src/token/domain/TokenContextFieldLoader.js +2 -0
  428. package/lib/esm/src/token/domain/TokenContextFieldLoader.js.map +7 -0
  429. package/lib/esm/src/token/domain/TokenContextFieldLoader.test.js +2 -0
  430. package/lib/esm/src/token/domain/TokenContextFieldLoader.test.js.map +7 -0
  431. package/lib/esm/src/token/domain/TokenContextLoader.js +1 -1
  432. package/lib/esm/src/token/domain/TokenContextLoader.js.map +3 -3
  433. package/lib/esm/src/token/domain/TokenContextLoader.test.js +1 -1
  434. package/lib/esm/src/token/domain/TokenContextLoader.test.js.map +3 -3
  435. package/lib/esm/src/transaction-check/data/HttpTransactionCheckDataSource.js +2 -0
  436. package/lib/esm/src/transaction-check/data/HttpTransactionCheckDataSource.js.map +7 -0
  437. package/lib/esm/src/transaction-check/data/HttpTransactionCheckDataSource.test.js +2 -0
  438. package/lib/esm/src/transaction-check/data/HttpTransactionCheckDataSource.test.js.map +7 -0
  439. package/lib/esm/src/transaction-check/data/HttpTypedDataCheckDataSource.js +2 -0
  440. package/lib/esm/src/transaction-check/data/HttpTypedDataCheckDataSource.js.map +7 -0
  441. package/lib/esm/src/transaction-check/data/HttpTypedDataCheckDataSource.test.js +2 -0
  442. package/lib/esm/src/transaction-check/data/HttpTypedDataCheckDataSource.test.js.map +7 -0
  443. package/lib/esm/src/transaction-check/data/TransactionCheckDataSource.js +1 -0
  444. package/lib/esm/src/transaction-check/data/TransactionCheckDataSource.js.map +7 -0
  445. package/lib/esm/src/transaction-check/data/TypedDataCheckDataSource.js +1 -0
  446. package/lib/esm/src/transaction-check/data/TypedDataCheckDataSource.js.map +7 -0
  447. package/lib/esm/src/transaction-check/data/dto/TransactionCheckDto.js +1 -0
  448. package/lib/esm/src/transaction-check/data/dto/TransactionCheckDto.js.map +7 -0
  449. package/lib/esm/src/transaction-check/data/dto/TypedDataCheckDto.js +1 -0
  450. package/lib/esm/src/transaction-check/data/dto/TypedDataCheckDto.js.map +7 -0
  451. package/lib/esm/src/transaction-check/di/transactionCheckModuleFactory.js +2 -0
  452. package/lib/esm/src/transaction-check/di/transactionCheckModuleFactory.js.map +7 -0
  453. package/lib/esm/src/transaction-check/di/transactionCheckTypes.js +2 -0
  454. package/lib/esm/src/transaction-check/di/transactionCheckTypes.js.map +7 -0
  455. package/lib/esm/src/transaction-check/domain/TransactionCheckContextLoader.js +2 -0
  456. package/lib/esm/src/transaction-check/domain/TransactionCheckContextLoader.js.map +7 -0
  457. package/lib/esm/src/transaction-check/domain/TransactionCheckContextLoader.test.js +2 -0
  458. package/lib/esm/src/transaction-check/domain/TransactionCheckContextLoader.test.js.map +7 -0
  459. package/lib/esm/src/transaction-check/domain/TypedDataCheckContextLoader.js +2 -0
  460. package/lib/esm/src/transaction-check/domain/TypedDataCheckContextLoader.js.map +7 -0
  461. package/lib/esm/src/transaction-check/domain/TypedDataCheckContextLoader.test.js +2 -0
  462. package/lib/esm/src/transaction-check/domain/TypedDataCheckContextLoader.test.js.map +7 -0
  463. package/lib/esm/src/trusted-name/data/HttpTrustedNameDataSource.js +1 -1
  464. package/lib/esm/src/trusted-name/data/HttpTrustedNameDataSource.js.map +3 -3
  465. package/lib/esm/src/trusted-name/data/HttpTrustedNameDataSource.test.js +1 -1
  466. package/lib/esm/src/trusted-name/data/HttpTrustedNameDataSource.test.js.map +2 -2
  467. package/lib/esm/src/trusted-name/di/trustedNameModuleFactory.js +1 -1
  468. package/lib/esm/src/trusted-name/di/trustedNameModuleFactory.js.map +3 -3
  469. package/lib/esm/src/trusted-name/di/trustedNameTypes.js +1 -1
  470. package/lib/esm/src/trusted-name/di/trustedNameTypes.js.map +2 -2
  471. package/lib/esm/src/trusted-name/domain/TrustedNameContextFieldLoader.js +2 -0
  472. package/lib/esm/src/trusted-name/domain/TrustedNameContextFieldLoader.js.map +7 -0
  473. package/lib/esm/src/trusted-name/domain/TrustedNameContextFieldLoader.test.js +2 -0
  474. package/lib/esm/src/trusted-name/domain/TrustedNameContextFieldLoader.test.js.map +7 -0
  475. package/lib/esm/src/trusted-name/domain/TrustedNameContextLoader.js +1 -1
  476. package/lib/esm/src/trusted-name/domain/TrustedNameContextLoader.js.map +3 -3
  477. package/lib/esm/src/trusted-name/domain/TrustedNameContextLoader.test.js +1 -1
  478. package/lib/esm/src/trusted-name/domain/TrustedNameContextLoader.test.js.map +3 -3
  479. package/lib/esm/src/typed-data/data/HttpTypedDataDataSource.js +1 -1
  480. package/lib/esm/src/typed-data/data/HttpTypedDataDataSource.js.map +3 -3
  481. package/lib/esm/src/typed-data/data/HttpTypedDataDataSource.test.js +1 -1
  482. package/lib/esm/src/typed-data/data/HttpTypedDataDataSource.test.js.map +3 -3
  483. package/lib/esm/src/typed-data/domain/DefaultTypedDataContextLoader.js +1 -1
  484. package/lib/esm/src/typed-data/domain/DefaultTypedDataContextLoader.js.map +3 -3
  485. package/lib/esm/src/typed-data/domain/DefaultTypedDataContextLoader.test.js +1 -1
  486. package/lib/esm/src/typed-data/domain/DefaultTypedDataContextLoader.test.js.map +3 -3
  487. package/lib/esm/src/uniswap/constants/uniswap.js +1 -1
  488. package/lib/esm/src/uniswap/constants/uniswap.js.map +3 -3
  489. package/lib/esm/src/uniswap/domain/UniswapContextLoader.js +1 -1
  490. package/lib/esm/src/uniswap/domain/UniswapContextLoader.js.map +3 -3
  491. package/lib/esm/src/uniswap/domain/UniswapContextLoader.test.js +1 -1
  492. package/lib/esm/src/uniswap/domain/UniswapContextLoader.test.js.map +3 -3
  493. package/lib/types/src/ContextModule.d.ts +3 -6
  494. package/lib/types/src/ContextModule.d.ts.map +1 -1
  495. package/lib/types/src/ContextModuleBuilder.d.ts +8 -10
  496. package/lib/types/src/ContextModuleBuilder.d.ts.map +1 -1
  497. package/lib/types/src/DefaultContextModule.d.ts +5 -8
  498. package/lib/types/src/DefaultContextModule.d.ts.map +1 -1
  499. package/lib/types/src/{transaction/data/TransactionDataSource.d.ts → calldata/data/CalldataDescriptorDataSource.d.ts} +4 -4
  500. package/lib/types/src/calldata/data/CalldataDescriptorDataSource.d.ts.map +1 -0
  501. package/lib/types/src/{transaction/data/HttpTransactionDataSource.d.ts → calldata/data/HttpCalldataDescriptorDataSource.d.ts} +6 -5
  502. package/lib/types/src/calldata/data/HttpCalldataDescriptorDataSource.d.ts.map +1 -0
  503. package/lib/types/src/calldata/data/HttpCalldataDescriptorDataSource.test.d.ts +2 -0
  504. package/lib/types/src/calldata/data/HttpCalldataDescriptorDataSource.test.d.ts.map +1 -0
  505. package/lib/types/src/{transaction → calldata}/data/dto/CalldataDto.d.ts +10 -1
  506. package/lib/types/src/calldata/data/dto/CalldataDto.d.ts.map +1 -0
  507. package/lib/types/src/calldata/di/calldataModuleFactory.d.ts +3 -0
  508. package/lib/types/src/calldata/di/calldataModuleFactory.d.ts.map +1 -0
  509. package/lib/types/src/calldata/di/calldataTypes.d.ts +6 -0
  510. package/lib/types/src/calldata/di/calldataTypes.d.ts.map +1 -0
  511. package/lib/types/src/calldata/domain/CalldataContextLoader.d.ts +23 -0
  512. package/lib/types/src/calldata/domain/CalldataContextLoader.d.ts.map +1 -0
  513. package/lib/types/src/calldata/domain/CalldataContextLoader.test.d.ts +2 -0
  514. package/lib/types/src/calldata/domain/CalldataContextLoader.test.d.ts.map +1 -0
  515. package/lib/types/src/config/model/ContextModuleConfig.d.ts +8 -3
  516. package/lib/types/src/config/model/ContextModuleConfig.d.ts.map +1 -1
  517. package/lib/types/src/di.d.ts.map +1 -1
  518. package/lib/types/src/dynamic-network/data/DynamicNetworkDataSource.d.ts +6 -0
  519. package/lib/types/src/dynamic-network/data/DynamicNetworkDataSource.d.ts.map +1 -0
  520. package/lib/types/src/dynamic-network/data/HttpDynamicNetworkDataSource.d.ts +13 -0
  521. package/lib/types/src/dynamic-network/data/HttpDynamicNetworkDataSource.d.ts.map +1 -0
  522. package/lib/types/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.d.ts +2 -0
  523. package/lib/types/src/dynamic-network/data/HttpDynamicNetworkDataSource.test.d.ts.map +1 -0
  524. package/lib/types/src/dynamic-network/data/dto/DynamicNetworkApiResponseDto.d.ts +14 -0
  525. package/lib/types/src/dynamic-network/data/dto/DynamicNetworkApiResponseDto.d.ts.map +1 -0
  526. package/lib/types/src/dynamic-network/di/dynamicNetworkModuleFactory.d.ts +3 -0
  527. package/lib/types/src/dynamic-network/di/dynamicNetworkModuleFactory.d.ts.map +1 -0
  528. package/lib/types/src/dynamic-network/di/dynamicNetworkTypes.d.ts +5 -0
  529. package/lib/types/src/dynamic-network/di/dynamicNetworkTypes.d.ts.map +1 -0
  530. package/lib/types/src/dynamic-network/domain/DynamicNetworkContextLoader.d.ts +19 -0
  531. package/lib/types/src/dynamic-network/domain/DynamicNetworkContextLoader.d.ts.map +1 -0
  532. package/lib/types/src/dynamic-network/domain/DynamicNetworkContextLoader.test.d.ts +2 -0
  533. package/lib/types/src/dynamic-network/domain/DynamicNetworkContextLoader.test.d.ts.map +1 -0
  534. package/lib/types/src/dynamic-network/model/DynamicNetworkConfiguration.d.ts +16 -0
  535. package/lib/types/src/dynamic-network/model/DynamicNetworkConfiguration.d.ts.map +1 -0
  536. package/lib/types/src/external-plugin/domain/ExternalPluginContextLoader.d.ts +20 -5
  537. package/lib/types/src/external-plugin/domain/ExternalPluginContextLoader.d.ts.map +1 -1
  538. package/lib/types/src/index.d.ts +41 -3
  539. package/lib/types/src/index.d.ts.map +1 -1
  540. package/lib/types/src/nft/di/nftModuleFactory.d.ts.map +1 -1
  541. package/lib/types/src/nft/di/nftTypes.d.ts +1 -0
  542. package/lib/types/src/nft/di/nftTypes.d.ts.map +1 -1
  543. package/lib/types/src/nft/domain/NftContextFieldLoader.d.ts +15 -0
  544. package/lib/types/src/nft/domain/NftContextFieldLoader.d.ts.map +1 -0
  545. package/lib/types/src/nft/domain/NftContextFieldLoader.test.d.ts +2 -0
  546. package/lib/types/src/nft/domain/NftContextFieldLoader.test.d.ts.map +1 -0
  547. package/lib/types/src/nft/domain/NftContextLoader.d.ts +10 -5
  548. package/lib/types/src/nft/domain/NftContextLoader.d.ts.map +1 -1
  549. package/lib/types/src/pki/domain/DefaultPkiCertificateLoader.d.ts.map +1 -1
  550. package/lib/types/src/pki/model/KeyUsage.d.ts +2 -1
  551. package/lib/types/src/pki/model/KeyUsage.d.ts.map +1 -1
  552. package/lib/types/src/pki/model/PkiCertificateInfo.d.ts +1 -2
  553. package/lib/types/src/pki/model/PkiCertificateInfo.d.ts.map +1 -1
  554. package/lib/types/src/proxy/data/HttpProxyDataSource.d.ts +13 -0
  555. package/lib/types/src/proxy/data/HttpProxyDataSource.d.ts.map +1 -0
  556. package/lib/types/src/proxy/data/HttpProxyDataSource.test.d.ts.map +1 -0
  557. package/lib/types/src/proxy/data/HttpSafeProxyDataSource.d.ts +13 -0
  558. package/lib/types/src/proxy/data/HttpSafeProxyDataSource.d.ts.map +1 -0
  559. package/lib/types/src/proxy/data/HttpSafeProxyDataSource.test.d.ts +2 -0
  560. package/lib/types/src/proxy/data/HttpSafeProxyDataSource.test.d.ts.map +1 -0
  561. package/lib/types/src/proxy/data/ProxyDataSource.d.ts +17 -0
  562. package/lib/types/src/proxy/data/ProxyDataSource.d.ts.map +1 -0
  563. package/lib/types/src/proxy/data/dto/ProxyDelegateCallDto.d.ts +5 -0
  564. package/lib/types/src/proxy/data/dto/ProxyDelegateCallDto.d.ts.map +1 -0
  565. package/lib/types/src/proxy/data/dto/ProxyImplementationAddressDto.d.ts.map +1 -0
  566. package/lib/types/src/proxy/data/dto/SafeProxyImplementationAddressDto.d.ts +10 -0
  567. package/lib/types/src/proxy/data/dto/SafeProxyImplementationAddressDto.d.ts.map +1 -0
  568. package/lib/types/src/proxy/di/proxyModuleFactory.d.ts +4 -0
  569. package/lib/types/src/proxy/di/proxyModuleFactory.d.ts.map +1 -0
  570. package/lib/types/src/proxy/di/proxyModuleFactory.test.d.ts +2 -0
  571. package/lib/types/src/proxy/di/proxyModuleFactory.test.d.ts.map +1 -0
  572. package/lib/types/src/proxy/di/proxyTypes.d.ts +5 -0
  573. package/lib/types/src/proxy/di/proxyTypes.d.ts.map +1 -0
  574. package/lib/types/src/proxy/domain/ProxyContextFieldLoader.d.ts +21 -0
  575. package/lib/types/src/proxy/domain/ProxyContextFieldLoader.d.ts.map +1 -0
  576. package/lib/types/src/proxy/domain/ProxyContextFieldLoader.test.d.ts +2 -0
  577. package/lib/types/src/proxy/domain/ProxyContextFieldLoader.test.d.ts.map +1 -0
  578. package/lib/types/src/proxy/model/ProxyDelegateCall.d.ts +7 -0
  579. package/lib/types/src/proxy/model/ProxyDelegateCall.d.ts.map +1 -0
  580. package/lib/types/src/safe/data/HttpSafeAccountDataSource.d.ts +11 -0
  581. package/lib/types/src/safe/data/HttpSafeAccountDataSource.d.ts.map +1 -0
  582. package/lib/types/src/safe/data/HttpSafeAccountDataSource.test.d.ts +2 -0
  583. package/lib/types/src/safe/data/HttpSafeAccountDataSource.test.d.ts.map +1 -0
  584. package/lib/types/src/safe/data/SafeAccountDataSource.d.ts +20 -0
  585. package/lib/types/src/safe/data/SafeAccountDataSource.d.ts.map +1 -0
  586. package/lib/types/src/safe/data/dto/SafeAccountDto.d.ts +10 -0
  587. package/lib/types/src/safe/data/dto/SafeAccountDto.d.ts.map +1 -0
  588. package/lib/types/src/safe/di/safeModuleFactory.d.ts +3 -0
  589. package/lib/types/src/safe/di/safeModuleFactory.d.ts.map +1 -0
  590. package/lib/types/src/safe/di/safeModuleFactory.test.d.ts +2 -0
  591. package/lib/types/src/safe/di/safeModuleFactory.test.d.ts.map +1 -0
  592. package/lib/types/src/safe/di/safeTypes.d.ts +5 -0
  593. package/lib/types/src/safe/di/safeTypes.d.ts.map +1 -0
  594. package/lib/types/src/safe/domain/SafeAddressLoader.d.ts +19 -0
  595. package/lib/types/src/safe/domain/SafeAddressLoader.d.ts.map +1 -0
  596. package/lib/types/src/safe/domain/SafeAddressLoader.test.d.ts +2 -0
  597. package/lib/types/src/safe/domain/SafeAddressLoader.test.d.ts.map +1 -0
  598. package/lib/types/src/shared/domain/ContextFieldLoader.d.ts +25 -0
  599. package/lib/types/src/shared/domain/ContextFieldLoader.d.ts.map +1 -0
  600. package/lib/types/src/shared/domain/ContextLoader.d.ts +13 -5
  601. package/lib/types/src/shared/domain/ContextLoader.d.ts.map +1 -1
  602. package/lib/types/src/shared/model/ClearSignContext.d.ts +76 -26
  603. package/lib/types/src/shared/model/ClearSignContext.d.ts.map +1 -1
  604. package/lib/types/src/shared/model/SolanaContextTypes.d.ts +47 -0
  605. package/lib/types/src/shared/model/SolanaContextTypes.d.ts.map +1 -0
  606. package/lib/types/src/shared/model/SolanaTransactionContext.d.ts +2 -0
  607. package/lib/types/src/shared/model/SolanaTransactionContext.d.ts.map +1 -1
  608. package/lib/types/src/shared/model/TransactionSubset.d.ts +1 -0
  609. package/lib/types/src/shared/model/TransactionSubset.d.ts.map +1 -1
  610. package/lib/types/src/shared/model/TypedDataClearSignContext.d.ts +33 -1
  611. package/lib/types/src/shared/model/TypedDataClearSignContext.d.ts.map +1 -1
  612. package/lib/types/src/shared/model/TypedDataContext.d.ts +3 -0
  613. package/lib/types/src/shared/model/TypedDataContext.d.ts.map +1 -1
  614. package/lib/types/src/shared/utils/KeyUsageMapper.d.ts +1 -2
  615. package/lib/types/src/shared/utils/KeyUsageMapper.d.ts.map +1 -1
  616. package/lib/types/src/solana/data/HttpSolanaOwnerInfoDataSource.d.ts.map +1 -1
  617. package/lib/types/src/solana/data/SolanaDataSource.d.ts +1 -4
  618. package/lib/types/src/solana/data/SolanaDataSource.d.ts.map +1 -1
  619. package/lib/types/src/solana/domain/DefaultSolanaContextLoader.d.ts +7 -3
  620. package/lib/types/src/solana/domain/DefaultSolanaContextLoader.d.ts.map +1 -1
  621. package/lib/types/src/solana/domain/solanaContextTypes.d.ts +7 -5
  622. package/lib/types/src/solana/domain/solanaContextTypes.d.ts.map +1 -1
  623. package/lib/types/src/solanaLifi/data/HttpSolanaLifiDataSource.d.ts +9 -0
  624. package/lib/types/src/solanaLifi/data/HttpSolanaLifiDataSource.d.ts.map +1 -0
  625. package/lib/types/src/solanaLifi/data/HttpSolanaLifiDataSource.test.d.ts +2 -0
  626. package/lib/types/src/solanaLifi/data/HttpSolanaLifiDataSource.test.d.ts.map +1 -0
  627. package/lib/types/src/solanaLifi/data/SolanaLifiDataSource.d.ts +13 -0
  628. package/lib/types/src/solanaLifi/data/SolanaLifiDataSource.d.ts.map +1 -0
  629. package/lib/types/src/solanaLifi/di/lifiModuleFactory.d.ts +3 -0
  630. package/lib/types/src/solanaLifi/di/lifiModuleFactory.d.ts.map +1 -0
  631. package/lib/types/src/solanaLifi/di/solanaLifiTypes.d.ts +5 -0
  632. package/lib/types/src/solanaLifi/di/solanaLifiTypes.d.ts.map +1 -0
  633. package/lib/types/src/solanaLifi/domain/SolanaLifiContextLoader.d.ts +16 -0
  634. package/lib/types/src/solanaLifi/domain/SolanaLifiContextLoader.d.ts.map +1 -0
  635. package/lib/types/src/solanaLifi/domain/SolanaLifiContextLoader.test.d.ts +2 -0
  636. package/lib/types/src/solanaLifi/domain/SolanaLifiContextLoader.test.d.ts.map +1 -0
  637. package/lib/types/src/solanaToken/data/HttpSolanaTokenDataSource.d.ts +9 -0
  638. package/lib/types/src/solanaToken/data/HttpSolanaTokenDataSource.d.ts.map +1 -0
  639. package/lib/types/src/solanaToken/data/HttpSolanaTokenDataSource.test.d.ts +2 -0
  640. package/lib/types/src/solanaToken/data/HttpSolanaTokenDataSource.test.d.ts.map +1 -0
  641. package/lib/types/src/solanaToken/data/SolanaTokenDataSource.d.ts +44 -0
  642. package/lib/types/src/solanaToken/data/SolanaTokenDataSource.d.ts.map +1 -0
  643. package/lib/types/src/solanaToken/di/solanaTokenTypes.d.ts +5 -0
  644. package/lib/types/src/solanaToken/di/solanaTokenTypes.d.ts.map +1 -0
  645. package/lib/types/src/solanaToken/di/tokenModuleFactory.d.ts +3 -0
  646. package/lib/types/src/solanaToken/di/tokenModuleFactory.d.ts.map +1 -0
  647. package/lib/types/src/solanaToken/domain/SolanaTokenContextLoader.d.ts +22 -0
  648. package/lib/types/src/solanaToken/domain/SolanaTokenContextLoader.d.ts.map +1 -0
  649. package/lib/types/src/solanaToken/domain/SolanaTokenContextLoader.test.d.ts +2 -0
  650. package/lib/types/src/solanaToken/domain/SolanaTokenContextLoader.test.d.ts.map +1 -0
  651. package/lib/types/src/token/data/HttpTokenDataSource.d.ts.map +1 -1
  652. package/lib/types/src/token/di/tokenModuleFactory.d.ts.map +1 -1
  653. package/lib/types/src/token/di/tokenTypes.d.ts +1 -0
  654. package/lib/types/src/token/di/tokenTypes.d.ts.map +1 -1
  655. package/lib/types/src/token/domain/TokenContextFieldLoader.d.ts +14 -0
  656. package/lib/types/src/token/domain/TokenContextFieldLoader.d.ts.map +1 -0
  657. package/lib/types/src/token/domain/TokenContextFieldLoader.test.d.ts +2 -0
  658. package/lib/types/src/token/domain/TokenContextFieldLoader.test.d.ts.map +1 -0
  659. package/lib/types/src/token/domain/TokenContextLoader.d.ts +10 -5
  660. package/lib/types/src/token/domain/TokenContextLoader.d.ts.map +1 -1
  661. package/lib/types/src/transaction-check/data/HttpTransactionCheckDataSource.d.ts +10 -0
  662. package/lib/types/src/transaction-check/data/HttpTransactionCheckDataSource.d.ts.map +1 -0
  663. package/lib/types/src/transaction-check/data/HttpTransactionCheckDataSource.test.d.ts +2 -0
  664. package/lib/types/src/transaction-check/data/HttpTransactionCheckDataSource.test.d.ts.map +1 -0
  665. package/lib/types/src/transaction-check/data/HttpTypedDataCheckDataSource.d.ts +10 -0
  666. package/lib/types/src/transaction-check/data/HttpTypedDataCheckDataSource.d.ts.map +1 -0
  667. package/lib/types/src/transaction-check/data/HttpTypedDataCheckDataSource.test.d.ts +2 -0
  668. package/lib/types/src/transaction-check/data/HttpTypedDataCheckDataSource.test.d.ts.map +1 -0
  669. package/lib/types/src/transaction-check/data/TransactionCheckDataSource.d.ts +14 -0
  670. package/lib/types/src/transaction-check/data/TransactionCheckDataSource.d.ts.map +1 -0
  671. package/lib/types/src/transaction-check/data/TypedDataCheckDataSource.d.ts +28 -0
  672. package/lib/types/src/transaction-check/data/TypedDataCheckDataSource.d.ts.map +1 -0
  673. package/lib/types/src/transaction-check/data/dto/TransactionCheckDto.d.ts +5 -0
  674. package/lib/types/src/transaction-check/data/dto/TransactionCheckDto.d.ts.map +1 -0
  675. package/lib/types/src/transaction-check/data/dto/TypedDataCheckDto.d.ts +5 -0
  676. package/lib/types/src/transaction-check/data/dto/TypedDataCheckDto.d.ts.map +1 -0
  677. package/lib/types/src/transaction-check/di/transactionCheckModuleFactory.d.ts +3 -0
  678. package/lib/types/src/transaction-check/di/transactionCheckModuleFactory.d.ts.map +1 -0
  679. package/lib/types/src/transaction-check/di/transactionCheckTypes.d.ts +7 -0
  680. package/lib/types/src/transaction-check/di/transactionCheckTypes.d.ts.map +1 -0
  681. package/lib/types/src/transaction-check/domain/TransactionCheckContextLoader.d.ts +19 -0
  682. package/lib/types/src/transaction-check/domain/TransactionCheckContextLoader.d.ts.map +1 -0
  683. package/lib/types/src/transaction-check/domain/TransactionCheckContextLoader.test.d.ts +2 -0
  684. package/lib/types/src/transaction-check/domain/TransactionCheckContextLoader.test.d.ts.map +1 -0
  685. package/lib/types/src/transaction-check/domain/TypedDataCheckContextLoader.d.ts +18 -0
  686. package/lib/types/src/transaction-check/domain/TypedDataCheckContextLoader.d.ts.map +1 -0
  687. package/lib/types/src/transaction-check/domain/TypedDataCheckContextLoader.test.d.ts +2 -0
  688. package/lib/types/src/transaction-check/domain/TypedDataCheckContextLoader.test.d.ts.map +1 -0
  689. package/lib/types/src/trusted-name/data/HttpTrustedNameDataSource.d.ts +7 -3
  690. package/lib/types/src/trusted-name/data/HttpTrustedNameDataSource.d.ts.map +1 -1
  691. package/lib/types/src/trusted-name/data/TrustedNameDataSource.d.ts +7 -2
  692. package/lib/types/src/trusted-name/data/TrustedNameDataSource.d.ts.map +1 -1
  693. package/lib/types/src/trusted-name/data/TrustedNameDto.d.ts +4 -5
  694. package/lib/types/src/trusted-name/data/TrustedNameDto.d.ts.map +1 -1
  695. package/lib/types/src/trusted-name/di/trustedNameModuleFactory.d.ts.map +1 -1
  696. package/lib/types/src/trusted-name/di/trustedNameTypes.d.ts +1 -0
  697. package/lib/types/src/trusted-name/di/trustedNameTypes.d.ts.map +1 -1
  698. package/lib/types/src/trusted-name/domain/TrustedNameContextFieldLoader.d.ts +22 -0
  699. package/lib/types/src/trusted-name/domain/TrustedNameContextFieldLoader.d.ts.map +1 -0
  700. package/lib/types/src/trusted-name/domain/TrustedNameContextFieldLoader.test.d.ts +2 -0
  701. package/lib/types/src/trusted-name/domain/TrustedNameContextFieldLoader.test.d.ts.map +1 -0
  702. package/lib/types/src/trusted-name/domain/TrustedNameContextLoader.d.ts +14 -6
  703. package/lib/types/src/trusted-name/domain/TrustedNameContextLoader.d.ts.map +1 -1
  704. package/lib/types/src/typed-data/data/FiltersDto.d.ts +32 -2
  705. package/lib/types/src/typed-data/data/FiltersDto.d.ts.map +1 -1
  706. package/lib/types/src/typed-data/data/HttpTypedDataDataSource.d.ts +3 -0
  707. package/lib/types/src/typed-data/data/HttpTypedDataDataSource.d.ts.map +1 -1
  708. package/lib/types/src/typed-data/data/HttpTypedDataDataSource.test.d.ts +1 -0
  709. package/lib/types/src/typed-data/data/HttpTypedDataDataSource.test.d.ts.map +1 -1
  710. package/lib/types/src/typed-data/data/TypedDataDataSource.d.ts +2 -1
  711. package/lib/types/src/typed-data/data/TypedDataDataSource.d.ts.map +1 -1
  712. package/lib/types/src/typed-data/domain/DefaultTypedDataContextLoader.d.ts +12 -1
  713. package/lib/types/src/typed-data/domain/DefaultTypedDataContextLoader.d.ts.map +1 -1
  714. package/lib/types/src/uniswap/constants/uniswap.d.ts +0 -1
  715. package/lib/types/src/uniswap/constants/uniswap.d.ts.map +1 -1
  716. package/lib/types/src/uniswap/domain/UniswapContextLoader.d.ts +10 -11
  717. package/lib/types/src/uniswap/domain/UniswapContextLoader.d.ts.map +1 -1
  718. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  719. package/package.json +36 -32
  720. package/lib/cjs/src/shared/model/TransactionContext.js +0 -2
  721. package/lib/cjs/src/shared/model/TransactionContext.js.map +0 -7
  722. package/lib/cjs/src/transaction/data/HttpProxyDataSource.js +0 -2
  723. package/lib/cjs/src/transaction/data/HttpProxyDataSource.js.map +0 -7
  724. package/lib/cjs/src/transaction/data/HttpProxyDataSource.test.js +0 -2
  725. package/lib/cjs/src/transaction/data/HttpProxyDataSource.test.js.map +0 -7
  726. package/lib/cjs/src/transaction/data/HttpTransactionDataSource.js +0 -2
  727. package/lib/cjs/src/transaction/data/HttpTransactionDataSource.js.map +0 -7
  728. package/lib/cjs/src/transaction/data/HttpTransactionDataSource.test.js +0 -2
  729. package/lib/cjs/src/transaction/data/HttpTransactionDataSource.test.js.map +0 -7
  730. package/lib/cjs/src/transaction/data/TransactionDataSource.js +0 -2
  731. package/lib/cjs/src/transaction/data/TransactionDataSource.js.map +0 -7
  732. package/lib/cjs/src/transaction/data/dto/CalldataDto.js +0 -2
  733. package/lib/cjs/src/transaction/data/dto/CalldataDto.js.map +0 -7
  734. package/lib/cjs/src/transaction/data/dto/ProxyDelegateCallDto.js +0 -2
  735. package/lib/cjs/src/transaction/data/dto/ProxyDelegateCallDto.js.map +0 -7
  736. package/lib/cjs/src/transaction/di/transactionModuleFactory.js +0 -2
  737. package/lib/cjs/src/transaction/di/transactionModuleFactory.js.map +0 -7
  738. package/lib/cjs/src/transaction/di/transactionTypes.js +0 -2
  739. package/lib/cjs/src/transaction/di/transactionTypes.js.map +0 -7
  740. package/lib/cjs/src/transaction/domain/TransactionContextLoader.js +0 -2
  741. package/lib/cjs/src/transaction/domain/TransactionContextLoader.js.map +0 -7
  742. package/lib/cjs/src/transaction/domain/TransactionContextLoader.test.js +0 -2
  743. package/lib/cjs/src/transaction/domain/TransactionContextLoader.test.js.map +0 -7
  744. package/lib/cjs/src/transaction/model/ProxyDelegateCall.js +0 -2
  745. package/lib/cjs/src/transaction/model/ProxyDelegateCall.js.map +0 -7
  746. package/lib/cjs/src/transaction/model/ProxyImplementationAddress.js +0 -2
  747. package/lib/cjs/src/transaction/model/ProxyImplementationAddress.js.map +0 -7
  748. package/lib/cjs/src/uniswap/constants/plugin.js +0 -2
  749. package/lib/cjs/src/uniswap/constants/plugin.js.map +0 -7
  750. package/lib/cjs/src/web3-check/data/HttpWeb3CheckDataSource.js +0 -2
  751. package/lib/cjs/src/web3-check/data/HttpWeb3CheckDataSource.js.map +0 -7
  752. package/lib/cjs/src/web3-check/data/HttpWeb3CheckDataSource.test.js +0 -2
  753. package/lib/cjs/src/web3-check/data/HttpWeb3CheckDataSource.test.js.map +0 -7
  754. package/lib/cjs/src/web3-check/data/Web3CheckDataSource.js +0 -2
  755. package/lib/cjs/src/web3-check/data/Web3CheckDataSource.js.map +0 -7
  756. package/lib/cjs/src/web3-check/data/Web3CheckDto.js +0 -2
  757. package/lib/cjs/src/web3-check/data/Web3CheckDto.js.map +0 -7
  758. package/lib/cjs/src/web3-check/di/web3CheckModuleFactory.js +0 -2
  759. package/lib/cjs/src/web3-check/di/web3CheckModuleFactory.js.map +0 -7
  760. package/lib/cjs/src/web3-check/di/web3CheckTypes.js +0 -2
  761. package/lib/cjs/src/web3-check/di/web3CheckTypes.js.map +0 -7
  762. package/lib/cjs/src/web3-check/domain/DefaultWeb3CheckLoader.js +0 -2
  763. package/lib/cjs/src/web3-check/domain/DefaultWeb3CheckLoader.js.map +0 -7
  764. package/lib/cjs/src/web3-check/domain/DefaultWeb3CheckLoader.test.js +0 -2
  765. package/lib/cjs/src/web3-check/domain/DefaultWeb3CheckLoader.test.js.map +0 -7
  766. package/lib/cjs/src/web3-check/domain/Web3CheckContextLoader.js +0 -2
  767. package/lib/cjs/src/web3-check/domain/Web3CheckContextLoader.js.map +0 -7
  768. package/lib/cjs/src/web3-check/domain/web3CheckTypes.js +0 -2
  769. package/lib/cjs/src/web3-check/domain/web3CheckTypes.js.map +0 -7
  770. package/lib/esm/src/shared/model/TransactionContext.js +0 -1
  771. package/lib/esm/src/transaction/data/HttpProxyDataSource.js +0 -2
  772. package/lib/esm/src/transaction/data/HttpProxyDataSource.js.map +0 -7
  773. package/lib/esm/src/transaction/data/HttpProxyDataSource.test.js +0 -2
  774. package/lib/esm/src/transaction/data/HttpProxyDataSource.test.js.map +0 -7
  775. package/lib/esm/src/transaction/data/HttpTransactionDataSource.js +0 -2
  776. package/lib/esm/src/transaction/data/HttpTransactionDataSource.js.map +0 -7
  777. package/lib/esm/src/transaction/data/HttpTransactionDataSource.test.js +0 -2
  778. package/lib/esm/src/transaction/data/HttpTransactionDataSource.test.js.map +0 -7
  779. package/lib/esm/src/transaction/data/TransactionDataSource.js +0 -1
  780. package/lib/esm/src/transaction/di/transactionModuleFactory.js +0 -2
  781. package/lib/esm/src/transaction/di/transactionModuleFactory.js.map +0 -7
  782. package/lib/esm/src/transaction/di/transactionTypes.js +0 -2
  783. package/lib/esm/src/transaction/di/transactionTypes.js.map +0 -7
  784. package/lib/esm/src/transaction/domain/TransactionContextLoader.js +0 -2
  785. package/lib/esm/src/transaction/domain/TransactionContextLoader.js.map +0 -7
  786. package/lib/esm/src/transaction/domain/TransactionContextLoader.test.js +0 -2
  787. package/lib/esm/src/transaction/domain/TransactionContextLoader.test.js.map +0 -7
  788. package/lib/esm/src/transaction/model/ProxyImplementationAddress.js +0 -1
  789. package/lib/esm/src/uniswap/constants/plugin.js +0 -2
  790. package/lib/esm/src/uniswap/constants/plugin.js.map +0 -7
  791. package/lib/esm/src/web3-check/data/HttpWeb3CheckDataSource.js +0 -2
  792. package/lib/esm/src/web3-check/data/HttpWeb3CheckDataSource.js.map +0 -7
  793. package/lib/esm/src/web3-check/data/HttpWeb3CheckDataSource.test.js +0 -2
  794. package/lib/esm/src/web3-check/data/HttpWeb3CheckDataSource.test.js.map +0 -7
  795. package/lib/esm/src/web3-check/data/Web3CheckDataSource.js +0 -1
  796. package/lib/esm/src/web3-check/data/Web3CheckDto.js +0 -1
  797. package/lib/esm/src/web3-check/di/web3CheckModuleFactory.js +0 -2
  798. package/lib/esm/src/web3-check/di/web3CheckModuleFactory.js.map +0 -7
  799. package/lib/esm/src/web3-check/di/web3CheckTypes.js +0 -2
  800. package/lib/esm/src/web3-check/di/web3CheckTypes.js.map +0 -7
  801. package/lib/esm/src/web3-check/domain/DefaultWeb3CheckLoader.js +0 -2
  802. package/lib/esm/src/web3-check/domain/DefaultWeb3CheckLoader.js.map +0 -7
  803. package/lib/esm/src/web3-check/domain/DefaultWeb3CheckLoader.test.js +0 -2
  804. package/lib/esm/src/web3-check/domain/DefaultWeb3CheckLoader.test.js.map +0 -7
  805. package/lib/esm/src/web3-check/domain/Web3CheckContextLoader.js +0 -1
  806. package/lib/esm/src/web3-check/domain/web3CheckTypes.js +0 -1
  807. package/lib/types/src/shared/model/TransactionContext.d.ts +0 -21
  808. package/lib/types/src/shared/model/TransactionContext.d.ts.map +0 -1
  809. package/lib/types/src/transaction/data/HttpProxyDataSource.d.ts +0 -32
  810. package/lib/types/src/transaction/data/HttpProxyDataSource.d.ts.map +0 -1
  811. package/lib/types/src/transaction/data/HttpProxyDataSource.test.d.ts.map +0 -1
  812. package/lib/types/src/transaction/data/HttpTransactionDataSource.d.ts.map +0 -1
  813. package/lib/types/src/transaction/data/HttpTransactionDataSource.test.d.ts +0 -2
  814. package/lib/types/src/transaction/data/HttpTransactionDataSource.test.d.ts.map +0 -1
  815. package/lib/types/src/transaction/data/TransactionDataSource.d.ts.map +0 -1
  816. package/lib/types/src/transaction/data/dto/CalldataDto.d.ts.map +0 -1
  817. package/lib/types/src/transaction/data/dto/ProxyDelegateCallDto.d.ts +0 -5
  818. package/lib/types/src/transaction/data/dto/ProxyDelegateCallDto.d.ts.map +0 -1
  819. package/lib/types/src/transaction/data/dto/ProxyImplementationAddressDto.d.ts.map +0 -1
  820. package/lib/types/src/transaction/di/transactionModuleFactory.d.ts +0 -3
  821. package/lib/types/src/transaction/di/transactionModuleFactory.d.ts.map +0 -1
  822. package/lib/types/src/transaction/di/transactionTypes.d.ts +0 -6
  823. package/lib/types/src/transaction/di/transactionTypes.d.ts.map +0 -1
  824. package/lib/types/src/transaction/domain/TransactionContextLoader.d.ts +0 -10
  825. package/lib/types/src/transaction/domain/TransactionContextLoader.d.ts.map +0 -1
  826. package/lib/types/src/transaction/domain/TransactionContextLoader.test.d.ts +0 -2
  827. package/lib/types/src/transaction/domain/TransactionContextLoader.test.d.ts.map +0 -1
  828. package/lib/types/src/transaction/model/ProxyDelegateCall.d.ts +0 -5
  829. package/lib/types/src/transaction/model/ProxyDelegateCall.d.ts.map +0 -1
  830. package/lib/types/src/transaction/model/ProxyImplementationAddress.d.ts +0 -4
  831. package/lib/types/src/transaction/model/ProxyImplementationAddress.d.ts.map +0 -1
  832. package/lib/types/src/uniswap/constants/plugin.d.ts +0 -3
  833. package/lib/types/src/uniswap/constants/plugin.d.ts.map +0 -1
  834. package/lib/types/src/web3-check/data/HttpWeb3CheckDataSource.d.ts +0 -14
  835. package/lib/types/src/web3-check/data/HttpWeb3CheckDataSource.d.ts.map +0 -1
  836. package/lib/types/src/web3-check/data/HttpWeb3CheckDataSource.test.d.ts +0 -2
  837. package/lib/types/src/web3-check/data/HttpWeb3CheckDataSource.test.d.ts.map +0 -1
  838. package/lib/types/src/web3-check/data/Web3CheckDataSource.d.ts +0 -6
  839. package/lib/types/src/web3-check/data/Web3CheckDataSource.d.ts.map +0 -1
  840. package/lib/types/src/web3-check/data/Web3CheckDto.d.ts +0 -20
  841. package/lib/types/src/web3-check/data/Web3CheckDto.d.ts.map +0 -1
  842. package/lib/types/src/web3-check/di/web3CheckModuleFactory.d.ts +0 -3
  843. package/lib/types/src/web3-check/di/web3CheckModuleFactory.d.ts.map +0 -1
  844. package/lib/types/src/web3-check/di/web3CheckTypes.d.ts +0 -5
  845. package/lib/types/src/web3-check/di/web3CheckTypes.d.ts.map +0 -1
  846. package/lib/types/src/web3-check/domain/DefaultWeb3CheckLoader.d.ts +0 -10
  847. package/lib/types/src/web3-check/domain/DefaultWeb3CheckLoader.d.ts.map +0 -1
  848. package/lib/types/src/web3-check/domain/DefaultWeb3CheckLoader.test.d.ts +0 -2
  849. package/lib/types/src/web3-check/domain/DefaultWeb3CheckLoader.test.d.ts.map +0 -1
  850. package/lib/types/src/web3-check/domain/Web3CheckContextLoader.d.ts +0 -6
  851. package/lib/types/src/web3-check/domain/Web3CheckContextLoader.d.ts.map +0 -1
  852. package/lib/types/src/web3-check/domain/web3CheckTypes.d.ts +0 -35
  853. package/lib/types/src/web3-check/domain/web3CheckTypes.d.ts.map +0 -1
  854. /package/lib/cjs/src/{transaction → proxy}/data/dto/ProxyImplementationAddressDto.js +0 -0
  855. /package/lib/esm/src/{shared/model/TransactionContext.js.map → calldata/data/CalldataDescriptorDataSource.js.map} +0 -0
  856. /package/lib/esm/src/{transaction → calldata}/data/dto/CalldataDto.js +0 -0
  857. /package/lib/esm/src/{transaction → calldata}/data/dto/CalldataDto.js.map +0 -0
  858. /package/lib/esm/src/{transaction/data/TransactionDataSource.js.map → dynamic-network/data/DynamicNetworkDataSource.js.map} +0 -0
  859. /package/lib/esm/src/{transaction/data/dto/ProxyDelegateCallDto.js.map → dynamic-network/data/dto/DynamicNetworkApiResponseDto.js.map} +0 -0
  860. /package/lib/esm/src/{transaction/data/dto/ProxyImplementationAddressDto.js.map → dynamic-network/model/DynamicNetworkConfiguration.js.map} +0 -0
  861. /package/lib/esm/src/{transaction/model/ProxyDelegateCall.js.map → proxy/data/ProxyDataSource.js.map} +0 -0
  862. /package/lib/esm/src/{transaction → proxy}/data/dto/ProxyDelegateCallDto.js +0 -0
  863. /package/lib/esm/src/{transaction/model/ProxyImplementationAddress.js.map → proxy/data/dto/ProxyDelegateCallDto.js.map} +0 -0
  864. /package/lib/esm/src/{transaction → proxy}/data/dto/ProxyImplementationAddressDto.js +0 -0
  865. /package/lib/esm/src/{web3-check/data/Web3CheckDataSource.js.map → proxy/data/dto/ProxyImplementationAddressDto.js.map} +0 -0
  866. /package/lib/esm/src/{web3-check/data/Web3CheckDto.js.map → proxy/data/dto/SafeProxyImplementationAddressDto.js.map} +0 -0
  867. /package/lib/esm/src/{transaction → proxy}/model/ProxyDelegateCall.js +0 -0
  868. /package/lib/esm/src/{web3-check/domain/Web3CheckContextLoader.js.map → proxy/model/ProxyDelegateCall.js.map} +0 -0
  869. /package/lib/esm/src/{web3-check/domain/web3CheckTypes.js.map → safe/data/SafeAccountDataSource.js.map} +0 -0
  870. /package/lib/types/src/{transaction → proxy}/data/HttpProxyDataSource.test.d.ts +0 -0
  871. /package/lib/types/src/{transaction → proxy}/data/dto/ProxyImplementationAddressDto.d.ts +0 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/token/domain/TokenContextLoader.test.ts"],
4
- "sourcesContent": ["import { Left, Right } from \"purify-ts\";\n\nimport { ClearSignContextType } from \"@/shared/model/ClearSignContext\";\nimport {\n type TransactionContext,\n type TransactionFieldContext,\n} from \"@/shared/model/TransactionContext\";\nimport { type TokenDataSource } from \"@/token/data/TokenDataSource\";\nimport { TokenContextLoader } from \"@/token/domain/TokenContextLoader\";\n\ndescribe(\"TokenContextLoader\", () => {\n const mockTokenDataSource: TokenDataSource = {\n getTokenInfosPayload: vi.fn(),\n };\n const loader = new TokenContextLoader(mockTokenDataSource);\n\n beforeEach(() => {\n vi.restoreAllMocks();\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockImplementation(\n ({ address }) => Promise.resolve(Right(`payload-${address}`)),\n );\n });\n\n describe(\"load function\", () => {\n it(\"should return an empty array if transaction dest is undefined\", async () => {\n // GIVEN\n const transaction = { to: undefined } as TransactionContext;\n\n // WHEN\n const result = await loader.load(transaction);\n\n // THEN\n expect(result).toEqual([]);\n });\n\n it(\"should return an error when datasource returns an error\", async () => {\n // GIVEN\n const transaction = {\n to: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n chainId: 1,\n selector: \"0x095ea7b3\",\n } as TransactionContext;\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockResolvedValue(\n Left(new Error(\"error\")),\n );\n\n // WHEN\n const result = await loader.load(transaction);\n\n // THEN\n expect(result).toEqual([\n { type: ClearSignContextType.ERROR, error: new Error(\"error\") },\n ]);\n });\n\n it(\"should return a correct response\", async () => {\n // GIVEN\n const transaction = {\n to: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n chainId: 1,\n selector: \"0x095ea7b3\",\n } as TransactionContext;\n\n // WHEN\n const result = await loader.load(transaction);\n\n // THEN\n expect(result).toEqual([\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n },\n ]);\n });\n });\n\n describe(\"loadField function\", () => {\n it(\"should return an error when field type if not supported\", async () => {\n const field: TransactionFieldContext = {\n type: ClearSignContextType.NFT,\n chainId: 7,\n address: \"0x1234\",\n };\n\n const result = await loader.loadField(field);\n\n expect(result).toEqual(null);\n });\n\n it(\"should return a payload\", async () => {\n // GIVEN\n const field: TransactionFieldContext = {\n type: ClearSignContextType.TOKEN,\n chainId: 7,\n address: \"0x1234\",\n };\n\n // WHEN\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockResolvedValue(\n Right(\"payload\"),\n );\n const result = await loader.loadField(field);\n\n // THEN\n expect(result).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"payload\",\n });\n });\n\n it(\"should return an error when unable to fetch the datasource\", async () => {\n // GIVEN\n const field: TransactionFieldContext = {\n type: ClearSignContextType.TOKEN,\n chainId: 7,\n address: \"0x1234\",\n };\n\n // WHEN\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockResolvedValue(\n Left(new Error(\"error\")),\n );\n const result = await loader.loadField(field);\n\n // THEN\n expect(result).toEqual({\n type: ClearSignContextType.ERROR,\n error: new Error(\"error\"),\n });\n });\n });\n});\n"],
5
- "mappings": "aAAA,IAAAA,EAA4B,qBAE5BC,EAAqC,2CAMrCC,EAAmC,6CAEnC,SAAS,qBAAsB,IAAM,CACnC,MAAMC,EAAuC,CAC3C,qBAAsB,GAAG,GAAG,CAC9B,EACMC,EAAS,IAAI,qBAAmBD,CAAmB,EAEzD,WAAW,IAAM,CACf,GAAG,gBAAgB,EACnB,GAAG,MAAMA,EAAqB,sBAAsB,EAAE,mBACpD,CAAC,CAAE,QAAAE,CAAQ,IAAM,QAAQ,WAAQ,SAAM,WAAWA,CAAO,EAAE,CAAC,CAC9D,CACF,CAAC,EAED,SAAS,gBAAiB,IAAM,CAC9B,GAAG,gEAAiE,SAAY,CAE9E,MAAMC,EAAc,CAAE,GAAI,MAAU,EAG9BC,EAAS,MAAMH,EAAO,KAAKE,CAAW,EAG5C,OAAOC,CAAM,EAAE,QAAQ,CAAC,CAAC,CAC3B,CAAC,EAED,GAAG,0DAA2D,SAAY,CAExE,MAAMD,EAAc,CAClB,GAAI,6CACJ,QAAS,EACT,SAAU,YACZ,EACA,GAAG,MAAMH,EAAqB,sBAAsB,EAAE,qBACpD,QAAK,IAAI,MAAM,OAAO,CAAC,CACzB,EAGA,MAAMI,EAAS,MAAMH,EAAO,KAAKE,CAAW,EAG5C,OAAOC,CAAM,EAAE,QAAQ,CACrB,CAAE,KAAM,uBAAqB,MAAO,MAAO,IAAI,MAAM,OAAO,CAAE,CAChE,CAAC,CACH,CAAC,EAED,GAAG,mCAAoC,SAAY,CAEjD,MAAMD,EAAc,CAClB,GAAI,6CACJ,QAAS,EACT,SAAU,YACZ,EAGMC,EAAS,MAAMH,EAAO,KAAKE,CAAW,EAG5C,OAAOC,CAAM,EAAE,QAAQ,CACrB,CACE,KAAM,uBAAqB,MAC3B,QAAS,oDACX,CACF,CAAC,CACH,CAAC,CACH,CAAC,EAED,SAAS,qBAAsB,IAAM,CACnC,GAAG,0DAA2D,SAAY,CACxE,MAAMC,EAAiC,CACrC,KAAM,uBAAqB,IAC3B,QAAS,EACT,QAAS,QACX,EAEMD,EAAS,MAAMH,EAAO,UAAUI,CAAK,EAE3C,OAAOD,CAAM,EAAE,QAAQ,IAAI,CAC7B,CAAC,EAED,GAAG,0BAA2B,SAAY,CAExC,MAAMC,EAAiC,CACrC,KAAM,uBAAqB,MAC3B,QAAS,EACT,QAAS,QACX,EAGA,GAAG,MAAML,EAAqB,sBAAsB,EAAE,qBACpD,SAAM,SAAS,CACjB,EACA,MAAMI,EAAS,MAAMH,EAAO,UAAUI,CAAK,EAG3C,OAAOD,CAAM,EAAE,QAAQ,CACrB,KAAM,uBAAqB,MAC3B,QAAS,SACX,CAAC,CACH,CAAC,EAED,GAAG,6DAA8D,SAAY,CAE3E,MAAMC,EAAiC,CACrC,KAAM,uBAAqB,MAC3B,QAAS,EACT,QAAS,QACX,EAGA,GAAG,MAAML,EAAqB,sBAAsB,EAAE,qBACpD,QAAK,IAAI,MAAM,OAAO,CAAC,CACzB,EACA,MAAMI,EAAS,MAAMH,EAAO,UAAUI,CAAK,EAG3C,OAAOD,CAAM,EAAE,QAAQ,CACrB,KAAM,uBAAqB,MAC3B,MAAO,IAAI,MAAM,OAAO,CAC1B,CAAC,CACH,CAAC,CACH,CAAC,CACH,CAAC",
6
- "names": ["import_purify_ts", "import_ClearSignContext", "import_TokenContextLoader", "mockTokenDataSource", "loader", "address", "transaction", "result", "field"]
4
+ "sourcesContent": ["import { Left, Right } from \"purify-ts\";\n\nimport { ClearSignContextType } from \"@/shared/model/ClearSignContext\";\nimport { type TokenDataSource } from \"@/token/data/TokenDataSource\";\nimport {\n type TokenContextInput,\n TokenContextLoader,\n} from \"@/token/domain/TokenContextLoader\";\n\ndescribe(\"TokenContextLoader\", () => {\n const mockTokenDataSource: TokenDataSource = {\n getTokenInfosPayload: vi.fn(),\n };\n const loader = new TokenContextLoader(mockTokenDataSource);\n\n beforeEach(() => {\n vi.restoreAllMocks();\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockImplementation(\n ({ address }) => Promise.resolve(Right(`payload-${address}`)),\n );\n });\n\n describe(\"canHandle function\", () => {\n const validInput: TokenContextInput = {\n to: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n selector: \"0x095ea7b3\",\n chainId: 1,\n };\n\n it(\"should return true for valid input\", () => {\n expect(loader.canHandle(validInput, [ClearSignContextType.TOKEN])).toBe(\n true,\n );\n });\n\n it(\"should return false for invalid expected type\", () => {\n expect(loader.canHandle(validInput, [ClearSignContextType.NFT])).toBe(\n false,\n );\n });\n\n it.each([\n [null, \"null input\"],\n [undefined, \"undefined input\"],\n [{}, \"empty object\"],\n [\"string\", \"string input\"],\n [123, \"number input\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, [ClearSignContextType.TOKEN])).toBe(false);\n });\n\n it.each([\n [{ ...validInput, to: undefined }, \"missing to\"],\n [{ ...validInput, selector: undefined }, \"missing selector\"],\n [{ ...validInput, chainId: undefined }, \"missing chainId\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, [ClearSignContextType.TOKEN])).toBe(false);\n });\n\n it.each([\n [{ ...validInput, to: \"invalid-hex\" }, \"invalid to hex\"],\n [{ ...validInput, to: \"0x\" }, \"empty to hex\"],\n [{ ...validInput, to: \"not-hex-at-all\" }, \"non-hex to\"],\n [{ ...validInput, selector: \"invalid-hex\" }, \"invalid selector hex\"],\n [{ ...validInput, selector: \"0x\" }, \"empty selector hex\"],\n [{ ...validInput, selector: \"not-hex-at-all\" }, \"non-hex selector\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, [ClearSignContextType.TOKEN])).toBe(false);\n });\n\n it.each([\n [{ ...validInput, chainId: \"1\" }, \"string chainId\"],\n [{ ...validInput, chainId: null }, \"null chainId\"],\n [{ ...validInput, chainId: undefined }, \"undefined chainId\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, [ClearSignContextType.TOKEN])).toBe(false);\n });\n });\n\n describe(\"load function\", () => {\n it(\"should return an error when datasource returns an error\", async () => {\n // GIVEN\n const input: TokenContextInput = {\n to: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n chainId: 1,\n selector: \"0x095ea7b3\",\n };\n vi.spyOn(mockTokenDataSource, \"getTokenInfosPayload\").mockResolvedValue(\n Left(new Error(\"error\")),\n );\n\n // WHEN\n const result = await loader.load(input);\n\n // THEN\n expect(result).toEqual([\n { type: ClearSignContextType.ERROR, error: new Error(\"error\") },\n ]);\n });\n\n it(\"should return a correct response\", async () => {\n // GIVEN\n const input: TokenContextInput = {\n to: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n chainId: 1,\n selector: \"0x095ea7b3\",\n };\n\n // WHEN\n const result = await loader.load(input);\n\n // THEN\n expect(result).toEqual([\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n },\n ]);\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_purify_ts", "import_ClearSignContext", "import_TokenContextLoader", "mockTokenDataSource", "loader", "address", "validInput", "input", "_description", "result"]
7
7
  }
@@ -0,0 +1,2 @@
1
+ "use strict";var y=Object.create;var a=Object.defineProperty;var m=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var D=Object.getPrototypeOf,b=Object.prototype.hasOwnProperty;var x=(t,r)=>{for(var o in r)a(t,o,{get:r[o],enumerable:!0})},u=(t,r,o,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of g(r))!b.call(t,e)&&e!==o&&a(t,e,{get:()=>r[e],enumerable:!(i=m(r,e))||i.enumerable});return t};var f=(t,r,o)=>(o=t!=null?y(D(t)):{},u(r||!t||!t.__esModule?a(o,"default",{value:t,enumerable:!0}):o,t)),w=t=>u(a({},"__esModule",{value:!0}),t),C=(t,r,o,i)=>{for(var e=i>1?void 0:i?m(r,o):r,n=t.length-1,c;n>=0;n--)(c=t[n])&&(e=(i?c(r,o,e):c(e))||e);return i&&e&&a(r,o,e),e},k=(t,r)=>(o,i)=>r(o,i,t);var R={};x(R,{HttpTransactionCheckDataSource:()=>s});module.exports=w(R);var d=f(require("axios")),h=require("inversify"),p=require("purify-ts"),E=require("../../config/di/configTypes"),l=require("../../shared/constant/HttpHeaders"),_=f(require("../../../package.json"));let s=class{constructor(r){this.config=r}async getTransactionCheck({chainId:r,rawTx:o,from:i}){let e;const n={tx:{from:i,raw:o},chain:r};try{e=(await d.default.request({method:"POST",url:`${this.config.web3checks.url}/ethereum/scan/tx`,data:n,headers:{[l.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${_.default.version}`,[l.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}})).data}catch{return(0,p.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Failed to fetch web3 checks information"))}if(!this._isTransactionCheckDto(e))return(0,p.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received"));const c={publicKeyId:e.public_key_id,descriptor:e.descriptor};return(0,p.Right)(c)}_isTransactionCheckDto(r){return r!=null&&typeof r=="object"&&"public_key_id"in r&&r.public_key_id!=null&&typeof r.public_key_id=="string"&&"descriptor"in r&&r.descriptor!=null&&typeof r.descriptor=="string"}};s=C([(0,h.injectable)(),k(0,(0,h.inject)(E.configTypes.Config))],s);0&&(module.exports={HttpTransactionCheckDataSource});
2
+ //# sourceMappingURL=HttpTransactionCheckDataSource.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/HttpTransactionCheckDataSource.ts"],
4
+ "sourcesContent": ["import axios from \"axios\";\nimport { inject, injectable } from \"inversify\";\nimport { Either, Left, Right } from \"purify-ts\";\n\nimport { configTypes } from \"@/config/di/configTypes\";\nimport { type ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport PACKAGE from \"@root/package.json\";\n\nimport { TransactionCheckDto } from \"./dto/TransactionCheckDto\";\nimport {\n GetTransactionCheckParams,\n TransactionCheck,\n} from \"./TransactionCheckDataSource\";\n\n@injectable()\nexport class HttpTransactionCheckDataSource {\n constructor(\n @inject(configTypes.Config) private readonly config: ContextModuleConfig,\n ) {}\n\n public async getTransactionCheck({\n chainId,\n rawTx,\n from,\n }: GetTransactionCheckParams): Promise<Either<Error, TransactionCheck>> {\n let transactionCheckDto: TransactionCheckDto;\n const requestDto = {\n tx: {\n from,\n raw: rawTx,\n },\n chain: chainId,\n };\n\n try {\n const response = await axios.request<TransactionCheckDto>({\n method: \"POST\",\n url: `${this.config.web3checks.url}/ethereum/scan/tx`,\n data: requestDto,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n transactionCheckDto = response.data;\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Failed to fetch web3 checks information\",\n ),\n );\n }\n\n if (!this._isTransactionCheckDto(transactionCheckDto)) {\n return Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received\",\n ),\n );\n }\n const result: TransactionCheck = {\n publicKeyId: transactionCheckDto.public_key_id,\n descriptor: transactionCheckDto.descriptor,\n };\n\n return Right(result);\n }\n\n private _isTransactionCheckDto(dto: unknown): dto is TransactionCheckDto {\n return (\n dto != null &&\n typeof dto == \"object\" &&\n \"public_key_id\" in dto &&\n dto.public_key_id != null &&\n typeof dto.public_key_id == \"string\" &&\n \"descriptor\" in dto &&\n dto.descriptor != null &&\n typeof dto.descriptor == \"string\"\n );\n }\n}\n"],
5
+ "mappings": "qtBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,oCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAkB,oBAClBC,EAAmC,qBACnCC,EAAoC,qBAEpCC,EAA4B,mCAE5BC,EAGO,yCACPC,EAAoB,iCASb,IAAMC,EAAN,KAAqC,CAC1C,YAC+CC,EAC7C,CAD6C,YAAAA,CAC5C,CAEH,MAAa,oBAAoB,CAC/B,QAAAC,EACA,MAAAC,EACA,KAAAC,CACF,EAAwE,CACtE,IAAIC,EACJ,MAAMC,EAAa,CACjB,GAAI,CACF,KAAAF,EACA,IAAKD,CACP,EACA,MAAOD,CACT,EAEA,GAAI,CAUFG,GATiB,MAAM,EAAAE,QAAM,QAA6B,CACxD,OAAQ,OACR,IAAK,GAAG,KAAK,OAAO,WAAW,GAAG,oBAClC,KAAMD,EACN,QAAS,CACP,CAAC,8BAA4B,EAAG,kBAAkB,EAAAE,QAAQ,OAAO,GACjE,CAAC,4BAA0B,EAAG,KAAK,OAAO,WAC5C,CACF,CAAC,GAC8B,IACjC,MAAiB,CACf,SAAO,QACL,IAAI,MACF,yFACF,CACF,CACF,CAEA,GAAI,CAAC,KAAK,uBAAuBH,CAAmB,EAClD,SAAO,QACL,IAAI,MACF,gGACF,CACF,EAEF,MAAMI,EAA2B,CAC/B,YAAaJ,EAAoB,cACjC,WAAYA,EAAoB,UAClC,EAEA,SAAO,SAAMI,CAAM,CACrB,CAEQ,uBAAuBC,EAA0C,CACvE,OACEA,GAAO,MACP,OAAOA,GAAO,UACd,kBAAmBA,GACnBA,EAAI,eAAiB,MACrB,OAAOA,EAAI,eAAiB,UAC5B,eAAgBA,GAChBA,EAAI,YAAc,MAClB,OAAOA,EAAI,YAAc,QAE7B,CACF,EAjEaV,EAANW,EAAA,IADN,cAAW,EAGPC,EAAA,eAAO,cAAY,MAAM,IAFjBZ",
6
+ "names": ["HttpTransactionCheckDataSource_exports", "__export", "HttpTransactionCheckDataSource", "__toCommonJS", "import_axios", "import_inversify", "import_purify_ts", "import_configTypes", "import_HttpHeaders", "import_package", "HttpTransactionCheckDataSource", "config", "chainId", "rawTx", "from", "transactionCheckDto", "requestDto", "axios", "PACKAGE", "result", "dto", "__decorateClass", "__decorateParam"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var l=Object.create;var d=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var m=Object.getOwnPropertyNames;var x=Object.getPrototypeOf,k=Object.prototype.hasOwnProperty;var C=(t,e,a,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of m(e))!k.call(t,o)&&o!==a&&d(t,o,{get:()=>e[o],enumerable:!(n=p(e,o))||n.enumerable});return t};var u=(t,e,a)=>(a=t!=null?l(x(t)):{},C(e||!t||!t.__esModule?d(a,"default",{value:t,enumerable:!0}):a,t));var c=u(require("axios")),s=require("purify-ts"),i=require("../../shared/constant/HttpHeaders"),r=require("../../transaction-check/data/HttpTransactionCheckDataSource"),h=u(require("../../../package.json"));vi.mock("axios");describe("HttpTransactionCheckDataSource",()=>{const t={web3checks:{url:"web3checksUrl"},originToken:"originToken"};beforeEach(()=>{vi.resetAllMocks()}),describe("getTransactionCheck",()=>{it("should return an object if the request is successful",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1},a={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(c.default,"request").mockResolvedValueOnce({data:a});const o=await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e);expect(o).toEqual((0,s.Right)({publicKeyId:"test-key-id",descriptor:"test-descriptor"}))}),it("should return an error if the request fails",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1};vi.spyOn(c.default,"request").mockRejectedValue(new Error("error"));const n=await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e);expect(n).toEqual((0,s.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Failed to fetch web3 checks information")))}),it("should return an error if the response is invalid",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1},a={};vi.spyOn(c.default,"request").mockResolvedValue({data:a});const o=await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e);expect(o).toEqual((0,s.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received")))}),it("should return an error if public_key_id is missing",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1},a={descriptor:"test-descriptor"};vi.spyOn(c.default,"request").mockResolvedValue({data:a});const o=await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e);expect(o).toEqual((0,s.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received")))}),it("should return an error if descriptor is missing",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1},a={public_key_id:"test-key-id"};vi.spyOn(c.default,"request").mockResolvedValue({data:a});const o=await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e);expect(o).toEqual((0,s.Left)(new Error("[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received")))}),it("should call axios with the correct headers",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1};vi.spyOn(c.default,"request").mockResolvedValueOnce({data:{}}),await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e),expect(c.default.request).toHaveBeenCalledWith(expect.objectContaining({headers:{[i.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${h.default.version}`,[i.LEDGER_ORIGIN_TOKEN_HEADER]:t.originToken}}))}),it("should call axios with the correct URL and method",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1};vi.spyOn(c.default,"request").mockResolvedValueOnce({data:{}}),await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e),expect(c.default.request).toHaveBeenCalledWith(expect.objectContaining({method:"POST",url:`${t.web3checks.url}/ethereum/scan/tx`}))}),it("should call axios with the correct request data",async()=>{const e={from:"0x1234567890123456789012345678901234567890",rawTx:"0xabcdef",chainId:1};vi.spyOn(c.default,"request").mockResolvedValueOnce({data:{}}),await new r.HttpTransactionCheckDataSource(t).getTransactionCheck(e),expect(c.default.request).toHaveBeenCalledWith(expect.objectContaining({data:{tx:{from:"0x1234567890123456789012345678901234567890",raw:"0xabcdef"},chain:1}}))})})});
2
+ //# sourceMappingURL=HttpTransactionCheckDataSource.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/HttpTransactionCheckDataSource.test.ts"],
4
+ "sourcesContent": ["import axios from \"axios\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { type ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport { type TransactionCheckDto } from \"@/transaction-check/data/dto/TransactionCheckDto\";\nimport { HttpTransactionCheckDataSource } from \"@/transaction-check/data/HttpTransactionCheckDataSource\";\nimport { type GetTransactionCheckParams } from \"@/transaction-check/data/TransactionCheckDataSource\";\nimport PACKAGE from \"@root/package.json\";\n\nvi.mock(\"axios\");\n\ndescribe(\"HttpTransactionCheckDataSource\", () => {\n const config = {\n web3checks: {\n url: \"web3checksUrl\",\n },\n originToken: \"originToken\",\n } as ContextModuleConfig;\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"getTransactionCheck\", () => {\n it(\"should return an object if the request is successful\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n const dto: TransactionCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n const result = await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(result).toEqual(\n Right({\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n }),\n );\n });\n\n it(\"should return an error if the request fails\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n vi.spyOn(axios, \"request\").mockRejectedValue(new Error(\"error\"));\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n const result = await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Failed to fetch web3 checks information\",\n ),\n ),\n );\n });\n\n it(\"should return an error if the response is invalid\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n const dto = {};\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n const result = await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if public_key_id is missing\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n const dto = {\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n const result = await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if descriptor is missing\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n const dto = {\n public_key_id: \"test-key-id\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n const result = await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTransactionCheckDataSource: Cannot exploit transaction check data received\",\n ),\n ),\n );\n });\n\n it(\"should call axios with the correct headers\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: {} });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: config.originToken,\n },\n }),\n );\n });\n\n it(\"should call axios with the correct URL and method\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: {} });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n method: \"POST\",\n url: `${config.web3checks.url}/ethereum/scan/tx`,\n }),\n );\n });\n\n it(\"should call axios with the correct request data\", async () => {\n // GIVEN\n const params: GetTransactionCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n rawTx: \"0xabcdef\",\n chainId: 1,\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: {} });\n\n // WHEN\n const dataSource = new HttpTransactionCheckDataSource(config);\n await dataSource.getTransactionCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n data: {\n tx: {\n from: \"0x1234567890123456789012345678901234567890\",\n raw: \"0xabcdef\",\n },\n chain: 1,\n },\n }),\n );\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_axios", "import_purify_ts", "import_HttpHeaders", "import_HttpTransactionCheckDataSource", "import_package", "config", "params", "dto", "axios", "result", "PACKAGE"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var T=Object.create;var p=Object.defineProperty;var h=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var _=Object.getPrototypeOf,g=Object.prototype.hasOwnProperty;var b=(t,e)=>{for(var r in e)p(t,r,{get:e[r],enumerable:!0})},m=(t,e,r,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of E(e))!g.call(t,o)&&o!==r&&p(t,o,{get:()=>e[o],enumerable:!(i=h(e,o))||i.enumerable});return t};var l=(t,e,r)=>(r=t!=null?T(_(t)):{},m(e||!t||!t.__esModule?p(r,"default",{value:t,enumerable:!0}):r,t)),x=t=>m(p({},"__esModule",{value:!0}),t),u=(t,e,r,i)=>{for(var o=i>1?void 0:i?h(e,r):e,a=t.length-1,c;a>=0;a--)(c=t[a])&&(o=(i?c(e,r,o):c(o))||o);return i&&o&&p(e,r,o),o},D=(t,e)=>(r,i)=>e(r,i,t);var R={};b(R,{HttpTypedDataCheckDataSource:()=>n});module.exports=x(R);var C=l(require("axios")),d=require("inversify"),s=require("purify-ts"),f=require("../../config/di/configTypes"),y=require("../../shared/constant/HttpHeaders"),k=l(require("../../../package.json"));let n=class{constructor(e){this.config=e}async getTypedDataCheck({from:e,data:r}){let i;const o={msg:{from:e,data:r}};try{i=(await C.default.request({method:"POST",url:`${this.config.web3checks.url}/ethereum/scan/eip-712`,data:o,headers:{[y.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${k.default.version}`,[y.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}})).data}catch{return(0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Failed to fetch typed data check information"))}if(!this._isTypedDataCheckDto(i))return(0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received"));const a={publicKeyId:i.public_key_id,descriptor:i.descriptor};return(0,s.Right)(a)}_isTypedDataCheckDto(e){return e!=null&&typeof e=="object"&&"public_key_id"in e&&e.public_key_id!=null&&typeof e.public_key_id=="string"&&"descriptor"in e&&e.descriptor!=null&&typeof e.descriptor=="string"}};n=u([(0,d.injectable)(),D(0,(0,d.inject)(f.configTypes.Config))],n);0&&(module.exports={HttpTypedDataCheckDataSource});
2
+ //# sourceMappingURL=HttpTypedDataCheckDataSource.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/HttpTypedDataCheckDataSource.ts"],
4
+ "sourcesContent": ["import axios from \"axios\";\nimport { inject, injectable } from \"inversify\";\nimport { Either, Left, Right } from \"purify-ts\";\n\nimport { configTypes } from \"@/config/di/configTypes\";\nimport { type ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport PACKAGE from \"@root/package.json\";\n\nimport { TypedDataCheckDto } from \"./dto/TypedDataCheckDto\";\nimport {\n GetTypedDataCheckParams,\n TypedDataCheck,\n TypedDataCheckDataSource,\n} from \"./TypedDataCheckDataSource\";\n\n@injectable()\nexport class HttpTypedDataCheckDataSource implements TypedDataCheckDataSource {\n constructor(\n @inject(configTypes.Config) private readonly config: ContextModuleConfig,\n ) {}\n\n public async getTypedDataCheck({\n from,\n data,\n }: GetTypedDataCheckParams): Promise<Either<Error, TypedDataCheck>> {\n let typedDataCheckDto: TypedDataCheckDto;\n const requestDto = {\n msg: {\n from,\n data,\n },\n };\n\n try {\n const response = await axios.request<TypedDataCheckDto>({\n method: \"POST\",\n url: `${this.config.web3checks.url}/ethereum/scan/eip-712`,\n data: requestDto,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n typedDataCheckDto = response.data;\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Failed to fetch typed data check information\",\n ),\n );\n }\n\n if (!this._isTypedDataCheckDto(typedDataCheckDto)) {\n return Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n );\n }\n\n const result: TypedDataCheck = {\n publicKeyId: typedDataCheckDto.public_key_id,\n descriptor: typedDataCheckDto.descriptor,\n };\n\n return Right(result);\n }\n\n private _isTypedDataCheckDto(dto: unknown): dto is TypedDataCheckDto {\n return (\n dto != null &&\n typeof dto == \"object\" &&\n \"public_key_id\" in dto &&\n dto.public_key_id != null &&\n typeof dto.public_key_id == \"string\" &&\n \"descriptor\" in dto &&\n dto.descriptor != null &&\n typeof dto.descriptor == \"string\"\n );\n }\n}\n"],
5
+ "mappings": "qtBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,kCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAkB,oBAClBC,EAAmC,qBACnCC,EAAoC,qBAEpCC,EAA4B,mCAE5BC,EAGO,yCACPC,EAAoB,iCAUb,IAAMC,EAAN,KAAuE,CAC5E,YAC+CC,EAC7C,CAD6C,YAAAA,CAC5C,CAEH,MAAa,kBAAkB,CAC7B,KAAAC,EACA,KAAAC,CACF,EAAoE,CAClE,IAAIC,EACJ,MAAMC,EAAa,CACjB,IAAK,CACH,KAAAH,EACA,KAAAC,CACF,CACF,EAEA,GAAI,CAUFC,GATiB,MAAM,EAAAE,QAAM,QAA2B,CACtD,OAAQ,OACR,IAAK,GAAG,KAAK,OAAO,WAAW,GAAG,yBAClC,KAAMD,EACN,QAAS,CACP,CAAC,8BAA4B,EAAG,kBAAkB,EAAAE,QAAQ,OAAO,GACjE,CAAC,4BAA0B,EAAG,KAAK,OAAO,WAC5C,CACF,CAAC,GAC4B,IAC/B,MAAiB,CACf,SAAO,QACL,IAAI,MACF,4FACF,CACF,CACF,CAEA,GAAI,CAAC,KAAK,qBAAqBH,CAAiB,EAC9C,SAAO,QACL,IAAI,MACF,6FACF,CACF,EAGF,MAAMI,EAAyB,CAC7B,YAAaJ,EAAkB,cAC/B,WAAYA,EAAkB,UAChC,EAEA,SAAO,SAAMI,CAAM,CACrB,CAEQ,qBAAqBC,EAAwC,CACnE,OACEA,GAAO,MACP,OAAOA,GAAO,UACd,kBAAmBA,GACnBA,EAAI,eAAiB,MACrB,OAAOA,EAAI,eAAiB,UAC5B,eAAgBA,GAChBA,EAAI,YAAc,MAClB,OAAOA,EAAI,YAAc,QAE7B,CACF,EAhEaT,EAANU,EAAA,IADN,cAAW,EAGPC,EAAA,eAAO,cAAY,MAAM,IAFjBX",
6
+ "names": ["HttpTypedDataCheckDataSource_exports", "__export", "HttpTypedDataCheckDataSource", "__toCommonJS", "import_axios", "import_inversify", "import_purify_ts", "import_configTypes", "import_HttpHeaders", "import_package", "HttpTypedDataCheckDataSource", "config", "from", "data", "typedDataCheckDto", "requestDto", "axios", "PACKAGE", "result", "dto", "__decorateClass", "__decorateParam"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var h=Object.create;var p=Object.defineProperty;var k=Object.getOwnPropertyDescriptor;var m=Object.getOwnPropertyNames;var D=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty;var T=(e,i,a,t)=>{if(i&&typeof i=="object"||typeof i=="function")for(let o of m(i))!C.call(e,o)&&o!==a&&p(e,o,{get:()=>i[o],enumerable:!(t=k(i,o))||t.enumerable});return e};var u=(e,i,a)=>(a=e!=null?h(D(e)):{},T(i||!e||!e.__esModule?p(a,"default",{value:e,enumerable:!0}):a,e));var r=u(require("axios")),s=require("purify-ts"),n=require("../../shared/constant/HttpHeaders"),d=require("../../transaction-check/data/HttpTypedDataCheckDataSource"),l=u(require("../../../package.json"));vi.mock("axios");describe("HttpTypedDataCheckDataSource",()=>{const e={web3checks:{url:"web3checksUrl"},originToken:"originToken"};beforeEach(()=>{vi.resetAllMocks()}),describe("getTypedDataCheck",()=>{const a={from:"0x1234567890123456789012345678901234567890",data:{domain:{name:"Test Domain",version:"1",chainId:1,verifyingContract:"0x1234567890123456789012345678901234567890"},types:{EIP712Domain:[{name:"name",type:"string"},{name:"version",type:"string"},{name:"chainId",type:"uint256"},{name:"verifyingContract",type:"address"}],Person:[{name:"name",type:"string"},{name:"wallet",type:"address"}]},primaryType:"Person",message:{name:"Alice",wallet:"0x1234567890123456789012345678901234567890"}}};it("should return an object if the request is successful",async()=>{const t={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValueOnce({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Right)({publicKeyId:"test-key-id",descriptor:"test-descriptor"}))}),it("should return an error if the request fails",async()=>{vi.spyOn(r.default,"request").mockRejectedValue(new Error("error"));const o=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(o).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Failed to fetch typed data check information")))}),it("should return an error if the response is invalid",async()=>{const t={};vi.spyOn(r.default,"request").mockResolvedValue({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received")))}),it("should return an error if public_key_id is missing",async()=>{const t={descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValue({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received")))}),it("should return an error if descriptor is missing",async()=>{const t={public_key_id:"test-key-id"};vi.spyOn(r.default,"request").mockResolvedValue({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received")))}),it("should return an error if public_key_id is null",async()=>{const t={public_key_id:null,descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValue({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received")))}),it("should return an error if descriptor is null",async()=>{const t={public_key_id:"test-key-id",descriptor:null};vi.spyOn(r.default,"request").mockResolvedValue({data:t});const c=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a);expect(c).toEqual((0,s.Left)(new Error("[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received")))}),it("should call axios with the correct headers",async()=>{const t={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValueOnce({data:t}),await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a),expect(r.default.request).toHaveBeenCalledWith(expect.objectContaining({headers:{[n.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${l.default.version}`,[n.LEDGER_ORIGIN_TOKEN_HEADER]:e.originToken}}))}),it("should call axios with the correct URL and method",async()=>{const t={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValueOnce({data:t}),await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a),expect(r.default.request).toHaveBeenCalledWith(expect.objectContaining({method:"POST",url:`${e.web3checks.url}/ethereum/scan/eip-712`}))}),it("should call axios with the correct request data",async()=>{const t={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValueOnce({data:t}),await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(a),expect(r.default.request).toHaveBeenCalledWith(expect.objectContaining({data:{msg:{from:a.from,data:a.data}}}))}),it("should handle empty typed data",async()=>{const o={from:"0x1234567890123456789012345678901234567890",data:{domain:{},types:{},primaryType:"",message:{}}},c={public_key_id:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(r.default,"request").mockResolvedValueOnce({data:c});const y=await new d.HttpTypedDataCheckDataSource(e).getTypedDataCheck(o);expect(y).toEqual((0,s.Right)({publicKeyId:"test-key-id",descriptor:"test-descriptor"}))})})});
2
+ //# sourceMappingURL=HttpTypedDataCheckDataSource.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/HttpTypedDataCheckDataSource.test.ts"],
4
+ "sourcesContent": ["import axios from \"axios\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { type ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport { type TypedDataCheckDto } from \"@/transaction-check/data/dto/TypedDataCheckDto\";\nimport { HttpTypedDataCheckDataSource } from \"@/transaction-check/data/HttpTypedDataCheckDataSource\";\nimport {\n type GetTypedDataCheckParams,\n type TypedData,\n} from \"@/transaction-check/data/TypedDataCheckDataSource\";\nimport PACKAGE from \"@root/package.json\";\n\nvi.mock(\"axios\");\n\ndescribe(\"HttpTypedDataCheckDataSource\", () => {\n const config = {\n web3checks: {\n url: \"web3checksUrl\",\n },\n originToken: \"originToken\",\n } as ContextModuleConfig;\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"getTypedDataCheck\", () => {\n const validTypedData: TypedData = {\n domain: {\n name: \"Test Domain\",\n version: \"1\",\n chainId: 1,\n verifyingContract: \"0x1234567890123456789012345678901234567890\",\n },\n types: {\n EIP712Domain: [\n { name: \"name\", type: \"string\" },\n { name: \"version\", type: \"string\" },\n { name: \"chainId\", type: \"uint256\" },\n { name: \"verifyingContract\", type: \"address\" },\n ],\n Person: [\n { name: \"name\", type: \"string\" },\n { name: \"wallet\", type: \"address\" },\n ],\n },\n primaryType: \"Person\",\n message: {\n name: \"Alice\",\n wallet: \"0x1234567890123456789012345678901234567890\",\n },\n };\n\n const params: GetTypedDataCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n data: validTypedData,\n };\n\n it(\"should return an object if the request is successful\", async () => {\n // GIVEN\n const dto: TypedDataCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Right({\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n }),\n );\n });\n\n it(\"should return an error if the request fails\", async () => {\n // GIVEN\n vi.spyOn(axios, \"request\").mockRejectedValue(new Error(\"error\"));\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Failed to fetch typed data check information\",\n ),\n ),\n );\n });\n\n it(\"should return an error if the response is invalid\", async () => {\n // GIVEN\n const dto = {};\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if public_key_id is missing\", async () => {\n // GIVEN\n const dto = {\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if descriptor is missing\", async () => {\n // GIVEN\n const dto = {\n public_key_id: \"test-key-id\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if public_key_id is null\", async () => {\n // GIVEN\n const dto = {\n public_key_id: null,\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n ),\n );\n });\n\n it(\"should return an error if descriptor is null\", async () => {\n // GIVEN\n const dto = {\n public_key_id: \"test-key-id\",\n descriptor: null,\n };\n vi.spyOn(axios, \"request\").mockResolvedValue({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(result).toEqual(\n Left(\n new Error(\n \"[ContextModule] HttpTypedDataCheckDataSource: Cannot exploit typed data check data received\",\n ),\n ),\n );\n });\n\n it(\"should call axios with the correct headers\", async () => {\n // GIVEN\n const dto: TypedDataCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: config.originToken,\n },\n }),\n );\n });\n\n it(\"should call axios with the correct URL and method\", async () => {\n // GIVEN\n const dto: TypedDataCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n method: \"POST\",\n url: `${config.web3checks.url}/ethereum/scan/eip-712`,\n }),\n );\n });\n\n it(\"should call axios with the correct request data\", async () => {\n // GIVEN\n const dto: TypedDataCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n await dataSource.getTypedDataCheck(params);\n\n // THEN\n expect(axios.request).toHaveBeenCalledWith(\n expect.objectContaining({\n data: {\n msg: {\n from: params.from,\n data: params.data,\n },\n },\n }),\n );\n });\n\n it(\"should handle empty typed data\", async () => {\n // GIVEN\n const emptyTypedData: TypedData = {\n domain: {},\n types: {},\n primaryType: \"\",\n message: {},\n };\n const paramsWithEmptyData: GetTypedDataCheckParams = {\n from: \"0x1234567890123456789012345678901234567890\",\n data: emptyTypedData,\n };\n const dto: TypedDataCheckDto = {\n public_key_id: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(axios, \"request\").mockResolvedValueOnce({ data: dto });\n\n // WHEN\n const dataSource = new HttpTypedDataCheckDataSource(config);\n const result = await dataSource.getTypedDataCheck(paramsWithEmptyData);\n\n // THEN\n expect(result).toEqual(\n Right({\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n }),\n );\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_axios", "import_purify_ts", "import_HttpHeaders", "import_HttpTypedDataCheckDataSource", "import_package", "config", "params", "dto", "axios", "result", "PACKAGE", "paramsWithEmptyData"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var n=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var o=Object.getOwnPropertyNames;var s=Object.prototype.hasOwnProperty;var p=(t,r,i,a)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of o(r))!s.call(t,e)&&e!==i&&n(t,e,{get:()=>r[e],enumerable:!(a=c(r,e))||a.enumerable});return t};var h=t=>p(n({},"__esModule",{value:!0}),t);var m={};module.exports=h(m);
2
+ //# sourceMappingURL=TransactionCheckDataSource.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/TransactionCheckDataSource.ts"],
4
+ "sourcesContent": ["import { type Either } from \"purify-ts\";\n\nexport type GetTransactionCheckParams = {\n chainId: number;\n rawTx: string;\n from: string;\n};\n\nexport type TransactionCheck = {\n publicKeyId: string;\n descriptor: string;\n};\n\nexport interface TransactionCheckDataSource {\n getTransactionCheck(\n params: GetTransactionCheckParams,\n ): Promise<Either<Error, TransactionCheck>>;\n}\n"],
5
+ "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
+ "names": ["TransactionCheckDataSource_exports", "__toCommonJS"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var i=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var o=(t,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of s(e))!y.call(t,r)&&r!==n&&i(t,r,{get:()=>e[r],enumerable:!(a=p(e,r))||a.enumerable});return t};var d=t=>o(i({},"__esModule",{value:!0}),t);var g={};module.exports=d(g);
2
+ //# sourceMappingURL=TypedDataCheckDataSource.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/data/TypedDataCheckDataSource.ts"],
4
+ "sourcesContent": ["import { type Either } from \"purify-ts\";\n\nexport type TypedData = {\n domain: {\n name?: string;\n version?: string;\n chainId?: number;\n verifyingContract?: string;\n salt?: string;\n };\n types: Record<string, Array<{ name: string; type: string }>>;\n primaryType: string;\n message: Record<string, unknown>;\n};\n\nexport type GetTypedDataCheckParams = {\n from: string;\n data: TypedData;\n};\n\nexport type TypedDataCheck = {\n publicKeyId: string;\n descriptor: string;\n};\n\nexport interface TypedDataCheckDataSource {\n getTypedDataCheck(\n params: GetTypedDataCheckParams,\n ): Promise<Either<Error, TypedDataCheck>>;\n}\n"],
5
+ "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
+ "names": ["TypedDataCheckDataSource_exports", "__toCommonJS"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var c=Object.defineProperty;var o=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var s=Object.prototype.hasOwnProperty;var a=(i,t,n,e)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of p(t))!s.call(i,r)&&r!==n&&c(i,r,{get:()=>t[r],enumerable:!(e=o(t,r))||e.enumerable});return i};var d=i=>a(c({},"__esModule",{value:!0}),i);var g={};module.exports=d(g);
2
+ //# sourceMappingURL=TransactionCheckDto.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/transaction-check/data/dto/TransactionCheckDto.ts"],
4
+ "sourcesContent": ["export type TransactionCheckDto = {\n public_key_id: string;\n descriptor: string;\n};\n"],
5
+ "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
+ "names": ["TransactionCheckDto_exports", "__toCommonJS"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var r=Object.defineProperty;var d=Object.getOwnPropertyDescriptor;var o=Object.getOwnPropertyNames;var s=Object.prototype.hasOwnProperty;var y=(e,t,c,p)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of o(t))!s.call(e,i)&&i!==c&&r(e,i,{get:()=>t[i],enumerable:!(p=d(t,i))||p.enumerable});return e};var a=e=>y(r({},"__esModule",{value:!0}),e);var g={};module.exports=a(g);
2
+ //# sourceMappingURL=TypedDataCheckDto.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/transaction-check/data/dto/TypedDataCheckDto.ts"],
4
+ "sourcesContent": ["export type TypedDataCheckDto = {\n public_key_id: string;\n descriptor: string;\n};\n"],
5
+ "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
+ "names": ["TypedDataCheckDto_exports", "__toCommonJS"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var c=Object.defineProperty;var k=Object.getOwnPropertyDescriptor;var T=Object.getOwnPropertyNames;var s=Object.prototype.hasOwnProperty;var D=(t,o)=>{for(var r in o)c(t,r,{get:o[r],enumerable:!0})},d=(t,o,r,n)=>{if(o&&typeof o=="object"||typeof o=="function")for(let a of T(o))!s.call(t,a)&&a!==r&&c(t,a,{get:()=>o[a],enumerable:!(n=k(o,a))||n.enumerable});return t};var f=t=>d(c({},"__esModule",{value:!0}),t);var y={};D(y,{transactionCheckModuleFactory:()=>u});module.exports=f(y);var C=require("inversify"),p=require("../../transaction-check/data/HttpTransactionCheckDataSource"),m=require("../../transaction-check/data/HttpTypedDataCheckDataSource"),e=require("../../transaction-check/di/transactionCheckTypes"),h=require("../../transaction-check/domain/TransactionCheckContextLoader"),i=require("../../transaction-check/domain/TypedDataCheckContextLoader");const u=()=>new C.ContainerModule(({bind:t})=>{t(e.transactionCheckTypes.TransactionCheckDataSource).to(p.HttpTransactionCheckDataSource),t(e.transactionCheckTypes.TransactionCheckContextLoader).to(h.TransactionCheckContextLoader),t(e.transactionCheckTypes.TypedDataCheckDataSource).to(m.HttpTypedDataCheckDataSource),t(e.transactionCheckTypes.TypedDataCheckContextLoader).to(i.TypedDataCheckContextLoader)});0&&(module.exports={transactionCheckModuleFactory});
2
+ //# sourceMappingURL=transactionCheckModuleFactory.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/di/transactionCheckModuleFactory.ts"],
4
+ "sourcesContent": ["import { ContainerModule } from \"inversify\";\n\nimport { HttpTransactionCheckDataSource } from \"@/transaction-check/data/HttpTransactionCheckDataSource\";\nimport { HttpTypedDataCheckDataSource } from \"@/transaction-check/data/HttpTypedDataCheckDataSource\";\nimport { transactionCheckTypes } from \"@/transaction-check/di/transactionCheckTypes\";\nimport { TransactionCheckContextLoader } from \"@/transaction-check/domain/TransactionCheckContextLoader\";\nimport { TypedDataCheckContextLoader } from \"@/transaction-check/domain/TypedDataCheckContextLoader\";\n\nexport const transactionCheckModuleFactory = () =>\n new ContainerModule(({ bind }) => {\n bind(transactionCheckTypes.TransactionCheckDataSource).to(\n HttpTransactionCheckDataSource,\n );\n bind(transactionCheckTypes.TransactionCheckContextLoader).to(\n TransactionCheckContextLoader,\n );\n bind(transactionCheckTypes.TypedDataCheckDataSource).to(\n HttpTypedDataCheckDataSource,\n );\n bind(transactionCheckTypes.TypedDataCheckContextLoader).to(\n TypedDataCheckContextLoader,\n );\n });\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,mCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAgC,qBAEhCC,EAA+C,mEAC/CC,EAA6C,iEAC7CC,EAAsC,wDACtCC,EAA8C,oEAC9CC,EAA4C,kEAErC,MAAMP,EAAgC,IAC3C,IAAI,kBAAgB,CAAC,CAAE,KAAAQ,CAAK,IAAM,CAChCA,EAAK,wBAAsB,0BAA0B,EAAE,GACrD,gCACF,EACAA,EAAK,wBAAsB,6BAA6B,EAAE,GACxD,+BACF,EACAA,EAAK,wBAAsB,wBAAwB,EAAE,GACnD,8BACF,EACAA,EAAK,wBAAsB,2BAA2B,EAAE,GACtD,6BACF,CACF,CAAC",
6
+ "names": ["transactionCheckModuleFactory_exports", "__export", "transactionCheckModuleFactory", "__toCommonJS", "import_inversify", "import_HttpTransactionCheckDataSource", "import_HttpTypedDataCheckDataSource", "import_transactionCheckTypes", "import_TransactionCheckContextLoader", "import_TypedDataCheckContextLoader", "bind"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var c=Object.defineProperty;var n=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var h=Object.prototype.hasOwnProperty;var k=(e,a)=>{for(var t in a)c(e,t,{get:a[t],enumerable:!0})},y=(e,a,t,r)=>{if(a&&typeof a=="object"||typeof a=="function")for(let o of C(a))!h.call(e,o)&&o!==t&&c(e,o,{get:()=>a[o],enumerable:!(r=n(a,o))||r.enumerable});return e};var T=e=>y(c({},"__esModule",{value:!0}),e);var D={};k(D,{transactionCheckTypes:()=>d});module.exports=T(D);const d={TransactionCheckDataSource:Symbol.for("TransactionCheckDataSource"),TransactionCheckContextLoader:Symbol.for("TransactionCheckContextLoader"),TypedDataCheckDataSource:Symbol.for("TypedDataCheckDataSource"),TypedDataCheckContextLoader:Symbol.for("TypedDataCheckContextLoader")};0&&(module.exports={transactionCheckTypes});
2
+ //# sourceMappingURL=transactionCheckTypes.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/di/transactionCheckTypes.ts"],
4
+ "sourcesContent": ["export const transactionCheckTypes = {\n TransactionCheckDataSource: Symbol.for(\"TransactionCheckDataSource\"),\n TransactionCheckContextLoader: Symbol.for(\"TransactionCheckContextLoader\"),\n TypedDataCheckDataSource: Symbol.for(\"TypedDataCheckDataSource\"),\n TypedDataCheckContextLoader: Symbol.for(\"TypedDataCheckContextLoader\"),\n};\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,2BAAAE,IAAA,eAAAC,EAAAH,GAAO,MAAME,EAAwB,CACnC,2BAA4B,OAAO,IAAI,4BAA4B,EACnE,8BAA+B,OAAO,IAAI,+BAA+B,EACzE,yBAA0B,OAAO,IAAI,0BAA0B,EAC/D,4BAA6B,OAAO,IAAI,6BAA6B,CACvE",
6
+ "names": ["transactionCheckTypes_exports", "__export", "transactionCheckTypes", "__toCommonJS"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var C=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var T=Object.getOwnPropertyNames;var k=Object.prototype.hasOwnProperty;var g=(o,e)=>{for(var r in e)C(o,r,{get:e[r],enumerable:!0})},u=(o,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of T(e))!k.call(o,t)&&t!==r&&C(o,t,{get:()=>e[t],enumerable:!(a=y(e,t))||a.enumerable});return o};var v=o=>u(C({},"__esModule",{value:!0}),o),p=(o,e,r,a)=>{for(var t=a>1?void 0:a?y(e,r):e,i=o.length-1,s;i>=0;i--)(s=o[i])&&(t=(a?s(e,r,t):s(t))||t);return a&&t&&C(e,r,t),t},l=(o,e)=>(r,a)=>e(r,a,o);var P={};g(P,{TransactionCheckContextLoader:()=>c});module.exports=v(P);var n=require("@ledgerhq/device-management-kit"),d=require("inversify"),I=require("../../pki/di/pkiTypes"),S=require("../../pki/model/KeyUsage"),m=require("../../shared/model/ClearSignContext"),h=require("../../transaction-check/di/transactionCheckTypes");const D=[m.ClearSignContextType.TRANSACTION_CHECK];let c=class{constructor(e,r){this.transactionCheckDataSource=e;this.certificateLoader=r}canHandle(e,r){return typeof e=="object"&&e!==null&&"from"in e&&e.from!==void 0&&(0,n.isHexaString)(e.from)&&"chainId"in e&&e.chainId!==void 0&&typeof e.chainId=="number"&&"transaction"in e&&e.transaction!==void 0&&"deviceModelId"in e&&e.deviceModelId!==void 0&&e.deviceModelId!==n.DeviceModelId.NANO_S&&typeof e.chainId=="number"&&(0,n.isHexaString)(e.from)&&e.from!=="0x"&&D.every(t=>r.includes(t))}async load(e){const{from:r,chainId:a,transaction:t}=e,i=(0,n.bufferToHexaString)(t);return!r||!i?[]:[await(await this.transactionCheckDataSource.getTransactionCheck({chainId:a,rawTx:i,from:r})).caseOf({Left:f=>Promise.resolve({type:m.ClearSignContextType.ERROR,error:f}),Right:async f=>{const x=await this.certificateLoader.loadCertificate({keyId:f.publicKeyId,keyUsage:S.KeyUsage.TxSimulationSigner,targetDevice:e.deviceModelId});return{type:m.ClearSignContextType.TRANSACTION_CHECK,payload:f.descriptor,certificate:x}}})]}};c=p([(0,d.injectable)(),l(0,(0,d.inject)(h.transactionCheckTypes.TransactionCheckDataSource)),l(1,(0,d.inject)(I.pkiTypes.PkiCertificateLoader))],c);0&&(module.exports={TransactionCheckContextLoader});
2
+ //# sourceMappingURL=TransactionCheckContextLoader.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/domain/TransactionCheckContextLoader.ts"],
4
+ "sourcesContent": ["import {\n bufferToHexaString,\n DeviceModelId,\n isHexaString,\n} from \"@ledgerhq/device-management-kit\";\nimport { inject, injectable } from \"inversify\";\n\nimport { pkiTypes } from \"@/pki/di/pkiTypes\";\nimport { type PkiCertificateLoader } from \"@/pki/domain/PkiCertificateLoader\";\nimport { KeyUsage } from \"@/pki/model/KeyUsage\";\nimport { ContextLoader } from \"@/shared/domain/ContextLoader\";\nimport {\n ClearSignContext,\n ClearSignContextType,\n} from \"@/shared/model/ClearSignContext\";\nimport { type TransactionCheckDataSource } from \"@/transaction-check/data/TransactionCheckDataSource\";\nimport { transactionCheckTypes } from \"@/transaction-check/di/transactionCheckTypes\";\n\nexport type TransactionCheckContextInput = {\n from: string;\n chainId: number;\n transaction: Uint8Array;\n deviceModelId: DeviceModelId;\n};\n\nconst SUPPORTED_TYPES: ClearSignContextType[] = [\n ClearSignContextType.TRANSACTION_CHECK,\n];\n\n@injectable()\nexport class TransactionCheckContextLoader\n implements ContextLoader<TransactionCheckContextInput>\n{\n constructor(\n @inject(transactionCheckTypes.TransactionCheckDataSource)\n private transactionCheckDataSource: TransactionCheckDataSource,\n @inject(pkiTypes.PkiCertificateLoader)\n private certificateLoader: PkiCertificateLoader,\n ) {}\n\n canHandle(\n input: unknown,\n expectedType: ClearSignContextType[],\n ): input is TransactionCheckContextInput {\n const result =\n typeof input === \"object\" &&\n input !== null &&\n \"from\" in input &&\n input.from !== undefined &&\n isHexaString(input.from) &&\n \"chainId\" in input &&\n input.chainId !== undefined &&\n typeof input.chainId === \"number\" &&\n \"transaction\" in input &&\n input.transaction !== undefined &&\n \"deviceModelId\" in input &&\n input.deviceModelId !== undefined &&\n input.deviceModelId !== DeviceModelId.NANO_S &&\n typeof input.chainId === \"number\" &&\n isHexaString(input.from) &&\n input.from !== \"0x\" &&\n SUPPORTED_TYPES.every((type) => expectedType.includes(type));\n return result;\n }\n\n async load(ctx: TransactionCheckContextInput): Promise<ClearSignContext[]> {\n const { from, chainId, transaction } = ctx;\n\n const rawTx = bufferToHexaString(transaction);\n\n if (!from || !rawTx) {\n return [];\n }\n\n const txCheck = await this.transactionCheckDataSource.getTransactionCheck({\n chainId,\n rawTx,\n from,\n });\n\n const context = await txCheck.caseOf<Promise<ClearSignContext>>({\n Left: (error) =>\n Promise.resolve({\n type: ClearSignContextType.ERROR,\n error,\n }),\n Right: async (data) => {\n const certificate = await this.certificateLoader.loadCertificate({\n keyId: data.publicKeyId,\n keyUsage: KeyUsage.TxSimulationSigner,\n targetDevice: ctx.deviceModelId,\n });\n\n return {\n type: ClearSignContextType.TRANSACTION_CHECK,\n payload: data.descriptor,\n certificate,\n };\n },\n });\n\n return [context];\n }\n}\n"],
5
+ "mappings": "okBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,mCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAIO,2CACPC,EAAmC,qBAEnCC,EAAyB,6BAEzBC,EAAyB,gCAEzBC,EAGO,2CAEPC,EAAsC,wDAStC,MAAMC,EAA0C,CAC9C,uBAAqB,iBACvB,EAGO,IAAMC,EAAN,KAEP,CACE,YAEUC,EAEAC,EACR,CAHQ,gCAAAD,EAEA,uBAAAC,CACP,CAEH,UACEC,EACAC,EACuC,CAmBvC,OAjBE,OAAOD,GAAU,UACjBA,IAAU,MACV,SAAUA,GACVA,EAAM,OAAS,WACf,gBAAaA,EAAM,IAAI,GACvB,YAAaA,GACbA,EAAM,UAAY,QAClB,OAAOA,EAAM,SAAY,UACzB,gBAAiBA,GACjBA,EAAM,cAAgB,QACtB,kBAAmBA,GACnBA,EAAM,gBAAkB,QACxBA,EAAM,gBAAkB,gBAAc,QACtC,OAAOA,EAAM,SAAY,aACzB,gBAAaA,EAAM,IAAI,GACvBA,EAAM,OAAS,MACfJ,EAAgB,MAAOM,GAASD,EAAa,SAASC,CAAI,CAAC,CAE/D,CAEA,MAAM,KAAKC,EAAgE,CACzE,KAAM,CAAE,KAAAC,EAAM,QAAAC,EAAS,YAAAC,CAAY,EAAIH,EAEjCI,KAAQ,sBAAmBD,CAAW,EAE5C,MAAI,CAACF,GAAQ,CAACG,EACL,CAAC,EA8BH,CArBS,MANA,MAAM,KAAK,2BAA2B,oBAAoB,CACxE,QAAAF,EACA,MAAAE,EACA,KAAAH,CACF,CAAC,GAE6B,OAAkC,CAC9D,KAAOI,GACL,QAAQ,QAAQ,CACd,KAAM,uBAAqB,MAC3B,MAAAA,CACF,CAAC,EACH,MAAO,MAAOC,GAAS,CACrB,MAAMC,EAAc,MAAM,KAAK,kBAAkB,gBAAgB,CAC/D,MAAOD,EAAK,YACZ,SAAU,WAAS,mBACnB,aAAcN,EAAI,aACpB,CAAC,EAED,MAAO,CACL,KAAM,uBAAqB,kBAC3B,QAASM,EAAK,WACd,YAAAC,CACF,CACF,CACF,CAAC,CAEc,CACjB,CACF,EAzEab,EAANc,EAAA,IADN,cAAW,EAKPC,EAAA,eAAO,wBAAsB,0BAA0B,GAEvDA,EAAA,eAAO,WAAS,oBAAoB,IAN5Bf",
6
+ "names": ["TransactionCheckContextLoader_exports", "__export", "TransactionCheckContextLoader", "__toCommonJS", "import_device_management_kit", "import_inversify", "import_pkiTypes", "import_KeyUsage", "import_ClearSignContext", "import_transactionCheckTypes", "SUPPORTED_TYPES", "TransactionCheckContextLoader", "transactionCheckDataSource", "certificateLoader", "input", "expectedType", "type", "ctx", "from", "chainId", "transaction", "rawTx", "error", "data", "certificate", "__decorateClass", "__decorateParam"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var l=require("@ledgerhq/device-management-kit"),c=require("purify-ts"),u=require("../../pki/model/KeyUsage"),d=require("../../shared/model/ClearSignContext"),f=require("../../transaction-check/domain/TransactionCheckContextLoader");describe("TransactionCheckContextLoader",()=>{const i={getTransactionCheck:vi.fn()},s={loadCertificate:vi.fn()},a=new f.TransactionCheckContextLoader(i,s),r=[d.ClearSignContextType.TRANSACTION_CHECK];beforeEach(()=>{vi.resetAllMocks()}),describe("canHandle function",()=>{const e={from:"0x1234567890123456789012345678901234567890",chainId:1,transaction:new Uint8Array([1,2,3]),deviceModelId:l.DeviceModelId.FLEX};it("should return true for valid input",()=>{expect(a.canHandle(e,r)).toBe(!0)}),it("should return false for invalid expected type",()=>{expect(a.canHandle(e,[d.ClearSignContextType.TOKEN])).toBe(!1)}),it.each([[null,"null input"],[void 0,"undefined input"],[{},"empty object"],["string","string input"],[123,"number input"]])("should return false for %s",(n,t)=>{expect(a.canHandle(n,r)).toBe(!1)}),it.each([[{...e,from:void 0},"missing from"],[{...e,chainId:void 0},"missing chainId"],[{...e,transaction:void 0},"missing transaction"],[{...e,deviceModelId:void 0},"missing deviceModelId"]])("should return false for %s",(n,t)=>{expect(a.canHandle(n,r)).toBe(!1)}),it.each([[{...e,from:"invalid-hex"},"invalid from hex"],[{...e,from:"0x"},"empty from hex"],[{...e,from:"not-hex"},"non-hex from"]])("should return false for %s",(n,t)=>{expect(a.canHandle(n,r)).toBe(!1)}),it("should return false for NANO_S device model",()=>{const n={...e,deviceModelId:l.DeviceModelId.NANO_S};expect(a.canHandle(n,r)).toBe(!1)}),it("should return false for non-number chainId",()=>{const n={...e,chainId:"not-a-number"};expect(a.canHandle(n,r)).toBe(!1)})}),describe("load function",()=>{const e={from:"0x1234567890123456789012345678901234567890",chainId:1,transaction:new Uint8Array([1,2,3]),deviceModelId:l.DeviceModelId.FLEX},n={descriptor:"cert-descriptor",signature:"cert-signature",keyUsageNumber:0,payload:new Uint8Array};it("should return empty array when from is empty",async()=>{const t={...e,from:""},o=await a.load(t);expect(o).toEqual([])}),it("should return error context when transaction check fails",async()=>{const t=new Error("Transaction check failed");vi.spyOn(i,"getTransactionCheck").mockResolvedValue((0,c.Left)(t));const o=await a.load(e);expect(o).toEqual([{type:d.ClearSignContextType.ERROR,error:t}])}),it("should return transaction check context when successful",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(i,"getTransactionCheck").mockResolvedValue((0,c.Right)(t)),vi.spyOn(s,"loadCertificate").mockResolvedValue(n);const o=await a.load(e);expect(i.getTransactionCheck).toHaveBeenCalledWith({chainId:e.chainId,rawTx:"0x010203",from:e.from}),expect(s.loadCertificate).toHaveBeenCalledWith({keyId:t.publicKeyId,keyUsage:u.KeyUsage.TxSimulationSigner,targetDevice:e.deviceModelId}),expect(o).toEqual([{type:d.ClearSignContextType.TRANSACTION_CHECK,payload:t.descriptor,certificate:n}])}),it("should handle certificate loading failure",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"},o=new Error("Certificate loading failed");vi.spyOn(i,"getTransactionCheck").mockResolvedValue((0,c.Right)(t)),vi.spyOn(s,"loadCertificate").mockRejectedValue(o),await expect(a.load(e)).rejects.toThrow(o)}),it("should convert transaction buffer to hex string correctly",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(i,"getTransactionCheck").mockResolvedValue((0,c.Right)(t)),vi.spyOn(s,"loadCertificate").mockResolvedValue(n),await a.load(e),expect(i.getTransactionCheck).toHaveBeenCalledWith({chainId:e.chainId,rawTx:"0x010203",from:e.from})})})});
2
+ //# sourceMappingURL=TransactionCheckContextLoader.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/domain/TransactionCheckContextLoader.test.ts"],
4
+ "sourcesContent": ["import { DeviceModelId } from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\n\nimport type { PkiCertificateLoader } from \"@/pki/domain/PkiCertificateLoader\";\nimport { KeyUsage } from \"@/pki/model/KeyUsage\";\nimport { ClearSignContextType } from \"@/shared/model/ClearSignContext\";\nimport { type TransactionCheckDataSource } from \"@/transaction-check/data/TransactionCheckDataSource\";\nimport {\n type TransactionCheckContextInput,\n TransactionCheckContextLoader,\n} from \"@/transaction-check/domain/TransactionCheckContextLoader\";\n\ndescribe(\"TransactionCheckContextLoader\", () => {\n const mockTransactionCheckDataSource: TransactionCheckDataSource = {\n getTransactionCheck: vi.fn(),\n };\n const mockCertificateLoader: PkiCertificateLoader = {\n loadCertificate: vi.fn(),\n };\n const loader = new TransactionCheckContextLoader(\n mockTransactionCheckDataSource,\n mockCertificateLoader,\n );\n\n const SUPPORTED_TYPES: ClearSignContextType[] = [\n ClearSignContextType.TRANSACTION_CHECK,\n ];\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"canHandle function\", () => {\n const validInput: TransactionCheckContextInput = {\n from: \"0x1234567890123456789012345678901234567890\",\n chainId: 1,\n transaction: new Uint8Array([1, 2, 3]),\n deviceModelId: DeviceModelId.FLEX,\n };\n\n it(\"should return true for valid input\", () => {\n expect(loader.canHandle(validInput, SUPPORTED_TYPES)).toBe(true);\n });\n\n it(\"should return false for invalid expected type\", () => {\n expect(loader.canHandle(validInput, [ClearSignContextType.TOKEN])).toBe(\n false,\n );\n });\n\n it.each([\n [null, \"null input\"],\n [undefined, \"undefined input\"],\n [{}, \"empty object\"],\n [\"string\", \"string input\"],\n [123, \"number input\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it.each([\n [{ ...validInput, from: undefined }, \"missing from\"],\n [{ ...validInput, chainId: undefined }, \"missing chainId\"],\n [{ ...validInput, transaction: undefined }, \"missing transaction\"],\n [{ ...validInput, deviceModelId: undefined }, \"missing deviceModelId\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it.each([\n [{ ...validInput, from: \"invalid-hex\" }, \"invalid from hex\"],\n [{ ...validInput, from: \"0x\" }, \"empty from hex\"],\n [{ ...validInput, from: \"not-hex\" }, \"non-hex from\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it(\"should return false for NANO_S device model\", () => {\n const inputWithNanoS = {\n ...validInput,\n deviceModelId: DeviceModelId.NANO_S,\n };\n expect(loader.canHandle(inputWithNanoS, SUPPORTED_TYPES)).toBe(false);\n });\n\n it(\"should return false for non-number chainId\", () => {\n const inputWithInvalidChainId = {\n ...validInput,\n chainId: \"not-a-number\" as unknown as number,\n };\n expect(loader.canHandle(inputWithInvalidChainId, SUPPORTED_TYPES)).toBe(\n false,\n );\n });\n });\n\n describe(\"load function\", () => {\n const validInput: TransactionCheckContextInput = {\n from: \"0x1234567890123456789012345678901234567890\",\n chainId: 1,\n transaction: new Uint8Array([1, 2, 3]),\n deviceModelId: DeviceModelId.FLEX,\n };\n\n const mockCertificate = {\n descriptor: \"cert-descriptor\",\n signature: \"cert-signature\",\n keyUsageNumber: 0,\n payload: new Uint8Array(),\n };\n\n it(\"should return empty array when from is empty\", async () => {\n const inputWithEmptyFrom = { ...validInput, from: \"\" };\n const result = await loader.load(inputWithEmptyFrom);\n expect(result).toEqual([]);\n });\n\n it(\"should return error context when transaction check fails\", async () => {\n const error = new Error(\"Transaction check failed\");\n vi.spyOn(\n mockTransactionCheckDataSource,\n \"getTransactionCheck\",\n ).mockResolvedValue(Left(error));\n\n const result = await loader.load(validInput);\n\n expect(result).toEqual([\n {\n type: ClearSignContextType.ERROR,\n error,\n },\n ]);\n });\n\n it(\"should return transaction check context when successful\", async () => {\n const transactionCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(\n mockTransactionCheckDataSource,\n \"getTransactionCheck\",\n ).mockResolvedValue(Right(transactionCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockResolvedValue(\n mockCertificate,\n );\n\n const result = await loader.load(validInput);\n\n expect(\n mockTransactionCheckDataSource.getTransactionCheck,\n ).toHaveBeenCalledWith({\n chainId: validInput.chainId,\n rawTx: \"0x010203\",\n from: validInput.from,\n });\n\n expect(mockCertificateLoader.loadCertificate).toHaveBeenCalledWith({\n keyId: transactionCheckData.publicKeyId,\n keyUsage: KeyUsage.TxSimulationSigner,\n targetDevice: validInput.deviceModelId,\n });\n\n expect(result).toEqual([\n {\n type: ClearSignContextType.TRANSACTION_CHECK,\n payload: transactionCheckData.descriptor,\n certificate: mockCertificate,\n },\n ]);\n });\n\n it(\"should handle certificate loading failure\", async () => {\n const transactionCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n const certificateError = new Error(\"Certificate loading failed\");\n\n vi.spyOn(\n mockTransactionCheckDataSource,\n \"getTransactionCheck\",\n ).mockResolvedValue(Right(transactionCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockRejectedValue(\n certificateError,\n );\n\n await expect(loader.load(validInput)).rejects.toThrow(certificateError);\n });\n\n it(\"should convert transaction buffer to hex string correctly\", async () => {\n const transactionCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(\n mockTransactionCheckDataSource,\n \"getTransactionCheck\",\n ).mockResolvedValue(Right(transactionCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockResolvedValue(\n mockCertificate,\n );\n\n await loader.load(validInput);\n\n expect(\n mockTransactionCheckDataSource.getTransactionCheck,\n ).toHaveBeenCalledWith({\n chainId: validInput.chainId,\n rawTx: \"0x010203\", // Uint8Array([1, 2, 3]) converted to hex\n from: validInput.from,\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_device_management_kit", "import_purify_ts", "import_KeyUsage", "import_ClearSignContext", "import_TransactionCheckContextLoader", "mockTransactionCheckDataSource", "mockCertificateLoader", "loader", "SUPPORTED_TYPES", "validInput", "input", "_description", "inputWithNanoS", "inputWithInvalidChainId", "mockCertificate", "inputWithEmptyFrom", "result", "error", "transactionCheckData", "certificateError"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var C=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var I=(o,e)=>{for(var t in e)C(o,t,{get:e[t],enumerable:!0})},g=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of k(e))!x.call(o,a)&&a!==t&&C(o,a,{get:()=>e[a],enumerable:!(r=f(e,a))||r.enumerable});return o};var h=o=>g(C({},"__esModule",{value:!0}),o),y=(o,e,t,r)=>{for(var a=r>1?void 0:r?f(e,t):e,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(r?i(e,t,a):i(a))||a);return r&&a&&C(e,t,a),a},s=(o,e)=>(t,r)=>e(t,r,o);var v={};I(v,{TypedDataCheckContextLoader:()=>c});module.exports=h(v);var m=require("@ledgerhq/device-management-kit"),d=require("inversify"),l=require("../../pki/di/pkiTypes"),S=require("../../pki/model/KeyUsage"),p=require("../../shared/model/ClearSignContext"),T=require("../../transaction-check/di/transactionCheckTypes");const u=[p.ClearSignContextType.TRANSACTION_CHECK];let c=class{constructor(e,t){this.typedDataCheckDataSource=e;this.certificateLoader=t}canHandle(e,t){return typeof e=="object"&&e!==null&&"from"in e&&e.from!==void 0&&(0,m.isHexaString)(e.from)&&e.from!=="0x"&&"data"in e&&typeof e.data=="object"&&"deviceModelId"in e&&e.deviceModelId!==void 0&&e.deviceModelId!==m.DeviceModelId.NANO_S&&u.every(a=>t.includes(a))}async load(e){const{from:t,data:r}=e;return!t||!r?[]:[await(await this.typedDataCheckDataSource.getTypedDataCheck({data:r,from:t})).caseOf({Left:i=>Promise.resolve({type:p.ClearSignContextType.ERROR,error:i}),Right:async i=>{const D=await this.certificateLoader.loadCertificate({keyId:i.publicKeyId,keyUsage:S.KeyUsage.TxSimulationSigner,targetDevice:e.deviceModelId});return{type:p.ClearSignContextType.TRANSACTION_CHECK,payload:i.descriptor,certificate:D}}})]}};c=y([(0,d.injectable)(),s(0,(0,d.inject)(T.transactionCheckTypes.TypedDataCheckDataSource)),s(1,(0,d.inject)(l.pkiTypes.PkiCertificateLoader))],c);0&&(module.exports={TypedDataCheckContextLoader});
2
+ //# sourceMappingURL=TypedDataCheckContextLoader.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/domain/TypedDataCheckContextLoader.ts"],
4
+ "sourcesContent": ["import { DeviceModelId, isHexaString } from \"@ledgerhq/device-management-kit\";\nimport { inject, injectable } from \"inversify\";\n\nimport { pkiTypes } from \"@/pki/di/pkiTypes\";\nimport { type PkiCertificateLoader } from \"@/pki/domain/PkiCertificateLoader\";\nimport { KeyUsage } from \"@/pki/model/KeyUsage\";\nimport { ContextLoader } from \"@/shared/domain/ContextLoader\";\nimport {\n ClearSignContext,\n ClearSignContextType,\n} from \"@/shared/model/ClearSignContext\";\nimport {\n TypedData,\n type TypedDataCheckDataSource,\n} from \"@/transaction-check/data/TypedDataCheckDataSource\";\nimport { transactionCheckTypes } from \"@/transaction-check/di/transactionCheckTypes\";\n\nexport type TypedDataCheckContextInput = {\n from: string;\n data: TypedData;\n deviceModelId: DeviceModelId;\n};\n\nconst SUPPORTED_TYPES: ClearSignContextType[] = [\n ClearSignContextType.TRANSACTION_CHECK,\n];\n\n@injectable()\nexport class TypedDataCheckContextLoader\n implements ContextLoader<TypedDataCheckContextInput>\n{\n constructor(\n @inject(transactionCheckTypes.TypedDataCheckDataSource)\n private typedDataCheckDataSource: TypedDataCheckDataSource,\n @inject(pkiTypes.PkiCertificateLoader)\n private certificateLoader: PkiCertificateLoader,\n ) {}\n\n canHandle(\n input: unknown,\n expectedType: ClearSignContextType[],\n ): input is TypedDataCheckContextInput {\n const result =\n typeof input === \"object\" &&\n input !== null &&\n \"from\" in input &&\n input.from !== undefined &&\n isHexaString(input.from) &&\n input.from !== \"0x\" &&\n \"data\" in input &&\n typeof input.data === \"object\" &&\n \"deviceModelId\" in input &&\n input.deviceModelId !== undefined &&\n input.deviceModelId !== DeviceModelId.NANO_S &&\n SUPPORTED_TYPES.every((type) => expectedType.includes(type));\n\n return result;\n }\n\n async load(ctx: TypedDataCheckContextInput): Promise<ClearSignContext[]> {\n const { from, data } = ctx;\n\n if (!from || !data) {\n return [];\n }\n\n const txCheck = await this.typedDataCheckDataSource.getTypedDataCheck({\n data,\n from,\n });\n\n const context = await txCheck.caseOf<Promise<ClearSignContext>>({\n Left: (error) =>\n Promise.resolve({\n type: ClearSignContextType.ERROR,\n error,\n }),\n Right: async (result) => {\n const certificate = await this.certificateLoader.loadCertificate({\n keyId: result.publicKeyId,\n keyUsage: KeyUsage.TxSimulationSigner,\n targetDevice: ctx.deviceModelId,\n });\n\n return {\n type: ClearSignContextType.TRANSACTION_CHECK,\n payload: result.descriptor,\n certificate,\n };\n },\n });\n\n return [context];\n }\n}\n"],
5
+ "mappings": "okBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,iCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAA4C,2CAC5CC,EAAmC,qBAEnCC,EAAyB,6BAEzBC,EAAyB,gCAEzBC,EAGO,2CAKPC,EAAsC,wDAQtC,MAAMC,EAA0C,CAC9C,uBAAqB,iBACvB,EAGO,IAAMC,EAAN,KAEP,CACE,YAEUC,EAEAC,EACR,CAHQ,8BAAAD,EAEA,uBAAAC,CACP,CAEH,UACEC,EACAC,EACqC,CAerC,OAbE,OAAOD,GAAU,UACjBA,IAAU,MACV,SAAUA,GACVA,EAAM,OAAS,WACf,gBAAaA,EAAM,IAAI,GACvBA,EAAM,OAAS,MACf,SAAUA,GACV,OAAOA,EAAM,MAAS,UACtB,kBAAmBA,GACnBA,EAAM,gBAAkB,QACxBA,EAAM,gBAAkB,gBAAc,QACtCJ,EAAgB,MAAOM,GAASD,EAAa,SAASC,CAAI,CAAC,CAG/D,CAEA,MAAM,KAAKC,EAA8D,CACvE,KAAM,CAAE,KAAAC,EAAM,KAAAC,CAAK,EAAIF,EAEvB,MAAI,CAACC,GAAQ,CAACC,EACL,CAAC,EA6BH,CArBS,MALA,MAAM,KAAK,yBAAyB,kBAAkB,CACpE,KAAAA,EACA,KAAAD,CACF,CAAC,GAE6B,OAAkC,CAC9D,KAAOE,GACL,QAAQ,QAAQ,CACd,KAAM,uBAAqB,MAC3B,MAAAA,CACF,CAAC,EACH,MAAO,MAAOC,GAAW,CACvB,MAAMC,EAAc,MAAM,KAAK,kBAAkB,gBAAgB,CAC/D,MAAOD,EAAO,YACd,SAAU,WAAS,mBACnB,aAAcJ,EAAI,aACpB,CAAC,EAED,MAAO,CACL,KAAM,uBAAqB,kBAC3B,QAASI,EAAO,WAChB,YAAAC,CACF,CACF,CACF,CAAC,CAEc,CACjB,CACF,EAlEaX,EAANY,EAAA,IADN,cAAW,EAKPC,EAAA,eAAO,wBAAsB,wBAAwB,GAErDA,EAAA,eAAO,WAAS,oBAAoB,IAN5Bb",
6
+ "names": ["TypedDataCheckContextLoader_exports", "__export", "TypedDataCheckContextLoader", "__toCommonJS", "import_device_management_kit", "import_inversify", "import_pkiTypes", "import_KeyUsage", "import_ClearSignContext", "import_transactionCheckTypes", "SUPPORTED_TYPES", "TypedDataCheckContextLoader", "typedDataCheckDataSource", "certificateLoader", "input", "expectedType", "type", "ctx", "from", "data", "error", "result", "certificate", "__decorateClass", "__decorateParam"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var l=require("@ledgerhq/device-management-kit"),d=require("purify-ts"),y=require("../../pki/model/KeyUsage"),s=require("../../shared/model/ClearSignContext"),m=require("../../transaction-check/domain/TypedDataCheckContextLoader");describe("TypedDataCheckContextLoader",()=>{const o={getTypedDataCheck:vi.fn()},c={loadCertificate:vi.fn()},n=new m.TypedDataCheckContextLoader(o,c),r=[s.ClearSignContextType.TRANSACTION_CHECK];beforeEach(()=>{vi.resetAllMocks()}),describe("canHandle function",()=>{const e={from:"0x1234567890123456789012345678901234567890",data:{domain:{name:"Test Domain",version:"1",chainId:1,verifyingContract:"0x1234567890123456789012345678901234567890"},types:{EIP712Domain:[{name:"name",type:"string"},{name:"version",type:"string"},{name:"chainId",type:"uint256"},{name:"verifyingContract",type:"address"}],Person:[{name:"name",type:"string"},{name:"wallet",type:"address"}]},primaryType:"Person",message:{name:"Alice",wallet:"0x1234567890123456789012345678901234567890"}},deviceModelId:l.DeviceModelId.FLEX};it("should return true for valid input",()=>{expect(n.canHandle(e,r)).toBe(!0)}),it("should return false for invalid expected type",()=>{expect(n.canHandle(e,[s.ClearSignContextType.TOKEN])).toBe(!1)}),it.each([[null,"null input"],[void 0,"undefined input"],[{},"empty object"],["string","string input"],[123,"number input"]])("should return false for %s",(a,t)=>{expect(n.canHandle(a,r)).toBe(!1)}),it.each([[{...e,from:void 0},"missing from"],[{...e,data:void 0},"missing data"],[{...e,deviceModelId:void 0},"missing deviceModelId"]])("should return false for %s",(a,t)=>{expect(n.canHandle(a,r)).toBe(!1)}),it.each([[{...e,from:"invalid-hex"},"invalid from hex"],[{...e,from:"0x"},"empty from hex"],[{...e,from:"not-hex"},"non-hex from"]])("should return false for %s",(a,t)=>{expect(n.canHandle(a,r)).toBe(!1)}),it("should return false for NANO_S device model",()=>{const a={...e,deviceModelId:l.DeviceModelId.NANO_S};expect(n.canHandle(a,r)).toBe(!1)}),it("should return false for non-object data",()=>{const a={...e,data:"not-an-object"};expect(n.canHandle(a,r)).toBe(!1)})}),describe("load function",()=>{const p={domain:{name:"Test Domain",version:"1",chainId:1,verifyingContract:"0x1234567890123456789012345678901234567890"},types:{EIP712Domain:[{name:"name",type:"string"},{name:"version",type:"string"},{name:"chainId",type:"uint256"},{name:"verifyingContract",type:"address"}],Person:[{name:"name",type:"string"},{name:"wallet",type:"address"}]},primaryType:"Person",message:{name:"Alice",wallet:"0x1234567890123456789012345678901234567890"}},e={from:"0x1234567890123456789012345678901234567890",data:p,deviceModelId:l.DeviceModelId.FLEX},a={descriptor:"cert-descriptor",signature:"cert-signature",keyUsageNumber:0,payload:new Uint8Array};it("should return empty array when from is empty",async()=>{const t={...e,from:""},i=await n.load(t);expect(i).toEqual([])}),it("should return error context when typed data check fails",async()=>{const t=new Error("Typed data check failed");vi.spyOn(o,"getTypedDataCheck").mockResolvedValue((0,d.Left)(t));const i=await n.load(e);expect(i).toEqual([{type:s.ClearSignContextType.ERROR,error:t}])}),it("should return transaction check context when successful",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(o,"getTypedDataCheck").mockResolvedValue((0,d.Right)(t)),vi.spyOn(c,"loadCertificate").mockResolvedValue(a);const i=await n.load(e);expect(o.getTypedDataCheck).toHaveBeenCalledWith({data:e.data,from:e.from}),expect(c.loadCertificate).toHaveBeenCalledWith({keyId:t.publicKeyId,keyUsage:y.KeyUsage.TxSimulationSigner,targetDevice:e.deviceModelId}),expect(i).toEqual([{type:s.ClearSignContextType.TRANSACTION_CHECK,payload:t.descriptor,certificate:a}])}),it("should handle certificate loading failure",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"},i=new Error("Certificate loading failed");vi.spyOn(o,"getTypedDataCheck").mockResolvedValue((0,d.Right)(t)),vi.spyOn(c,"loadCertificate").mockRejectedValue(i),await expect(n.load(e)).rejects.toThrow(i)}),it("should call typed data check with correct parameters",async()=>{const t={publicKeyId:"test-key-id",descriptor:"test-descriptor"};vi.spyOn(o,"getTypedDataCheck").mockResolvedValue((0,d.Right)(t)),vi.spyOn(c,"loadCertificate").mockResolvedValue(a),await n.load(e),expect(o.getTypedDataCheck).toHaveBeenCalledWith({data:p,from:e.from})})})});
2
+ //# sourceMappingURL=TypedDataCheckContextLoader.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transaction-check/domain/TypedDataCheckContextLoader.test.ts"],
4
+ "sourcesContent": ["import { DeviceModelId } from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\n\nimport type { PkiCertificateLoader } from \"@/pki/domain/PkiCertificateLoader\";\nimport { KeyUsage } from \"@/pki/model/KeyUsage\";\nimport { ClearSignContextType } from \"@/shared/model/ClearSignContext\";\nimport {\n type TypedData,\n type TypedDataCheckDataSource,\n} from \"@/transaction-check/data/TypedDataCheckDataSource\";\nimport {\n type TypedDataCheckContextInput,\n TypedDataCheckContextLoader,\n} from \"@/transaction-check/domain/TypedDataCheckContextLoader\";\n\ndescribe(\"TypedDataCheckContextLoader\", () => {\n const mockTypedDataCheckDataSource: TypedDataCheckDataSource = {\n getTypedDataCheck: vi.fn(),\n };\n const mockCertificateLoader: PkiCertificateLoader = {\n loadCertificate: vi.fn(),\n };\n const loader = new TypedDataCheckContextLoader(\n mockTypedDataCheckDataSource,\n mockCertificateLoader,\n );\n\n const SUPPORTED_TYPES: ClearSignContextType[] = [\n ClearSignContextType.TRANSACTION_CHECK,\n ];\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"canHandle function\", () => {\n const validTypedData: TypedData = {\n domain: {\n name: \"Test Domain\",\n version: \"1\",\n chainId: 1,\n verifyingContract: \"0x1234567890123456789012345678901234567890\",\n },\n types: {\n EIP712Domain: [\n { name: \"name\", type: \"string\" },\n { name: \"version\", type: \"string\" },\n { name: \"chainId\", type: \"uint256\" },\n { name: \"verifyingContract\", type: \"address\" },\n ],\n Person: [\n { name: \"name\", type: \"string\" },\n { name: \"wallet\", type: \"address\" },\n ],\n },\n primaryType: \"Person\",\n message: {\n name: \"Alice\",\n wallet: \"0x1234567890123456789012345678901234567890\",\n },\n };\n\n const validInput: TypedDataCheckContextInput = {\n from: \"0x1234567890123456789012345678901234567890\",\n data: validTypedData,\n deviceModelId: DeviceModelId.FLEX,\n };\n\n it(\"should return true for valid input\", () => {\n expect(loader.canHandle(validInput, SUPPORTED_TYPES)).toBe(true);\n });\n\n it(\"should return false for invalid expected type\", () => {\n expect(loader.canHandle(validInput, [ClearSignContextType.TOKEN])).toBe(\n false,\n );\n });\n\n it.each([\n [null, \"null input\"],\n [undefined, \"undefined input\"],\n [{}, \"empty object\"],\n [\"string\", \"string input\"],\n [123, \"number input\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it.each([\n [{ ...validInput, from: undefined }, \"missing from\"],\n [{ ...validInput, data: undefined }, \"missing data\"],\n [{ ...validInput, deviceModelId: undefined }, \"missing deviceModelId\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it.each([\n [{ ...validInput, from: \"invalid-hex\" }, \"invalid from hex\"],\n [{ ...validInput, from: \"0x\" }, \"empty from hex\"],\n [{ ...validInput, from: \"not-hex\" }, \"non-hex from\"],\n ])(\"should return false for %s\", (input, _description) => {\n expect(loader.canHandle(input, SUPPORTED_TYPES)).toBe(false);\n });\n\n it(\"should return false for NANO_S device model\", () => {\n const inputWithNanoS = {\n ...validInput,\n deviceModelId: DeviceModelId.NANO_S,\n };\n expect(loader.canHandle(inputWithNanoS, SUPPORTED_TYPES)).toBe(false);\n });\n\n it(\"should return false for non-object data\", () => {\n const inputWithInvalidData = {\n ...validInput,\n data: \"not-an-object\" as unknown as TypedData,\n };\n expect(loader.canHandle(inputWithInvalidData, SUPPORTED_TYPES)).toBe(\n false,\n );\n });\n });\n\n describe(\"load function\", () => {\n const validTypedData: TypedData = {\n domain: {\n name: \"Test Domain\",\n version: \"1\",\n chainId: 1,\n verifyingContract: \"0x1234567890123456789012345678901234567890\",\n },\n types: {\n EIP712Domain: [\n { name: \"name\", type: \"string\" },\n { name: \"version\", type: \"string\" },\n { name: \"chainId\", type: \"uint256\" },\n { name: \"verifyingContract\", type: \"address\" },\n ],\n Person: [\n { name: \"name\", type: \"string\" },\n { name: \"wallet\", type: \"address\" },\n ],\n },\n primaryType: \"Person\",\n message: {\n name: \"Alice\",\n wallet: \"0x1234567890123456789012345678901234567890\",\n },\n };\n\n const validInput: TypedDataCheckContextInput = {\n from: \"0x1234567890123456789012345678901234567890\",\n data: validTypedData,\n deviceModelId: DeviceModelId.FLEX,\n };\n\n const mockCertificate = {\n descriptor: \"cert-descriptor\",\n signature: \"cert-signature\",\n keyUsageNumber: 0,\n payload: new Uint8Array(),\n };\n\n it(\"should return empty array when from is empty\", async () => {\n const inputWithEmptyFrom = { ...validInput, from: \"\" };\n const result = await loader.load(inputWithEmptyFrom);\n expect(result).toEqual([]);\n });\n\n it(\"should return error context when typed data check fails\", async () => {\n const error = new Error(\"Typed data check failed\");\n vi.spyOn(\n mockTypedDataCheckDataSource,\n \"getTypedDataCheck\",\n ).mockResolvedValue(Left(error));\n\n const result = await loader.load(validInput);\n\n expect(result).toEqual([\n {\n type: ClearSignContextType.ERROR,\n error,\n },\n ]);\n });\n\n it(\"should return transaction check context when successful\", async () => {\n const typedDataCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(\n mockTypedDataCheckDataSource,\n \"getTypedDataCheck\",\n ).mockResolvedValue(Right(typedDataCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockResolvedValue(\n mockCertificate,\n );\n\n const result = await loader.load(validInput);\n\n expect(\n mockTypedDataCheckDataSource.getTypedDataCheck,\n ).toHaveBeenCalledWith({\n data: validInput.data,\n from: validInput.from,\n });\n\n expect(mockCertificateLoader.loadCertificate).toHaveBeenCalledWith({\n keyId: typedDataCheckData.publicKeyId,\n keyUsage: KeyUsage.TxSimulationSigner,\n targetDevice: validInput.deviceModelId,\n });\n\n expect(result).toEqual([\n {\n type: ClearSignContextType.TRANSACTION_CHECK,\n payload: typedDataCheckData.descriptor,\n certificate: mockCertificate,\n },\n ]);\n });\n\n it(\"should handle certificate loading failure\", async () => {\n const typedDataCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n const certificateError = new Error(\"Certificate loading failed\");\n\n vi.spyOn(\n mockTypedDataCheckDataSource,\n \"getTypedDataCheck\",\n ).mockResolvedValue(Right(typedDataCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockRejectedValue(\n certificateError,\n );\n\n await expect(loader.load(validInput)).rejects.toThrow(certificateError);\n });\n\n it(\"should call typed data check with correct parameters\", async () => {\n const typedDataCheckData = {\n publicKeyId: \"test-key-id\",\n descriptor: \"test-descriptor\",\n };\n vi.spyOn(\n mockTypedDataCheckDataSource,\n \"getTypedDataCheck\",\n ).mockResolvedValue(Right(typedDataCheckData));\n vi.spyOn(mockCertificateLoader, \"loadCertificate\").mockResolvedValue(\n mockCertificate,\n );\n\n await loader.load(validInput);\n\n expect(\n mockTypedDataCheckDataSource.getTypedDataCheck,\n ).toHaveBeenCalledWith({\n data: validTypedData,\n from: validInput.from,\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_device_management_kit", "import_purify_ts", "import_KeyUsage", "import_ClearSignContext", "import_TypedDataCheckContextLoader", "mockTypedDataCheckDataSource", "mockCertificateLoader", "loader", "SUPPORTED_TYPES", "validInput", "input", "_description", "inputWithNanoS", "inputWithInvalidData", "validTypedData", "mockCertificate", "inputWithEmptyFrom", "result", "error", "typedDataCheckData", "certificateError"]
7
+ }
@@ -1,2 +1,2 @@
1
- "use strict";var x=Object.create;var c=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var G=Object.getOwnPropertyNames;var _=Object.getPrototypeOf,P=Object.prototype.hasOwnProperty;var I=(o,e)=>{for(var t in e)c(o,t,{get:e[t],enumerable:!0})},D=(o,e,t,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of G(e))!P.call(o,r)&&r!==t&&c(o,r,{get:()=>e[r],enumerable:!(a=E(e,r))||a.enumerable});return o};var N=(o,e,t)=>(t=o!=null?x(_(o)):{},D(e||!o||!o.__esModule?c(t,"default",{value:o,enumerable:!0}):t,o)),v=o=>D(c({},"__esModule",{value:!0}),o),T=(o,e,t,a)=>{for(var r=a>1?void 0:a?E(e,t):e,i=o.length-1,s;i>=0;i--)(s=o[i])&&(r=(a?s(e,t,r):s(r))||r);return a&&r&&c(e,t,r),r},$=(o,e)=>(t,a)=>e(t,a,o);var w={};I(w,{HttpTrustedNameDataSource:()=>u});module.exports=v(w);var f=N(require("axios")),g=require("inversify"),n=require("purify-ts"),y=require("../../config/di/configTypes"),m=require("../../shared/constant/HttpHeaders"),l=N(require("../../../package.json"));let u=class{constructor(e){this.config=e}async getDomainNamePayload({chainId:e,domain:t,challenge:a}){try{const s=await f.default.request({method:"GET",url:`${this.config.metadataService.url}/names/ethereum/${e}/forward/${t}?types=eoa&sources=ens&challenge=${a}`,headers:{[m.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${l.default.version}`,[m.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}});return s.data.signedDescriptor?.data?(0,n.Right)(s.data.signedDescriptor.data):(0,n.Left)(new Error("[ContextModule] HttpTrustedNameDataSource: error getting domain payload"))}catch{return(0,n.Left)(new Error("[ContextModule] HttpTrustedNameDataSource: Failed to fetch domain name"))}}async getTrustedNamePayload({chainId:e,address:t,challenge:a,sources:r,types:i}){try{r=r.filter(h=>h==="ens"||h==="crypto_asset_list");const d=(await f.default.request({method:"GET",url:`${this.config.metadataService.url}/names/ethereum/${e}/reverse/${t}?types=${i.join(",")}&sources=${r.join(",")}&challenge=${a}`,headers:{[m.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${l.default.version}`,[m.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}})).data;if(!d?.signedDescriptor?.data)return(0,n.Left)(new Error(`[ContextModule] HttpTrustedNameDataSource: no trusted name metadata for address ${t}`));const p=d.signedDescriptor.data;if(!d.signedDescriptor.signatures||typeof d.signedDescriptor.signatures[this.config.cal.mode]!="string")return(0,n.Right)(p);const C=d.signedDescriptor.signatures[this.config.cal.mode];return(0,n.Right)(this.formatTrustedName(p,C))}catch{return(0,n.Left)(new Error("[ContextModule] HttpTrustedNameDataSource: Failed to fetch trusted name"))}}formatTrustedName(e,t){t.length%2!==0&&(t="0"+t);const a="15",r=(t.length/2).toString(16);return`${e}${a}${r}${t}`}};u=T([(0,g.injectable)(),$(0,(0,g.inject)(y.configTypes.Config))],u);0&&(module.exports={HttpTrustedNameDataSource});
1
+ "use strict";var k=Object.create;var m=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var I=Object.getPrototypeOf,x=Object.prototype.hasOwnProperty;var P=(o,e)=>{for(var t in e)m(o,t,{get:e[t],enumerable:!0})},D=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of C(e))!x.call(o,r)&&r!==t&&m(o,r,{get:()=>e[r],enumerable:!(n=l(e,r))||n.enumerable});return o};var N=(o,e,t)=>(t=o!=null?k(I(o)):{},D(e||!o||!o.__esModule?m(t,"default",{value:o,enumerable:!0}):t,o)),w=o=>D(m({},"__esModule",{value:!0}),o),T=(o,e,t,n)=>{for(var r=n>1?void 0:n?l(e,t):e,i=o.length-1,s;i>=0;i--)(s=o[i])&&(r=(n?s(e,t,r):s(r))||r);return n&&r&&m(e,t,r),r},h=(o,e)=>(t,n)=>e(t,n,o);var G={};P(G,{HttpTrustedNameDataSource:()=>c});module.exports=w(G);var g=N(require("axios")),u=require("inversify"),a=require("purify-ts"),$=require("../../config/di/configTypes"),d=require("../../shared/constant/HttpHeaders"),f=N(require("../../../package.json"));let c=class{constructor(e){this.config=e}async getDomainNamePayload({chainId:e,domain:t,challenge:n}){let r;try{r=(await g.default.request({method:"GET",url:`${this.config.metadataServiceDomain.url}/v2/names/ethereum/${e}/forward/${t}?types=eoa&sources=ens&challenge=${n}`,headers:{[d.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${f.default.version}`,[d.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}})).data}catch{return(0,a.Left)(new Error("[ContextModule] HttpTrustedNameDataSource: Failed to fetch domain name"))}return r?this.isTrustedNameDto(r)?(0,a.Right)({data:r.signedDescriptor.data,keyId:r.keyId,keyUsage:r.keyUsage}):(0,a.Left)(new Error(`[ContextModule] HttpTrustedNameDataSource: Invalid trusted name response format for domain ${t} on chain ${e}`)):(0,a.Left)(new Error(`[ContextModule] HttpTrustedNameDataSource: No data received for domain ${t} on chain ${e}`))}async getTrustedNamePayload({chainId:e,address:t,challenge:n,sources:r,types:i}){let s;try{r=r.filter(y=>y==="ens"||y==="crypto_asset_list"),s=(await g.default.request({method:"GET",url:`${this.config.metadataServiceDomain.url}/v2/names/ethereum/${e}/reverse/${t}?types=${i.join(",")}&sources=${r.join(",")}&challenge=${n}`,headers:{[d.LEDGER_CLIENT_VERSION_HEADER]:`context-module/${f.default.version}`,[d.LEDGER_ORIGIN_TOKEN_HEADER]:this.config.originToken}})).data}catch{return(0,a.Left)(new Error("[ContextModule] HttpTrustedNameDataSource: Failed to fetch trusted name"))}if(!s)return(0,a.Left)(new Error(`[ContextModule] HttpTrustedNameDataSource: No data received for address ${t} on chain ${e}`));if(!this.isTrustedNameDto(s))return(0,a.Left)(new Error(`[ContextModule] HttpTrustedNameDataSource: Invalid trusted name response format for address ${t} on chain ${e}`));if(typeof s.signedDescriptor.signatures[this.config.cal.mode]!="string")return(0,a.Right)({data:s.signedDescriptor.data,keyId:s.keyId,keyUsage:s.keyUsage});const p=s.signedDescriptor.signatures[this.config.cal.mode];return(0,a.Right)({data:this.formatTrustedName(s.signedDescriptor.data,p),keyId:s.keyId,keyUsage:s.keyUsage})}formatTrustedName(e,t){t.length%2!==0&&(t="0"+t);const n="15",r=(t.length/2).toString(16);return`${e}${n}${r}${t}`}isTrustedNameDto(e){return typeof e=="object"&&e!==null&&"signedDescriptor"in e&&"keyId"in e&&"keyUsage"in e&&typeof e.keyId=="string"&&typeof e.keyUsage=="string"&&typeof e.signedDescriptor=="object"&&e.signedDescriptor!==null&&"data"in e.signedDescriptor&&"signatures"in e.signedDescriptor&&typeof e.signedDescriptor.data=="string"&&typeof e.signedDescriptor.signatures=="object"}};c=T([(0,u.injectable)(),h(0,(0,u.inject)($.configTypes.Config))],c);0&&(module.exports={HttpTrustedNameDataSource});
2
2
  //# sourceMappingURL=HttpTrustedNameDataSource.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/trusted-name/data/HttpTrustedNameDataSource.ts"],
4
- "sourcesContent": ["import axios from \"axios\";\nimport { inject, injectable } from \"inversify\";\nimport { Either, Left, Right } from \"purify-ts\";\n\nimport { configTypes } from \"@/config/di/configTypes\";\nimport type { ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport {\n GetDomainNameInfosParams,\n GetTrustedNameInfosParams,\n TrustedNameDataSource,\n} from \"@/trusted-name/data/TrustedNameDataSource\";\nimport PACKAGE from \"@root/package.json\";\n\nimport { TrustedNameDto } from \"./TrustedNameDto\";\n\n@injectable()\nexport class HttpTrustedNameDataSource implements TrustedNameDataSource {\n constructor(\n @inject(configTypes.Config) private readonly config: ContextModuleConfig,\n ) {}\n\n public async getDomainNamePayload({\n chainId,\n domain,\n challenge,\n }: GetDomainNameInfosParams): Promise<Either<Error, string>> {\n try {\n const type = \"eoa\"; // Externally owned account\n const source = \"ens\"; // Ethereum name service\n const response = await axios.request<TrustedNameDto>({\n method: \"GET\",\n url: `${this.config.metadataService.url}/names/ethereum/${chainId}/forward/${domain}?types=${type}&sources=${source}&challenge=${challenge}`,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n\n return response.data.signedDescriptor?.data\n ? Right(response.data.signedDescriptor.data)\n : Left(\n new Error(\n \"[ContextModule] HttpTrustedNameDataSource: error getting domain payload\",\n ),\n );\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTrustedNameDataSource: Failed to fetch domain name\",\n ),\n );\n }\n }\n\n public async getTrustedNamePayload({\n chainId,\n address,\n challenge,\n sources,\n types,\n }: GetTrustedNameInfosParams): Promise<Either<Error, string>> {\n try {\n // TODO remove that filtering once https://ledgerhq.atlassian.net/browse/BACK-8075 is done\n // For now we have to filter or trusted names won't work with the generic parser, because transaction\n // fields descriptors can contain unsupported sources.\n sources = sources.filter(\n (source) => source === \"ens\" || source === \"crypto_asset_list\",\n );\n const response = await axios.request<TrustedNameDto>({\n method: \"GET\",\n url: `${this.config.metadataService.url}/names/ethereum/${chainId}/reverse/${address}?types=${types.join(\",\")}&sources=${sources.join(\",\")}&challenge=${challenge}`,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n const trustedName = response.data;\n if (!trustedName?.signedDescriptor?.data) {\n return Left(\n new Error(\n `[ContextModule] HttpTrustedNameDataSource: no trusted name metadata for address ${address}`,\n ),\n );\n }\n const payload = trustedName.signedDescriptor.data;\n\n if (\n !trustedName.signedDescriptor.signatures ||\n typeof trustedName.signedDescriptor.signatures[this.config.cal.mode] !==\n \"string\"\n ) {\n // If we have no separated signature but a valid descriptor, it may mean the descriptor was\n // signed on-the-fly for dynamic sources such as ens\n return Right(payload);\n }\n\n const signature =\n trustedName.signedDescriptor.signatures[this.config.cal.mode]!;\n return Right(this.formatTrustedName(payload, signature));\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTrustedNameDataSource: Failed to fetch trusted name\",\n ),\n );\n }\n }\n\n private formatTrustedName(payload: string, signature: string): string {\n // Ensure correct padding\n if (signature.length % 2 !== 0) {\n signature = \"0\" + signature;\n }\n // TLV encoding as according to trusted name documentation\n const signatureTag = \"15\";\n const signatureLength = (signature.length / 2).toString(16);\n return `${payload}${signatureTag}${signatureLength}${signature}`;\n }\n}\n"],
5
- "mappings": "qtBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,+BAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAkB,oBAClBC,EAAmC,qBACnCC,EAAoC,qBAEpCC,EAA4B,mCAE5BC,EAGO,yCAMPC,EAAoB,iCAKb,IAAMC,EAAN,KAAiE,CACtE,YAC+CC,EAC7C,CAD6C,YAAAA,CAC5C,CAEH,MAAa,qBAAqB,CAChC,QAAAC,EACA,OAAAC,EACA,UAAAC,CACF,EAA6D,CAC3D,GAAI,CAGF,MAAMC,EAAW,MAAM,EAAAC,QAAM,QAAwB,CACnD,OAAQ,MACR,IAAK,GAAG,KAAK,OAAO,gBAAgB,GAAG,mBAAmBJ,CAAO,YAAYC,CAAM,oCAA8CC,CAAS,GAC1I,QAAS,CACP,CAAC,8BAA4B,EAAG,kBAAkB,EAAAG,QAAQ,OAAO,GACjE,CAAC,4BAA0B,EAAG,KAAK,OAAO,WAC5C,CACF,CAAC,EAED,OAAOF,EAAS,KAAK,kBAAkB,QACnC,SAAMA,EAAS,KAAK,iBAAiB,IAAI,KACzC,QACE,IAAI,MACF,yEACF,CACF,CACN,MAAiB,CACf,SAAO,QACL,IAAI,MACF,wEACF,CACF,CACF,CACF,CAEA,MAAa,sBAAsB,CACjC,QAAAH,EACA,QAAAM,EACA,UAAAJ,EACA,QAAAK,EACA,MAAAC,CACF,EAA8D,CAC5D,GAAI,CAIFD,EAAUA,EAAQ,OACfE,GAAWA,IAAW,OAASA,IAAW,mBAC7C,EASA,MAAMC,GARW,MAAM,EAAAN,QAAM,QAAwB,CACnD,OAAQ,MACR,IAAK,GAAG,KAAK,OAAO,gBAAgB,GAAG,mBAAmBJ,CAAO,YAAYM,CAAO,UAAUE,EAAM,KAAK,GAAG,CAAC,YAAYD,EAAQ,KAAK,GAAG,CAAC,cAAcL,CAAS,GACjK,QAAS,CACP,CAAC,8BAA4B,EAAG,kBAAkB,EAAAG,QAAQ,OAAO,GACjE,CAAC,4BAA0B,EAAG,KAAK,OAAO,WAC5C,CACF,CAAC,GAC4B,KAC7B,GAAI,CAACK,GAAa,kBAAkB,KAClC,SAAO,QACL,IAAI,MACF,mFAAmFJ,CAAO,EAC5F,CACF,EAEF,MAAMK,EAAUD,EAAY,iBAAiB,KAE7C,GACE,CAACA,EAAY,iBAAiB,YAC9B,OAAOA,EAAY,iBAAiB,WAAW,KAAK,OAAO,IAAI,IAAI,GACjE,SAIF,SAAO,SAAMC,CAAO,EAGtB,MAAMC,EACJF,EAAY,iBAAiB,WAAW,KAAK,OAAO,IAAI,IAAI,EAC9D,SAAO,SAAM,KAAK,kBAAkBC,EAASC,CAAS,CAAC,CACzD,MAAiB,CACf,SAAO,QACL,IAAI,MACF,yEACF,CACF,CACF,CACF,CAEQ,kBAAkBD,EAAiBC,EAA2B,CAEhEA,EAAU,OAAS,IAAM,IAC3BA,EAAY,IAAMA,GAGpB,MAAMC,EAAe,KACfC,GAAmBF,EAAU,OAAS,GAAG,SAAS,EAAE,EAC1D,MAAO,GAAGD,CAAO,GAAGE,CAAY,GAAGC,CAAe,GAAGF,CAAS,EAChE,CACF,EAtGad,EAANiB,EAAA,IADN,cAAW,EAGPC,EAAA,eAAO,cAAY,MAAM,IAFjBlB",
6
- "names": ["HttpTrustedNameDataSource_exports", "__export", "HttpTrustedNameDataSource", "__toCommonJS", "import_axios", "import_inversify", "import_purify_ts", "import_configTypes", "import_HttpHeaders", "import_package", "HttpTrustedNameDataSource", "config", "chainId", "domain", "challenge", "response", "axios", "PACKAGE", "address", "sources", "types", "source", "trustedName", "payload", "signature", "signatureTag", "signatureLength", "__decorateClass", "__decorateParam"]
4
+ "sourcesContent": ["import axios from \"axios\";\nimport { inject, injectable } from \"inversify\";\nimport { Either, Left, Right } from \"purify-ts\";\n\nimport { configTypes } from \"@/config/di/configTypes\";\nimport type { ContextModuleConfig } from \"@/config/model/ContextModuleConfig\";\nimport {\n LEDGER_CLIENT_VERSION_HEADER,\n LEDGER_ORIGIN_TOKEN_HEADER,\n} from \"@/shared/constant/HttpHeaders\";\nimport {\n GetDomainNameInfosParams,\n GetTrustedNameInfosParams,\n TrustedNameDataSource,\n TrustedNamePayload,\n} from \"@/trusted-name/data/TrustedNameDataSource\";\nimport PACKAGE from \"@root/package.json\";\n\nimport { TrustedNameDto } from \"./TrustedNameDto\";\n\n@injectable()\nexport class HttpTrustedNameDataSource implements TrustedNameDataSource {\n constructor(\n @inject(configTypes.Config) private readonly config: ContextModuleConfig,\n ) {}\n\n public async getDomainNamePayload({\n chainId,\n domain,\n challenge,\n }: GetDomainNameInfosParams): Promise<Either<Error, TrustedNamePayload>> {\n let dto: TrustedNameDto | undefined;\n try {\n const type = \"eoa\"; // Externally owned account\n const source = \"ens\"; // Ethereum name service\n const response = await axios.request<TrustedNameDto>({\n method: \"GET\",\n url: `${this.config.metadataServiceDomain.url}/v2/names/ethereum/${chainId}/forward/${domain}?types=${type}&sources=${source}&challenge=${challenge}`,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n dto = response.data;\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTrustedNameDataSource: Failed to fetch domain name\",\n ),\n );\n }\n\n if (!dto) {\n return Left(\n new Error(\n `[ContextModule] HttpTrustedNameDataSource: No data received for domain ${domain} on chain ${chainId}`,\n ),\n );\n }\n\n if (!this.isTrustedNameDto(dto)) {\n return Left(\n new Error(\n `[ContextModule] HttpTrustedNameDataSource: Invalid trusted name response format for domain ${domain} on chain ${chainId}`,\n ),\n );\n }\n\n return Right({\n data: dto.signedDescriptor.data,\n keyId: dto.keyId,\n keyUsage: dto.keyUsage,\n });\n }\n\n public async getTrustedNamePayload({\n chainId,\n address,\n challenge,\n sources,\n types,\n }: GetTrustedNameInfosParams): Promise<Either<Error, TrustedNamePayload>> {\n let dto: TrustedNameDto | undefined;\n try {\n // TODO remove that filtering once https://ledgerhq.atlassian.net/browse/BACK-8075 is done\n // For now we have to filter or trusted names won't work with the generic parser, because transaction\n // fields descriptors can contain unsupported sources.\n sources = sources.filter(\n (source) => source === \"ens\" || source === \"crypto_asset_list\",\n );\n const response = await axios.request<TrustedNameDto>({\n method: \"GET\",\n url: `${this.config.metadataServiceDomain.url}/v2/names/ethereum/${chainId}/reverse/${address}?types=${types.join(\",\")}&sources=${sources.join(\",\")}&challenge=${challenge}`,\n headers: {\n [LEDGER_CLIENT_VERSION_HEADER]: `context-module/${PACKAGE.version}`,\n [LEDGER_ORIGIN_TOKEN_HEADER]: this.config.originToken,\n },\n });\n dto = response.data;\n } catch (_error) {\n return Left(\n new Error(\n \"[ContextModule] HttpTrustedNameDataSource: Failed to fetch trusted name\",\n ),\n );\n }\n\n if (!dto) {\n return Left(\n new Error(\n `[ContextModule] HttpTrustedNameDataSource: No data received for address ${address} on chain ${chainId}`,\n ),\n );\n }\n\n if (!this.isTrustedNameDto(dto)) {\n return Left(\n new Error(\n `[ContextModule] HttpTrustedNameDataSource: Invalid trusted name response format for address ${address} on chain ${chainId}`,\n ),\n );\n }\n\n if (\n typeof dto.signedDescriptor.signatures[this.config.cal.mode] !== \"string\"\n ) {\n // If we have no separated signature but a valid descriptor, it may mean the descriptor was\n // signed on-the-fly for dynamic sources such as ens\n return Right({\n data: dto.signedDescriptor.data,\n keyId: dto.keyId,\n keyUsage: dto.keyUsage,\n });\n }\n\n const signature = dto.signedDescriptor.signatures[this.config.cal.mode]!;\n return Right({\n data: this.formatTrustedName(dto.signedDescriptor.data, signature),\n keyId: dto.keyId,\n keyUsage: dto.keyUsage,\n });\n }\n\n private formatTrustedName(payload: string, signature: string): string {\n // Ensure correct padding\n if (signature.length % 2 !== 0) {\n signature = \"0\" + signature;\n }\n // TLV encoding as according to trusted name documentation\n const signatureTag = \"15\";\n const signatureLength = (signature.length / 2).toString(16);\n return `${payload}${signatureTag}${signatureLength}${signature}`;\n }\n /**\n * Type guard to validate ProxyDelegateCallDto\n */\n private isTrustedNameDto(value: unknown): value is TrustedNameDto {\n return (\n typeof value === \"object\" &&\n value !== null &&\n \"signedDescriptor\" in value &&\n \"keyId\" in value &&\n \"keyUsage\" in value &&\n typeof value.keyId === \"string\" &&\n typeof value.keyUsage === \"string\" &&\n typeof value.signedDescriptor === \"object\" &&\n value.signedDescriptor !== null &&\n \"data\" in value.signedDescriptor &&\n \"signatures\" in value.signedDescriptor &&\n typeof value.signedDescriptor.data === \"string\" &&\n typeof value.signedDescriptor.signatures === \"object\"\n );\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["HttpTrustedNameDataSource_exports", "__export", "HttpTrustedNameDataSource", "__toCommonJS", "import_axios", "import_inversify", "import_purify_ts", "import_configTypes", "import_HttpHeaders", "import_package", "HttpTrustedNameDataSource", "config", "chainId", "domain", "challenge", "dto", "axios", "PACKAGE", "address", "sources", "types", "source", "signature", "payload", "signatureTag", "signatureLength", "value", "__decorateClass", "__decorateParam"]
7
7
  }