@ledgerhq/device-signer-kit-ethereum 1.7.0 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/README.md +59 -1
  2. package/lib/cjs/api/SignerEth.js +1 -1
  3. package/lib/cjs/api/SignerEth.js.map +1 -1
  4. package/lib/cjs/api/SignerEthBuilder.test.js +1 -1
  5. package/lib/cjs/api/SignerEthBuilder.test.js.map +2 -2
  6. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  7. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
  8. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
  9. package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
  10. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  11. package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  12. package/lib/cjs/api/model/SafeAddressOptions.js +2 -0
  13. package/lib/cjs/api/model/SafeAddressOptions.js.map +7 -0
  14. package/lib/cjs/internal/DefaultSignerEth.js +1 -1
  15. package/lib/cjs/internal/DefaultSignerEth.js.map +3 -3
  16. package/lib/cjs/internal/app-binder/EthAppBinder.js +1 -1
  17. package/lib/cjs/internal/app-binder/EthAppBinder.js.map +3 -3
  18. package/lib/cjs/internal/app-binder/EthAppBinder.test.js +1 -1
  19. package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +2 -2
  20. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  21. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  22. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  23. package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  24. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  25. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  26. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  27. package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  28. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  29. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  30. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  31. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  32. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  33. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +2 -2
  34. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  35. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  36. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  37. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  38. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  39. package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  40. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  41. package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  42. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js +2 -0
  43. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  44. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  45. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  46. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  47. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  48. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  49. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  50. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  51. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  52. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  53. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  54. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  55. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  56. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  57. package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  58. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  59. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  60. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  61. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  62. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  63. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  64. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  65. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  66. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js +2 -0
  67. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  68. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  69. package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  70. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js +2 -0
  71. package/lib/cjs/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  72. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  73. package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  74. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  75. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  76. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  77. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  78. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  79. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  80. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  81. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  82. package/lib/cjs/internal/di.js +1 -1
  83. package/lib/cjs/internal/di.js.map +3 -3
  84. package/lib/cjs/internal/safe/di/safeModule.js +2 -0
  85. package/lib/cjs/internal/safe/di/safeModule.js.map +7 -0
  86. package/lib/cjs/internal/safe/di/safeModule.test.js +2 -0
  87. package/lib/cjs/internal/safe/di/safeModule.test.js.map +7 -0
  88. package/lib/cjs/internal/safe/di/safeTypes.js +2 -0
  89. package/lib/cjs/internal/safe/di/safeTypes.js.map +7 -0
  90. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  91. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  92. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  93. package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  94. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +1 -1
  95. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +2 -2
  96. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  97. package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +2 -2
  98. package/lib/cjs/package.json +2 -2
  99. package/lib/esm/api/SignerEthBuilder.test.js +1 -1
  100. package/lib/esm/api/SignerEthBuilder.test.js.map +2 -2
  101. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  102. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
  103. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
  104. package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
  105. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
  106. package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
  107. package/lib/esm/api/model/SafeAddressOptions.js +1 -0
  108. package/lib/esm/api/model/SafeAddressOptions.js.map +7 -0
  109. package/lib/esm/internal/DefaultSignerEth.js +1 -1
  110. package/lib/esm/internal/DefaultSignerEth.js.map +3 -3
  111. package/lib/esm/internal/app-binder/EthAppBinder.js +1 -1
  112. package/lib/esm/internal/app-binder/EthAppBinder.js.map +3 -3
  113. package/lib/esm/internal/app-binder/EthAppBinder.test.js +1 -1
  114. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +2 -2
  115. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
  116. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
  117. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
  118. package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
  119. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
  120. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
  121. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
  122. package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
  123. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  124. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
  125. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  126. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
  127. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
  128. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +2 -2
  129. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  130. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
  131. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
  132. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
  133. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
  134. package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
  135. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
  136. package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
  137. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js +2 -0
  138. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
  139. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
  140. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
  141. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
  142. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
  143. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  144. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
  145. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js +2 -0
  146. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
  147. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
  148. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
  149. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
  150. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
  151. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
  152. package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
  153. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
  154. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
  155. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
  156. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
  157. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
  158. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
  159. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
  160. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
  161. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js +2 -0
  162. package/lib/esm/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
  163. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
  164. package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
  165. package/lib/esm/internal/app-binder/task/ProvideContextTask.js +2 -0
  166. package/lib/esm/internal/app-binder/task/ProvideContextTask.js.map +7 -0
  167. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js +2 -0
  168. package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
  169. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  170. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  171. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  172. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  173. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
  174. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
  175. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
  176. package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
  177. package/lib/esm/internal/di.js +1 -1
  178. package/lib/esm/internal/di.js.map +3 -3
  179. package/lib/esm/internal/safe/di/safeModule.js +2 -0
  180. package/lib/esm/internal/safe/di/safeModule.js.map +7 -0
  181. package/lib/esm/internal/safe/di/safeModule.test.js +2 -0
  182. package/lib/esm/internal/safe/di/safeModule.test.js.map +7 -0
  183. package/lib/esm/internal/safe/di/safeTypes.js +2 -0
  184. package/lib/esm/internal/safe/di/safeTypes.js.map +7 -0
  185. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
  186. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
  187. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
  188. package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
  189. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +1 -1
  190. package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +2 -2
  191. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
  192. package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +2 -2
  193. package/lib/esm/package.json +2 -2
  194. package/lib/types/api/SignerEth.d.ts +3 -0
  195. package/lib/types/api/SignerEth.d.ts.map +1 -1
  196. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +9 -8
  197. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
  198. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +4 -0
  199. package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -1
  200. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts +30 -0
  201. package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts.map +1 -0
  202. package/lib/types/api/model/SafeAddressOptions.d.ts +5 -0
  203. package/lib/types/api/model/SafeAddressOptions.d.ts.map +1 -0
  204. package/lib/types/internal/DefaultSignerEth.d.ts +3 -0
  205. package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -1
  206. package/lib/types/internal/app-binder/EthAppBinder.d.ts +6 -0
  207. package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -1
  208. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts +34 -0
  209. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts.map +1 -0
  210. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts +2 -0
  211. package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts.map +1 -0
  212. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +29 -1
  213. package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -1
  214. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +14 -18
  215. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -1
  216. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +4 -0
  217. package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -1
  218. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts +20 -0
  219. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts.map +1 -0
  220. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts +2 -0
  221. package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts.map +1 -0
  222. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts +6 -0
  223. package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts.map +1 -0
  224. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts +51 -0
  225. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts.map +1 -0
  226. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts +2 -0
  227. package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts.map +1 -0
  228. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts +8 -1
  229. package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
  230. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts +39 -0
  231. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts.map +1 -0
  232. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts +2 -0
  233. package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts.map +1 -0
  234. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts +19 -0
  235. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts.map +1 -0
  236. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts +2 -0
  237. package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts.map +1 -0
  238. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts +28 -0
  239. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts.map +1 -0
  240. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts +2 -0
  241. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts.map +1 -0
  242. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts +21 -0
  243. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts.map +1 -0
  244. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts +2 -0
  245. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts.map +1 -0
  246. package/lib/types/internal/app-binder/task/{PreBuildContextTask.d.ts → ParseTransactionTask.d.ts} +6 -6
  247. package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts.map +1 -0
  248. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts +2 -0
  249. package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts.map +1 -0
  250. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts +22 -0
  251. package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts.map +1 -0
  252. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts +2 -0
  253. package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts.map +1 -0
  254. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +14 -3
  255. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -1
  256. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts +36 -0
  257. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts.map +1 -0
  258. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts +2 -0
  259. package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts.map +1 -0
  260. package/lib/types/internal/di.d.ts.map +1 -1
  261. package/lib/types/internal/safe/di/safeModule.d.ts +3 -0
  262. package/lib/types/internal/safe/di/safeModule.d.ts.map +1 -0
  263. package/lib/types/internal/safe/di/safeModule.test.d.ts +2 -0
  264. package/lib/types/internal/safe/di/safeModule.test.d.ts.map +1 -0
  265. package/lib/types/internal/safe/di/safeTypes.d.ts +4 -0
  266. package/lib/types/internal/safe/di/safeTypes.d.ts.map +1 -0
  267. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts +9 -0
  268. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts.map +1 -0
  269. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts +2 -0
  270. package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts.map +1 -0
  271. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  272. package/package.json +9 -9
  273. package/lib/cjs/internal/app-binder/task/BuildSubContextTask.js +0 -2
  274. package/lib/cjs/internal/app-binder/task/BuildSubContextTask.js.map +0 -7
  275. package/lib/cjs/internal/app-binder/task/BuildSubContextTask.test.js +0 -2
  276. package/lib/cjs/internal/app-binder/task/BuildSubContextTask.test.js.map +0 -7
  277. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  278. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  279. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  280. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  281. package/lib/cjs/internal/app-binder/task/PreBuildContextTask.js +0 -2
  282. package/lib/cjs/internal/app-binder/task/PreBuildContextTask.js.map +0 -7
  283. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  284. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  285. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  286. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  287. package/lib/esm/internal/app-binder/task/BuildSubContextTask.js +0 -2
  288. package/lib/esm/internal/app-binder/task/BuildSubContextTask.js.map +0 -7
  289. package/lib/esm/internal/app-binder/task/BuildSubContextTask.test.js +0 -2
  290. package/lib/esm/internal/app-binder/task/BuildSubContextTask.test.js.map +0 -7
  291. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
  292. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
  293. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
  294. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
  295. package/lib/esm/internal/app-binder/task/PreBuildContextTask.js +0 -2
  296. package/lib/esm/internal/app-binder/task/PreBuildContextTask.js.map +0 -7
  297. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
  298. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
  299. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
  300. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
  301. package/lib/types/internal/app-binder/task/BuildSubContextTask.d.ts +0 -20
  302. package/lib/types/internal/app-binder/task/BuildSubContextTask.d.ts.map +0 -1
  303. package/lib/types/internal/app-binder/task/BuildSubContextTask.test.d.ts +0 -2
  304. package/lib/types/internal/app-binder/task/BuildSubContextTask.test.d.ts.map +0 -1
  305. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -28
  306. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
  307. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +0 -2
  308. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +0 -1
  309. package/lib/types/internal/app-binder/task/PreBuildContextTask.d.ts.map +0 -1
  310. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -44
  311. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
  312. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +0 -2
  313. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +0 -1
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildFullContextsTask.test.ts"],
4
+ "sourcesContent": ["import {\n ClearSignContextReferenceType,\n ClearSignContextType,\n type ContextModule,\n type TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { type GetConfigCommandResponse } from \"@api/app-binder/GetConfigCommandTypes\";\nimport { type TransactionOptions } from \"@api/index\";\nimport { ClearSigningType } from \"@api/model/ClearSigningType\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport {\n BuildBaseContexts,\n type BuildBaseContextsArgs,\n} from \"./BuildBaseContexts\";\nimport { BuildFullContextsTask } from \"./BuildFullContextsTask\";\nimport {\n BuildSubcontextsTask,\n type BuildSubcontextsTaskArgs,\n} from \"./BuildSubcontextsTask\";\nimport {\n ParseNestedTransactionTask,\n type ParseNestedTransactionTaskArgs,\n} from \"./ParseNestedTransactionTask\";\n\ndescribe(\"BuildFullContextsTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n const contextModuleMock = {} as ContextModule;\n const mapperMock = {} as TransactionMapperService;\n const parserMock = {} as TransactionParserService;\n\n const defaultAppConfig: GetConfigCommandResponse = {\n blindSigningEnabled: false,\n web3ChecksEnabled: false,\n web3ChecksOptIn: false,\n version: \"1.0.0\",\n };\n const defaultOptions: TransactionOptions = {};\n const defaultSubset: TransactionSubset = {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n };\n const defaultDerivationPath = \"44'/60'/0'/0/0\";\n\n const buildSubContextTaskRunMock = vi.fn();\n const buildSubcontextsTaskFactory = (\n _api: InternalApi,\n _args: BuildSubcontextsTaskArgs,\n ) =>\n ({\n run: buildSubContextTaskRunMock,\n }) as unknown as BuildSubcontextsTask;\n\n const buildBaseContextsTaskRunMock = vi.fn();\n const buildBaseContextsTaskFactory = (\n _api: InternalApi,\n _args: BuildBaseContextsArgs,\n ) =>\n ({\n run: buildBaseContextsTaskRunMock,\n }) as unknown as BuildBaseContexts;\n\n const parseNestedTransactionTaskRunMock = vi.fn();\n const parseNestedTransactionTaskFactory = (\n _args: ParseNestedTransactionTaskArgs,\n ) =>\n ({\n run: parseNestedTransactionTaskRunMock,\n }) as unknown as ParseNestedTransactionTask;\n\n describe(\"Init\", () => {\n it(\"should init with defaults tasks\", () => {\n const task = new BuildFullContextsTask(apiMock, {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n options: defaultOptions,\n appConfig: defaultAppConfig,\n derivationPath: defaultDerivationPath,\n subset: defaultSubset,\n deviceModelId: DeviceModelId.STAX,\n });\n\n expect(task).toBeDefined();\n expect(\n task[\"_buildSubcontextsTaskFactory\"](\n apiMock,\n {} as BuildSubcontextsTaskArgs,\n ),\n ).toBeInstanceOf(BuildSubcontextsTask);\n expect(\n task[\"_buildBaseContextsTaskFactory\"](\n apiMock,\n {} as BuildBaseContextsArgs,\n ),\n ).toBeInstanceOf(BuildBaseContexts);\n expect(\n task[\"_preBuildNestedCallDataTaskFactory\"](\n {} as ParseNestedTransactionTaskArgs,\n ),\n ).toBeInstanceOf(ParseNestedTransactionTask);\n });\n });\n\n describe(\"Happy path\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n it(\"should build with no context\", async () => {\n // GIVEN\n buildBaseContextsTaskRunMock.mockReturnValue({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n\n const task = new BuildFullContextsTask(\n apiMock,\n {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n options: defaultOptions,\n appConfig: defaultAppConfig,\n derivationPath: defaultDerivationPath,\n subset: defaultSubset,\n deviceModelId: DeviceModelId.STAX,\n },\n buildSubcontextsTaskFactory,\n buildBaseContextsTaskFactory,\n parseNestedTransactionTaskFactory,\n );\n\n // WHEN\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n });\n\n it(\"should build with multiple contexts and no subcontexts\", async () => {\n // GIVEN\n buildBaseContextsTaskRunMock.mockReturnValueOnce({\n clearSignContexts: [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n ],\n clearSigningType: ClearSigningType.EIP7730,\n });\n buildSubContextTaskRunMock.mockReturnValue({\n subcontextCallbacks: [],\n });\n\n const task = new BuildFullContextsTask(\n apiMock,\n {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n options: defaultOptions,\n appConfig: defaultAppConfig,\n derivationPath: defaultDerivationPath,\n subset: defaultSubset,\n deviceModelId: DeviceModelId.STAX,\n },\n buildSubcontextsTaskFactory,\n buildBaseContextsTaskFactory,\n parseNestedTransactionTaskFactory,\n );\n\n // WHEN\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [\n {\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n subcontextCallbacks: [],\n },\n {\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n subcontextCallbacks: [],\n },\n {\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n subcontextCallbacks: [],\n },\n ],\n clearSigningType: ClearSigningType.EIP7730,\n });\n });\n\n it(\"should build with multiple contexts and subcontexts\", async () => {\n // GIVEN\n buildBaseContextsTaskRunMock.mockReturnValueOnce({\n clearSignContexts: [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n ],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n buildSubContextTaskRunMock.mockReturnValueOnce({\n subcontextCallbacks: [],\n });\n buildSubContextTaskRunMock.mockReturnValueOnce({\n subcontextCallbacks: [\n () =>\n Promise.resolve({\n type: ClearSignContextType.TOKEN,\n payload: \"payload-3\",\n }),\n () =>\n Promise.resolve({\n type: ClearSignContextType.TOKEN,\n payload: \"payload-4\",\n }),\n ],\n });\n\n const task = new BuildFullContextsTask(\n apiMock,\n {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n options: defaultOptions,\n appConfig: defaultAppConfig,\n derivationPath: defaultDerivationPath,\n subset: defaultSubset,\n deviceModelId: DeviceModelId.STAX,\n },\n buildSubcontextsTaskFactory,\n buildBaseContextsTaskFactory,\n parseNestedTransactionTaskFactory,\n );\n\n // WHEN\n const result = await task.run();\n\n // THEN\n expect(result.clearSignContexts[0]).toEqual({\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n subcontextCallbacks: [],\n });\n expect(result.clearSignContexts[1]).toEqual({\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n subcontextCallbacks: [expect.any(Function), expect.any(Function)],\n });\n await expect(\n result.clearSignContexts[1]!.subcontextCallbacks[0]!(),\n ).resolves.toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"payload-3\",\n });\n await expect(\n result.clearSignContexts[1]!.subcontextCallbacks[1]!(),\n ).resolves.toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"payload-4\",\n });\n });\n\n it(\"should build with nested contexts\", async () => {\n // GIVEN\n buildBaseContextsTaskRunMock.mockReturnValueOnce({\n clearSignContexts: [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n subset: {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n },\n },\n },\n ],\n clearSigningType: ClearSigningType.EIP7730,\n });\n // nested context\n buildBaseContextsTaskRunMock.mockReturnValueOnce({\n clearSignContexts: [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-4\",\n },\n ],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n buildSubContextTaskRunMock.mockReturnValue({\n subcontextCallbacks: [],\n });\n parseNestedTransactionTaskRunMock.mockReturnValue({\n subsets: [\n {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n },\n ],\n });\n\n const task = new BuildFullContextsTask(\n apiMock,\n {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n options: defaultOptions,\n appConfig: defaultAppConfig,\n derivationPath: defaultDerivationPath,\n subset: defaultSubset,\n deviceModelId: DeviceModelId.STAX,\n },\n buildSubcontextsTaskFactory,\n buildBaseContextsTaskFactory,\n parseNestedTransactionTaskFactory,\n );\n\n // WHEN\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n clearSignContexts: expect.any(Array),\n clearSigningType: ClearSigningType.EIP7730,\n });\n expect(result.clearSignContexts[0]).toEqual({\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n subcontextCallbacks: [],\n });\n expect(result.clearSignContexts[1]).toEqual({\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n subset: {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n },\n },\n },\n subcontextCallbacks: [],\n });\n expect(result.clearSignContexts[2]).toEqual({\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-3\",\n },\n subcontextCallbacks: [],\n });\n expect(result.clearSignContexts[3]).toEqual({\n context: {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-4\",\n },\n subcontextCallbacks: [],\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_device_management_kit", "import_ClearSigningType", "import_makeInternalApi", "import_BuildBaseContexts", "import_BuildFullContextsTask", "import_BuildSubcontextsTask", "import_ParseNestedTransactionTask", "apiMock", "contextModuleMock", "mapperMock", "parserMock", "defaultAppConfig", "defaultOptions", "defaultSubset", "defaultDerivationPath", "buildSubContextTaskRunMock", "buildSubcontextsTaskFactory", "_api", "_args", "buildBaseContextsTaskRunMock", "buildBaseContextsTaskFactory", "parseNestedTransactionTaskRunMock", "parseNestedTransactionTaskFactory", "task", "result"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var a=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var c=Object.getOwnPropertyNames;var p=Object.prototype.hasOwnProperty;var C=(s,e)=>{for(var o in e)a(s,o,{get:e[o],enumerable:!0})},f=(s,e,o,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of c(e))!p.call(s,t)&&t!==o&&a(s,t,{get:()=>e[t],enumerable:!(n=l(e,t))||n.enumerable});return s};var g=s=>f(a({},"__esModule",{value:!0}),s);var S={};C(S,{BuildSafeAddressContextTask:()=>u});module.exports=g(S);var r=require("@ledgerhq/context-module"),d=require("@ledgerhq/device-management-kit"),i=require("../../app-binder/command/GetChallengeCommand");class u{constructor(e,o){this._api=e;this._args=o}async run(){const e=await this._api.sendCommand(new i.GetChallengeCommand);if(!(0,d.isSuccessCommandResult)(e))throw new Error("Failed to get challenge");const o=e.data.challenge,n=await this._args.contextModule.getContexts({safeContractAddress:this._args.safeContractAddress,chainId:this._args.options.chainId,deviceModelId:this._args.deviceModelId,challenge:o},[r.ClearSignContextType.SAFE,r.ClearSignContextType.SIGNER]);if(n.forEach(t=>{if(t.type===r.ClearSignContextType.ERROR)throw new Error(t.error.message)}),n.length!==2||n.find(t=>t.type===r.ClearSignContextType.SAFE)===void 0||n.find(t=>t.type===r.ClearSignContextType.SIGNER)===void 0)throw new Error("Invalid safe address contexts");return{clearSignContexts:n}}}0&&(module.exports={BuildSafeAddressContextTask});
2
+ //# sourceMappingURL=BuildSafeAddressContextTask.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildSafeAddressContextTask.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextSuccess,\n ClearSignContextType,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n type DeviceModelId,\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { type SafeAddressOptions } from \"@api/model/SafeAddressOptions\";\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\n\nexport type BuildSafeAddressContextTaskArgs = {\n readonly contextModule: ContextModule;\n readonly safeContractAddress: string;\n readonly options: SafeAddressOptions;\n readonly deviceModelId: DeviceModelId;\n};\n\nexport type BuildSafeAddressContextTaskResult = {\n readonly clearSignContexts: ClearSignContextSuccess[];\n};\n\nexport class BuildSafeAddressContextTask {\n constructor(\n private readonly _api: InternalApi,\n private readonly _args: BuildSafeAddressContextTaskArgs,\n ) {}\n\n async run(): Promise<BuildSafeAddressContextTaskResult> {\n const challengeResponse = await this._api.sendCommand(\n new GetChallengeCommand(),\n );\n\n if (!isSuccessCommandResult(challengeResponse)) {\n throw new Error(\"Failed to get challenge\");\n }\n\n const challenge = challengeResponse.data.challenge;\n\n const contexts = await this._args.contextModule.getContexts(\n {\n safeContractAddress: this._args.safeContractAddress,\n chainId: this._args.options.chainId,\n deviceModelId: this._args.deviceModelId,\n challenge,\n },\n [ClearSignContextType.SAFE, ClearSignContextType.SIGNER],\n );\n\n contexts.forEach((context) => {\n if (context.type === ClearSignContextType.ERROR) {\n throw new Error(context.error.message);\n }\n });\n\n // should contain one SAFE and one SIGNER context\n if (\n contexts.length !== 2 ||\n contexts.find((context) => context.type === ClearSignContextType.SAFE) ===\n undefined ||\n contexts.find(\n (context) => context.type === ClearSignContextType.SIGNER,\n ) === undefined\n ) {\n throw new Error(\"Invalid safe address contexts\");\n }\n\n return {\n clearSignContexts: contexts as ClearSignContextSuccess[],\n };\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,iCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAIO,oCACPC,EAIO,2CAGPC,EAAoC,4DAa7B,MAAMJ,CAA4B,CACvC,YACmBK,EACAC,EACjB,CAFiB,UAAAD,EACA,WAAAC,CAChB,CAEH,MAAM,KAAkD,CACtD,MAAMC,EAAoB,MAAM,KAAK,KAAK,YACxC,IAAI,qBACN,EAEA,GAAI,IAAC,0BAAuBA,CAAiB,EAC3C,MAAM,IAAI,MAAM,yBAAyB,EAG3C,MAAMC,EAAYD,EAAkB,KAAK,UAEnCE,EAAW,MAAM,KAAK,MAAM,cAAc,YAC9C,CACE,oBAAqB,KAAK,MAAM,oBAChC,QAAS,KAAK,MAAM,QAAQ,QAC5B,cAAe,KAAK,MAAM,cAC1B,UAAAD,CACF,EACA,CAAC,uBAAqB,KAAM,uBAAqB,MAAM,CACzD,EASA,GAPAC,EAAS,QAASC,GAAY,CAC5B,GAAIA,EAAQ,OAAS,uBAAqB,MACxC,MAAM,IAAI,MAAMA,EAAQ,MAAM,OAAO,CAEzC,CAAC,EAICD,EAAS,SAAW,GACpBA,EAAS,KAAMC,GAAYA,EAAQ,OAAS,uBAAqB,IAAI,IACnE,QACFD,EAAS,KACNC,GAAYA,EAAQ,OAAS,uBAAqB,MACrD,IAAM,OAEN,MAAM,IAAI,MAAM,+BAA+B,EAGjD,MAAO,CACL,kBAAmBD,CACrB,CACF,CACF",
6
+ "names": ["BuildSafeAddressContextTask_exports", "__export", "BuildSafeAddressContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_GetChallengeCommand", "_api", "_args", "challengeResponse", "challenge", "contexts", "context"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var a=require("@ledgerhq/context-module"),n=require("@ledgerhq/device-management-kit"),S=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),l=require("./BuildSafeAddressContextTask");describe("BuildSafeAddressContextTask",()=>{const o=(0,S.makeDeviceActionInternalApiMock)(),e={getContexts:vi.fn(),getFieldContext:vi.fn(),getTypedDataFilters:vi.fn(),getWeb3Checks:vi.fn(),getSolanaContext:vi.fn()},p="0x12345678",d="0x1234567890123456789012345678901234567890",r=1,i=(0,n.CommandResultFactory)({data:{challenge:p}}),h=(0,n.CommandResultFactory)({data:void 0,error:{}}),C={type:a.ClearSignContextType.SAFE,payload:"safe_payload"},x={type:a.ClearSignContextType.SIGNER,payload:"signer_payload"};beforeEach(()=>{vi.resetAllMocks()}),describe("run",()=>{it("should successfully build safe address contexts with valid SAFE and SIGNER contexts",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([C,x]);const c=await new l.BuildSafeAddressContextTask(o,t).run();expect(c).toEqual({clearSignContexts:[C,x]}),expect(o.sendCommand).toHaveBeenCalledTimes(1),expect(e.getContexts).toHaveBeenCalledWith({safeContractAddress:d,chainId:r,deviceModelId:n.DeviceModelId.FLEX,challenge:p},[a.ClearSignContextType.SAFE,a.ClearSignContextType.SIGNER])}),it("should include certificates when provided in contexts",async()=>{const t={type:a.ClearSignContextType.SAFE,payload:"safe_payload",certificate:{keyUsageNumber:1,payload:new Uint8Array([1,2,3])}},s={type:a.ClearSignContextType.SIGNER,payload:"signer_payload",certificate:{keyUsageNumber:2,payload:new Uint8Array([4,5,6])}},c={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([t,s]);const g=await new l.BuildSafeAddressContextTask(o,c).run();expect(g).toEqual({clearSignContexts:[t,s]})})}),describe("error handling",()=>{it("should throw error when GetChallengeCommand fails",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(h);const s=new l.BuildSafeAddressContextTask(o,t);await expect(s.run()).rejects.toThrow("Failed to get challenge")}),it("should throw error when context contains ERROR type",async()=>{const t={type:a.ClearSignContextType.ERROR,error:new Error("Context error")},s={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([t,x]);const c=new l.BuildSafeAddressContextTask(o,s);await expect(c.run()).rejects.toThrow("Context error")}),it("should throw error when only one context is returned",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([C]);const s=new l.BuildSafeAddressContextTask(o,t);await expect(s.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error when no contexts are returned",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([]);const s=new l.BuildSafeAddressContextTask(o,t);await expect(s.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error when more than two contexts are returned",async()=>{const t={type:a.ClearSignContextType.TOKEN,payload:"extra_payload"},s={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([C,x,t]);const c=new l.BuildSafeAddressContextTask(o,s);await expect(c.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error when SAFE context is missing",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([x,x]);const s=new l.BuildSafeAddressContextTask(o,t);await expect(s.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error when SIGNER context is missing",async()=>{const t={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([C,C]);const s=new l.BuildSafeAddressContextTask(o,t);await expect(s.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error when contexts are of wrong types",async()=>{const t={type:a.ClearSignContextType.TOKEN,payload:"token_payload"},s={type:a.ClearSignContextType.NFT,payload:"nft_payload"},c={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([t,s]);const u=new l.BuildSafeAddressContextTask(o,c);await expect(u.run()).rejects.toThrow("Invalid safe address contexts")}),it("should throw error with multiple ERROR contexts",async()=>{const t={type:a.ClearSignContextType.ERROR,error:new Error("First error")},s={type:a.ClearSignContextType.ERROR,error:new Error("Second error")},c={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([t,s]);const u=new l.BuildSafeAddressContextTask(o,c);await expect(u.run()).rejects.toThrow("First error")})}),describe("device model variants",()=>{it.each([[n.DeviceModelId.NANO_S,"Nano S"],[n.DeviceModelId.NANO_SP,"Nano S Plus"],[n.DeviceModelId.NANO_X,"Nano X"],[n.DeviceModelId.FLEX,"Flex"],[n.DeviceModelId.STAX,"Stax"]])("should successfully build contexts for %s device",async(t,s)=>{const c={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:t};o.sendCommand.mockResolvedValue(i),e.getContexts=vi.fn().mockResolvedValue([C,x]);const g=await new l.BuildSafeAddressContextTask(o,c).run();expect(g).toEqual({clearSignContexts:[C,x]}),expect(e.getContexts).toHaveBeenCalledWith(expect.objectContaining({deviceModelId:t}),[a.ClearSignContextType.SAFE,a.ClearSignContextType.SIGNER])})}),describe("challenge handling",()=>{it("should pass the correct challenge to contextModule",async()=>{const t="0xabcdef12",s={contextModule:e,safeContractAddress:d,options:{chainId:r},deviceModelId:n.DeviceModelId.FLEX};o.sendCommand.mockResolvedValue((0,n.CommandResultFactory)({data:{challenge:t}})),e.getContexts=vi.fn().mockResolvedValue([C,x]),await new l.BuildSafeAddressContextTask(o,s).run(),expect(e.getContexts).toHaveBeenCalledWith(expect.objectContaining({challenge:t}),[a.ClearSignContextType.SAFE,a.ClearSignContextType.SIGNER])})})});
2
+ //# sourceMappingURL=BuildSafeAddressContextTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildSafeAddressContextTask.test.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContext,\n type ClearSignContextSuccess,\n ClearSignContextType,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceModelId,\n type UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\n\nimport {\n BuildSafeAddressContextTask,\n type BuildSafeAddressContextTaskArgs,\n} from \"./BuildSafeAddressContextTask\";\n\ndescribe(\"BuildSafeAddressContextTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n const contextModuleMock: ContextModule = {\n getContexts: vi.fn(),\n getFieldContext: vi.fn(),\n getTypedDataFilters: vi.fn(),\n getWeb3Checks: vi.fn(),\n getSolanaContext: vi.fn(),\n };\n\n const TEST_CHALLENGE = \"0x12345678\";\n const TEST_SAFE_ADDRESS = \"0x1234567890123456789012345678901234567890\";\n const TEST_CHAIN_ID = 1;\n\n const successChallengeResult = CommandResultFactory({\n data: { challenge: TEST_CHALLENGE },\n });\n\n const errorResult = CommandResultFactory({\n data: undefined,\n error: {} as UnknownDeviceExchangeError,\n });\n\n const validSafeContext: ClearSignContextSuccess<ClearSignContextType.SAFE> = {\n type: ClearSignContextType.SAFE,\n payload: \"safe_payload\",\n };\n\n const validSignerContext: ClearSignContextSuccess<ClearSignContextType.SIGNER> =\n {\n type: ClearSignContextType.SIGNER,\n payload: \"signer_payload\",\n };\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n describe(\"run\", () => {\n it(\"should successfully build safe address contexts with valid SAFE and SIGNER contexts\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSafeContext, validSignerContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [validSafeContext, validSignerContext],\n });\n expect(apiMock.sendCommand).toHaveBeenCalledTimes(1);\n expect(contextModuleMock.getContexts).toHaveBeenCalledWith(\n {\n safeContractAddress: TEST_SAFE_ADDRESS,\n chainId: TEST_CHAIN_ID,\n deviceModelId: DeviceModelId.FLEX,\n challenge: TEST_CHALLENGE,\n },\n [ClearSignContextType.SAFE, ClearSignContextType.SIGNER],\n );\n });\n\n it(\"should include certificates when provided in contexts\", async () => {\n // GIVEN\n const safeContextWithCert: ClearSignContextSuccess<ClearSignContextType.SAFE> =\n {\n type: ClearSignContextType.SAFE,\n payload: \"safe_payload\",\n certificate: {\n keyUsageNumber: 1,\n payload: new Uint8Array([1, 2, 3]),\n },\n };\n const signerContextWithCert: ClearSignContextSuccess<ClearSignContextType.SIGNER> =\n {\n type: ClearSignContextType.SIGNER,\n payload: \"signer_payload\",\n certificate: {\n keyUsageNumber: 2,\n payload: new Uint8Array([4, 5, 6]),\n },\n };\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([safeContextWithCert, signerContextWithCert]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [safeContextWithCert, signerContextWithCert],\n });\n });\n });\n\n describe(\"error handling\", () => {\n it(\"should throw error when GetChallengeCommand fails\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(errorResult);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Failed to get challenge\");\n });\n\n it(\"should throw error when context contains ERROR type\", async () => {\n // GIVEN\n const errorContext: ClearSignContext = {\n type: ClearSignContextType.ERROR,\n error: new Error(\"Context error\"),\n };\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([errorContext, validSignerContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Context error\");\n });\n\n it(\"should throw error when only one context is returned\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSafeContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error when no contexts are returned\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi.fn().mockResolvedValue([]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error when more than two contexts are returned\", async () => {\n // GIVEN\n const extraContext: ClearSignContextSuccess<ClearSignContextType.TOKEN> =\n {\n type: ClearSignContextType.TOKEN,\n payload: \"extra_payload\",\n };\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([\n validSafeContext,\n validSignerContext,\n extraContext,\n ]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error when SAFE context is missing\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSignerContext, validSignerContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error when SIGNER context is missing\", async () => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSafeContext, validSafeContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error when contexts are of wrong types\", async () => {\n // GIVEN\n const wrongContext1: ClearSignContextSuccess<ClearSignContextType.TOKEN> =\n {\n type: ClearSignContextType.TOKEN,\n payload: \"token_payload\",\n };\n const wrongContext2: ClearSignContextSuccess<ClearSignContextType.NFT> = {\n type: ClearSignContextType.NFT,\n payload: \"nft_payload\",\n };\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([wrongContext1, wrongContext2]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Invalid safe address contexts\");\n });\n\n it(\"should throw error with multiple ERROR contexts\", async () => {\n // GIVEN\n const errorContext1: ClearSignContext = {\n type: ClearSignContextType.ERROR,\n error: new Error(\"First error\"),\n };\n const errorContext2: ClearSignContext = {\n type: ClearSignContextType.ERROR,\n error: new Error(\"Second error\"),\n };\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([errorContext1, errorContext2]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"First error\");\n });\n });\n\n describe(\"device model variants\", () => {\n it.each([\n [DeviceModelId.NANO_S, \"Nano S\"],\n [DeviceModelId.NANO_SP, \"Nano S Plus\"],\n [DeviceModelId.NANO_X, \"Nano X\"],\n [DeviceModelId.FLEX, \"Flex\"],\n [DeviceModelId.STAX, \"Stax\"],\n ])(\n \"should successfully build contexts for %s device\",\n async (deviceModelId, _deviceName) => {\n // GIVEN\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId,\n };\n apiMock.sendCommand.mockResolvedValue(successChallengeResult);\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSafeContext, validSignerContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n const result = await task.run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [validSafeContext, validSignerContext],\n });\n expect(contextModuleMock.getContexts).toHaveBeenCalledWith(\n expect.objectContaining({\n deviceModelId,\n }),\n [ClearSignContextType.SAFE, ClearSignContextType.SIGNER],\n );\n },\n );\n });\n\n describe(\"challenge handling\", () => {\n it(\"should pass the correct challenge to contextModule\", async () => {\n // GIVEN\n const customChallenge = \"0xabcdef12\";\n const args: BuildSafeAddressContextTaskArgs = {\n contextModule: contextModuleMock,\n safeContractAddress: TEST_SAFE_ADDRESS,\n options: { chainId: TEST_CHAIN_ID },\n deviceModelId: DeviceModelId.FLEX,\n };\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({\n data: { challenge: customChallenge },\n }),\n );\n contextModuleMock.getContexts = vi\n .fn()\n .mockResolvedValue([validSafeContext, validSignerContext]);\n\n // WHEN\n const task = new BuildSafeAddressContextTask(apiMock, args);\n await task.run();\n\n // THEN\n expect(contextModuleMock.getContexts).toHaveBeenCalledWith(\n expect.objectContaining({\n challenge: customChallenge,\n }),\n [ClearSignContextType.SAFE, ClearSignContextType.SIGNER],\n );\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_device_management_kit", "import_makeInternalApi", "import_BuildSafeAddressContextTask", "apiMock", "contextModuleMock", "TEST_CHALLENGE", "TEST_SAFE_ADDRESS", "TEST_CHAIN_ID", "successChallengeResult", "errorResult", "validSafeContext", "validSignerContext", "args", "result", "safeContextWithCert", "signerContextWithCert", "task", "errorContext", "extraContext", "wrongContext1", "wrongContext2", "errorContext1", "errorContext2", "deviceModelId", "_deviceName", "customChallenge"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var d=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var b=Object.prototype.hasOwnProperty;var p=(r,e)=>{for(var n in e)d(r,n,{get:e[n],enumerable:!0})},h=(r,e,n,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of g(e))!b.call(r,a)&&a!==n&&d(r,a,{get:()=>e[a],enumerable:!(s=C(e,a))||s.enumerable});return r};var S=r=>h(d({},"__esModule",{value:!0}),r);var y={};p(y,{BuildSubcontextsTask:()=>T});module.exports=S(y);var t=require("@ledgerhq/context-module"),c=require("@ledgerhq/device-management-kit"),x=require("../../app-binder/command/GetChallengeCommand");class T{constructor(e,n){this.api=e;this.args=n}run(){const e=this.args.context,n=e.type;switch(n){case t.ClearSignContextType.TRANSACTION_INFO:case t.ClearSignContextType.WEB3_CHECK:case t.ClearSignContextType.PLUGIN:case t.ClearSignContextType.EXTERNAL_PLUGIN:case t.ClearSignContextType.DYNAMIC_NETWORK:case t.ClearSignContextType.DYNAMIC_NETWORK_ICON:case t.ClearSignContextType.ENUM:case t.ClearSignContextType.TRUSTED_NAME:case t.ClearSignContextType.TOKEN:case t.ClearSignContextType.NFT:case t.ClearSignContextType.SAFE:case t.ClearSignContextType.SIGNER:return{subcontextCallbacks:[]};case t.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:return{subcontextCallbacks:e.reference?this._getSubcontextsFromReference(e.reference):[]};case t.ClearSignContextType.PROXY_INFO:return{subcontextCallbacks:this._getSubcontextFromProxy(e)};default:{const s=n;throw new Error(`Uncovered type: ${s}`)}}}_getSubcontextsFromReference(e){const n=e.type;switch(n){case t.ClearSignContextReferenceType.TOKEN:case t.ClearSignContextReferenceType.NFT:return this._getSubcontextsFromTokenOrNftReference(e);case t.ClearSignContextReferenceType.ENUM:return this._getSubcontextsFromEnumReference(e);case t.ClearSignContextReferenceType.TRUSTED_NAME:return this._getSubcontextsFromTrustedNameReference(e);case t.ClearSignContextReferenceType.CALLDATA:return[];default:{const s=n;throw new Error(`Uncovered reference type: ${s}`)}}}_getSubcontextsFromTokenOrNftReference(e){if(e.value!==void 0){const s={chainId:this.args.subset.chainId,address:e.value},a=e.type===t.ClearSignContextReferenceType.TOKEN?t.ClearSignContextType.TOKEN:t.ClearSignContextType.NFT;return[()=>this.args.contextModule.getFieldContext(s,a)]}const n=[];if(e.valuePath!==void 0){const s=this.args.transactionParser.extractValue(this.args.subset,e.valuePath).orDefault([]);for(const a of s){const o=(0,c.bufferToHexaString)(a.slice(Math.max(0,a.length-20))),l=e.type===t.ClearSignContextReferenceType.TOKEN?t.ClearSignContextType.TOKEN:t.ClearSignContextType.NFT;n.push(()=>this.args.contextModule.getFieldContext({chainId:this.args.subset.chainId,address:o},l))}}return n}_getSubcontextsFromEnumReference(e){const n=[];if(!e.valuePath)return n;const s=this.args.transactionParser.extractValue(this.args.subset,e.valuePath).orDefault([]);for(const a of s){const o=a[a.length-1];if(o===void 0)continue;const i=this.args.contextOptional.filter(u=>u.type===t.ClearSignContextType.ENUM).find(u=>u.value===o&&u.id===e.id);i&&n.push(()=>Promise.resolve(i))}return n}_getSubcontextsFromTrustedNameReference(e){const n=[];if(!e.valuePath)return n;const s=this.args.transactionParser.extractValue(this.args.subset,e.valuePath).orDefault([]);for(const a of s)n.push(async()=>{const o=(0,c.bufferToHexaString)(a.slice(Math.max(0,a.length-20))),l=await this.api.sendCommand(new x.GetChallengeCommand);return(0,c.isSuccessCommandResult)(l)?await this.args.contextModule.getFieldContext({chainId:this.args.subset.chainId,address:o,challenge:l.data.challenge,types:e.types,sources:e.sources,deviceModelId:this.args.deviceModelId},t.ClearSignContextType.TRUSTED_NAME):{type:t.ClearSignContextType.ERROR,error:new Error("Failed to get challenge")}});return n}_getSubcontextFromProxy(e){return[async()=>{const n=await this.api.sendCommand(new x.GetChallengeCommand);return(0,c.isSuccessCommandResult)(n)?this.args.subset.to===void 0?{type:t.ClearSignContextType.ERROR,error:new Error("Failed to get proxy address")}:await this.args.contextModule.getFieldContext({chainId:this.args.subset.chainId,proxyAddress:this.args.subset.to,calldata:this.args.subset.data,deviceModelId:this.args.deviceModelId,challenge:n.data.challenge},t.ClearSignContextType.PROXY_INFO):{type:t.ClearSignContextType.ERROR,error:new Error("Failed to get challenge")}}]}}0&&(module.exports={BuildSubcontextsTask});
2
+ //# sourceMappingURL=BuildSubcontextsTask.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildSubcontextsTask.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContext,\n type ClearSignContextReference,\n ClearSignContextReferenceType,\n type ClearSignContextSuccess,\n ClearSignContextType,\n type ContextModule,\n type TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport {\n bufferToHexaString,\n type DeviceModelId,\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nexport type BuildSubcontextsTaskArgs = {\n readonly context: ClearSignContextSuccess;\n readonly contextOptional: ClearSignContextSuccess[];\n readonly transactionParser: TransactionParserService;\n readonly subset: TransactionSubset;\n readonly deviceModelId: DeviceModelId;\n readonly contextModule: ContextModule;\n};\n\ntype SubcontextCallback = () => Promise<ClearSignContext>;\n\nexport type BuildSubcontextsTaskResult = {\n subcontextCallbacks: SubcontextCallback[];\n};\n\nexport class BuildSubcontextsTask {\n constructor(\n private readonly api: InternalApi,\n private readonly args: BuildSubcontextsTaskArgs,\n ) {}\n\n run(): BuildSubcontextsTaskResult {\n const context = this.args.context;\n const type = context.type;\n\n switch (type) {\n case ClearSignContextType.TRANSACTION_INFO:\n case ClearSignContextType.WEB3_CHECK:\n case ClearSignContextType.PLUGIN:\n case ClearSignContextType.EXTERNAL_PLUGIN:\n case ClearSignContextType.DYNAMIC_NETWORK:\n case ClearSignContextType.DYNAMIC_NETWORK_ICON:\n case ClearSignContextType.ENUM:\n case ClearSignContextType.TRUSTED_NAME:\n case ClearSignContextType.TOKEN:\n case ClearSignContextType.NFT:\n case ClearSignContextType.SAFE:\n case ClearSignContextType.SIGNER:\n return {\n subcontextCallbacks: [],\n };\n case ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:\n return {\n subcontextCallbacks: context.reference\n ? this._getSubcontextsFromReference(context.reference)\n : [],\n };\n case ClearSignContextType.PROXY_INFO:\n return {\n subcontextCallbacks: this._getSubcontextFromProxy(context),\n };\n default: {\n const uncoveredType: never = type;\n throw new Error(`Uncovered type: ${uncoveredType}`);\n }\n }\n }\n\n private _getSubcontextsFromReference(\n reference: ClearSignContextReference,\n ): SubcontextCallback[] {\n const referenceType = reference.type;\n\n switch (referenceType) {\n case ClearSignContextReferenceType.TOKEN:\n case ClearSignContextReferenceType.NFT:\n return this._getSubcontextsFromTokenOrNftReference(reference);\n case ClearSignContextReferenceType.ENUM:\n return this._getSubcontextsFromEnumReference(reference);\n case ClearSignContextReferenceType.TRUSTED_NAME:\n return this._getSubcontextsFromTrustedNameReference(reference);\n case ClearSignContextReferenceType.CALLDATA:\n // calldata reference is handled by the BuildFullContextsTask and ParseNestedTransactionTask\n return [];\n default: {\n const uncoveredReferenceType: never = referenceType;\n throw new Error(`Uncovered reference type: ${uncoveredReferenceType}`);\n }\n }\n }\n\n private _getSubcontextsFromTokenOrNftReference(\n reference: ClearSignContextReference<\n ClearSignContextReferenceType.TOKEN | ClearSignContextReferenceType.NFT\n >,\n ): SubcontextCallback[] {\n // if the reference is a string, it means it is a direct address\n // and we don't need to extract the value from the transaction\n // as it is already provided in the reference\n if (reference.value !== undefined) {\n const transactionFieldContext = {\n chainId: this.args.subset.chainId,\n address: reference.value,\n };\n\n const expectedType =\n reference.type === ClearSignContextReferenceType.TOKEN\n ? ClearSignContextType.TOKEN\n : ClearSignContextType.NFT;\n\n return [\n () =>\n this.args.contextModule.getFieldContext(\n transactionFieldContext,\n expectedType,\n ),\n ];\n }\n\n const subcontextCallbacks: SubcontextCallback[] = [];\n\n // if the reference is a path, it means we need to extract the value\n // from the transaction and provide it to the device\n if (reference.valuePath !== undefined) {\n const referenceValues = this.args.transactionParser\n .extractValue(this.args.subset, reference.valuePath)\n .orDefault([]);\n\n for (const value of referenceValues) {\n const address = bufferToHexaString(\n value.slice(Math.max(0, value.length - 20)),\n );\n\n const expectedType =\n reference.type === ClearSignContextReferenceType.TOKEN\n ? ClearSignContextType.TOKEN\n : ClearSignContextType.NFT;\n\n subcontextCallbacks.push(() =>\n this.args.contextModule.getFieldContext(\n {\n chainId: this.args.subset.chainId,\n address,\n },\n expectedType,\n ),\n );\n }\n }\n\n return subcontextCallbacks;\n }\n\n private _getSubcontextsFromEnumReference(\n reference: ClearSignContextReference<ClearSignContextReferenceType.ENUM>,\n ): SubcontextCallback[] {\n const subcontextCallbacks: SubcontextCallback[] = [];\n\n if (!reference.valuePath) {\n return subcontextCallbacks;\n }\n\n const referenceValues = this.args.transactionParser\n .extractValue(this.args.subset, reference.valuePath)\n .orDefault([]);\n\n for (const value of referenceValues) {\n const enumValue = value[value.length - 1];\n if (enumValue === undefined) {\n continue;\n }\n\n const enumsContext = this.args.contextOptional.filter(\n (c) => c.type === ClearSignContextType.ENUM,\n );\n\n const subcontext = enumsContext.find(\n (enumContext) =>\n enumContext.value === enumValue && enumContext.id === reference.id,\n );\n\n if (subcontext) {\n subcontextCallbacks.push(() => Promise.resolve(subcontext));\n }\n }\n return subcontextCallbacks;\n }\n\n private _getSubcontextsFromTrustedNameReference(\n reference: ClearSignContextReference<ClearSignContextReferenceType.TRUSTED_NAME>,\n ): SubcontextCallback[] {\n const subcontextCallbacks: SubcontextCallback[] = [];\n\n if (!reference.valuePath) {\n return subcontextCallbacks;\n }\n\n const referenceValues = this.args.transactionParser\n .extractValue(this.args.subset, reference.valuePath)\n .orDefault([]);\n\n for (const value of referenceValues) {\n {\n subcontextCallbacks.push(async () => {\n const address = bufferToHexaString(\n value.slice(Math.max(0, value.length - 20)),\n );\n\n const getChallengeResult = await this.api.sendCommand(\n new GetChallengeCommand(),\n );\n if (!isSuccessCommandResult(getChallengeResult)) {\n return {\n type: ClearSignContextType.ERROR,\n error: new Error(\"Failed to get challenge\"),\n };\n }\n\n const subcontext = await this.args.contextModule.getFieldContext(\n {\n chainId: this.args.subset.chainId,\n address,\n challenge: getChallengeResult.data.challenge,\n types: reference.types,\n sources: reference.sources,\n deviceModelId: this.args.deviceModelId,\n },\n ClearSignContextType.TRUSTED_NAME,\n );\n\n return subcontext;\n });\n }\n }\n\n return subcontextCallbacks;\n }\n\n private _getSubcontextFromProxy(\n _context: ClearSignContextSuccess<ClearSignContextType.PROXY_INFO>,\n ): SubcontextCallback[] {\n return [\n async () => {\n const getChallengeResult = await this.api.sendCommand(\n new GetChallengeCommand(),\n );\n if (!isSuccessCommandResult(getChallengeResult)) {\n return {\n type: ClearSignContextType.ERROR,\n error: new Error(\"Failed to get challenge\"),\n };\n }\n\n if (this.args.subset.to === undefined) {\n return {\n type: ClearSignContextType.ERROR,\n error: new Error(\"Failed to get proxy address\"),\n };\n }\n\n const subcontext = await this.args.contextModule.getFieldContext(\n {\n chainId: this.args.subset.chainId,\n proxyAddress: this.args.subset.to,\n calldata: this.args.subset.data,\n deviceModelId: this.args.deviceModelId,\n challenge: getChallengeResult.data.challenge,\n },\n ClearSignContextType.PROXY_INFO,\n );\n\n return subcontext;\n },\n ];\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["BuildSubcontextsTask_exports", "__export", "BuildSubcontextsTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_GetChallengeCommand", "api", "args", "context", "type", "uncoveredType", "reference", "referenceType", "uncoveredReferenceType", "transactionFieldContext", "expectedType", "subcontextCallbacks", "referenceValues", "value", "address", "enumValue", "subcontext", "c", "enumContext", "getChallengeResult", "_context"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var e=require("@ledgerhq/context-module"),i=require("@ledgerhq/device-management-kit"),d=require("purify-ts"),b=require("../../app-binder/command/GetChallengeCommand"),N=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),r=require("./BuildSubcontextsTask");describe("BuildSubcontextsTask",()=>{const x={getFieldContext:vi.fn()},p={extractValue:vi.fn()},o=(0,N.makeDeviceActionInternalApiMock)();let l;beforeEach(()=>{vi.resetAllMocks(),l={context:{type:e.ClearSignContextType.TRANSACTION_INFO,payload:"test payload"},contextOptional:[],transactionParser:p,subset:{chainId:1,data:"0x",selector:"0x",to:"0x",value:BigInt(0)},contextModule:x,deviceModelId:i.DeviceModelId.STAX}}),describe("when context type is a simple type",()=>{const c=[e.ClearSignContextType.TRANSACTION_INFO,e.ClearSignContextType.WEB3_CHECK,e.ClearSignContextType.PLUGIN,e.ClearSignContextType.EXTERNAL_PLUGIN,e.ClearSignContextType.DYNAMIC_NETWORK,e.ClearSignContextType.DYNAMIC_NETWORK_ICON,e.ClearSignContextType.ENUM,e.ClearSignContextType.TRUSTED_NAME,e.ClearSignContextType.TOKEN,e.ClearSignContextType.NFT];it.each(c)("should return context with empty subcontextCallbacks for %s",t=>{const n={...l,context:{type:t,payload:"test payload"}},s=new r.BuildSubcontextsTask(o,n).run();expect(s.subcontextCallbacks).toHaveLength(0)})}),describe("when context has a direct value reference",()=>{it("should create a callback to get context with the direct value",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,value:"0x1234567890123456789012345678901234567890"}},t={...l,context:c},a={chainId:1,address:"0x1234567890123456789012345678901234567890"},n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0];await s(),expect(x.getFieldContext).toHaveBeenCalledWith(a,e.ClearSignContextType.TOKEN)}),it("should handle undefined value in reference",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:void 0},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("when context has a valuePath reference",()=>{beforeEach(()=>{o.sendCommand.mockResolvedValue((0,i.CommandResultFactory)({data:{challenge:"test-challenge"}}))}),describe("when extractValue returns Left (error)",()=>{it("should return context with empty subcontextCallbacks",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:[{type:"SLICE",start:0,end:20}]}},t={...l,context:c};p.extractValue.mockReturnValue((0,d.Left)(new Error("Extraction failed")));const a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("when extractValue returns Right with values",()=>{describe("for ENUM type",()=>{it("should create callbacks for matching enum contexts",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:1,valuePath:[{type:"TUPLE",offset:0}]}},t={type:e.ClearSignContextType.ENUM,id:1,value:1,payload:"enum context 1"},a={type:e.ClearSignContextType.ENUM,id:1,value:2,payload:"enum context 2"},n={type:e.ClearSignContextType.ENUM,id:2,value:2,payload:"enum context 3"},s={...l,context:c,contextOptional:[t,a,n]},u=[new Uint8Array([1,2])];p.extractValue.mockReturnValue((0,d.Right)(u));const y=new r.BuildSubcontextsTask(o,s).run();expect(y.subcontextCallbacks).toHaveLength(1);const C=y.subcontextCallbacks[0],h=await C();expect(h).toEqual(a)}),it("should create callbacks for matching enum contexts with two values",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:1,valuePath:[{type:"TUPLE",offset:0}]}},t={type:e.ClearSignContextType.ENUM,id:1,value:1,payload:"enum context 1"},a={type:e.ClearSignContextType.ENUM,id:1,value:2,payload:"enum context 2"},n={type:e.ClearSignContextType.ENUM,id:2,value:2,payload:"enum context 3"},s={...l,context:c,contextOptional:[t,a,n]},u=[new Uint8Array([1,2]),new Uint8Array([3,2,1])];p.extractValue.mockReturnValue((0,d.Right)(u));const y=new r.BuildSubcontextsTask(o,s).run();expect(y.subcontextCallbacks).toHaveLength(2);const C=y.subcontextCallbacks[0],h=y.subcontextCallbacks[1],g=await C(),E=await h();expect(g).toEqual(a),expect(E).toEqual(t)}),it("should skip when enum value is undefined",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:1,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([])];p.extractValue.mockReturnValue((0,d.Right)(a));const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(0)}),it("should create callback with enum id 0",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:0,valuePath:[{type:"TUPLE",offset:0}]}},t={type:e.ClearSignContextType.ENUM,id:0,value:0,payload:"enum context 1"},a={type:e.ClearSignContextType.ENUM,id:1,value:1,payload:"enum context 2"},n={...l,context:c,contextOptional:[t,a]},s=[new Uint8Array([1,0])];p.extractValue.mockReturnValue((0,d.Right)(s));const u=new r.BuildSubcontextsTask(o,n).run();expect(u.subcontextCallbacks).toHaveLength(1);const y=u.subcontextCallbacks[0],C=await y();expect(C).toEqual(t)}),it("should skip when no matching enum context found",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:1,valuePath:[{type:"TUPLE",offset:0}]}},t={type:e.ClearSignContextType.ENUM,id:2,value:2,payload:"enum context"},a={...l,context:c,contextOptional:[t]},n=[new Uint8Array([1,2])];p.extractValue.mockReturnValue((0,d.Right)(n));const s=new r.BuildSubcontextsTask(o,a).run();expect(s.subcontextCallbacks).toHaveLength(0)})}),describe("for TOKEN type",()=>{it("should create callbacks to get token context",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.TOKEN,payload:"token result"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({type:e.ClearSignContextType.TOKEN,payload:"token result"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516"},e.ClearSignContextType.TOKEN)}),it("should create callbacks to get token as constant",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,value:"0x030405060708090a0b0c0d0e0f10111213141516"}},t={...l,context:c};x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.TOKEN,payload:"token result"});const a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(1);const n=a.subcontextCallbacks[0],s=await n();expect(s).toEqual({type:e.ClearSignContextType.TOKEN,payload:"token result"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516"},e.ClearSignContextType.TOKEN)})}),describe("for NFT type",()=>{it("should create callbacks to get NFT context",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.NFT,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.NFT,payload:"nft result"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({type:e.ClearSignContextType.NFT,payload:"nft result"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516"},e.ClearSignContextType.NFT)}),it("should create callbacks to get NFT as constant",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.NFT,value:"0x030405060708090a0b0c0d0e0f10111213141516"}},t={...l,context:c};x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.NFT,payload:"nft result"});const a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(1);const n=a.subcontextCallbacks[0],s=await n();expect(s).toEqual({type:e.ClearSignContextType.NFT,payload:"nft result"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516"},e.ClearSignContextType.NFT)})}),describe("for TRUSTED_NAME type",()=>{it("should create callbacks to get trusted name context with challenge",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TRUSTED_NAME,valuePath:[{type:"TUPLE",offset:0}],types:["type1","type2"],sources:["source1","source2"]}},t={...l,context:c},a=[new Uint8Array([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.TRUSTED_NAME,payload:"trusted name result"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({type:e.ClearSignContextType.TRUSTED_NAME,payload:"trusted name result"}),expect(o.sendCommand).toHaveBeenCalledWith(expect.any(b.GetChallengeCommand)),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516",challenge:"test-challenge",types:["type1","type2"],sources:["source1","source2"],deviceModelId:i.DeviceModelId.STAX},e.ClearSignContextType.TRUSTED_NAME)}),it("should handle challenge command failure",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TRUSTED_NAME,valuePath:[{type:"TUPLE",offset:0}],types:["type1"],sources:["source1"]}},t={...l,context:c},a=[new Uint8Array([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22])];p.extractValue.mockReturnValue((0,d.Right)(a));const n=new i.UnknownDeviceExchangeError("Failed");o.sendCommand.mockResolvedValueOnce((0,i.CommandResultFactory)({error:n}));const s=new r.BuildSubcontextsTask(o,t).run();expect(s.subcontextCallbacks).toHaveLength(1);const u=s.subcontextCallbacks[0],y=await u();expect(y).toEqual({error:new Error("Failed to get challenge"),type:e.ClearSignContextType.ERROR})})}),describe("for multiple values",()=>{it("should create callbacks for each extracted value",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22]),new Uint8Array([33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValueOnce({type:e.ClearSignContextType.TOKEN,payload:"token result 1"}),x.getFieldContext.mockResolvedValueOnce({type:e.ClearSignContextType.TOKEN,payload:"token result 2"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(2);const s=n.subcontextCallbacks[0],u=n.subcontextCallbacks[1],y=await s(),C=await u();expect(y).toEqual({type:e.ClearSignContextType.TOKEN,payload:"token result 1"}),expect(C).toEqual({type:e.ClearSignContextType.TOKEN,payload:"token result 2"}),expect(x.getFieldContext).toHaveBeenCalledTimes(2),expect(x.getFieldContext).toHaveBeenNthCalledWith(1,{chainId:1,address:"0x030405060708090a0b0c0d0e0f10111213141516"},e.ClearSignContextType.TOKEN),expect(x.getFieldContext).toHaveBeenNthCalledWith(2,{chainId:1,address:"0x232425262728292a2b2c2d2e2f30313233343536"},e.ClearSignContextType.TOKEN)})})})}),describe("when context has no reference",()=>{it("should return context with empty subcontextCallbacks",()=>{const c={type:e.ClearSignContextType.TOKEN,payload:"test payload"},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("when context has reference but no valuePath",()=>{it("should return context with empty subcontextCallbacks",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:void 0}},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("error handling",()=>{it("should throw error for uncovered context type",()=>{const t={...l,context:{type:"UNKNOWN_TYPE",payload:"test payload"}};expect(()=>new r.BuildSubcontextsTask(o,t).run()).toThrow("Uncovered type: UNKNOWN_TYPE")}),it("should throw error for uncovered reference type",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:"UNKNOWN_REFERENCE_TYPE"}},t={...l,context:c};expect(()=>new r.BuildSubcontextsTask(o,t).run()).toThrow("Uncovered reference type: UNKNOWN_REFERENCE_TYPE")})}),describe("CALLDATA reference type",()=>{it("should return empty subcontextCallbacks for CALLDATA reference",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,callee:[{type:"TUPLE",offset:0}],valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("references without valuePath",()=>{it("should return empty subcontextCallbacks for ENUM reference without valuePath",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.ENUM,id:1,valuePath:void 0}},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)}),it("should return empty subcontextCallbacks for TRUSTED_NAME reference without valuePath",()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TRUSTED_NAME,types:["type1"],sources:["source1"],valuePath:void 0}},t={...l,context:c},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(0)})}),describe("PROXY_INFO context type",()=>{beforeEach(()=>{o.sendCommand.mockResolvedValue((0,i.CommandResultFactory)({data:{challenge:"test-challenge"}}))}),it("should create callback to get proxy delegate call context",async()=>{const c={type:e.ClearSignContextType.PROXY_INFO,payload:"proxy payload"},t={...l,context:c,subset:{...l.subset,to:"0x1234567890123456789012345678901234567890",data:"0xabcdef"}};x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.PROXY_INFO,payload:"proxy result"});const a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(1);const n=a.subcontextCallbacks[0],s=await n();expect(s).toEqual({type:e.ClearSignContextType.PROXY_INFO,payload:"proxy result"}),expect(o.sendCommand).toHaveBeenCalledWith(expect.any(b.GetChallengeCommand)),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,proxyAddress:"0x1234567890123456789012345678901234567890",calldata:"0xabcdef",deviceModelId:i.DeviceModelId.STAX,challenge:"test-challenge"},e.ClearSignContextType.PROXY_INFO)}),it("should handle challenge command failure",async()=>{const c={type:e.ClearSignContextType.PROXY_INFO,payload:"proxy payload"},t={...l,context:c,subset:{...l.subset,to:"0x1234567890123456789012345678901234567890",data:"0xabcdef"}},a=new i.UnknownDeviceExchangeError("Failed");o.sendCommand.mockResolvedValueOnce((0,i.CommandResultFactory)({error:a}));const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({error:new Error("Failed to get challenge"),type:e.ClearSignContextType.ERROR}),expect(o.sendCommand).toHaveBeenCalledWith(expect.any(b.GetChallengeCommand)),expect(x.getFieldContext).not.toHaveBeenCalled()}),it("should handle missing proxy address",async()=>{const c={type:e.ClearSignContextType.PROXY_INFO,payload:"proxy payload"},t={...l,context:c,subset:{...l.subset,to:void 0,data:"0xabcdef"}},a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(1);const n=a.subcontextCallbacks[0],s=await n();expect(s).toEqual({error:new Error("Failed to get proxy address"),type:e.ClearSignContextType.ERROR}),expect(o.sendCommand).toHaveBeenCalledWith(expect.any(b.GetChallengeCommand)),expect(x.getFieldContext).not.toHaveBeenCalled()}),it("should use correct device model id in context",async()=>{const c={type:e.ClearSignContextType.PROXY_INFO,payload:"proxy payload"},t={...l,context:c,deviceModelId:i.DeviceModelId.NANO_SP,subset:{...l.subset,to:"0x1234567890123456789012345678901234567890",data:"0xabcdef"}};x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.PROXY_INFO,payload:"proxy result"});const a=new r.BuildSubcontextsTask(o,t).run();expect(a.subcontextCallbacks).toHaveLength(1);const n=a.subcontextCallbacks[0];await n(),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,proxyAddress:"0x1234567890123456789012345678901234567890",calldata:"0xabcdef",deviceModelId:i.DeviceModelId.NANO_SP,challenge:"test-challenge"},e.ClearSignContextType.PROXY_INFO)})}),describe("edge cases",()=>{it("should handle value array shorter than 20 bytes for address extraction",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([1,2,3])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.ERROR,message:"Invalid address"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({type:e.ClearSignContextType.ERROR,message:"Invalid address"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x010203"},e.ClearSignContextType.TOKEN)}),it("should handle empty value array",async()=>{const c={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:[{type:"TUPLE",offset:0}]}},t={...l,context:c},a=[new Uint8Array([])];p.extractValue.mockReturnValue((0,d.Right)(a)),x.getFieldContext.mockResolvedValue({type:e.ClearSignContextType.TOKEN,payload:"token result"});const n=new r.BuildSubcontextsTask(o,t).run();expect(n.subcontextCallbacks).toHaveLength(1);const s=n.subcontextCallbacks[0],u=await s();expect(u).toEqual({type:e.ClearSignContextType.TOKEN,payload:"token result"}),expect(x.getFieldContext).toHaveBeenCalledWith({chainId:1,address:"0x"},e.ClearSignContextType.TOKEN)})})});
2
+ //# sourceMappingURL=BuildSubcontextsTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/BuildSubcontextsTask.test.ts"],
4
+ "sourcesContent": ["import {\n type ClearSignContextReference,\n ClearSignContextReferenceType,\n type ClearSignContextSuccess,\n ClearSignContextType,\n type ContextModule,\n type GenericPath,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceModelId,\n UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport {\n BuildSubcontextsTask,\n type BuildSubcontextsTaskArgs,\n} from \"./BuildSubcontextsTask\";\n\ndescribe(\"BuildSubcontextsTask\", () => {\n const contextModuleMock = {\n getFieldContext: vi.fn(),\n };\n const transactionParserMock = {\n extractValue: vi.fn(),\n };\n const apiMock = makeDeviceActionInternalApiMock();\n\n let defaultArgs: BuildSubcontextsTaskArgs;\n\n beforeEach(() => {\n vi.resetAllMocks();\n defaultArgs = {\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"test payload\",\n },\n contextOptional: [],\n transactionParser:\n transactionParserMock as unknown as TransactionParserService,\n subset: {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n to: \"0x\",\n value: BigInt(0),\n },\n contextModule: contextModuleMock as unknown as ContextModule,\n deviceModelId: DeviceModelId.STAX,\n };\n });\n\n describe(\"when context type is a simple type\", () => {\n const simpleTypes: ClearSignContextSuccess[\"type\"][] = [\n ClearSignContextType.TRANSACTION_INFO,\n ClearSignContextType.WEB3_CHECK,\n ClearSignContextType.PLUGIN,\n ClearSignContextType.EXTERNAL_PLUGIN,\n ClearSignContextType.DYNAMIC_NETWORK,\n ClearSignContextType.DYNAMIC_NETWORK_ICON,\n ClearSignContextType.ENUM,\n ClearSignContextType.TRUSTED_NAME,\n ClearSignContextType.TOKEN,\n ClearSignContextType.NFT,\n ];\n\n it.each(simpleTypes)(\n \"should return context with empty subcontextCallbacks for %s\",\n (type) => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type,\n payload: \"test payload\",\n } as ClearSignContextSuccess;\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n },\n );\n });\n\n describe(\"when context has a direct value reference\", () => {\n it(\"should create a callback to get context with the direct value\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n value: \"0x1234567890123456789012345678901234567890\",\n },\n };\n const args = { ...defaultArgs, context };\n const expectedContext = {\n chainId: 1,\n address: \"0x1234567890123456789012345678901234567890\",\n };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n\n // Verify the callback calls getContext with correct parameters\n const callback = result.subcontextCallbacks[0]!;\n await callback();\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n expectedContext,\n ClearSignContextType.TOKEN,\n );\n });\n\n it(\"should handle undefined value in reference\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: undefined as unknown as ClearSignContextReference,\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"when context has a valuePath reference\", () => {\n beforeEach(() => {\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { challenge: \"test-challenge\" } }),\n );\n });\n\n describe(\"when extractValue returns Left (error)\", () => {\n it(\"should return context with empty subcontextCallbacks\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: [{ type: \"SLICE\", start: 0, end: 20 }],\n },\n };\n const args = { ...defaultArgs, context };\n transactionParserMock.extractValue.mockReturnValue(\n Left(new Error(\"Extraction failed\")),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"when extractValue returns Right with values\", () => {\n describe(\"for ENUM type\", () => {\n it(\"should create callbacks for matching enum contexts\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 1,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n // enum with the same id but different value\n const enumContext1: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 1,\n value: 1,\n payload: \"enum context 1\",\n };\n // enum to select, id and value match\n const enumContext2: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 1,\n value: 2,\n payload: \"enum context 2\",\n };\n // other enum context with different id\n const enumContext3: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 2,\n value: 2,\n payload: \"enum context 3\",\n };\n const args = {\n ...defaultArgs,\n context,\n contextOptional: [enumContext1, enumContext2, enumContext3],\n };\n const extractedValues = [new Uint8Array([0x01, 0x02])]; // Last byte is 2\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual(enumContext2);\n });\n\n it(\"should create callbacks for matching enum contexts with two values\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 1,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n // enum to select, id and value match\n const enumContext1: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 1,\n value: 1,\n payload: \"enum context 1\",\n };\n // enum to select, id and value match\n const enumContext2: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 1,\n value: 2,\n payload: \"enum context 2\",\n };\n // other enum context with different id\n const enumContext3: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 2,\n value: 2,\n payload: \"enum context 3\",\n };\n const args = {\n ...defaultArgs,\n context,\n contextOptional: [enumContext1, enumContext2, enumContext3],\n };\n const extractedValues = [\n new Uint8Array([0x01, 0x02]),\n new Uint8Array([0x03, 0x02, 0x01]),\n ]; // Last byte is 2\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(2);\n const callback1 = result.subcontextCallbacks[0]!;\n const callback2 = result.subcontextCallbacks[1]!;\n const callbackResult1 = await callback1();\n const callbackResult2 = await callback2();\n expect(callbackResult1).toEqual(enumContext2);\n expect(callbackResult2).toEqual(enumContext1);\n });\n\n it(\"should skip when enum value is undefined\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 1,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [new Uint8Array([])]; // Empty array\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n\n it(\"should create callback with enum id 0\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 0,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const enumContext1: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 0,\n value: 0,\n payload: \"enum context 1\",\n };\n const enumContext2: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 1,\n value: 1,\n payload: \"enum context 2\",\n };\n const args = {\n ...defaultArgs,\n context,\n contextOptional: [enumContext1, enumContext2],\n };\n const extractedValues = [new Uint8Array([0x01, 0x00])];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual(enumContext1);\n });\n\n it(\"should skip when no matching enum context found\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 1,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const enumContext: ClearSignContextSuccess = {\n type: ClearSignContextType.ENUM,\n id: 2, // Different ID\n value: 2,\n payload: \"enum context\",\n };\n const args = {\n ...defaultArgs,\n context,\n contextOptional: [enumContext],\n };\n const extractedValues = [new Uint8Array([0x01, 0x02])];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"for TOKEN type\", () => {\n it(\"should create callbacks to get token context\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,\n 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n ]),\n ];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n ClearSignContextType.TOKEN,\n );\n });\n\n it(\"should create callbacks to get token as constant\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n value: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n };\n const args = { ...defaultArgs, context };\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n ClearSignContextType.TOKEN,\n );\n });\n });\n\n describe(\"for NFT type\", () => {\n it(\"should create callbacks to get NFT context\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.NFT,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,\n 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n ]),\n ];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.NFT,\n payload: \"nft result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.NFT,\n payload: \"nft result\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n ClearSignContextType.NFT,\n );\n });\n\n it(\"should create callbacks to get NFT as constant\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.NFT,\n value: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n };\n const args = { ...defaultArgs, context };\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.NFT,\n payload: \"nft result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.NFT,\n payload: \"nft result\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n ClearSignContextType.NFT,\n );\n });\n });\n\n describe(\"for TRUSTED_NAME type\", () => {\n it(\"should create callbacks to get trusted name context with challenge\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TRUSTED_NAME,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n types: [\"type1\", \"type2\"],\n sources: [\"source1\", \"source2\"],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,\n 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n ]),\n ];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.TRUSTED_NAME,\n payload: \"trusted name result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.TRUSTED_NAME,\n payload: \"trusted name result\",\n });\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n challenge: \"test-challenge\",\n types: [\"type1\", \"type2\"],\n sources: [\"source1\", \"source2\"],\n deviceModelId: DeviceModelId.STAX,\n },\n ClearSignContextType.TRUSTED_NAME,\n );\n });\n\n it(\"should handle challenge command failure\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TRUSTED_NAME,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n types: [\"type1\"],\n sources: [\"source1\"],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,\n 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n ]),\n ];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n const error = new UnknownDeviceExchangeError(\"Failed\");\n apiMock.sendCommand.mockResolvedValueOnce(\n CommandResultFactory({\n error,\n }),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n error: new Error(\"Failed to get challenge\"),\n type: ClearSignContextType.ERROR,\n });\n });\n });\n\n describe(\"for multiple values\", () => {\n it(\"should create callbacks for each extracted value\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,\n 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n ]),\n new Uint8Array([\n 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2a, 0x2b,\n 0x2c, 0x2d, 0x2e, 0x2f, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36,\n ]),\n ];\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValueOnce({\n type: ClearSignContextType.TOKEN,\n payload: \"token result 1\",\n });\n contextModuleMock.getFieldContext.mockResolvedValueOnce({\n type: ClearSignContextType.TOKEN,\n payload: \"token result 2\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(2);\n const callback1 = result.subcontextCallbacks[0]!;\n const callback2 = result.subcontextCallbacks[1]!;\n const callbackResult1 = await callback1();\n const callbackResult2 = await callback2();\n expect(callbackResult1).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"token result 1\",\n });\n expect(callbackResult2).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"token result 2\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledTimes(2);\n expect(contextModuleMock.getFieldContext).toHaveBeenNthCalledWith(\n 1,\n {\n chainId: 1,\n address: \"0x030405060708090a0b0c0d0e0f10111213141516\",\n },\n ClearSignContextType.TOKEN,\n );\n expect(contextModuleMock.getFieldContext).toHaveBeenNthCalledWith(\n 2,\n {\n chainId: 1,\n address: \"0x232425262728292a2b2c2d2e2f30313233343536\",\n },\n ClearSignContextType.TOKEN,\n );\n });\n });\n });\n });\n\n describe(\"when context has no reference\", () => {\n it(\"should return context with empty subcontextCallbacks\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TOKEN,\n payload: \"test payload\",\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"when context has reference but no valuePath\", () => {\n it(\"should return context with empty subcontextCallbacks\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: undefined as unknown as GenericPath,\n },\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"error handling\", () => {\n it(\"should throw error for uncovered context type\", () => {\n // GIVEN\n const context = {\n type: \"UNKNOWN_TYPE\" as ClearSignContextSuccess[\"type\"],\n payload: \"test payload\",\n } as ClearSignContextSuccess;\n const args = { ...defaultArgs, context };\n\n // WHEN / THEN\n expect(() => new BuildSubcontextsTask(apiMock, args).run()).toThrow(\n \"Uncovered type: UNKNOWN_TYPE\",\n );\n });\n\n it(\"should throw error for uncovered reference type\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: \"UNKNOWN_REFERENCE_TYPE\" as ClearSignContextReference[\"type\"],\n } as ClearSignContextReference,\n };\n const args = { ...defaultArgs, context };\n\n // WHEN / THEN\n expect(() => new BuildSubcontextsTask(apiMock, args).run()).toThrow(\n \"Uncovered reference type: UNKNOWN_REFERENCE_TYPE\",\n );\n });\n });\n\n describe(\"CALLDATA reference type\", () => {\n it(\"should return empty subcontextCallbacks for CALLDATA reference\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n callee: [{ type: \"TUPLE\", offset: 0 }],\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"references without valuePath\", () => {\n it(\"should return empty subcontextCallbacks for ENUM reference without valuePath\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.ENUM,\n id: 1,\n valuePath: undefined as unknown as GenericPath,\n },\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n\n it(\"should return empty subcontextCallbacks for TRUSTED_NAME reference without valuePath\", () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TRUSTED_NAME,\n types: [\"type1\"],\n sources: [\"source1\"],\n valuePath: undefined as unknown as GenericPath,\n },\n };\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(0);\n });\n });\n\n describe(\"PROXY_INFO context type\", () => {\n beforeEach(() => {\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { challenge: \"test-challenge\" } }),\n );\n });\n\n it(\"should create callback to get proxy delegate call context\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy payload\",\n };\n const args = {\n ...defaultArgs,\n context,\n subset: {\n ...defaultArgs.subset,\n to: \"0x1234567890123456789012345678901234567890\",\n data: \"0xabcdef\",\n },\n };\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n\n expect(callbackResult).toEqual({\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy result\",\n });\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n proxyAddress: \"0x1234567890123456789012345678901234567890\",\n calldata: \"0xabcdef\",\n deviceModelId: DeviceModelId.STAX,\n challenge: \"test-challenge\",\n },\n ClearSignContextType.PROXY_INFO,\n );\n });\n\n it(\"should handle challenge command failure\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy payload\",\n };\n const args = {\n ...defaultArgs,\n context,\n subset: {\n ...defaultArgs.subset,\n to: \"0x1234567890123456789012345678901234567890\",\n data: \"0xabcdef\",\n },\n };\n const error = new UnknownDeviceExchangeError(\"Failed\");\n apiMock.sendCommand.mockResolvedValueOnce(\n CommandResultFactory({\n error,\n }),\n );\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n\n expect(callbackResult).toEqual({\n error: new Error(\"Failed to get challenge\"),\n type: ClearSignContextType.ERROR,\n });\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n expect(contextModuleMock.getFieldContext).not.toHaveBeenCalled();\n });\n\n it(\"should handle missing proxy address\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy payload\",\n };\n const args = {\n ...defaultArgs,\n context,\n subset: {\n ...defaultArgs.subset,\n to: undefined,\n data: \"0xabcdef\",\n },\n };\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n\n expect(callbackResult).toEqual({\n error: new Error(\"Failed to get proxy address\"),\n type: ClearSignContextType.ERROR,\n });\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n expect(contextModuleMock.getFieldContext).not.toHaveBeenCalled();\n });\n\n it(\"should use correct device model id in context\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy payload\",\n };\n const args = {\n ...defaultArgs,\n context,\n deviceModelId: DeviceModelId.NANO_SP,\n subset: {\n ...defaultArgs.subset,\n to: \"0x1234567890123456789012345678901234567890\",\n data: \"0xabcdef\",\n },\n };\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.PROXY_INFO,\n payload: \"proxy result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n await callback();\n\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n proxyAddress: \"0x1234567890123456789012345678901234567890\",\n calldata: \"0xabcdef\",\n deviceModelId: DeviceModelId.NANO_SP,\n challenge: \"test-challenge\",\n },\n ClearSignContextType.PROXY_INFO,\n );\n });\n });\n\n describe(\"edge cases\", () => {\n it(\"should handle value array shorter than 20 bytes for address extraction\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [new Uint8Array([0x01, 0x02, 0x03])]; // Only 3 bytes\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.ERROR,\n message: \"Invalid address\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.ERROR,\n message: \"Invalid address\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x010203\",\n },\n ClearSignContextType.TOKEN,\n );\n });\n\n it(\"should handle empty value array\", async () => {\n // GIVEN\n const context: ClearSignContextSuccess = {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: [{ type: \"TUPLE\", offset: 0 }],\n },\n };\n const args = { ...defaultArgs, context };\n const extractedValues = [new Uint8Array([])]; // Empty array\n transactionParserMock.extractValue.mockReturnValue(\n Right(extractedValues),\n );\n contextModuleMock.getFieldContext.mockResolvedValue({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n\n // WHEN\n const result = new BuildSubcontextsTask(apiMock, args).run();\n\n // THEN\n expect(result.subcontextCallbacks).toHaveLength(1);\n\n // Verify the callback calls getContext with empty address\n const callback = result.subcontextCallbacks[0]!;\n const callbackResult = await callback();\n expect(callbackResult).toEqual({\n type: ClearSignContextType.TOKEN,\n payload: \"token result\",\n });\n expect(contextModuleMock.getFieldContext).toHaveBeenCalledWith(\n {\n chainId: 1,\n address: \"0x\",\n },\n ClearSignContextType.TOKEN,\n );\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_device_management_kit", "import_purify_ts", "import_GetChallengeCommand", "import_makeInternalApi", "import_BuildSubcontextsTask", "contextModuleMock", "transactionParserMock", "apiMock", "defaultArgs", "simpleTypes", "type", "args", "result", "context", "expectedContext", "callback", "enumContext1", "enumContext2", "enumContext3", "extractedValues", "callbackResult", "callback1", "callback2", "callbackResult1", "callbackResult2", "enumContext", "error"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var l=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var g=Object.prototype.hasOwnProperty;var A=(a,e)=>{for(var r in e)l(a,r,{get:e[r],enumerable:!0})},I=(a,e,r,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of b(e))!g.call(a,s)&&s!==r&&l(a,s,{get:()=>e[s],enumerable:!(t=y(e,s))||t.enumerable});return a};var N=a=>I(l({},"__esModule",{value:!0}),a);var E={};A(E,{ParseNestedTransactionTask:()=>m});module.exports=N(E);var p=require("@ledgerhq/context-module"),c=require("@ledgerhq/device-management-kit");const P=10;class m{constructor(e){this._args=e}run(){const{parser:e,subset:r,context:t}=this._args,s=[];if(!t.reference||t.reference.type!==p.ClearSignContextReferenceType.CALLDATA||!t.reference.valuePath)throw new Error("Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.");const{valuePath:x}=t.reference,i=e.extractValue(r,x).unsafeCoerce(),u=e.extractValue(r,t.reference.callee).unsafeCoerce(),S=t.reference.selector?e.extractValue(r,t.reference.selector).orDefault([]):[],C=t.reference.chainId?e.extractValue(r,t.reference.chainId).orDefault([]):[];for(let n=0;n<i.length;n++){const o=i[n],T=C[n],d=u[n]?.slice(Math.max(0,u[n].length-20)),f=S[n],h={data:o?(0,c.bufferToHexaString)(o):"0x",chainId:T?Number(T):r.chainId,to:d?(0,c.bufferToHexaString)(d):r.to,selector:f?(0,c.bufferToHexaString)(f):o?(0,c.bufferToHexaString)(o).slice(0,P):"0x"};s.push(h)}return{subsets:s}}}0&&(module.exports={ParseNestedTransactionTask});
2
+ //# sourceMappingURL=ParseNestedTransactionTask.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ParseNestedTransactionTask.ts"],
4
+ "sourcesContent": ["import {\n ClearSignContextReferenceType,\n type ClearSignContextSuccess,\n type ClearSignContextType,\n type TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport { bufferToHexaString } from \"@ledgerhq/device-management-kit\";\n\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nconst DEFAULT_SELECTOR_LENGTH = 10;\n\nexport type ParseNestedTransactionTaskResult = {\n readonly subsets: TransactionSubset[];\n};\n\nexport type ParseNestedTransactionTaskArgs = {\n readonly parser: TransactionParserService;\n readonly subset: TransactionSubset;\n readonly context: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION>;\n};\n\n/**\n * This task is used to construct the nested call data subset list from the transaction subset.\n * It will extract values from the transaction subset using the value path.\n *\n */\nexport class ParseNestedTransactionTask {\n constructor(private readonly _args: ParseNestedTransactionTaskArgs) {}\n\n run(): ParseNestedTransactionTaskResult {\n const { parser, subset, context } = this._args;\n const nestedSubsets: TransactionSubset[] = [];\n\n if (\n !context.reference ||\n context.reference.type !== ClearSignContextReferenceType.CALLDATA ||\n !context.reference.valuePath\n ) {\n throw new Error(\n \"Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.\",\n );\n }\n\n const { valuePath } = context.reference;\n\n // values and callee are required\n const extractedValues = parser\n .extractValue(subset, valuePath)\n .unsafeCoerce();\n const extractedTo = parser\n .extractValue(subset, context.reference.callee)\n .unsafeCoerce();\n\n // selector and chainId are optional\n const extractedSelectors = context.reference.selector\n ? parser.extractValue(subset, context.reference.selector).orDefault([])\n : [];\n const extractedChainId = context.reference.chainId\n ? parser.extractValue(subset, context.reference.chainId).orDefault([])\n : [];\n\n for (let i = 0; i < extractedValues.length; i++) {\n const data = extractedValues[i];\n const chainId = extractedChainId[i];\n const to = extractedTo[i]?.slice(\n Math.max(0, extractedTo[i]!.length - 20),\n );\n const selector = extractedSelectors[i];\n\n const nestedSubset: TransactionSubset = {\n data: data ? bufferToHexaString(data) : \"0x\", // ASK: Should we use 0x or return an error?\n chainId: chainId ? Number(chainId) : subset.chainId,\n to: to ? bufferToHexaString(to) : subset.to,\n selector: selector\n ? bufferToHexaString(selector)\n : data\n ? bufferToHexaString(data).slice(0, DEFAULT_SELECTOR_LENGTH)\n : \"0x\",\n };\n\n nestedSubsets.push(nestedSubset);\n }\n\n return {\n subsets: nestedSubsets,\n };\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,gCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAKO,oCACPC,EAAmC,2CAInC,MAAMC,EAA0B,GAiBzB,MAAMJ,CAA2B,CACtC,YAA6BK,EAAuC,CAAvC,WAAAA,CAAwC,CAErE,KAAwC,CACtC,KAAM,CAAE,OAAAC,EAAQ,OAAAC,EAAQ,QAAAC,CAAQ,EAAI,KAAK,MACnCC,EAAqC,CAAC,EAE5C,GACE,CAACD,EAAQ,WACTA,EAAQ,UAAU,OAAS,gCAA8B,UACzD,CAACA,EAAQ,UAAU,UAEnB,MAAM,IAAI,MACR,mGACF,EAGF,KAAM,CAAE,UAAAE,CAAU,EAAIF,EAAQ,UAGxBG,EAAkBL,EACrB,aAAaC,EAAQG,CAAS,EAC9B,aAAa,EACVE,EAAcN,EACjB,aAAaC,EAAQC,EAAQ,UAAU,MAAM,EAC7C,aAAa,EAGVK,EAAqBL,EAAQ,UAAU,SACzCF,EAAO,aAAaC,EAAQC,EAAQ,UAAU,QAAQ,EAAE,UAAU,CAAC,CAAC,EACpE,CAAC,EACCM,EAAmBN,EAAQ,UAAU,QACvCF,EAAO,aAAaC,EAAQC,EAAQ,UAAU,OAAO,EAAE,UAAU,CAAC,CAAC,EACnE,CAAC,EAEL,QAASO,EAAI,EAAGA,EAAIJ,EAAgB,OAAQI,IAAK,CAC/C,MAAMC,EAAOL,EAAgBI,CAAC,EACxBE,EAAUH,EAAiBC,CAAC,EAC5BG,EAAKN,EAAYG,CAAC,GAAG,MACzB,KAAK,IAAI,EAAGH,EAAYG,CAAC,EAAG,OAAS,EAAE,CACzC,EACMI,EAAWN,EAAmBE,CAAC,EAE/BK,EAAkC,CACtC,KAAMJ,KAAO,sBAAmBA,CAAI,EAAI,KACxC,QAASC,EAAU,OAAOA,CAAO,EAAIV,EAAO,QAC5C,GAAIW,KAAK,sBAAmBA,CAAE,EAAIX,EAAO,GACzC,SAAUY,KACN,sBAAmBA,CAAQ,EAC3BH,KACE,sBAAmBA,CAAI,EAAE,MAAM,EAAGZ,CAAuB,EACzD,IACR,EAEAK,EAAc,KAAKW,CAAY,CACjC,CAEA,MAAO,CACL,QAASX,CACX,CACF,CACF",
6
+ "names": ["ParseNestedTransactionTask_exports", "__export", "ParseNestedTransactionTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "DEFAULT_SELECTOR_LENGTH", "_args", "parser", "subset", "context", "nestedSubsets", "valuePath", "extractedValues", "extractedTo", "extractedSelectors", "extractedChainId", "i", "data", "chainId", "to", "selector", "nestedSubset"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var e=require("@ledgerhq/context-module"),s=require("purify-ts"),c=require("./ParseNestedTransactionTask");describe("ParseNestedTransactionTask",()=>{const n={extractValue:vi.fn()},u={chainId:1,to:"0x1234567890123456789012345678901234567890",data:"0x060708090A",selector:"0x06070809",value:0n},t=[{type:e.DataPathElementType.TUPLE,offset:1},{type:e.DataPathElementType.TUPLE,offset:2},{type:e.DataPathElementType.LEAF,leafType:e.DataPathLeafType.STATIC_LEAF}],x={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,valuePath:t,selector:t,callee:t,amount:t}};let o;beforeEach(()=>{vi.resetAllMocks(),o={parser:n,subset:u,context:x}}),describe("run",()=>{describe("error cases",()=>{it("should throw error when context has no reference",()=>{const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload"},r={...o,context:a};expect(()=>new c.ParseNestedTransactionTask(r).run()).toThrow("Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.")}),it("should throw error when reference type is not CALLDATA",()=>{const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.TOKEN,valuePath:t}},r={...o,context:a};expect(()=>new c.ParseNestedTransactionTask(r).run()).toThrow("Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.")}),it("should throw error when reference has no valuePath",()=>{const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,valuePath:void 0,selector:void 0,callee:void 0,amount:void 0,spender:void 0,chainId:void 0}},r={...o,context:a};expect(()=>new c.ParseNestedTransactionTask(r).run()).toThrow("Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.")}),it("should throw error when parser returns error",()=>{n.extractValue.mockReturnValue((0,s.Left)(new Error("Parser error")));const a={...o};expect(()=>new c.ParseNestedTransactionTask(a).run()).toThrow("Parser error")})}),describe("success cases",()=>{it("should return new subset with extracted data when all fields are provided",()=>{n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([1,2,3,4])])),n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([2,3,4,5])])),n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([3,4,5,6])]));const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,valuePath:t,selector:t,callee:t,amount:t}},r={...o,context:a},l=new c.ParseNestedTransactionTask(r).run();expect(n.extractValue).toHaveBeenCalledWith(u,t),expect(l).toEqual({subsets:[{data:"0x01020304",chainId:1,selector:"0x03040506",to:"0x02030405"}]})}),it("should use data.slice(0, 10) as selector when selector is not provided",()=>{n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([1,2,3,4,5,6,7,8,9,10])])),n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([2,3,4,5])])),n.extractValue.mockReturnValueOnce((0,s.Left)(new Error("Parser error"))),n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([3,4,5,6])]));const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,valuePath:t,callee:t,amount:t}},r={...o,context:a},l=new c.ParseNestedTransactionTask(r).run();expect(l.subsets[0]).toEqual({data:"0x0102030405060708090a",chainId:1,selector:"0x01020304",to:"0x02030405"})}),it("should use defaults values when no value are returned from parser",()=>{n.extractValue.mockReturnValueOnce((0,s.Right)([new Uint8Array([1,2,3,4])])),n.extractValue.mockReturnValue((0,s.Right)([]));const a={type:e.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,payload:"test payload",reference:{type:e.ClearSignContextReferenceType.CALLDATA,valuePath:t,selector:t,callee:t,amount:t}},r={...o,context:a},l=new c.ParseNestedTransactionTask(r).run();expect(l.subsets[0]).toEqual({data:"0x01020304",chainId:1,selector:"0x01020304",to:"0x1234567890123456789012345678901234567890"})}),it("should preserve chainId from original subset",()=>{n.extractValue.mockReturnValue((0,s.Right)([new Uint8Array([1,2,3,4])]));const a={...u,chainId:137},r={...o,subset:a},l=new c.ParseNestedTransactionTask(r).run();expect(l.subsets[0]?.chainId).toBe(137)})})})});
2
+ //# sourceMappingURL=ParseNestedTransactionTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ParseNestedTransactionTask.test.ts"],
4
+ "sourcesContent": ["import {\n ClearSignContextReferenceType,\n type ClearSignContextSuccess,\n ClearSignContextType,\n type DataPathElement,\n DataPathElementType,\n DataPathLeafType,\n type GenericPath,\n type TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport {\n ParseNestedTransactionTask,\n type ParseNestedTransactionTaskArgs,\n} from \"./ParseNestedTransactionTask\";\n\ndescribe(\"ParseNestedTransactionTask\", () => {\n const transactionParserMock = {\n extractValue: vi.fn(),\n };\n\n const defaultSubset: TransactionSubset = {\n chainId: 1,\n to: \"0x1234567890123456789012345678901234567890\",\n data: \"0x060708090A\",\n selector: \"0x06070809\",\n value: 0n,\n };\n\n const mockValuePath: DataPathElement[] = [\n {\n type: DataPathElementType.TUPLE,\n offset: 1,\n },\n {\n type: DataPathElementType.TUPLE,\n offset: 2,\n },\n {\n type: DataPathElementType.LEAF,\n leafType: DataPathLeafType.STATIC_LEAF,\n },\n ];\n\n const defaultContext: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n valuePath: mockValuePath,\n selector: mockValuePath,\n callee: mockValuePath,\n amount: mockValuePath,\n },\n };\n\n let defaultArgs: ParseNestedTransactionTaskArgs;\n\n beforeEach(() => {\n vi.resetAllMocks();\n defaultArgs = {\n parser: transactionParserMock as unknown as TransactionParserService,\n subset: defaultSubset,\n context: defaultContext,\n };\n });\n\n describe(\"run\", () => {\n describe(\"error cases\", () => {\n it(\"should throw error when context has no reference\", () => {\n // GIVEN\n const contextWithoutReference: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n };\n const args = { ...defaultArgs, context: contextWithoutReference };\n\n // WHEN & THEN\n expect(() => new ParseNestedTransactionTask(args).run()).toThrow(\n \"Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.\",\n );\n });\n\n it(\"should throw error when reference type is not CALLDATA\", () => {\n // GIVEN\n const contextWithWrongType: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.TOKEN,\n valuePath: mockValuePath,\n },\n };\n const args = { ...defaultArgs, context: contextWithWrongType };\n\n // WHEN & THEN\n expect(() => new ParseNestedTransactionTask(args).run()).toThrow(\n \"Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.\",\n );\n });\n\n it(\"should throw error when reference has no valuePath\", () => {\n // GIVEN\n const contextWithoutValuePath: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n valuePath: undefined as unknown as GenericPath,\n selector: undefined as unknown as GenericPath,\n callee: undefined as unknown as GenericPath,\n amount: undefined as unknown as GenericPath,\n spender: undefined as unknown as GenericPath,\n chainId: undefined as unknown as GenericPath,\n },\n };\n const args = { ...defaultArgs, context: contextWithoutValuePath };\n\n // WHEN & THEN\n expect(() => new ParseNestedTransactionTask(args).run()).toThrow(\n \"Invalid reference for nested call data. Expected a reference with type CALLDATA and a value path.\",\n );\n });\n\n it(\"should throw error when parser returns error\", () => {\n // GIVEN\n transactionParserMock.extractValue.mockReturnValue(\n Left(new Error(\"Parser error\")),\n );\n const args = { ...defaultArgs };\n\n // WHEN & THEN\n expect(() => new ParseNestedTransactionTask(args).run()).toThrow(\n \"Parser error\",\n );\n });\n });\n\n describe(\"success cases\", () => {\n it(\"should return new subset with extracted data when all fields are provided\", () => {\n // GIVEN\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x01, 0x02, 0x03, 0x04])]),\n );\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x02, 0x03, 0x04, 0x05])]),\n );\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x03, 0x04, 0x05, 0x06])]),\n );\n\n const context: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n valuePath: mockValuePath,\n selector: mockValuePath,\n callee: mockValuePath,\n amount: mockValuePath,\n },\n };\n\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new ParseNestedTransactionTask(args).run();\n\n // THEN\n expect(transactionParserMock.extractValue).toHaveBeenCalledWith(\n defaultSubset,\n mockValuePath,\n );\n expect(result).toEqual({\n subsets: [\n {\n data: \"0x01020304\",\n chainId: 1,\n selector: \"0x03040506\",\n to: \"0x02030405\",\n },\n ],\n });\n });\n\n it(\"should use data.slice(0, 10) as selector when selector is not provided\", () => {\n // GIVEN\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([\n new Uint8Array([\n 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a,\n ]),\n ]),\n );\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x02, 0x03, 0x04, 0x05])]),\n );\n transactionParserMock.extractValue.mockReturnValueOnce(\n Left(new Error(\"Parser error\")),\n );\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x03, 0x04, 0x05, 0x06])]),\n );\n\n const context: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n valuePath: mockValuePath,\n callee: mockValuePath,\n amount: mockValuePath,\n },\n };\n\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new ParseNestedTransactionTask(args).run();\n\n // THEN\n expect(result.subsets[0]).toEqual({\n data: \"0x0102030405060708090a\",\n chainId: 1,\n selector: \"0x01020304\",\n to: \"0x02030405\",\n });\n });\n\n it(\"should use defaults values when no value are returned from parser\", () => {\n // GIVEN\n transactionParserMock.extractValue.mockReturnValueOnce(\n Right([new Uint8Array([0x01, 0x02, 0x03, 0x04])]),\n );\n transactionParserMock.extractValue.mockReturnValue(Right([]));\n\n const context: ClearSignContextSuccess<ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION> =\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"test payload\",\n reference: {\n type: ClearSignContextReferenceType.CALLDATA,\n valuePath: mockValuePath,\n selector: mockValuePath,\n callee: mockValuePath,\n amount: mockValuePath,\n },\n };\n\n const args = { ...defaultArgs, context };\n\n // WHEN\n const result = new ParseNestedTransactionTask(args).run();\n\n // THEN\n expect(result.subsets[0]).toEqual({\n data: \"0x01020304\",\n chainId: 1,\n selector: \"0x01020304\",\n to: \"0x1234567890123456789012345678901234567890\",\n });\n });\n\n it(\"should preserve chainId from original subset\", () => {\n // GIVEN\n transactionParserMock.extractValue.mockReturnValue(\n Right([new Uint8Array([0x01, 0x02, 0x03, 0x04])]),\n );\n\n const subsetWithDifferentChainId: TransactionSubset = {\n ...defaultSubset,\n chainId: 137, // Polygon\n };\n\n const args = { ...defaultArgs, subset: subsetWithDifferentChainId };\n\n // WHEN\n const result = new ParseNestedTransactionTask(args).run();\n\n // THEN\n expect(result.subsets[0]?.chainId).toBe(137);\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["import_context_module", "import_purify_ts", "import_ParseNestedTransactionTask", "transactionParserMock", "defaultSubset", "mockValuePath", "defaultContext", "defaultArgs", "contextWithoutReference", "args", "contextWithWrongType", "contextWithoutValuePath", "context", "result", "subsetWithDifferentChainId"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var n=Object.defineProperty;var o=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var i=(r,a)=>{for(var t in a)n(r,t,{get:a[t],enumerable:!0})},T=(r,a,t,e)=>{if(a&&typeof a=="object"||typeof a=="function")for(let s of p(a))!c.call(r,s)&&s!==t&&n(r,s,{get:()=>a[s],enumerable:!(e=o(a,s))||e.enumerable});return r};var y=r=>T(n({},"__esModule",{value:!0}),r);var m={};i(m,{ParseTransactionTask:()=>u});module.exports=y(m);class u{constructor(a){this._args=a}run(){const{mapper:a,transaction:t}=this._args,{subset:e,type:s}=a.mapTransactionToSubset(t).unsafeCoerce();return{subset:e,type:s}}}0&&(module.exports={ParseTransactionTask});
2
+ //# sourceMappingURL=ParseTransactionTask.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ParseTransactionTask.ts"],
4
+ "sourcesContent": ["import { type TransactionSubset } from \"@ledgerhq/context-module\";\n\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nexport type ParseTransactionTaskResult = {\n readonly subset: TransactionSubset;\n readonly type: TransactionType;\n};\n\nexport type ParseTransactionTaskArgs = {\n readonly mapper: TransactionMapperService;\n readonly transaction: Uint8Array;\n};\n\nexport class ParseTransactionTask {\n constructor(private readonly _args: ParseTransactionTaskArgs) {}\n\n run(): ParseTransactionTaskResult {\n const { mapper, transaction } = this._args;\n\n const { subset, type } = mapper\n .mapTransactionToSubset(transaction)\n .unsafeCoerce();\n return { subset, type };\n }\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,0BAAAE,IAAA,eAAAC,EAAAH,GAeO,MAAME,CAAqB,CAChC,YAA6BE,EAAiC,CAAjC,WAAAA,CAAkC,CAE/D,KAAkC,CAChC,KAAM,CAAE,OAAAC,EAAQ,YAAAC,CAAY,EAAI,KAAK,MAE/B,CAAE,OAAAC,EAAQ,KAAAC,CAAK,EAAIH,EACtB,uBAAuBC,CAAW,EAClC,aAAa,EAChB,MAAO,CAAE,OAAAC,EAAQ,KAAAC,CAAK,CACxB,CACF",
6
+ "names": ["ParseTransactionTask_exports", "__export", "ParseTransactionTask", "__toCommonJS", "_args", "mapper", "transaction", "subset", "type"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var r=require("purify-ts"),a=require("./ParseTransactionTask");describe("ParseTransactionTask",()=>{const t={mapTransactionToSubset:vi.fn()};let s,c,n;beforeEach(()=>{vi.resetAllMocks(),c=new Uint8Array([1,2,3,4]),n={subset:{chainId:1,to:"0x1234567890123456789012345678901234567890",data:"0x1234567890",selector:"0x12345678",value:1000n},serializedTransaction:new Uint8Array([5,6,7,8]),type:2},s={mapper:t,transaction:c}}),describe("run",()=>{it("should successfully parse transaction and return subset and type",()=>{t.mapTransactionToSubset.mockReturnValue((0,r.Right)(n));const e=new a.ParseTransactionTask(s).run();expect(t.mapTransactionToSubset).toHaveBeenCalledWith(c),expect(e).toEqual({subset:n.subset,type:n.type})}),it("should pass through the transaction data to the mapper",()=>{const e=new Uint8Array([10,11,12,13,14]),o={...s,transaction:e};t.mapTransactionToSubset.mockReturnValue((0,r.Right)(n)),new a.ParseTransactionTask(o).run(),expect(t.mapTransactionToSubset).toHaveBeenCalledWith(e)}),it("should return correct subset structure",()=>{const e={chainId:42,to:"0xabcdefabcdefabcdefabcdefabcdefabcdefabcd",data:"0xdeadbeef",selector:"0xdeadbeef",value:2000n,from:"0x9876543210987654321098765432109876543210"},o={...n,subset:e,type:1};t.mapTransactionToSubset.mockReturnValue((0,r.Right)(o));const u=new a.ParseTransactionTask(s).run();expect(u.subset).toEqual(e),expect(u.type).toEqual(1)}),it("should throw when mapper returns Left (error)",()=>{const e=new Error("Invalid transaction format");t.mapTransactionToSubset.mockReturnValue((0,r.Left)(e)),expect(()=>new a.ParseTransactionTask(s).run()).toThrow()}),it("should throw when mapper returns Left with specific error message",()=>{const e=new Error("Pre-EIP-155 transactions are not supported");t.mapTransactionToSubset.mockReturnValue((0,r.Left)(e)),expect(()=>new a.ParseTransactionTask(s).run()).toThrow()})}),describe("constructor",()=>{it("should store args correctly",()=>{const e=new a.ParseTransactionTask(s);expect(e).toBeInstanceOf(a.ParseTransactionTask),t.mapTransactionToSubset.mockReturnValue((0,r.Right)(n));const o=e.run();expect(o).toBeDefined()})})});
2
+ //# sourceMappingURL=ParseTransactionTask.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/internal/app-binder/task/ParseTransactionTask.test.ts"],
4
+ "sourcesContent": ["import { type TransactionSubset } from \"@ledgerhq/context-module\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport { type TransactionMapperResult } from \"@internal/transaction/service/mapper/model/TransactionMapperResult\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nimport {\n ParseTransactionTask,\n type ParseTransactionTaskArgs,\n} from \"./ParseTransactionTask\";\n\ndescribe(\"ParseTransactionTask\", () => {\n const mockMapper = {\n mapTransactionToSubset: vi.fn(),\n };\n\n let defaultArgs: ParseTransactionTaskArgs;\n let mockTransaction: Uint8Array;\n let mockMapperResult: TransactionMapperResult;\n\n beforeEach(() => {\n vi.resetAllMocks();\n\n mockTransaction = new Uint8Array([0x01, 0x02, 0x03, 0x04]);\n\n mockMapperResult = {\n subset: {\n chainId: 1,\n to: \"0x1234567890123456789012345678901234567890\",\n data: \"0x1234567890\",\n selector: \"0x12345678\",\n value: 1000n,\n },\n serializedTransaction: new Uint8Array([0x05, 0x06, 0x07, 0x08]),\n type: 2 as TransactionType,\n };\n\n defaultArgs = {\n mapper: mockMapper as unknown as TransactionMapperService,\n transaction: mockTransaction,\n };\n });\n\n describe(\"run\", () => {\n it(\"should successfully parse transaction and return subset and type\", () => {\n // GIVEN\n mockMapper.mapTransactionToSubset.mockReturnValue(\n Right(mockMapperResult),\n );\n\n // WHEN\n const result = new ParseTransactionTask(defaultArgs).run();\n\n // THEN\n expect(mockMapper.mapTransactionToSubset).toHaveBeenCalledWith(\n mockTransaction,\n );\n expect(result).toEqual({\n subset: mockMapperResult.subset,\n type: mockMapperResult.type,\n });\n });\n\n it(\"should pass through the transaction data to the mapper\", () => {\n // GIVEN\n const customTransaction = new Uint8Array([0x0a, 0x0b, 0x0c, 0x0d, 0x0e]);\n const customArgs = {\n ...defaultArgs,\n transaction: customTransaction,\n };\n mockMapper.mapTransactionToSubset.mockReturnValue(\n Right(mockMapperResult),\n );\n\n // WHEN\n new ParseTransactionTask(customArgs).run();\n\n // THEN\n expect(mockMapper.mapTransactionToSubset).toHaveBeenCalledWith(\n customTransaction,\n );\n });\n\n it(\"should return correct subset structure\", () => {\n // GIVEN\n const customSubset: TransactionSubset = {\n chainId: 42,\n to: \"0xabcdefabcdefabcdefabcdefabcdefabcdefabcd\",\n data: \"0xdeadbeef\",\n selector: \"0xdeadbeef\",\n value: 2000n,\n from: \"0x9876543210987654321098765432109876543210\",\n };\n const customMapperResult: TransactionMapperResult = {\n ...mockMapperResult,\n subset: customSubset,\n type: 1 as TransactionType,\n };\n mockMapper.mapTransactionToSubset.mockReturnValue(\n Right(customMapperResult),\n );\n\n // WHEN\n const result = new ParseTransactionTask(defaultArgs).run();\n\n // THEN\n expect(result.subset).toEqual(customSubset);\n expect(result.type).toEqual(1);\n });\n\n it(\"should throw when mapper returns Left (error)\", () => {\n // GIVEN\n const mappingError = new Error(\"Invalid transaction format\");\n mockMapper.mapTransactionToSubset.mockReturnValue(Left(mappingError));\n\n // WHEN / THEN\n expect(() => new ParseTransactionTask(defaultArgs).run()).toThrow();\n });\n\n it(\"should throw when mapper returns Left with specific error message\", () => {\n // GIVEN\n const specificError = new Error(\n \"Pre-EIP-155 transactions are not supported\",\n );\n mockMapper.mapTransactionToSubset.mockReturnValue(Left(specificError));\n\n // WHEN / THEN\n expect(() => new ParseTransactionTask(defaultArgs).run()).toThrow();\n });\n });\n\n describe(\"constructor\", () => {\n it(\"should store args correctly\", () => {\n // GIVEN / WHEN\n const task = new ParseTransactionTask(defaultArgs);\n\n // THEN\n expect(task).toBeInstanceOf(ParseTransactionTask);\n // We can't directly test private properties, but we can verify behavior\n mockMapper.mapTransactionToSubset.mockReturnValue(\n Right(mockMapperResult),\n );\n const result = task.run();\n expect(result).toBeDefined();\n });\n });\n});\n"],
5
+ "mappings": "aACA,IAAAA,EAA4B,qBAM5BC,EAGO,kCAEP,SAAS,uBAAwB,IAAM,CACrC,MAAMC,EAAa,CACjB,uBAAwB,GAAG,GAAG,CAChC,EAEA,IAAIC,EACAC,EACAC,EAEJ,WAAW,IAAM,CACf,GAAG,cAAc,EAEjBD,EAAkB,IAAI,WAAW,CAAC,EAAM,EAAM,EAAM,CAAI,CAAC,EAEzDC,EAAmB,CACjB,OAAQ,CACN,QAAS,EACT,GAAI,6CACJ,KAAM,eACN,SAAU,aACV,MAAO,KACT,EACA,sBAAuB,IAAI,WAAW,CAAC,EAAM,EAAM,EAAM,CAAI,CAAC,EAC9D,KAAM,CACR,EAEAF,EAAc,CACZ,OAAQD,EACR,YAAaE,CACf,CACF,CAAC,EAED,SAAS,MAAO,IAAM,CACpB,GAAG,mEAAoE,IAAM,CAE3EF,EAAW,uBAAuB,mBAChC,SAAMG,CAAgB,CACxB,EAGA,MAAMC,EAAS,IAAI,uBAAqBH,CAAW,EAAE,IAAI,EAGzD,OAAOD,EAAW,sBAAsB,EAAE,qBACxCE,CACF,EACA,OAAOE,CAAM,EAAE,QAAQ,CACrB,OAAQD,EAAiB,OACzB,KAAMA,EAAiB,IACzB,CAAC,CACH,CAAC,EAED,GAAG,yDAA0D,IAAM,CAEjE,MAAME,EAAoB,IAAI,WAAW,CAAC,GAAM,GAAM,GAAM,GAAM,EAAI,CAAC,EACjEC,EAAa,CACjB,GAAGL,EACH,YAAaI,CACf,EACAL,EAAW,uBAAuB,mBAChC,SAAMG,CAAgB,CACxB,EAGA,IAAI,uBAAqBG,CAAU,EAAE,IAAI,EAGzC,OAAON,EAAW,sBAAsB,EAAE,qBACxCK,CACF,CACF,CAAC,EAED,GAAG,yCAA0C,IAAM,CAEjD,MAAME,EAAkC,CACtC,QAAS,GACT,GAAI,6CACJ,KAAM,aACN,SAAU,aACV,MAAO,MACP,KAAM,4CACR,EACMC,EAA8C,CAClD,GAAGL,EACH,OAAQI,EACR,KAAM,CACR,EACAP,EAAW,uBAAuB,mBAChC,SAAMQ,CAAkB,CAC1B,EAGA,MAAMJ,EAAS,IAAI,uBAAqBH,CAAW,EAAE,IAAI,EAGzD,OAAOG,EAAO,MAAM,EAAE,QAAQG,CAAY,EAC1C,OAAOH,EAAO,IAAI,EAAE,QAAQ,CAAC,CAC/B,CAAC,EAED,GAAG,gDAAiD,IAAM,CAExD,MAAMK,EAAe,IAAI,MAAM,4BAA4B,EAC3DT,EAAW,uBAAuB,mBAAgB,QAAKS,CAAY,CAAC,EAGpE,OAAO,IAAM,IAAI,uBAAqBR,CAAW,EAAE,IAAI,CAAC,EAAE,QAAQ,CACpE,CAAC,EAED,GAAG,oEAAqE,IAAM,CAE5E,MAAMS,EAAgB,IAAI,MACxB,4CACF,EACAV,EAAW,uBAAuB,mBAAgB,QAAKU,CAAa,CAAC,EAGrE,OAAO,IAAM,IAAI,uBAAqBT,CAAW,EAAE,IAAI,CAAC,EAAE,QAAQ,CACpE,CAAC,CACH,CAAC,EAED,SAAS,cAAe,IAAM,CAC5B,GAAG,8BAA+B,IAAM,CAEtC,MAAMU,EAAO,IAAI,uBAAqBV,CAAW,EAGjD,OAAOU,CAAI,EAAE,eAAe,sBAAoB,EAEhDX,EAAW,uBAAuB,mBAChC,SAAMG,CAAgB,CACxB,EACA,MAAMC,EAASO,EAAK,IAAI,EACxB,OAAOP,CAAM,EAAE,YAAY,CAC7B,CAAC,CACH,CAAC,CACH,CAAC",
6
+ "names": ["import_purify_ts", "import_ParseTransactionTask", "mockMapper", "defaultArgs", "mockTransaction", "mockMapperResult", "result", "customTransaction", "customArgs", "customSubset", "customMapperResult", "mappingError", "specificError", "task"]
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var u=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var f=Object.getOwnPropertyNames;var w=Object.prototype.hasOwnProperty;var N=(e,o)=>{for(var n in o)u(e,n,{get:o[n],enumerable:!0})},E=(e,o,n,r)=>{if(o&&typeof o=="object"||typeof o=="function")for(let a of f(o))!w.call(e,a)&&a!==n&&u(e,a,{get:()=>o[a],enumerable:!(r=l(o,a))||r.enumerable});return e};var v=e=>E(u({},"__esModule",{value:!0}),e);var R={};N(R,{ProvideContextTask:()=>S});module.exports=v(R);var t=require("@ledgerhq/context-module"),d=require("@ledgerhq/device-management-kit"),c=require("../../app-binder/command/ProvideEnumCommand"),i=require("../../app-binder/command/ProvideNetworkConfigurationCommand"),C=require("../../app-binder/command/ProvideNFTInformationCommand"),h=require("../../app-binder/command/ProvideProxyInfoCommand"),s=require("../../app-binder/command/ProvideSafeAccountCommand"),k=require("../../app-binder/command/ProvideTokenInformationCommand"),p=require("../../app-binder/command/ProvideTransactionFieldDescriptionCommand"),y=require("../../app-binder/command/ProvideTransactionInformationCommand"),F=require("../../app-binder/command/ProvideTrustedNameCommand"),T=require("../../app-binder/command/ProvideWeb3CheckCommand"),I=require("../../app-binder/command/SetExternalPluginCommand"),P=require("../../app-binder/command/SetPluginCommand"),_=require("./SendPayloadInChunksTask");class S{constructor(o,n,r=(a,m)=>new _.SendPayloadInChunksTask(a,m)){this._api=o;this._args=n;this._sendPayloadInChunksTaskFactory=r}async run(){const{type:o,payload:n,certificate:r}=this._args.context;switch(r&&await this._api.sendCommand(new d.LoadCertificateCommand({keyUsage:r.keyUsageNumber,certificate:r.payload})),o){case t.ClearSignContextType.PLUGIN:return await this._api.sendCommand(new P.SetPluginCommand({payload:n}));case t.ClearSignContextType.EXTERNAL_PLUGIN:return await this._api.sendCommand(new I.SetExternalPluginCommand({payload:n}));case t.ClearSignContextType.NFT:return await this._api.sendCommand(new C.ProvideNFTInformationCommand({payload:n}));case t.ClearSignContextType.TOKEN:return await this._api.sendCommand(new k.ProvideTokenInformationCommand({payload:n}));case t.ClearSignContextType.TRANSACTION_INFO:return await this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:m=>new y.ProvideTransactionInformationCommand({data:m.chunkedData,isFirstChunk:m.isFirstChunk})}).run();case t.ClearSignContextType.TRUSTED_NAME:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new F.ProvideTrustedNameCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case t.ClearSignContextType.ENUM:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new c.ProvideEnumCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case t.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new p.ProvideTransactionFieldDescriptionCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case t.ClearSignContextType.WEB3_CHECK:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new T.ProvideWeb3CheckCommand({payload:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case t.ClearSignContextType.PROXY_INFO:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new h.ProvideProxyInfoCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case t.ClearSignContextType.DYNAMIC_NETWORK:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new i.ProvideNetworkConfigurationCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk,configurationType:i.NetworkConfigurationType.CONFIGURATION})}).run();case t.ClearSignContextType.DYNAMIC_NETWORK_ICON:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new i.ProvideNetworkConfigurationCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk,configurationType:i.NetworkConfigurationType.ICON}),withPayloadLength:!1}).run();case t.ClearSignContextType.SAFE:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new s.ProvideSafeAccountCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk,type:s.ProvideSafeAccountCommandType.SAFE_DESCRIPTOR})}).run();case t.ClearSignContextType.SIGNER:return this._sendPayloadInChunksTaskFactory(this._api,{payload:n,commandFactory:a=>new s.ProvideSafeAccountCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk,type:s.ProvideSafeAccountCommandType.SIGNER_DESCRIPTOR})}).run();default:{const a=o;return(0,d.CommandResultFactory)({error:new d.InvalidStatusWordError(`The context type [${a}] is not covered`)})}}}}0&&(module.exports={ProvideContextTask});
2
+ //# sourceMappingURL=ProvideContextTask.js.map