@ledgerhq/device-signer-kit-solana 0.0.0-transactionInspector-resolutionObj-20250916153045 → 0.0.0-trusted-names-native-transfer-1-20260121120757

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 (259) hide show
  1. package/README.md +113 -24
  2. package/lib/cjs/api/SignerSolana.js +1 -1
  3. package/lib/cjs/api/SignerSolana.js.map +1 -1
  4. package/lib/cjs/api/SignerSolanaBuilder.js +1 -1
  5. package/lib/cjs/api/SignerSolanaBuilder.js.map +3 -3
  6. package/lib/cjs/api/SolanaTools.js +1 -1
  7. package/lib/cjs/api/SolanaTools.js.map +1 -1
  8. package/lib/cjs/api/app-binder/SignMessageDeviceActionTypes.js.map +1 -1
  9. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
  10. package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +3 -3
  11. package/lib/cjs/api/index.js +1 -1
  12. package/lib/cjs/api/index.js.map +2 -2
  13. package/lib/cjs/api/model/SolanaTransactionOptionalConfig.js +2 -0
  14. package/lib/cjs/api/model/SolanaTransactionOptionalConfig.js.map +7 -0
  15. package/lib/cjs/api/model/TransactionResolutionContext.js +1 -1
  16. package/lib/cjs/api/model/TransactionResolutionContext.js.map +3 -3
  17. package/lib/cjs/internal/DefaultSignerSolana.js +1 -1
  18. package/lib/cjs/internal/DefaultSignerSolana.js.map +3 -3
  19. package/lib/cjs/internal/app-binder/SolanaAppBinder.js +1 -1
  20. package/lib/cjs/internal/app-binder/SolanaAppBinder.js.map +3 -3
  21. package/lib/cjs/internal/app-binder/SolanaAppBinder.test.js +1 -1
  22. package/lib/cjs/internal/app-binder/SolanaAppBinder.test.js.map +3 -3
  23. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
  24. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
  25. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
  26. package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
  27. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +1 -1
  28. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  29. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  30. package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  31. package/lib/cjs/internal/app-binder/command/GetPubKeyCommand.js +1 -1
  32. package/lib/cjs/internal/app-binder/command/GetPubKeyCommand.js.map +3 -3
  33. package/lib/cjs/internal/app-binder/command/GetPubKeyCommand.test.js +1 -1
  34. package/lib/cjs/internal/app-binder/command/GetPubKeyCommand.test.js.map +2 -2
  35. package/lib/cjs/internal/app-binder/command/ProvideTLVDescriptorCommand.js +1 -1
  36. package/lib/cjs/internal/app-binder/command/ProvideTLVDescriptorCommand.js.map +2 -2
  37. package/lib/cjs/internal/app-binder/command/ProvideTLVDescriptorCommand.test.js +1 -1
  38. package/lib/cjs/internal/app-binder/command/ProvideTLVDescriptorCommand.test.js.map +2 -2
  39. package/lib/cjs/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.js +2 -0
  40. package/lib/cjs/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.js.map +7 -0
  41. package/lib/cjs/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.js +2 -0
  42. package/lib/cjs/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.js.map +7 -0
  43. package/lib/cjs/internal/app-binder/command/SignOffChainMessageCommand.js +1 -1
  44. package/lib/cjs/internal/app-binder/command/SignOffChainMessageCommand.js.map +3 -3
  45. package/lib/cjs/internal/app-binder/command/SignOffChainMessageCommand.test.js +1 -1
  46. package/lib/cjs/internal/app-binder/command/SignOffChainMessageCommand.test.js.map +3 -3
  47. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +1 -1
  48. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +3 -3
  49. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  50. package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  51. package/lib/cjs/internal/app-binder/device-action/SignTransactionDeviceAction.js +1 -1
  52. package/lib/cjs/internal/app-binder/device-action/SignTransactionDeviceAction.js.map +3 -3
  53. package/lib/cjs/internal/app-binder/device-action/SignTransactionDeviceAction.test.js +1 -1
  54. package/lib/cjs/internal/app-binder/device-action/SignTransactionDeviceAction.test.js.map +3 -3
  55. package/lib/cjs/internal/app-binder/services/GenerateSolanaTransaction.test.js.map +3 -3
  56. package/lib/cjs/internal/app-binder/services/TransactionInspector.js +1 -1
  57. package/lib/cjs/internal/app-binder/services/TransactionInspector.js.map +3 -3
  58. package/lib/cjs/internal/app-binder/services/TransactionInspector.test.js +2 -0
  59. package/lib/cjs/internal/app-binder/services/TransactionInspector.test.js.map +7 -0
  60. package/lib/cjs/internal/app-binder/services/bs58Encoder.js +2 -0
  61. package/lib/cjs/internal/app-binder/services/bs58Encoder.js.map +7 -0
  62. package/lib/cjs/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.js +2 -0
  63. package/lib/cjs/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.js.map +7 -0
  64. package/lib/cjs/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.js +2 -0
  65. package/lib/cjs/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.js.map +7 -0
  66. package/lib/cjs/internal/app-binder/services/utils/NullLoggerPublisherService.js +2 -0
  67. package/lib/cjs/internal/app-binder/services/utils/NullLoggerPublisherService.js.map +7 -0
  68. package/lib/cjs/internal/app-binder/services/utils/NullLoggerPublisherService.test.js +2 -0
  69. package/lib/cjs/internal/app-binder/services/utils/NullLoggerPublisherService.test.js.map +7 -0
  70. package/lib/cjs/internal/app-binder/services/utils/transactionDecoders.js +1 -1
  71. package/lib/cjs/internal/app-binder/services/utils/transactionDecoders.js.map +3 -3
  72. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +1 -1
  73. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +3 -3
  74. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +1 -1
  75. package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +3 -3
  76. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +1 -1
  77. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +3 -3
  78. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +1 -1
  79. package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +3 -3
  80. package/lib/cjs/internal/app-binder/task/SendSignMessageTask.js +1 -1
  81. package/lib/cjs/internal/app-binder/task/SendSignMessageTask.js.map +3 -3
  82. package/lib/cjs/internal/app-binder/task/SendSignMessageTask.test.js +3 -1
  83. package/lib/cjs/internal/app-binder/task/SendSignMessageTask.test.js.map +3 -3
  84. package/lib/cjs/internal/di.js +1 -1
  85. package/lib/cjs/internal/di.js.map +3 -3
  86. package/lib/cjs/internal/externalTypes.js +1 -1
  87. package/lib/cjs/internal/externalTypes.js.map +2 -2
  88. package/lib/cjs/internal/use-cases/transaction/SignTransactionUseCase.js +1 -1
  89. package/lib/cjs/internal/use-cases/transaction/SignTransactionUseCase.js.map +3 -3
  90. package/lib/cjs/internal/use-cases/transaction/SignTransactionUseCase.test.js +1 -1
  91. package/lib/cjs/internal/use-cases/transaction/SignTransactionUseCase.test.js.map +2 -2
  92. package/lib/cjs/package.json +40 -36
  93. package/lib/esm/api/SignerSolanaBuilder.js +1 -1
  94. package/lib/esm/api/SignerSolanaBuilder.js.map +3 -3
  95. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -0
  96. package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +4 -4
  97. package/lib/esm/api/index.js +1 -1
  98. package/lib/esm/api/index.js.map +2 -2
  99. package/lib/esm/api/model/SolanaTransactionOptionalConfig.js +1 -0
  100. package/lib/esm/api/model/TransactionResolutionContext.js +1 -0
  101. package/lib/esm/api/model/TransactionResolutionContext.js.map +4 -4
  102. package/lib/esm/internal/DefaultSignerSolana.js.map +3 -3
  103. package/lib/esm/internal/app-binder/SolanaAppBinder.js +1 -1
  104. package/lib/esm/internal/app-binder/SolanaAppBinder.js.map +3 -3
  105. package/lib/esm/internal/app-binder/SolanaAppBinder.test.js +1 -1
  106. package/lib/esm/internal/app-binder/SolanaAppBinder.test.js.map +3 -3
  107. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
  108. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
  109. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
  110. package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
  111. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +1 -1
  112. package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
  113. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
  114. package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
  115. package/lib/esm/internal/app-binder/command/GetPubKeyCommand.js +1 -1
  116. package/lib/esm/internal/app-binder/command/GetPubKeyCommand.js.map +3 -3
  117. package/lib/esm/internal/app-binder/command/GetPubKeyCommand.test.js +1 -1
  118. package/lib/esm/internal/app-binder/command/GetPubKeyCommand.test.js.map +2 -2
  119. package/lib/esm/internal/app-binder/command/ProvideTLVDescriptorCommand.js +1 -1
  120. package/lib/esm/internal/app-binder/command/ProvideTLVDescriptorCommand.js.map +2 -2
  121. package/lib/esm/internal/app-binder/command/ProvideTLVDescriptorCommand.test.js +1 -1
  122. package/lib/esm/internal/app-binder/command/ProvideTLVDescriptorCommand.test.js.map +2 -2
  123. package/lib/esm/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.js +2 -0
  124. package/lib/esm/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.js.map +7 -0
  125. package/lib/esm/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.js +2 -0
  126. package/lib/esm/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.js.map +7 -0
  127. package/lib/esm/internal/app-binder/command/SignOffChainMessageCommand.js +1 -1
  128. package/lib/esm/internal/app-binder/command/SignOffChainMessageCommand.js.map +3 -3
  129. package/lib/esm/internal/app-binder/command/SignOffChainMessageCommand.test.js +1 -1
  130. package/lib/esm/internal/app-binder/command/SignOffChainMessageCommand.test.js.map +3 -3
  131. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +1 -1
  132. package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +3 -3
  133. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
  134. package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
  135. package/lib/esm/internal/app-binder/device-action/SignTransactionDeviceAction.js +1 -1
  136. package/lib/esm/internal/app-binder/device-action/SignTransactionDeviceAction.js.map +3 -3
  137. package/lib/esm/internal/app-binder/device-action/SignTransactionDeviceAction.test.js +1 -1
  138. package/lib/esm/internal/app-binder/device-action/SignTransactionDeviceAction.test.js.map +3 -3
  139. package/lib/esm/internal/app-binder/services/GenerateSolanaTransaction.test.js.map +3 -3
  140. package/lib/esm/internal/app-binder/services/TransactionInspector.js +1 -1
  141. package/lib/esm/internal/app-binder/services/TransactionInspector.js.map +3 -3
  142. package/lib/esm/internal/app-binder/services/TransactionInspector.test.js +2 -0
  143. package/lib/esm/internal/app-binder/services/TransactionInspector.test.js.map +7 -0
  144. package/lib/esm/internal/app-binder/services/bs58Encoder.js +2 -0
  145. package/lib/esm/internal/app-binder/services/bs58Encoder.js.map +7 -0
  146. package/lib/esm/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.js +2 -0
  147. package/lib/esm/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.js.map +7 -0
  148. package/lib/esm/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.js +2 -0
  149. package/lib/esm/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.js.map +7 -0
  150. package/lib/esm/internal/app-binder/services/utils/NullLoggerPublisherService.js +2 -0
  151. package/lib/esm/internal/app-binder/services/utils/NullLoggerPublisherService.js.map +7 -0
  152. package/lib/esm/internal/app-binder/services/utils/NullLoggerPublisherService.test.js +2 -0
  153. package/lib/esm/internal/app-binder/services/utils/NullLoggerPublisherService.test.js.map +7 -0
  154. package/lib/esm/internal/app-binder/services/utils/transactionDecoders.js +1 -1
  155. package/lib/esm/internal/app-binder/services/utils/transactionDecoders.js.map +3 -3
  156. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +1 -1
  157. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +3 -3
  158. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +1 -1
  159. package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +3 -3
  160. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +1 -1
  161. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +3 -3
  162. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +1 -1
  163. package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +3 -3
  164. package/lib/esm/internal/app-binder/task/SendSignMessageTask.js +1 -1
  165. package/lib/esm/internal/app-binder/task/SendSignMessageTask.js.map +3 -3
  166. package/lib/esm/internal/app-binder/task/SendSignMessageTask.test.js +3 -1
  167. package/lib/esm/internal/app-binder/task/SendSignMessageTask.test.js.map +3 -3
  168. package/lib/esm/internal/di.js +1 -1
  169. package/lib/esm/internal/di.js.map +3 -3
  170. package/lib/esm/internal/externalTypes.js +1 -1
  171. package/lib/esm/internal/externalTypes.js.map +2 -2
  172. package/lib/esm/internal/use-cases/transaction/SignTransactionUseCase.js +1 -1
  173. package/lib/esm/internal/use-cases/transaction/SignTransactionUseCase.js.map +3 -3
  174. package/lib/esm/internal/use-cases/transaction/SignTransactionUseCase.test.js +1 -1
  175. package/lib/esm/internal/use-cases/transaction/SignTransactionUseCase.test.js.map +2 -2
  176. package/lib/esm/package.json +40 -36
  177. package/lib/types/api/SignerSolana.d.ts +2 -3
  178. package/lib/types/api/SignerSolana.d.ts.map +1 -1
  179. package/lib/types/api/SignerSolanaBuilder.d.ts.map +1 -1
  180. package/lib/types/api/SolanaTools.d.ts +1 -2
  181. package/lib/types/api/SolanaTools.d.ts.map +1 -1
  182. package/lib/types/api/app-binder/SignMessageDeviceActionTypes.d.ts +3 -2
  183. package/lib/types/api/app-binder/SignMessageDeviceActionTypes.d.ts.map +1 -1
  184. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +12 -3
  185. package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
  186. package/lib/types/api/index.d.ts +2 -1
  187. package/lib/types/api/index.d.ts.map +1 -1
  188. package/lib/types/api/model/SolanaTransactionOptionalConfig.d.ts +7 -0
  189. package/lib/types/api/model/SolanaTransactionOptionalConfig.d.ts.map +1 -0
  190. package/lib/types/api/model/TransactionResolutionContext.d.ts +7 -0
  191. package/lib/types/api/model/TransactionResolutionContext.d.ts.map +1 -1
  192. package/lib/types/internal/DefaultSignerSolana.d.ts +293 -2
  193. package/lib/types/internal/DefaultSignerSolana.d.ts.map +1 -1
  194. package/lib/types/internal/app-binder/SolanaAppBinder.d.ts +5 -5
  195. package/lib/types/internal/app-binder/SolanaAppBinder.d.ts.map +1 -1
  196. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts +1 -0
  197. package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts.map +1 -1
  198. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts +1 -0
  199. package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -1
  200. package/lib/types/internal/app-binder/command/GetPubKeyCommand.d.ts +4 -1
  201. package/lib/types/internal/app-binder/command/GetPubKeyCommand.d.ts.map +1 -1
  202. package/lib/types/internal/app-binder/command/ProvideTLVDescriptorCommand.d.ts +1 -0
  203. package/lib/types/internal/app-binder/command/ProvideTLVDescriptorCommand.d.ts.map +1 -1
  204. package/lib/types/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.d.ts +29 -0
  205. package/lib/types/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.d.ts.map +1 -0
  206. package/lib/types/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.d.ts +2 -0
  207. package/lib/types/internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand.test.d.ts.map +1 -0
  208. package/lib/types/internal/app-binder/command/SignOffChainMessageCommand.d.ts +14 -9
  209. package/lib/types/internal/app-binder/command/SignOffChainMessageCommand.d.ts.map +1 -1
  210. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts +3 -0
  211. package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -1
  212. package/lib/types/internal/app-binder/device-action/SignTransactionDeviceAction.d.ts +10 -3
  213. package/lib/types/internal/app-binder/device-action/SignTransactionDeviceAction.d.ts.map +1 -1
  214. package/lib/types/internal/app-binder/services/TransactionInspector.d.ts +13 -11
  215. package/lib/types/internal/app-binder/services/TransactionInspector.d.ts.map +1 -1
  216. package/lib/types/internal/app-binder/services/TransactionInspector.test.d.ts +2 -0
  217. package/lib/types/internal/app-binder/services/TransactionInspector.test.d.ts.map +1 -0
  218. package/lib/types/internal/app-binder/services/bs58Encoder.d.ts +9 -0
  219. package/lib/types/internal/app-binder/services/bs58Encoder.d.ts.map +1 -0
  220. package/lib/types/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.d.ts +8 -0
  221. package/lib/types/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.d.ts.map +1 -0
  222. package/lib/types/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.d.ts +2 -0
  223. package/lib/types/internal/app-binder/services/utils/DefaultSolanaMessageNormaliser.test.d.ts.map +1 -0
  224. package/lib/types/internal/app-binder/services/utils/NullLoggerPublisherService.d.ts +3 -0
  225. package/lib/types/internal/app-binder/services/utils/NullLoggerPublisherService.d.ts.map +1 -0
  226. package/lib/types/internal/app-binder/services/utils/NullLoggerPublisherService.test.d.ts +2 -0
  227. package/lib/types/internal/app-binder/services/utils/NullLoggerPublisherService.test.d.ts.map +1 -0
  228. package/lib/types/internal/app-binder/services/utils/transactionDecoders.d.ts.map +1 -1
  229. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +9 -12
  230. package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +1 -1
  231. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +14 -7
  232. package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +1 -1
  233. package/lib/types/internal/app-binder/task/SendSignMessageTask.d.ts +22 -6
  234. package/lib/types/internal/app-binder/task/SendSignMessageTask.d.ts.map +1 -1
  235. package/lib/types/internal/di.d.ts.map +1 -1
  236. package/lib/types/internal/externalTypes.d.ts +1 -0
  237. package/lib/types/internal/externalTypes.d.ts.map +1 -1
  238. package/lib/types/internal/use-cases/transaction/SignTransactionUseCase.d.ts +2 -4
  239. package/lib/types/internal/use-cases/transaction/SignTransactionUseCase.d.ts.map +1 -1
  240. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  241. package/package.json +33 -29
  242. package/lib/cjs/api/model/TransactionOptions.js +0 -2
  243. package/lib/cjs/api/model/TransactionOptions.js.map +0 -7
  244. package/lib/cjs/internal/app-binder/command/ProvideTrustedNamePKICommand.js +0 -2
  245. package/lib/cjs/internal/app-binder/command/ProvideTrustedNamePKICommand.js.map +0 -7
  246. package/lib/cjs/internal/app-binder/command/ProvideTrustedNamePKICommand.test.js +0 -2
  247. package/lib/cjs/internal/app-binder/command/ProvideTrustedNamePKICommand.test.js.map +0 -7
  248. package/lib/esm/api/model/TransactionOptions.js +0 -1
  249. package/lib/esm/internal/app-binder/command/ProvideTrustedNamePKICommand.js +0 -2
  250. package/lib/esm/internal/app-binder/command/ProvideTrustedNamePKICommand.js.map +0 -7
  251. package/lib/esm/internal/app-binder/command/ProvideTrustedNamePKICommand.test.js +0 -2
  252. package/lib/esm/internal/app-binder/command/ProvideTrustedNamePKICommand.test.js.map +0 -7
  253. package/lib/types/api/model/TransactionOptions.d.ts +0 -8
  254. package/lib/types/api/model/TransactionOptions.d.ts.map +0 -1
  255. package/lib/types/internal/app-binder/command/ProvideTrustedNamePKICommand.d.ts +0 -13
  256. package/lib/types/internal/app-binder/command/ProvideTrustedNamePKICommand.d.ts.map +0 -1
  257. package/lib/types/internal/app-binder/command/ProvideTrustedNamePKICommand.test.d.ts +0 -2
  258. package/lib/types/internal/app-binder/command/ProvideTrustedNamePKICommand.test.d.ts.map +0 -1
  259. /package/lib/esm/api/model/{TransactionOptions.js.map → SolanaTransactionOptionalConfig.js.map} +0 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/internal/app-binder/services/utils/transactionDecoders.ts"],
4
- "sourcesContent": ["import {\n ASSOCIATED_TOKEN_PROGRAM_ID,\n decodeBurnCheckedInstruction,\n decodeBurnInstruction,\n decodeCloseAccountInstruction,\n decodeFreezeAccountInstruction,\n decodeInitializeAccount2Instruction,\n decodeInitializeAccount3Instruction,\n decodeInitializeAccountInstruction,\n decodeInitializeImmutableOwnerInstruction,\n decodeSyncNativeInstruction,\n decodeThawAccountInstruction,\n decodeTransferCheckedInstruction,\n decodeTransferCheckedWithFeeInstruction,\n decodeTransferInstruction,\n TOKEN_2022_PROGRAM_ID,\n TOKEN_PROGRAM_ID,\n} from \"@solana/spl-token\";\nimport { type PublicKey, type TransactionInstruction } from \"@solana/web3.js\";\n\nimport {\n type NormalizedCompiledIx,\n type NormalizedMessage,\n type TxInspectorResult,\n} from \"@internal/app-binder/services/TransactionInspector\";\n\nexport type IxContext = {\n programId: PublicKey;\n ixMeta: NormalizedCompiledIx;\n message: NormalizedMessage;\n instruction: TransactionInstruction;\n};\n\nexport type Decoder = {\n when: (ctx: IxContext) => boolean;\n decode: (ctx: IxContext) => TxInspectorResult[\"data\"] | null;\n};\n\nconst isTokenProgramId = (pid: PublicKey) =>\n pid.equals(TOKEN_PROGRAM_ID) || pid.equals(TOKEN_2022_PROGRAM_ID);\n\nconst safe = <T>(fn: () => T): T | null => {\n try {\n return fn();\n } catch {\n return null;\n }\n};\n\nexport const DECODERS: Decoder[] = [\n // ATA creation (with derivation fallback)\n {\n when: ({ programId }) => programId.equals(ASSOCIATED_TOKEN_PROGRAM_ID),\n decode: ({ ixMeta, message }) => {\n const byIdx = (n: number): PublicKey | null => {\n const i = ixMeta.accountKeyIndexes[n];\n return i !== undefined ? (message.allKeys[i] ?? null) : null;\n };\n\n const ataPk = byIdx(1);\n const ownerPk = byIdx(2);\n const mintPk = byIdx(3);\n if (!ownerPk || !mintPk || !ataPk) return null;\n\n return {\n createATA: {\n address: ataPk.toBase58(),\n mintAddress: mintPk.toBase58(),\n },\n };\n },\n },\n\n // Token-2022 fee\u2019d transfer (CWIF)\n {\n when: ({ programId }) => programId.equals(TOKEN_2022_PROGRAM_ID),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferCheckedWithFeeInstruction(instruction, programId);\n return {\n tokenAddress: destination.pubkey.toBase58(),\n };\n }),\n },\n\n // Transfers\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferInstruction(instruction, programId);\n return { tokenAddress: destination.pubkey.toBase58() };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferCheckedInstruction(instruction, programId);\n return {\n tokenAddress: destination.pubkey.toBase58(),\n };\n }),\n },\n\n // Account init\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccountInstruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccount2Instruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccount3Instruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeInitializeImmutableOwnerInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n\n // Lifecycle / WSOL\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeCloseAccountInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeSyncNativeInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n\n // Mint / Burn\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeBurnCheckedInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeBurnInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n\n // Freeze / Thaw\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeFreezeAccountInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeThawAccountInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n\n // LAST-RESORT: tag as SPL by program id only (when decoders can't run)\n {\n when: ({ programId }) =>\n programId.equals(ASSOCIATED_TOKEN_PROGRAM_ID) ||\n programId.equals(TOKEN_PROGRAM_ID) ||\n programId.equals(TOKEN_2022_PROGRAM_ID),\n decode: () => null,\n },\n];\n"],
5
- "mappings": "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",
6
- "names": ["ASSOCIATED_TOKEN_PROGRAM_ID", "decodeBurnCheckedInstruction", "decodeBurnInstruction", "decodeCloseAccountInstruction", "decodeFreezeAccountInstruction", "decodeInitializeAccount2Instruction", "decodeInitializeAccount3Instruction", "decodeInitializeAccountInstruction", "decodeInitializeImmutableOwnerInstruction", "decodeSyncNativeInstruction", "decodeThawAccountInstruction", "decodeTransferCheckedInstruction", "decodeTransferCheckedWithFeeInstruction", "decodeTransferInstruction", "TOKEN_2022_PROGRAM_ID", "TOKEN_PROGRAM_ID", "isTokenProgramId", "pid", "safe", "fn", "DECODERS", "programId", "ixMeta", "message", "byIdx", "n", "i", "ataPk", "ownerPk", "mintPk", "instruction", "destination", "account", "mint"]
4
+ "sourcesContent": ["import {\n ASSOCIATED_TOKEN_PROGRAM_ID,\n decodeBurnCheckedInstruction,\n decodeBurnInstruction,\n decodeCloseAccountInstruction,\n decodeFreezeAccountInstruction,\n decodeInitializeAccount2Instruction,\n decodeInitializeAccount3Instruction,\n decodeInitializeAccountInstruction,\n decodeInitializeImmutableOwnerInstruction,\n decodeSyncNativeInstruction,\n decodeThawAccountInstruction,\n decodeTransferCheckedInstruction,\n decodeTransferCheckedWithFeeInstruction,\n decodeTransferInstruction,\n getAssociatedTokenAddressSync,\n TOKEN_2022_PROGRAM_ID,\n TOKEN_PROGRAM_ID,\n} from \"@solana/spl-token\";\nimport {\n type PublicKey,\n SystemProgram,\n SYSVAR_RENT_PUBKEY,\n type TransactionInstruction,\n} from \"@solana/web3.js\";\n\nimport {\n type NormalizedCompiledIx,\n type NormalizedMessage,\n type TxInspectorResult,\n} from \"@internal/app-binder/services/TransactionInspector\";\n\nexport type IxContext = {\n programId: PublicKey;\n ixMeta: NormalizedCompiledIx;\n message: NormalizedMessage;\n instruction: TransactionInstruction;\n};\n\nexport type Decoder = {\n when: (ctx: IxContext) => boolean;\n decode: (ctx: IxContext) => TxInspectorResult[\"data\"] | null;\n};\n\nconst isTokenProgramId = (pid: PublicKey) =>\n pid.equals(TOKEN_PROGRAM_ID) || pid.equals(TOKEN_2022_PROGRAM_ID);\n\nconst safe = <T>(fn: () => T): T | null => {\n try {\n return fn();\n } catch {\n return null;\n }\n};\n\nexport const DECODERS: Decoder[] = [\n // ATA creation (with derivation fallback)\n {\n when: ({ programId }) => programId.equals(ASSOCIATED_TOKEN_PROGRAM_ID),\n decode: ({ ixMeta, message }) => {\n const indexes = ixMeta.accountKeyIndexes ?? [];\n const byIndexes = (n: number) =>\n indexes[n] !== undefined ? (message.allKeys[indexes[n]] ?? null) : null;\n\n // canonical ATA instruction layout: [payer, ata, owner, mint, system, tokenProgram, rent?]\n const ataPk = byIndexes(1);\n const mintPk = byIndexes(3);\n if (!ataPk || !mintPk) return null;\n\n const accs = indexes\n .map((i) => message.allKeys[i])\n .filter((k): k is PublicKey => !!k);\n\n // prefer token-2022 if present among instruction accounts, else token classic\n const tokenProgInIx =\n accs.find((pk) => pk.equals(TOKEN_2022_PROGRAM_ID)) ??\n accs.find((pk) => pk.equals(TOKEN_PROGRAM_ID)) ??\n null;\n\n const isProgramOrSysvar = (pk: PublicKey) =>\n pk.equals(SystemProgram.programId) ||\n pk.equals(TOKEN_PROGRAM_ID) ||\n pk.equals(TOKEN_2022_PROGRAM_ID) ||\n pk.equals(ASSOCIATED_TOKEN_PROGRAM_ID) ||\n pk.equals(SYSVAR_RENT_PUBKEY);\n\n // candidate owners: exclude programs/sysvars, the ATA itself, and the mint\n const ownerCandidates = accs.filter(\n (pk) =>\n !isProgramOrSysvar(pk) && !pk.equals(ataPk) && !pk.equals(mintPk),\n );\n\n const derive = (owner: PublicKey, tokenProg: PublicKey) =>\n getAssociatedTokenAddressSync(\n mintPk,\n owner,\n true, // allowOwnerOffCurve\n tokenProg,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n );\n\n // try with the token program actually referenced in the instruction (if any)\n if (tokenProgInIx) {\n for (const owner of ownerCandidates) {\n if (derive(owner, tokenProgInIx).equals(ataPk)) {\n return {\n createATA: {\n address: owner.toBase58(),\n mintAddress: mintPk.toBase58(),\n },\n };\n }\n }\n }\n\n // fallback: try both classic and 2022 (covers odd wrappers/missing program acct)\n for (const owner of ownerCandidates) {\n const dClassic = derive(owner, TOKEN_PROGRAM_ID);\n if (dClassic.equals(ataPk)) {\n return {\n createATA: {\n address: owner.toBase58(),\n mintAddress: mintPk.toBase58(),\n },\n };\n }\n const d22 = derive(owner, TOKEN_2022_PROGRAM_ID);\n if (d22.equals(ataPk)) {\n return {\n createATA: {\n address: owner.toBase58(),\n mintAddress: mintPk.toBase58(),\n },\n };\n }\n }\n return null;\n },\n },\n\n // Token-2022 fee\u2019d transfer\n {\n when: ({ programId }) => programId.equals(TOKEN_2022_PROGRAM_ID),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferCheckedWithFeeInstruction(instruction, programId);\n return {\n tokenAddress: destination.pubkey.toBase58(),\n };\n }),\n },\n\n // Transfers\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferInstruction(instruction, programId);\n return { tokenAddress: destination.pubkey.toBase58() };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { destination },\n } = decodeTransferCheckedInstruction(instruction, programId);\n return {\n tokenAddress: destination.pubkey.toBase58(),\n };\n }),\n },\n\n // Account init\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccountInstruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccount2Instruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account, mint },\n } = decodeInitializeAccount3Instruction(instruction, programId);\n return {\n createATA: {\n address: account.pubkey.toBase58(),\n mintAddress: mint.pubkey.toBase58(),\n },\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeInitializeImmutableOwnerInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n\n // Lifecycle / WSOL\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeCloseAccountInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeSyncNativeInstruction(instruction, programId);\n return { tokenAddress: account.pubkey.toBase58() };\n }),\n },\n\n // Mint / Burn\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeBurnCheckedInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeBurnInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n\n // Freeze / Thaw\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeFreezeAccountInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n {\n when: ({ programId }) => isTokenProgramId(programId),\n decode: ({ instruction, programId }) =>\n safe(() => {\n const {\n keys: { account },\n } = decodeThawAccountInstruction(instruction, programId);\n return {\n tokenAddress: account.pubkey.toBase58(),\n };\n }),\n },\n\n // LAST-RESORT: tag as SPL by program id only (when decoders can't run)\n {\n when: ({ programId }) =>\n programId.equals(ASSOCIATED_TOKEN_PROGRAM_ID) ||\n programId.equals(TOKEN_PROGRAM_ID) ||\n programId.equals(TOKEN_2022_PROGRAM_ID),\n decode: () => null,\n },\n];\n"],
5
+ "mappings": "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",
6
+ "names": ["ASSOCIATED_TOKEN_PROGRAM_ID", "decodeBurnCheckedInstruction", "decodeBurnInstruction", "decodeCloseAccountInstruction", "decodeFreezeAccountInstruction", "decodeInitializeAccount2Instruction", "decodeInitializeAccount3Instruction", "decodeInitializeAccountInstruction", "decodeInitializeImmutableOwnerInstruction", "decodeSyncNativeInstruction", "decodeThawAccountInstruction", "decodeTransferCheckedInstruction", "decodeTransferCheckedWithFeeInstruction", "decodeTransferInstruction", "getAssociatedTokenAddressSync", "TOKEN_2022_PROGRAM_ID", "TOKEN_PROGRAM_ID", "SystemProgram", "SYSVAR_RENT_PUBKEY", "isTokenProgramId", "pid", "safe", "fn", "DECODERS", "programId", "ixMeta", "message", "indexes", "byIndexes", "n", "ataPk", "mintPk", "accs", "i", "k", "tokenProgInIx", "pk", "isProgramOrSysvar", "ownerCandidates", "derive", "owner", "tokenProg", "instruction", "destination", "account", "mint"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{isSuccessCommandResult as i}from"@ledgerhq/device-management-kit";import{GetChallengeCommand as s}from"../../app-binder/command/GetChallengeCommand";class u{constructor(o,e){this.api=o;this.args=e}async run(){const{contextModule:o,options:e}=this.args,a=this.api.getDeviceSessionState();let n;const r=await this.api.sendCommand(new s);return i(r)&&(n=r.data.challenge),(await o.getSolanaContext({deviceModelId:a.deviceModelId,tokenAddress:e.tokenAddress,challenge:n,createATA:e.createATA})).caseOf({Left:t=>{throw t},Right:t=>({challenge:n,descriptor:t.descriptor,addressResult:{tokenAccount:t.tokenAccount,owner:t.owner,contract:t.contract},calCertificate:t.certificate})})}}export{u as BuildTransactionContextTask};
1
+ import{isSuccessCommandResult as l}from"@ledgerhq/device-management-kit";import{GetChallengeCommand as i}from"../../app-binder/command/GetChallengeCommand";class p{constructor(o,t){this.api=o;this.args=t;this._logger=t.loggerFactory("BuildTransactionContextTask")}_logger;async run(){this._logger.debug("[run] Starting BuildTransactionContextTask");const{contextModule:o,options:t}=this.args,s=this.api.getDeviceSessionState();let a;const n=await this.api.sendCommand(new i);if(l(n))a=n.data.challenge;else throw new Error("Failed to get challenge from device");const r={deviceModelId:s.deviceModelId,tokenAddress:t.tokenAddress,challenge:a,createATA:t.createATA,tokenInternalId:t.tokenInternalId,templateId:t.templateId};return this._logger.debug("[run] Calling contextModule.getSolanaContext",{data:{args:r}}),(await o.getSolanaContext(r)).caseOf({Left:e=>{throw this._logger.error("[run] Solana context result",{data:{error:{message:e.message,name:e.name,stack:e.stack}}}),e},Right:e=>(this._logger.debug("[run] Solana context result",{data:{result:e}}),e)})}}export{p as BuildTransactionContextTask};
2
2
  //# sourceMappingURL=BuildTransactionContextTask.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.ts"],
4
- "sourcesContent": ["import {\n type ContextModule,\n type PkiCertificate,\n} from \"@ledgerhq/context-module\";\nimport {\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { type TransactionOptions } from \"@api/model/TransactionOptions\";\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\n\nexport type SolanaBuildContextResult = {\n challenge: string | undefined;\n addressResult: {\n tokenAccount: string;\n owner: string;\n contract: string;\n };\n calCertificate: PkiCertificate;\n descriptor: Uint8Array;\n};\n\nexport type BuildTransactionContextTaskArgs = {\n readonly contextModule: ContextModule;\n readonly options: TransactionOptions;\n};\n\nexport class BuildTransactionContextTask {\n constructor(\n private readonly api: InternalApi,\n private readonly args: BuildTransactionContextTaskArgs,\n ) {}\n\n async run(): Promise<SolanaBuildContextResult> {\n const { contextModule, options } = this.args;\n const deviceState = this.api.getDeviceSessionState();\n\n // get challenge\n let challenge: string | undefined;\n const challengeRes = await this.api.sendCommand(new GetChallengeCommand());\n if (isSuccessCommandResult(challengeRes)) {\n challenge = challengeRes.data.challenge;\n }\n\n // get Solana context\n const contextResult = await contextModule.getSolanaContext({\n deviceModelId: deviceState.deviceModelId,\n tokenAddress: options.tokenAddress,\n challenge,\n createATA: options.createATA,\n });\n\n return contextResult.caseOf({\n Left: (err) => {\n throw err;\n },\n Right: (ctx) => {\n return {\n challenge,\n descriptor: ctx.descriptor,\n addressResult: {\n tokenAccount: ctx.tokenAccount,\n owner: ctx.owner,\n contract: ctx.contract,\n },\n calCertificate: ctx.certificate,\n };\n },\n });\n }\n}\n"],
5
- "mappings": "AAIA,OAEE,0BAAAA,MACK,kCAGP,OAAS,uBAAAC,MAA2B,mDAkB7B,MAAMC,CAA4B,CACvC,YACmBC,EACAC,EACjB,CAFiB,SAAAD,EACA,UAAAC,CAChB,CAEH,MAAM,KAAyC,CAC7C,KAAM,CAAE,cAAAC,EAAe,QAAAC,CAAQ,EAAI,KAAK,KAClCC,EAAc,KAAK,IAAI,sBAAsB,EAGnD,IAAIC,EACJ,MAAMC,EAAe,MAAM,KAAK,IAAI,YAAY,IAAIR,CAAqB,EACzE,OAAID,EAAuBS,CAAY,IACrCD,EAAYC,EAAa,KAAK,YAIV,MAAMJ,EAAc,iBAAiB,CACzD,cAAeE,EAAY,cAC3B,aAAcD,EAAQ,aACtB,UAAAE,EACA,UAAWF,EAAQ,SACrB,CAAC,GAEoB,OAAO,CAC1B,KAAOI,GAAQ,CACb,MAAMA,CACR,EACA,MAAQC,IACC,CACL,UAAAH,EACA,WAAYG,EAAI,WAChB,cAAe,CACb,aAAcA,EAAI,aAClB,MAAOA,EAAI,MACX,SAAUA,EAAI,QAChB,EACA,eAAgBA,EAAI,WACtB,EAEJ,CAAC,CACH,CACF",
6
- "names": ["isSuccessCommandResult", "GetChallengeCommand", "BuildTransactionContextTask", "api", "args", "contextModule", "options", "deviceState", "challenge", "challengeRes", "err", "ctx"]
4
+ "sourcesContent": ["import {\n type ContextModule,\n type PkiCertificate,\n type SolanaContextLoaderResults,\n} from \"@ledgerhq/context-module\";\nimport {\n type InternalApi,\n isSuccessCommandResult,\n type LoggerPublisherService,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { type TransactionResolutionContext } from \"@api/model/TransactionResolutionContext\";\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\n\nexport type SolanaBuildContextResult = {\n trustedNamePKICertificate: PkiCertificate;\n tlvDescriptor: Uint8Array;\n loadersResults: SolanaContextLoaderResults;\n};\n\nexport type BuildTransactionContextTaskArgs = {\n readonly contextModule: ContextModule;\n readonly options: TransactionResolutionContext;\n readonly loggerFactory: (tag: string) => LoggerPublisherService;\n};\n\nexport class BuildTransactionContextTask {\n private readonly _logger: LoggerPublisherService;\n constructor(\n private readonly api: InternalApi,\n private readonly args: BuildTransactionContextTaskArgs,\n ) {\n this._logger = args.loggerFactory(\"BuildTransactionContextTask\");\n }\n\n async run(): Promise<SolanaBuildContextResult> {\n this._logger.debug(\"[run] Starting BuildTransactionContextTask\");\n const { contextModule, options } = this.args;\n const deviceState = this.api.getDeviceSessionState();\n\n // get challenge\n let challenge: string | undefined;\n const challengeRes = await this.api.sendCommand(new GetChallengeCommand());\n if (isSuccessCommandResult(challengeRes)) {\n challenge = challengeRes.data.challenge;\n } else {\n throw new Error(\"Failed to get challenge from device\");\n }\n\n const contextModuleGetSolanaContextArgs = {\n deviceModelId: deviceState.deviceModelId,\n tokenAddress: options.tokenAddress,\n challenge,\n createATA: options.createATA,\n tokenInternalId: options.tokenInternalId,\n templateId: options.templateId,\n };\n // get Solana context\n this._logger.debug(\"[run] Calling contextModule.getSolanaContext\", {\n data: {\n args: contextModuleGetSolanaContextArgs,\n },\n });\n const contextResult = await contextModule.getSolanaContext(\n contextModuleGetSolanaContextArgs,\n );\n\n return contextResult.caseOf({\n Left: (err) => {\n this._logger.error(\"[run] Solana context result\", {\n data: {\n error: {\n message: err.message,\n name: err.name,\n stack: err.stack,\n },\n },\n });\n throw err;\n },\n Right: (ctx) => {\n this._logger.debug(\"[run] Solana context result\", {\n data: {\n result: ctx,\n },\n });\n return ctx;\n },\n });\n }\n}\n"],
5
+ "mappings": "AAKA,OAEE,0BAAAA,MAEK,kCAGP,OAAS,uBAAAC,MAA2B,mDAc7B,MAAMC,CAA4B,CAEvC,YACmBC,EACAC,EACjB,CAFiB,SAAAD,EACA,UAAAC,EAEjB,KAAK,QAAUA,EAAK,cAAc,6BAA6B,CACjE,CANiB,QAQjB,MAAM,KAAyC,CAC7C,KAAK,QAAQ,MAAM,4CAA4C,EAC/D,KAAM,CAAE,cAAAC,EAAe,QAAAC,CAAQ,EAAI,KAAK,KAClCC,EAAc,KAAK,IAAI,sBAAsB,EAGnD,IAAIC,EACJ,MAAMC,EAAe,MAAM,KAAK,IAAI,YAAY,IAAIR,CAAqB,EACzE,GAAID,EAAuBS,CAAY,EACrCD,EAAYC,EAAa,KAAK,cAE9B,OAAM,IAAI,MAAM,qCAAqC,EAGvD,MAAMC,EAAoC,CACxC,cAAeH,EAAY,cAC3B,aAAcD,EAAQ,aACtB,UAAAE,EACA,UAAWF,EAAQ,UACnB,gBAAiBA,EAAQ,gBACzB,WAAYA,EAAQ,UACtB,EAEA,YAAK,QAAQ,MAAM,+CAAgD,CACjE,KAAM,CACJ,KAAMI,CACR,CACF,CAAC,GACqB,MAAML,EAAc,iBACxCK,CACF,GAEqB,OAAO,CAC1B,KAAOC,GAAQ,CACb,WAAK,QAAQ,MAAM,8BAA+B,CAChD,KAAM,CACJ,MAAO,CACL,QAASA,EAAI,QACb,KAAMA,EAAI,KACV,MAAOA,EAAI,KACb,CACF,CACF,CAAC,EACKA,CACR,EACA,MAAQC,IACN,KAAK,QAAQ,MAAM,8BAA+B,CAChD,KAAM,CACJ,OAAQA,CACV,CACF,CAAC,EACMA,EAEX,CAAC,CACH,CACF",
6
+ "names": ["isSuccessCommandResult", "GetChallengeCommand", "BuildTransactionContextTask", "api", "args", "contextModule", "options", "deviceState", "challenge", "challengeRes", "contextModuleGetSolanaContextArgs", "err", "ctx"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{CommandResultStatus as u,DeviceModelId as l}from"@ledgerhq/device-management-kit";import{Left as f,Right as m}from"purify-ts";import{beforeEach as C,describe as k,expect as n,it as r,vi as t}from"vitest";import{GetChallengeCommand as A}from"../../app-binder/command/GetChallengeCommand";import{BuildTransactionContextTask as d}from"./BuildTransactionContextTask";const a={getSolanaContext:t.fn(),getContext:t.fn(),getContexts:t.fn(),getTypedDataFilters:t.fn(),getWeb3Checks:t.fn()},i={contextModule:a,options:{tokenAddress:"someAddress",createATA:void 0}},e={descriptor:new Uint8Array([1,2,3]),tokenAccount:"someTokenAccount",owner:"someOwner",contract:"someContract",certificate:{payload:new Uint8Array([170,187]),keyUsageNumber:1}};let o;k("BuildTransactionContextTask",()=>{C(()=>{t.resetAllMocks(),o={getDeviceSessionState:t.fn().mockReturnValue({deviceModelId:l.NANO_X}),sendCommand:t.fn().mockResolvedValue({status:u.Success,data:{challenge:"someChallenge"}})}}),r("returns context successfully when challenge command succeeds",async()=>{a.getSolanaContext.mockResolvedValue(m(e));const s=await new d(o,i).run();n(o.sendCommand).toHaveBeenCalledWith(n.any(A)),n(a.getSolanaContext).toHaveBeenCalledWith({deviceModelId:l.NANO_X,tokenAddress:"someAddress",challenge:"someChallenge",createATA:void 0}),n(s).toEqual({challenge:"someChallenge",descriptor:e.descriptor,calCertificate:e.certificate,addressResult:{tokenAccount:e.tokenAccount,owner:e.owner,contract:e.contract}})}),r("returns context when challenge command fails",async()=>{o.sendCommand.mockResolvedValue({status:u.Error,data:{}}),a.getSolanaContext.mockResolvedValue(m(e));const s=await new d(o,i).run();n(a.getSolanaContext).toHaveBeenCalledWith({deviceModelId:l.NANO_X,tokenAddress:"someAddress",challenge:void 0,createATA:void 0}),n(s).toEqual({challenge:void 0,descriptor:e.descriptor,calCertificate:e.certificate,addressResult:{tokenAccount:e.tokenAccount,owner:e.owner,contract:e.contract}})}),r("throws if getSolanaContext returns Left",async()=>{const c=new Error("Solana context failure");a.getSolanaContext.mockResolvedValue(f(c));const s=new d(o,i);await n(s.run()).rejects.toThrow("Solana context failure")})});
1
+ import{CommandResultStatus as i,DeviceModelId as u}from"@ledgerhq/device-management-kit";import{Left as C,Right as m}from"purify-ts";import{beforeEach as f,describe as g,expect as e,it as r,vi as s}from"vitest";import{GetChallengeCommand as x}from"../../app-binder/command/GetChallengeCommand";import{NullLoggerPublisherService as k}from"../../app-binder/services/utils/NullLoggerPublisherService";import{BuildTransactionContextTask as c}from"./BuildTransactionContextTask";const o={getSolanaContext:s.fn()},d={contextModule:o,loggerFactory:k,options:{tokenAddress:"someAddress",createATA:void 0}},n={tlvDescriptor:new Uint8Array([1,2,3]),trustedNamePKICertificate:{payload:new Uint8Array([170,187]),keyUsageNumber:1},loadersResults:[]};let t;g("BuildTransactionContextTask",()=>{f(()=>{s.resetAllMocks(),t={getDeviceSessionState:s.fn().mockReturnValue({deviceModelId:u.NANO_X}),sendCommand:s.fn().mockResolvedValue({status:i.Success,data:{challenge:"someChallenge"}})}}),r("returns context successfully when challenge command succeeds",async()=>{o.getSolanaContext.mockResolvedValue(m(n));const l=await new c(t,d).run();e(t.sendCommand).toHaveBeenCalledWith(e.any(x)),e(o.getSolanaContext).toHaveBeenCalledWith({deviceModelId:u.NANO_X,tokenAddress:"someAddress",challenge:"someChallenge",createATA:void 0}),e(l).toEqual({tlvDescriptor:n.tlvDescriptor,trustedNamePKICertificate:n.trustedNamePKICertificate,loadersResults:[]})}),r("throws if challenge command fails",async()=>{t.sendCommand.mockResolvedValue({status:i.Error,data:{}}),o.getSolanaContext.mockResolvedValue(m(n));const a=new c(t,d);await e(a.run()).rejects.toThrow("Failed to get challenge from device")}),r("throws if getSolanaContext returns Left",async()=>{const a=new Error("Solana context failure");o.getSolanaContext.mockResolvedValue(C(a));const l=new c(t,d);await e(l.run()).rejects.toThrow("Solana context failure")})});
2
2
  //# sourceMappingURL=BuildTransactionContextTask.test.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.test.ts"],
4
- "sourcesContent": ["/* eslint-disable @typescript-eslint/no-unsafe-call */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n CommandResultStatus,\n DeviceModelId,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\nimport { beforeEach, describe, expect, it, vi } from \"vitest\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\n\nimport {\n BuildTransactionContextTask,\n type SolanaBuildContextResult,\n} from \"./BuildTransactionContextTask\";\n\nconst contextModuleMock: ContextModule = {\n getSolanaContext: vi.fn(),\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n getWeb3Checks: vi.fn(),\n};\n\nconst defaultArgs = {\n contextModule: contextModuleMock,\n options: {\n tokenAddress: \"someAddress\",\n createATA: undefined,\n },\n};\n\nconst domainSolanaPayload = {\n descriptor: new Uint8Array([1, 2, 3]),\n tokenAccount: \"someTokenAccount\",\n owner: \"someOwner\",\n contract: \"someContract\",\n certificate: { payload: new Uint8Array([0xaa, 0xbb]), keyUsageNumber: 1 },\n} as const;\n\nlet apiMock: InternalApi;\n\ndescribe(\"BuildTransactionContextTask\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n\n apiMock = {\n getDeviceSessionState: vi\n .fn()\n .mockReturnValue({ deviceModelId: DeviceModelId.NANO_X }),\n sendCommand: vi.fn().mockResolvedValue({\n status: CommandResultStatus.Success,\n data: { challenge: \"someChallenge\" },\n }),\n } as unknown as InternalApi;\n });\n\n it(\"returns context successfully when challenge command succeeds\", async () => {\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(\n Right(domainSolanaPayload),\n );\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n const result = await task.run();\n\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n\n expect(contextModuleMock.getSolanaContext).toHaveBeenCalledWith({\n deviceModelId: DeviceModelId.NANO_X,\n tokenAddress: \"someAddress\",\n challenge: \"someChallenge\",\n createATA: undefined,\n });\n\n expect(result).toEqual<SolanaBuildContextResult>({\n challenge: \"someChallenge\",\n descriptor: domainSolanaPayload.descriptor,\n calCertificate: domainSolanaPayload.certificate,\n addressResult: {\n tokenAccount: domainSolanaPayload.tokenAccount,\n owner: domainSolanaPayload.owner,\n contract: domainSolanaPayload.contract,\n },\n });\n });\n\n it(\"returns context when challenge command fails\", async () => {\n (apiMock.sendCommand as any).mockResolvedValue({\n status: CommandResultStatus.Error,\n data: {},\n });\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(\n Right(domainSolanaPayload),\n );\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n const result = await task.run();\n\n expect(contextModuleMock.getSolanaContext).toHaveBeenCalledWith({\n deviceModelId: DeviceModelId.NANO_X,\n tokenAddress: \"someAddress\",\n challenge: undefined,\n createATA: undefined,\n });\n\n expect(result).toEqual<SolanaBuildContextResult>({\n challenge: undefined,\n descriptor: domainSolanaPayload.descriptor,\n calCertificate: domainSolanaPayload.certificate,\n addressResult: {\n tokenAccount: domainSolanaPayload.tokenAccount,\n owner: domainSolanaPayload.owner,\n contract: domainSolanaPayload.contract,\n },\n });\n });\n\n it(\"throws if getSolanaContext returns Left\", async () => {\n const error = new Error(\"Solana context failure\");\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(Left(error));\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n await expect(task.run()).rejects.toThrow(\"Solana context failure\");\n });\n});\n"],
5
- "mappings": "AAIA,OACE,uBAAAA,EACA,iBAAAC,MAEK,kCACP,OAAS,QAAAC,EAAM,SAAAC,MAAa,YAC5B,OAAS,cAAAC,EAAY,YAAAC,EAAU,UAAAC,EAAQ,MAAAC,EAAI,MAAAC,MAAU,SAErD,OAAS,uBAAAC,MAA2B,mDAEpC,OACE,+BAAAC,MAEK,gCAEP,MAAMC,EAAmC,CACvC,iBAAkBH,EAAG,GAAG,EACxB,WAAYA,EAAG,GAAG,EAClB,YAAaA,EAAG,GAAG,EACnB,oBAAqBA,EAAG,GAAG,EAC3B,cAAeA,EAAG,GAAG,CACvB,EAEMI,EAAc,CAClB,cAAeD,EACf,QAAS,CACP,aAAc,cACd,UAAW,MACb,CACF,EAEME,EAAsB,CAC1B,WAAY,IAAI,WAAW,CAAC,EAAG,EAAG,CAAC,CAAC,EACpC,aAAc,mBACd,MAAO,YACP,SAAU,eACV,YAAa,CAAE,QAAS,IAAI,WAAW,CAAC,IAAM,GAAI,CAAC,EAAG,eAAgB,CAAE,CAC1E,EAEA,IAAIC,EAEJT,EAAS,8BAA+B,IAAM,CAC5CD,EAAW,IAAM,CACfI,EAAG,cAAc,EAEjBM,EAAU,CACR,sBAAuBN,EACpB,GAAG,EACH,gBAAgB,CAAE,cAAeP,EAAc,MAAO,CAAC,EAC1D,YAAaO,EAAG,GAAG,EAAE,kBAAkB,CACrC,OAAQR,EAAoB,QAC5B,KAAM,CAAE,UAAW,eAAgB,CACrC,CAAC,CACH,CACF,CAAC,EAEDO,EAAG,+DAAgE,SAAY,CAC5EI,EAAkB,iBAAyB,kBAC1CR,EAAMU,CAAmB,CAC3B,EAGA,MAAME,EAAS,MADF,IAAIL,EAA4BI,EAASF,CAAW,EACvC,IAAI,EAE9BN,EAAOQ,EAAQ,WAAW,EAAE,qBAC1BR,EAAO,IAAIG,CAAmB,CAChC,EAEAH,EAAOK,EAAkB,gBAAgB,EAAE,qBAAqB,CAC9D,cAAeV,EAAc,OAC7B,aAAc,cACd,UAAW,gBACX,UAAW,MACb,CAAC,EAEDK,EAAOS,CAAM,EAAE,QAAkC,CAC/C,UAAW,gBACX,WAAYF,EAAoB,WAChC,eAAgBA,EAAoB,YACpC,cAAe,CACb,aAAcA,EAAoB,aAClC,MAAOA,EAAoB,MAC3B,SAAUA,EAAoB,QAChC,CACF,CAAC,CACH,CAAC,EAEDN,EAAG,+CAAgD,SAAY,CAC5DO,EAAQ,YAAoB,kBAAkB,CAC7C,OAAQd,EAAoB,MAC5B,KAAM,CAAC,CACT,CAAC,EACAW,EAAkB,iBAAyB,kBAC1CR,EAAMU,CAAmB,CAC3B,EAGA,MAAME,EAAS,MADF,IAAIL,EAA4BI,EAASF,CAAW,EACvC,IAAI,EAE9BN,EAAOK,EAAkB,gBAAgB,EAAE,qBAAqB,CAC9D,cAAeV,EAAc,OAC7B,aAAc,cACd,UAAW,OACX,UAAW,MACb,CAAC,EAEDK,EAAOS,CAAM,EAAE,QAAkC,CAC/C,UAAW,OACX,WAAYF,EAAoB,WAChC,eAAgBA,EAAoB,YACpC,cAAe,CACb,aAAcA,EAAoB,aAClC,MAAOA,EAAoB,MAC3B,SAAUA,EAAoB,QAChC,CACF,CAAC,CACH,CAAC,EAEDN,EAAG,0CAA2C,SAAY,CACxD,MAAMS,EAAQ,IAAI,MAAM,wBAAwB,EAC/CL,EAAkB,iBAAyB,kBAAkBT,EAAKc,CAAK,CAAC,EAEzE,MAAMC,EAAO,IAAIP,EAA4BI,EAASF,CAAW,EAEjE,MAAMN,EAAOW,EAAK,IAAI,CAAC,EAAE,QAAQ,QAAQ,wBAAwB,CACnE,CAAC,CACH,CAAC",
6
- "names": ["CommandResultStatus", "DeviceModelId", "Left", "Right", "beforeEach", "describe", "expect", "it", "vi", "GetChallengeCommand", "BuildTransactionContextTask", "contextModuleMock", "defaultArgs", "domainSolanaPayload", "apiMock", "result", "error", "task"]
4
+ "sourcesContent": ["/* eslint-disable @typescript-eslint/no-unsafe-call */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n CommandResultStatus,\n DeviceModelId,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\nimport { beforeEach, describe, expect, it, vi } from \"vitest\";\n\nimport { GetChallengeCommand } from \"@internal/app-binder/command/GetChallengeCommand\";\nimport { NullLoggerPublisherService } from \"@internal/app-binder/services/utils/NullLoggerPublisherService\";\n\nimport {\n BuildTransactionContextTask,\n type SolanaBuildContextResult,\n} from \"./BuildTransactionContextTask\";\n\nconst contextModuleMock: ContextModule = {\n getSolanaContext: vi.fn(),\n} as unknown as ContextModule;\n\nconst defaultArgs = {\n contextModule: contextModuleMock,\n loggerFactory: NullLoggerPublisherService,\n options: {\n tokenAddress: \"someAddress\",\n createATA: undefined,\n },\n};\n\nconst solanaContextRightPayload = {\n tlvDescriptor: new Uint8Array([1, 2, 3]),\n trustedNamePKICertificate: {\n payload: new Uint8Array([0xaa, 0xbb]),\n keyUsageNumber: 1,\n },\n loadersResults: [], // required by the task's return type\n} as const;\n\nlet apiMock: InternalApi;\n\ndescribe(\"BuildTransactionContextTask\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n\n apiMock = {\n getDeviceSessionState: vi\n .fn()\n .mockReturnValue({ deviceModelId: DeviceModelId.NANO_X }),\n sendCommand: vi.fn().mockResolvedValue({\n status: CommandResultStatus.Success,\n data: { challenge: \"someChallenge\" },\n }),\n } as unknown as InternalApi;\n });\n\n it(\"returns context successfully when challenge command succeeds\", async () => {\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(\n Right(solanaContextRightPayload),\n );\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n const result = await task.run();\n\n // challenge is fetched\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n expect.any(GetChallengeCommand),\n );\n\n // getSolanaContext called with challenge\n expect(contextModuleMock.getSolanaContext).toHaveBeenCalledWith({\n deviceModelId: DeviceModelId.NANO_X,\n tokenAddress: \"someAddress\",\n challenge: \"someChallenge\",\n createATA: undefined,\n });\n\n // matches SolanaBuildContextResult shape\n expect(result).toEqual<SolanaBuildContextResult>({\n tlvDescriptor: solanaContextRightPayload.tlvDescriptor,\n trustedNamePKICertificate:\n solanaContextRightPayload.trustedNamePKICertificate,\n loadersResults: [],\n });\n });\n\n it(\"throws if challenge command fails\", async () => {\n (apiMock.sendCommand as any).mockResolvedValue({\n status: CommandResultStatus.Error,\n data: {},\n });\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(\n Right(solanaContextRightPayload),\n );\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n await expect(task.run()).rejects.toThrow(\n \"Failed to get challenge from device\",\n );\n });\n\n it(\"throws if getSolanaContext returns Left\", async () => {\n const error = new Error(\"Solana context failure\");\n (contextModuleMock.getSolanaContext as any).mockResolvedValue(Left(error));\n\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n await expect(task.run()).rejects.toThrow(\"Solana context failure\");\n });\n});\n"],
5
+ "mappings": "AAIA,OACE,uBAAAA,EACA,iBAAAC,MAEK,kCACP,OAAS,QAAAC,EAAM,SAAAC,MAAa,YAC5B,OAAS,cAAAC,EAAY,YAAAC,EAAU,UAAAC,EAAQ,MAAAC,EAAI,MAAAC,MAAU,SAErD,OAAS,uBAAAC,MAA2B,mDACpC,OAAS,8BAAAC,MAAkC,iEAE3C,OACE,+BAAAC,MAEK,gCAEP,MAAMC,EAAmC,CACvC,iBAAkBJ,EAAG,GAAG,CAC1B,EAEMK,EAAc,CAClB,cAAeD,EACf,cAAeF,EACf,QAAS,CACP,aAAc,cACd,UAAW,MACb,CACF,EAEMI,EAA4B,CAChC,cAAe,IAAI,WAAW,CAAC,EAAG,EAAG,CAAC,CAAC,EACvC,0BAA2B,CACzB,QAAS,IAAI,WAAW,CAAC,IAAM,GAAI,CAAC,EACpC,eAAgB,CAClB,EACA,eAAgB,CAAC,CACnB,EAEA,IAAIC,EAEJV,EAAS,8BAA+B,IAAM,CAC5CD,EAAW,IAAM,CACfI,EAAG,cAAc,EAEjBO,EAAU,CACR,sBAAuBP,EACpB,GAAG,EACH,gBAAgB,CAAE,cAAeP,EAAc,MAAO,CAAC,EAC1D,YAAaO,EAAG,GAAG,EAAE,kBAAkB,CACrC,OAAQR,EAAoB,QAC5B,KAAM,CAAE,UAAW,eAAgB,CACrC,CAAC,CACH,CACF,CAAC,EAEDO,EAAG,+DAAgE,SAAY,CAC5EK,EAAkB,iBAAyB,kBAC1CT,EAAMW,CAAyB,CACjC,EAGA,MAAME,EAAS,MADF,IAAIL,EAA4BI,EAASF,CAAW,EACvC,IAAI,EAG9BP,EAAOS,EAAQ,WAAW,EAAE,qBAC1BT,EAAO,IAAIG,CAAmB,CAChC,EAGAH,EAAOM,EAAkB,gBAAgB,EAAE,qBAAqB,CAC9D,cAAeX,EAAc,OAC7B,aAAc,cACd,UAAW,gBACX,UAAW,MACb,CAAC,EAGDK,EAAOU,CAAM,EAAE,QAAkC,CAC/C,cAAeF,EAA0B,cACzC,0BACEA,EAA0B,0BAC5B,eAAgB,CAAC,CACnB,CAAC,CACH,CAAC,EAEDP,EAAG,oCAAqC,SAAY,CACjDQ,EAAQ,YAAoB,kBAAkB,CAC7C,OAAQf,EAAoB,MAC5B,KAAM,CAAC,CACT,CAAC,EACAY,EAAkB,iBAAyB,kBAC1CT,EAAMW,CAAyB,CACjC,EAEA,MAAMG,EAAO,IAAIN,EAA4BI,EAASF,CAAW,EAEjE,MAAMP,EAAOW,EAAK,IAAI,CAAC,EAAE,QAAQ,QAC/B,qCACF,CACF,CAAC,EAEDV,EAAG,0CAA2C,SAAY,CACxD,MAAMW,EAAQ,IAAI,MAAM,wBAAwB,EAC/CN,EAAkB,iBAAyB,kBAAkBV,EAAKgB,CAAK,CAAC,EAEzE,MAAMD,EAAO,IAAIN,EAA4BI,EAASF,CAAW,EAEjE,MAAMP,EAAOW,EAAK,IAAI,CAAC,EAAE,QAAQ,QAAQ,wBAAwB,CACnE,CAAC,CACH,CAAC",
6
+ "names": ["CommandResultStatus", "DeviceModelId", "Left", "Right", "beforeEach", "describe", "expect", "it", "vi", "GetChallengeCommand", "NullLoggerPublisherService", "BuildTransactionContextTask", "contextModuleMock", "defaultArgs", "solanaContextRightPayload", "apiMock", "result", "task", "error"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{isSuccessCommandResult as a}from"@ledgerhq/device-management-kit";import{Nothing as n}from"purify-ts";import{ProvideTLVDescriptorCommand as p}from"../../app-binder/command/ProvideTLVDescriptorCommand";import{ProvideTrustedNamePKICommand as s}from"../../app-binder/command/ProvideTrustedNamePKICommand";class C{constructor(t,o){this.api=t;this.context=o}async run(){const{descriptor:t,certificate:o}=this.context,{payload:i}=o,r=await this.api.sendCommand(new s({pkiBlob:i}));if(!a(r))throw r;const e=await this.api.sendCommand(new p({payload:t}));if(!a(e))throw e;return n}}export{C as ProvideSolanaTransactionContextTask};
1
+ import{SolanaContextTypes as o}from"@ledgerhq/context-module";import{isSuccessCommandResult as m,LoadCertificateCommand as g}from"@ledgerhq/device-management-kit";import{Nothing as u}from"purify-ts";import{ProvideTLVTransactionInstructionDescriptorCommand as l}from"../../app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand";import{ProvideTLVDescriptorCommand as y}from"../../app-binder/command/ProvideTLVDescriptorCommand";import{DefaultSolanaMessageNormaliser as S}from"../../app-binder/services/utils/DefaultSolanaMessageNormaliser";const f="test";class A{constructor(i,e){this.api=i;this.args=e;this._logger=e.loggerFactory("ProvideSolanaTransactionContextTask"),this._normaliser=e.normaliser??S}_logger;_normaliser;async run(){this._logger.debug("[run] Starting ProvideSolanaTransactionContextTask");const{tlvDescriptor:i,trustedNamePKICertificate:e,loadersResults:a,transactionBytes:r}=this.args;await this.api.sendCommand(new g({certificate:e.payload,keyUsage:e.keyUsageNumber})),await this.api.sendCommand(new y({payload:i})),this._logger.debug("[run] Providing optional Solana context from loaders",{data:{loadersResults:a}});for(const s of a)switch(s.type){case o.SOLANA_TOKEN:{const t=a.find(n=>n.type===o.SOLANA_TOKEN);this._logger.debug(`[run] Providing ${o.SOLANA_TOKEN}`,{data:{args:{tokenMetadataResult:t}}}),t&&await this.provideTokenMetadataContext(t);break}case o.SOLANA_LIFI:{const t=a.find(n=>n.type===o.SOLANA_LIFI);this._logger.debug(`[run] Providing ${o.SOLANA_LIFI}`,{data:{args:{lifiDescriptorListResult:t,transactionBytes:r}}}),t&&await this.provideSwapContext(t,r);break}case o.ERROR:{this._logger.debug("[run] Loader result of type ERROR, skipping");break}default:{this._logger.debug("[run] Loader result of unknown type, skipping");break}}return u}async provideTokenMetadataContext(i){const{payload:e,certificate:a}=i;if(e&&a){const r=await this.api.sendCommand(new g({certificate:a.payload,keyUsage:a.keyUsageNumber}));if(!m(r))throw new Error("[SignerSolana] ProvideSolanaTransactionContextTask: Failed to send tokenMetadataCertificate to device, latest firmware version required");await this.api.sendCommand(new l({kind:"descriptor",dataHex:e.solanaTokenDescriptor.data,signatureHex:e.solanaTokenDescriptor.signature,isFirstMessage:!0,swapSignatureTag:!1}))}}async provideSwapContext(i,e){const a=i.payload;if(a){const r=await this._normaliser.normaliseMessage(e);for(const[s,t]of r.compiledInstructions.entries()){const p=r.allKeys[t.programIdIndex]?.toBase58(),d=p?a[p]:void 0,c=d&&d.signatures[f];d&&c?await this.api.sendCommand(new l({kind:"descriptor",dataHex:d.data,signatureHex:c,isFirstMessage:s===0,swapSignatureTag:!0})):await this.api.sendCommand(new l({kind:"empty",isFirstMessage:s===0,swapSignatureTag:!0}))}}}}export{A as ProvideSolanaTransactionContextTask,f as SWAP_MODE};
2
2
  //# sourceMappingURL=ProvideTransactionContextTask.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.ts"],
4
- "sourcesContent": ["import { type PkiCertificate } from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { type Maybe, Nothing } from \"purify-ts\";\n\nimport { ProvideTLVDescriptorCommand } from \"@internal/app-binder/command/ProvideTLVDescriptorCommand\";\nimport { ProvideTrustedNamePKICommand } from \"@internal/app-binder/command/ProvideTrustedNamePKICommand\";\nimport { type SolanaAppErrorCodes } from \"@internal/app-binder/command/utils/SolanaApplicationErrors\";\n\nexport type SolanaContextForDevice = {\n descriptor: Uint8Array;\n certificate: PkiCertificate;\n};\n\nexport class ProvideSolanaTransactionContextTask {\n constructor(\n private readonly api: InternalApi,\n private readonly context: SolanaContextForDevice,\n ) {}\n\n async run(): Promise<Maybe<CommandErrorResult<SolanaAppErrorCodes>>> {\n const { descriptor, certificate } = this.context;\n const { payload: certificatePayload } = certificate;\n\n // send CAL certificate + signature\n const pkiResult = await this.api.sendCommand(\n new ProvideTrustedNamePKICommand({\n pkiBlob: certificatePayload,\n }),\n );\n if (!isSuccessCommandResult(pkiResult)) {\n throw pkiResult;\n }\n\n // send signed TLV descriptor\n const tlvResult = await this.api.sendCommand(\n new ProvideTLVDescriptorCommand({ payload: descriptor }),\n );\n if (!isSuccessCommandResult(tlvResult)) {\n throw tlvResult;\n }\n\n return Nothing;\n }\n}\n"],
5
- "mappings": "AACA,OAGE,0BAAAA,MACK,kCACP,OAAqB,WAAAC,MAAe,YAEpC,OAAS,+BAAAC,MAAmC,2DAC5C,OAAS,gCAAAC,MAAoC,4DAQtC,MAAMC,CAAoC,CAC/C,YACmBC,EACAC,EACjB,CAFiB,SAAAD,EACA,aAAAC,CAChB,CAEH,MAAM,KAA+D,CACnE,KAAM,CAAE,WAAAC,EAAY,YAAAC,CAAY,EAAI,KAAK,QACnC,CAAE,QAASC,CAAmB,EAAID,EAGlCE,EAAY,MAAM,KAAK,IAAI,YAC/B,IAAIP,EAA6B,CAC/B,QAASM,CACX,CAAC,CACH,EACA,GAAI,CAACT,EAAuBU,CAAS,EACnC,MAAMA,EAIR,MAAMC,EAAY,MAAM,KAAK,IAAI,YAC/B,IAAIT,EAA4B,CAAE,QAASK,CAAW,CAAC,CACzD,EACA,GAAI,CAACP,EAAuBW,CAAS,EACnC,MAAMA,EAGR,OAAOV,CACT,CACF",
6
- "names": ["isSuccessCommandResult", "Nothing", "ProvideTLVDescriptorCommand", "ProvideTrustedNamePKICommand", "ProvideSolanaTransactionContextTask", "api", "context", "descriptor", "certificate", "certificatePayload", "pkiResult", "tlvResult"]
4
+ "sourcesContent": ["import {\n SolanaContextTypes,\n type SolanaLifiContextSuccess,\n type SolanaTokenContextSuccess,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type InternalApi,\n isSuccessCommandResult,\n LoadCertificateCommand,\n type LoggerPublisherService,\n} from \"@ledgerhq/device-management-kit\";\nimport { type Maybe, Nothing } from \"purify-ts\";\n\nimport { ProvideTLVTransactionInstructionDescriptorCommand } from \"@internal/app-binder//command/ProvideTLVTransactionInstructionDescriptorCommand\";\nimport { ProvideTLVDescriptorCommand } from \"@internal/app-binder/command/ProvideTLVDescriptorCommand\";\nimport { type SolanaAppErrorCodes } from \"@internal/app-binder/command/utils/SolanaApplicationErrors\";\nimport {\n DefaultSolanaMessageNormaliser,\n type SolanaMessageNormaliserConstructor,\n} from \"@internal/app-binder/services/utils/DefaultSolanaMessageNormaliser\";\n\nimport { type SolanaBuildContextResult } from \"./BuildTransactionContextTask\";\n\nexport const SWAP_MODE = \"test\";\n\nexport type ProvideSolanaTransactionContextTaskArgs =\n SolanaBuildContextResult & {\n readonly transactionBytes: Uint8Array;\n readonly loggerFactory: (tag: string) => LoggerPublisherService;\n readonly normaliser?: SolanaMessageNormaliserConstructor;\n };\n\nexport class ProvideSolanaTransactionContextTask {\n private readonly _logger: LoggerPublisherService;\n private readonly _normaliser: SolanaMessageNormaliserConstructor;\n constructor(\n private readonly api: InternalApi,\n private readonly args: ProvideSolanaTransactionContextTaskArgs,\n ) {\n this._logger = args.loggerFactory(\"ProvideSolanaTransactionContextTask\");\n this._normaliser = args.normaliser ?? DefaultSolanaMessageNormaliser;\n }\n\n async run(): Promise<Maybe<CommandErrorResult<SolanaAppErrorCodes>>> {\n this._logger.debug(\"[run] Starting ProvideSolanaTransactionContextTask\");\n const {\n tlvDescriptor,\n trustedNamePKICertificate,\n loadersResults,\n transactionBytes,\n } = this.args;\n\n // --------------------------------------------------------------------\n // providing default solana context\n\n // send PKI certificate + signature\n await this.api.sendCommand(\n new LoadCertificateCommand({\n certificate: trustedNamePKICertificate.payload,\n keyUsage: trustedNamePKICertificate.keyUsageNumber,\n }),\n );\n\n // send signed descriptor\n await this.api.sendCommand(\n new ProvideTLVDescriptorCommand({ payload: tlvDescriptor }),\n );\n\n // --------------------------------------------------------------------\n // providing optional solana context via context module loaders results\n\n this._logger.debug(\"[run] Providing optional Solana context from loaders\", {\n data: { loadersResults },\n });\n for (const loaderResult of loadersResults) {\n switch (loaderResult.type) {\n // always resolve SOLANA_TOKEN first\n case SolanaContextTypes.SOLANA_TOKEN: {\n const tokenMetadataResult = loadersResults.find(\n (res) => res.type === SolanaContextTypes.SOLANA_TOKEN,\n );\n this._logger.debug(\n `[run] Providing ${SolanaContextTypes.SOLANA_TOKEN}`,\n { data: { args: { tokenMetadataResult } } },\n );\n if (tokenMetadataResult) {\n await this.provideTokenMetadataContext(tokenMetadataResult);\n }\n break;\n }\n\n case SolanaContextTypes.SOLANA_LIFI: {\n const lifiDescriptorListResult = loadersResults.find(\n (res) => res.type === SolanaContextTypes.SOLANA_LIFI,\n );\n this._logger.debug(\n `[run] Providing ${SolanaContextTypes.SOLANA_LIFI}`,\n { data: { args: { lifiDescriptorListResult, transactionBytes } } },\n );\n if (lifiDescriptorListResult) {\n await this.provideSwapContext(\n lifiDescriptorListResult,\n transactionBytes,\n );\n }\n break;\n }\n\n case SolanaContextTypes.ERROR: {\n this._logger.debug(`[run] Loader result of type ERROR, skipping`);\n break;\n }\n\n default: {\n this._logger.debug(`[run] Loader result of unknown type, skipping`);\n break;\n }\n }\n }\n\n return Nothing;\n }\n\n private async provideTokenMetadataContext(\n tokenMetadataResult: SolanaTokenContextSuccess,\n ): Promise<void> {\n const {\n payload: tokenMetadataPayload,\n certificate: tokenMetadataCertificate,\n } = tokenMetadataResult;\n\n if (tokenMetadataPayload && tokenMetadataCertificate) {\n // send token metadata certificate\n const tokenMetadataCertificateToDeviceResult = await this.api.sendCommand(\n new LoadCertificateCommand({\n certificate: tokenMetadataCertificate.payload,\n keyUsage: tokenMetadataCertificate.keyUsageNumber,\n }),\n );\n if (!isSuccessCommandResult(tokenMetadataCertificateToDeviceResult)) {\n // IMPORTANT, TO BE MAPPED TO LatestFirmwareVersionRequired(\"LatestFirmwareVersionRequired\") ERROR\n throw new Error(\n \"[SignerSolana] ProvideSolanaTransactionContextTask: Failed to send tokenMetadataCertificate to device, latest firmware version required\",\n );\n }\n\n // send token metadata signed descriptor\n await this.api.sendCommand(\n new ProvideTLVTransactionInstructionDescriptorCommand({\n kind: \"descriptor\",\n dataHex: tokenMetadataPayload.solanaTokenDescriptor.data,\n signatureHex: tokenMetadataPayload.solanaTokenDescriptor.signature,\n // token metadata is a single chunk, so this is always the first message\n isFirstMessage: true,\n swapSignatureTag: false,\n }),\n );\n }\n }\n\n private async provideSwapContext(\n lifiDescriptorListResult: SolanaLifiContextSuccess,\n transactionBytes: Uint8Array,\n ): Promise<void> {\n const lifiDescriptors = lifiDescriptorListResult.payload;\n\n if (lifiDescriptors) {\n const message = await this._normaliser.normaliseMessage(transactionBytes);\n\n for (const [\n index,\n instruction,\n ] of message.compiledInstructions.entries()) {\n const programId = message.allKeys[instruction.programIdIndex];\n const programIdStr = programId?.toBase58();\n const descriptor = programIdStr\n ? lifiDescriptors[programIdStr]\n : undefined;\n\n const sigHex = descriptor && descriptor.signatures[SWAP_MODE];\n\n if (descriptor && sigHex) {\n await this.api.sendCommand(\n new ProvideTLVTransactionInstructionDescriptorCommand({\n kind: \"descriptor\",\n dataHex: descriptor.data,\n signatureHex: sigHex,\n isFirstMessage: index === 0,\n swapSignatureTag: true,\n }),\n );\n } else {\n await this.api.sendCommand(\n new ProvideTLVTransactionInstructionDescriptorCommand({\n kind: \"empty\",\n isFirstMessage: index === 0,\n swapSignatureTag: true,\n }),\n );\n }\n }\n }\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["SolanaContextTypes", "isSuccessCommandResult", "LoadCertificateCommand", "Nothing", "ProvideTLVTransactionInstructionDescriptorCommand", "ProvideTLVDescriptorCommand", "DefaultSolanaMessageNormaliser", "SWAP_MODE", "ProvideSolanaTransactionContextTask", "api", "args", "tlvDescriptor", "trustedNamePKICertificate", "loadersResults", "transactionBytes", "loaderResult", "tokenMetadataResult", "res", "lifiDescriptorListResult", "tokenMetadataPayload", "tokenMetadataCertificate", "tokenMetadataCertificateToDeviceResult", "lifiDescriptors", "message", "index", "instruction", "programIdStr", "descriptor", "sigHex"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{CommandResultFactory as r}from"@ledgerhq/device-management-kit";import{Maybe as k,Nothing as y}from"purify-ts";import{beforeEach as v,describe as x,expect as o,it as m,vi as p}from"vitest";import{ProvideTLVDescriptorCommand as w}from"../../app-binder/command/ProvideTLVDescriptorCommand";import{ProvideTrustedNamePKICommand as T}from"../../app-binder/command/ProvideTrustedNamePKICommand";import{ProvideSolanaTransactionContextTask as c}from"./ProvideTransactionContextTask";x("ProvideSolanaTransactionContextTask",()=>{let e,t;const d=Uint8Array.from([170,170,170]),l={payload:Uint8Array.from([222,173,190,239,222,173,190,239])},i={_tag:"SomeError",errorCode:0,message:"SomeError"};v(()=>{p.resetAllMocks(),e={sendCommand:p.fn()},t={descriptor:d,certificate:l}}),m("returns Nothing when both commands succeed",async()=>{const a=r({data:k.of(null)});e.sendCommand.mockResolvedValue(a);const s=await new c(e,t).run();o(e.sendCommand).toHaveBeenCalledTimes(2);const u=e.sendCommand.mock.calls[0];o(u).toBeDefined();const C=u[0];o(C).toBeInstanceOf(T),o(C.args.pkiBlob).toStrictEqual(l.payload);const f=e.sendCommand.mock.calls[1][0];o(f).toBeInstanceOf(w),o(f.args.payload).toStrictEqual(d),o(s).toStrictEqual(y)}),m("throws error if PKI command fails",async()=>{const a=r({error:i});e.sendCommand.mockResolvedValueOnce(a);const n=new c(e,t);await o(n.run()).rejects.toBe(a),o(e.sendCommand).toHaveBeenCalledTimes(1)}),m("throws error if TLV command fails",async()=>{const a=r({data:k.of(null)}),n=r({error:i});e.sendCommand.mockResolvedValueOnce(a).mockResolvedValueOnce(n);const s=new c(e,t);await o(s.run()).rejects.toBe(n),o(e.sendCommand).toHaveBeenCalledTimes(2)})});
1
+ import{SolanaContextTypes as y}from"@ledgerhq/context-module";import{CommandResultFactory as W,LoadCertificateCommand as N}from"@ledgerhq/device-management-kit";import{ASSOCIATED_TOKEN_PROGRAM_ID as V,createAssociatedTokenAccountInstruction as Y,createTransferInstruction as X,getAssociatedTokenAddressSync as z,TOKEN_PROGRAM_ID as K}from"@solana/spl-token";import{Keypair as k,PublicKey as J,SystemProgram as P,Transaction as ae,TransactionInstruction as Q,TransactionMessage as se,VersionedTransaction as te}from"@solana/web3.js";import ne from"bs58";import{Buffer as Z}from"buffer";import{Nothing as A}from"purify-ts";import{beforeEach as oe,describe as U,expect as e,it as f,vi as h}from"vitest";import{ProvideTLVDescriptorCommand as G}from"../../app-binder/command/ProvideTLVDescriptorCommand";import{ProvideTLVTransactionInstructionDescriptorCommand as B}from"../../app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand";import{DefaultSolanaMessageNormaliser as j}from"../../app-binder/services/utils/DefaultSolanaMessageNormaliser";import{NullLoggerPublisherService as O}from"../../app-binder/services/utils/NullLoggerPublisherService";import{ProvideSolanaTransactionContextTask as I,SWAP_MODE as v}from"./ProvideTransactionContextTask";const ee=ne.encode(new Uint8Array(32).fill(170));function re(a,s,u){const d=u??s[0]??k.generate(),g=new ae;g.recentBlockhash=ee,g.feePayer=d.publicKey,g.add(...a);const p=new Set,c=[d,...s].filter(t=>{const o=t.publicKey.toBase58();return p.has(o)?!1:(p.add(o),!0)});return g.sign(...c),{raw:g.serialize(),payer:d}}function $(a,s,u){const d=u??s[0]??k.generate(),g=new se({payerKey:d.publicKey,recentBlockhash:ee,instructions:a}).compileToV0Message(),p=new te(g);return p.sign([d,...s]),{raw:p.serialize(),payer:d}}const x=a=>({toBase58:()=>a}),F=a=>({normaliseMessage:h.fn(async()=>a)});U("ProvideSolanaTransactionContextTask (merged)",()=>{let a;const s=W({data:void 0}),u={payload:new Uint8Array([240,202,204,26]),keyUsageNumber:1},d=new Uint8Array([170,187,204]),g={payload:new Uint8Array([240,202,204,26]),keyUsageNumber:2},p={data:"f0cacc1a",signature:"01020304"},c="f0cacc1a";oe(()=>{h.resetAllMocks(),a={sendCommand:h.fn()}}),U("basic context",()=>{f("sends PKI certificate then TLV descriptor and returns Nothing (no loaders results)",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:[],transactionBytes:new Uint8Array([240]),loggerFactory:O},m=await new I(a,t).run();e(a.sendCommand).toHaveBeenCalledTimes(2);const r=a.sendCommand.mock.calls[0][0];e(r).toBeInstanceOf(N),e(r.args.certificate).toStrictEqual(u.payload),e(r.args.keyUsage).toBe(u.keyUsageNumber);const i=a.sendCommand.mock.calls[1][0];e(i).toBeInstanceOf(G),e(i.args.payload).toStrictEqual(d),e(m).toStrictEqual(A)}),f("propagates a rejection thrown by InternalApi.sendCommand",async()=>{a.sendCommand.mockRejectedValueOnce(new Error("oupsy"));const t={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:[],transactionBytes:new Uint8Array([202]),loggerFactory:O},o=new I(a,t);await e(o.run()).rejects.toThrow("oupsy"),e(a.sendCommand).toHaveBeenCalledTimes(1)}),f("ignores SolanaContextTypes.ERROR entries (no extra APDUs beyond base context)",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t=[{type:y.ERROR,error:{message:"err"}}],o={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:t,transactionBytes:new Uint8Array([26]),loggerFactory:O},r=await new I(a,o).run();e(r).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(2),e(a.sendCommand.mock.calls[0][0]).toBeInstanceOf(N),e(a.sendCommand.mock.calls[1][0]).toBeInstanceOf(G)})}),U("basic context + token",()=>{f("when token metadata present, sends token certificate then TLV transaction-instruction descriptor",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g}],o={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:t,transactionBytes:new Uint8Array([26]),loggerFactory:O},r=await new I(a,o).run();e(a.sendCommand).toHaveBeenCalledTimes(4);const i=a.sendCommand.mock.calls[2][0];e(i).toBeInstanceOf(N),e(i.args.certificate).toStrictEqual(g.payload),e(i.args.keyUsage).toBe(g.keyUsageNumber);const l=a.sendCommand.mock.calls[3][0];e(l).toBeInstanceOf(B),e(l.args.kind).toBe("descriptor"),e(l.args.dataHex).toBe(p.data),e(l.args.signatureHex).toBe(p.signature),e(l.args.isFirstMessage).toBe(!0),e(l.args.swapSignatureTag).toBe(!1),e(r).toStrictEqual(A)}),f("does not send token commands if token payload is missing",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t=[{type:y.SOLANA_TOKEN,payload:void 0,certificate:g}],o={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:t,transactionBytes:new Uint8Array([240]),loggerFactory:O},r=await new I(a,o).run();e(a.sendCommand).toHaveBeenCalledTimes(2),e(r).toStrictEqual(A)}),f("does not send token commands if token certificate is missing",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:void 0}],o={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:t,transactionBytes:new Uint8Array([202]),loggerFactory:O},r=await new I(a,o).run();e(a.sendCommand).toHaveBeenCalledTimes(2),e(r).toStrictEqual(A)}),f("throws a mapped error when sending token certificate returns a CommandErrorResult",async()=>{const t=W({error:{_tag:"SomeError",errorCode:27264,message:"bad"}});a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(t);const o=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g}],m={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:o,transactionBytes:new Uint8Array([204]),loggerFactory:O},r=new I(a,m);await e(r.run()).rejects.toThrow("[SignerSolana] ProvideSolanaTransactionContextTask: Failed to send tokenMetadataCertificate to device, latest firmware version required"),e(a.sendCommand).toHaveBeenCalledTimes(3);const i=a.sendCommand.mock.calls[2][0];e(i).toBeInstanceOf(N)}),f("does not send swap APDUs when SOLANA_LIFI context is missing (token present)",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s);const t=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g}],o={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:t,transactionBytes:new Uint8Array([26]),normaliser:{normaliseMessage:h.fn()},loggerFactory:O},r=await new I(a,o).run();e(r).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(4),e(a.sendCommand.mock.calls[0][0]).toBeInstanceOf(N),e(a.sendCommand.mock.calls[1][0]).toBeInstanceOf(G),e(a.sendCommand.mock.calls[2][0]).toBeInstanceOf(N);const i=a.sendCommand.mock.calls[3][0];e(i).toBeInstanceOf(B),e(i.args.swapSignatureTag).toBe(!1),e(i.args.isFirstMessage).toBe(!0)})}),U("basic context + token + lifi",()=>{f("sends one APDU per instruction in order (descriptor/empty/descriptor) after base + token are sent",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t={compiledInstructions:[{programIdIndex:0},{programIdIndex:1},{programIdIndex:2}],allKeys:[x("A_PID"),x("B_PID"),x("C_PID")]},o=F(t),m=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{A_PID:{data:c,signatures:{[v]:c}},C_PID:{data:c,signatures:{[v]:c}}}}],r={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:m,transactionBytes:new Uint8Array([240]),normaliser:o,loggerFactory:O},l=await new I(a,r).run();e(l).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(7);const n=a.sendCommand.mock.calls[4][0];e(n).toBeInstanceOf(B),e(n.args.kind).toBe("descriptor"),e(n.args.dataHex).toBe(c),e(n.args.signatureHex).toBe(c),e(n.args.isFirstMessage).toBe(!0),e(n.args.swapSignatureTag).toBe(!0);const R=a.sendCommand.mock.calls[5][0];e(R).toBeInstanceOf(B),e(R.args.kind).toBe("empty"),e(R.args.isFirstMessage).toBe(!1),e(R.args.swapSignatureTag).toBe(!0);const T=a.sendCommand.mock.calls[6][0];e(T).toBeInstanceOf(B),e(T.args.kind).toBe("descriptor"),e(T.args.dataHex).toBe(c),e(T.args.signatureHex).toBe(c),e(T.args.isFirstMessage).toBe(!1),e(T.args.swapSignatureTag).toBe(!0),e(o.normaliseMessage).toHaveBeenCalledOnce()}),f("sends empty when descriptor exists but signatures[SWAP_MODE] is missing",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t={compiledInstructions:[{programIdIndex:0}],allKeys:[x("ONLY_PID")]},o=F(t),m=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{ONLY_PID:{data:c,signatures:{}}}}],r={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:m,transactionBytes:new Uint8Array([202]),normaliser:o,loggerFactory:O},l=await new I(a,r).run();e(l).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(5);const n=a.sendCommand.mock.calls[4][0];e(n).toBeInstanceOf(B),e(n.args.kind).toBe("empty"),e(n.args.isFirstMessage).toBe(!0),e(n.args.swapSignatureTag).toBe(!0)}),f("sends empty when programId is missing for an instruction",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t={compiledInstructions:[{programIdIndex:5}],allKeys:[x("X")]},o=F(t),m=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{}}],r={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:m,transactionBytes:new Uint8Array([204]),normaliser:o,loggerFactory:O},l=await new I(a,r).run();e(l).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(5);const n=a.sendCommand.mock.calls[4][0];e(n).toBeInstanceOf(B),e(n.args.kind).toBe("empty"),e(n.args.isFirstMessage).toBe(!0),e(n.args.swapSignatureTag).toBe(!0)}),f("propagates a rejection thrown by InternalApi.sendCommand on the second swap APDU (after base + token succeed)",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockRejectedValueOnce(new Error("err"));const t={compiledInstructions:[{programIdIndex:0},{programIdIndex:1},{programIdIndex:2}],allKeys:[x("A_PID"),x("B_PID"),x("C_PID")]},o=F(t),m=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{A_PID:{data:c,signatures:{[v]:c}},C_PID:{data:c,signatures:{[v]:c}}}}],r={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:m,transactionBytes:new Uint8Array([26]),normaliser:o,loggerFactory:O},i=new I(a,r);await e(i.run()).rejects.toThrow("err"),e(a.sendCommand).toHaveBeenCalledTimes(6);const l=a.sendCommand.mock.calls[4][0];e(l).toBeInstanceOf(B),e(l.args.kind).toBe("descriptor"),e(l.args.isFirstMessage).toBe(!0),e(l.args.swapSignatureTag).toBe(!0);const n=a.sendCommand.mock.calls[5][0];e(n).toBeInstanceOf(B),e(n.args.kind).toBe("empty"),e(n.args.isFirstMessage).toBe(!1),e(n.args.swapSignatureTag).toBe(!0)}),f("uses signatures[SWAP_MODE] specifically when present",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t={compiledInstructions:[{programIdIndex:0}],allKeys:[x("SIG_PID")]},o=F(t),m=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{SIG_PID:{data:c,signatures:{prod:"deadbeef",[v]:c}}}}],r={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:m,transactionBytes:new Uint8Array([240]),normaliser:o,loggerFactory:O},l=await new I(a,r).run();e(l).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(5);const n=a.sendCommand.mock.calls[4][0];e(n).toBeInstanceOf(B),e(n.args.kind).toBe("descriptor"),e(n.args.dataHex).toBe(c),e(n.args.signatureHex).toBe(c),e(n.args.isFirstMessage).toBe(!0),e(n.args.swapSignatureTag).toBe(!0)}),f("parses a real *legacy* tx via DefaultSolanaMessageNormaliser and preserves APDU order (descriptor, empty, descriptor) after base + token",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t=k.generate(),o=k.generate().publicKey,m=P.transfer({fromPubkey:t.publicKey,toPubkey:o,lamports:1234}),r=k.generate(),i=k.generate().publicKey,l=k.generate().publicKey,n=X(i,l,r.publicKey,42n,[],K),R=new J("MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"),T=new Q({programId:R,keys:[],data:Z.from("hi")}),{raw:D}=re([m,n,T],[t,r],t),_=P.programId.toBase58(),b=R.toBase58(),M=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{[_]:{data:c,signatures:{[v]:c}},[b]:{data:c,signatures:{[v]:c}}}}],E={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:M,transactionBytes:D,normaliser:j,loggerFactory:O},L=await new I(a,E).run();e(L).toStrictEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(7);const S=a.sendCommand.mock.calls[4][0];e(S.args.kind).toBe("descriptor"),e(S.args.isFirstMessage).toBe(!0),e(S.args.swapSignatureTag).toBe(!0);const C=a.sendCommand.mock.calls[5][0];e(C.args.kind).toBe("empty"),e(C.args.isFirstMessage).toBe(!1),e(C.args.swapSignatureTag).toBe(!0);const w=a.sendCommand.mock.calls[6][0];e(w.args.kind).toBe("descriptor"),e(w.args.isFirstMessage).toBe(!1),e(w.args.swapSignatureTag).toBe(!0)}),f("parses a real *v0* tx via DefaultSolanaMessageNormaliser (no ALTs) and preserves APDU order (descriptor, descriptor, empty) after base + token",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t=k.generate(),o=k.generate().publicKey,m=P.transfer({fromPubkey:t.publicKey,toPubkey:o,lamports:5678}),r=k.generate().publicKey,i=k.generate().publicKey,l=z(i,r,!0,K,V),n=Y(t.publicKey,l,r,i,K,V),R=new J("MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"),T=new Q({programId:R,keys:[],data:Z.from("hello")}),{raw:D}=$([m,n,T],[],t),_=P.programId.toBase58(),b=V.toBase58(),M=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{[_]:{data:c,signatures:{[v]:c}},[b]:{data:c,signatures:{[v]:c}}}}],E={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:M,transactionBytes:D,normaliser:j,loggerFactory:O},L=await new I(a,E).run();e(L).toEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(7);const S=a.sendCommand.mock.calls[4][0];e(S).toBeInstanceOf(B),e(S.args.kind).toBe("descriptor"),e(S.args.isFirstMessage).toBe(!0),e(S.args.swapSignatureTag).toBe(!0);const C=a.sendCommand.mock.calls[5][0];e(C).toBeInstanceOf(B),e(C.args.kind).toBe("descriptor"),e(C.args.isFirstMessage).toBe(!1),e(C.args.swapSignatureTag).toBe(!0);const w=a.sendCommand.mock.calls[6][0];e(w).toBeInstanceOf(B),e(w.args.kind).toBe("empty"),e(w.args.isFirstMessage).toBe(!1),e(w.args.swapSignatureTag).toBe(!0)}),f("parses a real *v0* tx via DefaultSolanaMessageNormaliser and preserves APDU order System, createATA, token transfer (descriptor, descriptor, empty) after base + token",async()=>{a.sendCommand.mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValueOnce(s).mockResolvedValue(s);const t=k.generate(),o=k.generate().publicKey,m=P.transfer({fromPubkey:t.publicKey,toPubkey:o,lamports:7777}),r=k.generate(),i=k.generate().publicKey,l=k.generate().publicKey,n=z(i,l,!0,K,V),R=Y(t.publicKey,n,l,i,K,V),T=k.generate().publicKey,D=X(T,n,r.publicKey,9n,[],K),{raw:_}=$([m,R,D],[r],t),b=P.programId.toBase58(),M=V.toBase58(),E=[{type:y.SOLANA_TOKEN,payload:{solanaTokenDescriptor:p},certificate:g},{type:y.SOLANA_LIFI,payload:{[b]:{data:c,signatures:{[v]:c}},[M]:{data:c,signatures:{[v]:c}}}}],q={trustedNamePKICertificate:u,tlvDescriptor:d,loadersResults:E,transactionBytes:_,normaliser:j,loggerFactory:O},S=await new I(a,q).run();e(S).toEqual(A),e(a.sendCommand).toHaveBeenCalledTimes(7);const C=a.sendCommand.mock.calls[4][0];e(C).toBeInstanceOf(B),e(C.args.kind).toBe("descriptor"),e(C.args.isFirstMessage).toBe(!0),e(C.args.swapSignatureTag).toBe(!0);const w=a.sendCommand.mock.calls[5][0];e(w).toBeInstanceOf(B),e(w.args.kind).toBe("descriptor"),e(w.args.isFirstMessage).toBe(!1),e(w.args.swapSignatureTag).toBe(!0);const H=a.sendCommand.mock.calls[6][0];e(H).toBeInstanceOf(B),e(H.args.kind).toBe("empty"),e(H.args.isFirstMessage).toBe(!1),e(H.args.swapSignatureTag).toBe(!0)})})});
2
2
  //# sourceMappingURL=ProvideTransactionContextTask.test.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.test.ts"],
4
- "sourcesContent": ["/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { CommandResultFactory } from \"@ledgerhq/device-management-kit\";\nimport { Maybe, Nothing } from \"purify-ts\";\nimport { beforeEach, describe, expect, it, type Mock, vi } from \"vitest\";\n\nimport { ProvideTLVDescriptorCommand } from \"@internal/app-binder/command/ProvideTLVDescriptorCommand\";\nimport { ProvideTrustedNamePKICommand } from \"@internal/app-binder/command/ProvideTrustedNamePKICommand\";\n\nimport {\n ProvideSolanaTransactionContextTask,\n type SolanaContextForDevice,\n} from \"./ProvideTransactionContextTask\";\n\ndescribe(\"ProvideSolanaTransactionContextTask\", () => {\n let fakeApi: { sendCommand: Mock };\n let context: SolanaContextForDevice;\n\n const dummyDescriptor = Uint8Array.from([0xaa, 0xaa, 0xaa]);\n const dummyCertificate: any = {\n payload: Uint8Array.from([0xde, 0xad, 0xbe, 0xef, 0xde, 0xad, 0xbe, 0xef]),\n };\n\n const mockError = { _tag: \"SomeError\", errorCode: 0, message: \"SomeError\" };\n\n beforeEach(() => {\n vi.resetAllMocks();\n fakeApi = {\n sendCommand: vi.fn(),\n };\n context = {\n descriptor: dummyDescriptor,\n certificate: dummyCertificate,\n };\n });\n\n it(\"returns Nothing when both commands succeed\", async () => {\n // given\n const successResult = CommandResultFactory({ data: Maybe.of(null) });\n fakeApi.sendCommand.mockResolvedValue(successResult);\n\n const task = new ProvideSolanaTransactionContextTask(\n fakeApi as unknown as any,\n context,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(fakeApi.sendCommand).toHaveBeenCalledTimes(2);\n\n const firstCallCall = fakeApi.sendCommand.mock.calls[0];\n expect(firstCallCall).toBeDefined();\n const firstCallArg = firstCallCall![0];\n expect(firstCallArg).toBeInstanceOf(ProvideTrustedNamePKICommand);\n expect(\n (firstCallArg as ProvideTrustedNamePKICommand).args.pkiBlob,\n ).toStrictEqual(dummyCertificate.payload);\n\n const secondCallArg = fakeApi.sendCommand.mock.calls[1]![0]!;\n expect(secondCallArg).toBeInstanceOf(ProvideTLVDescriptorCommand);\n expect(\n (secondCallArg as ProvideTLVDescriptorCommand).args.payload,\n ).toStrictEqual(dummyDescriptor);\n\n expect(result).toStrictEqual(Nothing);\n });\n\n it(\"throws error if PKI command fails\", async () => {\n const errorResult = CommandResultFactory({ error: mockError });\n fakeApi.sendCommand.mockResolvedValueOnce(errorResult);\n\n const task = new ProvideSolanaTransactionContextTask(\n fakeApi as unknown as any,\n context,\n );\n\n await expect(task.run()).rejects.toBe(errorResult);\n expect(fakeApi.sendCommand).toHaveBeenCalledTimes(1);\n });\n\n it(\"throws error if TLV command fails\", async () => {\n const successResult = CommandResultFactory({ data: Maybe.of(null) });\n const tlvErrorResult = CommandResultFactory({ error: mockError });\n\n fakeApi.sendCommand\n .mockResolvedValueOnce(successResult)\n .mockResolvedValueOnce(tlvErrorResult);\n\n const task = new ProvideSolanaTransactionContextTask(\n fakeApi as unknown as any,\n context,\n );\n\n await expect(task.run()).rejects.toBe(tlvErrorResult);\n expect(fakeApi.sendCommand).toHaveBeenCalledTimes(2);\n });\n});\n"],
5
- "mappings": "AAGA,OAAS,wBAAAA,MAA4B,kCACrC,OAAS,SAAAC,EAAO,WAAAC,MAAe,YAC/B,OAAS,cAAAC,EAAY,YAAAC,EAAU,UAAAC,EAAQ,MAAAC,EAAe,MAAAC,MAAU,SAEhE,OAAS,+BAAAC,MAAmC,2DAC5C,OAAS,gCAAAC,MAAoC,4DAE7C,OACE,uCAAAC,MAEK,kCAEPN,EAAS,sCAAuC,IAAM,CACpD,IAAIO,EACAC,EAEJ,MAAMC,EAAkB,WAAW,KAAK,CAAC,IAAM,IAAM,GAAI,CAAC,EACpDC,EAAwB,CAC5B,QAAS,WAAW,KAAK,CAAC,IAAM,IAAM,IAAM,IAAM,IAAM,IAAM,IAAM,GAAI,CAAC,CAC3E,EAEMC,EAAY,CAAE,KAAM,YAAa,UAAW,EAAG,QAAS,WAAY,EAE1EZ,EAAW,IAAM,CACfI,EAAG,cAAc,EACjBI,EAAU,CACR,YAAaJ,EAAG,GAAG,CACrB,EACAK,EAAU,CACR,WAAYC,EACZ,YAAaC,CACf,CACF,CAAC,EAEDR,EAAG,6CAA8C,SAAY,CAE3D,MAAMU,EAAgBhB,EAAqB,CAAE,KAAMC,EAAM,GAAG,IAAI,CAAE,CAAC,EACnEU,EAAQ,YAAY,kBAAkBK,CAAa,EAQnD,MAAMC,EAAS,MANF,IAAIP,EACfC,EACAC,CACF,EAG0B,IAAI,EAG9BP,EAAOM,EAAQ,WAAW,EAAE,sBAAsB,CAAC,EAEnD,MAAMO,EAAgBP,EAAQ,YAAY,KAAK,MAAM,CAAC,EACtDN,EAAOa,CAAa,EAAE,YAAY,EAClC,MAAMC,EAAeD,EAAe,CAAC,EACrCb,EAAOc,CAAY,EAAE,eAAeV,CAA4B,EAChEJ,EACGc,EAA8C,KAAK,OACtD,EAAE,cAAcL,EAAiB,OAAO,EAExC,MAAMM,EAAgBT,EAAQ,YAAY,KAAK,MAAM,CAAC,EAAG,CAAC,EAC1DN,EAAOe,CAAa,EAAE,eAAeZ,CAA2B,EAChEH,EACGe,EAA8C,KAAK,OACtD,EAAE,cAAcP,CAAe,EAE/BR,EAAOY,CAAM,EAAE,cAAcf,CAAO,CACtC,CAAC,EAEDI,EAAG,oCAAqC,SAAY,CAClD,MAAMe,EAAcrB,EAAqB,CAAE,MAAOe,CAAU,CAAC,EAC7DJ,EAAQ,YAAY,sBAAsBU,CAAW,EAErD,MAAMC,EAAO,IAAIZ,EACfC,EACAC,CACF,EAEA,MAAMP,EAAOiB,EAAK,IAAI,CAAC,EAAE,QAAQ,KAAKD,CAAW,EACjDhB,EAAOM,EAAQ,WAAW,EAAE,sBAAsB,CAAC,CACrD,CAAC,EAEDL,EAAG,oCAAqC,SAAY,CAClD,MAAMU,EAAgBhB,EAAqB,CAAE,KAAMC,EAAM,GAAG,IAAI,CAAE,CAAC,EAC7DsB,EAAiBvB,EAAqB,CAAE,MAAOe,CAAU,CAAC,EAEhEJ,EAAQ,YACL,sBAAsBK,CAAa,EACnC,sBAAsBO,CAAc,EAEvC,MAAMD,EAAO,IAAIZ,EACfC,EACAC,CACF,EAEA,MAAMP,EAAOiB,EAAK,IAAI,CAAC,EAAE,QAAQ,KAAKC,CAAc,EACpDlB,EAAOM,EAAQ,WAAW,EAAE,sBAAsB,CAAC,CACrD,CAAC,CACH,CAAC",
6
- "names": ["CommandResultFactory", "Maybe", "Nothing", "beforeEach", "describe", "expect", "it", "vi", "ProvideTLVDescriptorCommand", "ProvideTrustedNamePKICommand", "ProvideSolanaTransactionContextTask", "fakeApi", "context", "dummyDescriptor", "dummyCertificate", "mockError", "successResult", "result", "firstCallCall", "firstCallArg", "secondCallArg", "errorResult", "task", "tlvErrorResult"]
4
+ "sourcesContent": ["/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/require-await */\n/* eslint-disable @typescript-eslint/no-unsafe-return */\n\nimport { SolanaContextTypes } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n LoadCertificateCommand,\n} from \"@ledgerhq/device-management-kit\";\nimport {\n ASSOCIATED_TOKEN_PROGRAM_ID,\n createAssociatedTokenAccountInstruction,\n createTransferInstruction,\n getAssociatedTokenAddressSync,\n TOKEN_PROGRAM_ID,\n} from \"@solana/spl-token\";\nimport {\n Keypair,\n PublicKey,\n SystemProgram,\n Transaction,\n TransactionInstruction,\n TransactionMessage,\n VersionedTransaction,\n} from \"@solana/web3.js\";\nimport bs58 from \"bs58\";\nimport { Buffer } from \"buffer\";\nimport { Nothing } from \"purify-ts\";\nimport { beforeEach, describe, expect, it, type Mock, vi } from \"vitest\";\n\nimport { ProvideTLVDescriptorCommand } from \"@internal/app-binder/command/ProvideTLVDescriptorCommand\";\nimport { ProvideTLVTransactionInstructionDescriptorCommand } from \"@internal/app-binder/command/ProvideTLVTransactionInstructionDescriptorCommand\";\nimport { DefaultSolanaMessageNormaliser } from \"@internal/app-binder/services/utils/DefaultSolanaMessageNormaliser\";\nimport { NullLoggerPublisherService } from \"@internal/app-binder/services/utils/NullLoggerPublisherService\";\n\nimport {\n ProvideSolanaTransactionContextTask,\n SWAP_MODE,\n} from \"./ProvideTransactionContextTask\";\n\nconst DUMMY_BLOCKHASH = bs58.encode(new Uint8Array(32).fill(0xaa));\n\nfunction makeSignedRawLegacy(\n ixs: TransactionInstruction[],\n signers: Keypair[],\n feePayer?: Keypair,\n) {\n const payer = feePayer ?? signers[0] ?? Keypair.generate();\n const tx = new Transaction();\n tx.recentBlockhash = DUMMY_BLOCKHASH;\n tx.feePayer = payer.publicKey;\n tx.add(...ixs);\n const seen = new Set<string>();\n const uniq = [payer, ...signers].filter((kp) => {\n const k = kp.publicKey.toBase58();\n if (seen.has(k)) return false;\n seen.add(k);\n return true;\n });\n tx.sign(...uniq);\n return { raw: tx.serialize(), payer };\n}\n\nfunction makeSignedRawV0(\n ixs: TransactionInstruction[],\n signers: Keypair[],\n feePayer?: Keypair,\n) {\n const payer = feePayer ?? signers[0] ?? Keypair.generate();\n const messageV0 = new TransactionMessage({\n payerKey: payer.publicKey,\n recentBlockhash: DUMMY_BLOCKHASH,\n instructions: ixs,\n }).compileToV0Message(); // no ALTs -> offline-safe\n\n const vtx = new VersionedTransaction(messageV0);\n vtx.sign([payer, ...signers]);\n return { raw: vtx.serialize(), payer };\n}\n\nconst makeKey = (base58: string) => ({ toBase58: () => base58 });\n\nconst buildNormaliser = (message: any) =>\n ({\n normaliseMessage: vi.fn(async () => message),\n }) as const;\n\ndescribe(\"ProvideSolanaTransactionContextTask (merged)\", () => {\n let api: { sendCommand: Mock };\n const success = CommandResultFactory({ data: undefined });\n\n const baseCert = {\n payload: new Uint8Array([0xf0, 0xca, 0xcc, 0x1a]),\n keyUsageNumber: 1,\n } as const;\n const tlvDescriptor = new Uint8Array([0xaa, 0xbb, 0xcc]);\n\n const tokenCert = {\n payload: new Uint8Array([0xf0, 0xca, 0xcc, 0x1a]),\n keyUsageNumber: 2,\n } as const;\n\n const tokenDescriptor = {\n data: \"f0cacc1a\",\n signature: \"01020304\",\n } as const;\n\n const SIG = \"f0cacc1a\";\n\n beforeEach(() => {\n vi.resetAllMocks();\n api = {\n sendCommand: vi.fn(),\n };\n });\n\n // basic context\n describe(\"basic context\", () => {\n it(\"sends PKI certificate then TLV descriptor and returns Nothing (no loaders results)\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // LoadCertificateCommand (trusted name PKI)\n .mockResolvedValueOnce(success); // ProvideTLVDescriptorCommand\n\n const args = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults: [],\n transactionBytes: new Uint8Array([0xf0]), // unused in this path\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n args as any,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(api.sendCommand).toHaveBeenCalledTimes(2);\n\n const first = api.sendCommand.mock.calls[0]![0]!;\n expect(first).toBeInstanceOf(LoadCertificateCommand);\n expect(first.args.certificate).toStrictEqual(baseCert.payload);\n expect(first.args.keyUsage).toBe(baseCert.keyUsageNumber);\n\n const second = api.sendCommand.mock.calls[1]![0]!;\n expect(second).toBeInstanceOf(ProvideTLVDescriptorCommand);\n expect(second.args.payload).toStrictEqual(tlvDescriptor);\n\n expect(result).toStrictEqual(Nothing);\n });\n\n it(\"propagates a rejection thrown by InternalApi.sendCommand\", async () => {\n // given\n api.sendCommand.mockRejectedValueOnce(new Error(\"oupsy\"));\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults: [],\n transactionBytes: new Uint8Array([0xca]),\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n await expect(task.run()).rejects.toThrow(\"oupsy\");\n expect(api.sendCommand).toHaveBeenCalledTimes(1);\n });\n\n it(\"ignores SolanaContextTypes.ERROR entries (no extra APDUs beyond base context)\", async () => {\n // given: include an ERROR loader which should be ignored\n api.sendCommand\n .mockResolvedValueOnce(success) // PKI\n .mockResolvedValueOnce(success); // TLV\n\n const loadersResults = [\n { type: SolanaContextTypes.ERROR, error: { message: \"err\" } as any },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0x1a]),\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n expect(api.sendCommand).toHaveBeenCalledTimes(2);\n expect(api.sendCommand.mock.calls[0]![0]!).toBeInstanceOf(\n LoadCertificateCommand,\n );\n expect(api.sendCommand.mock.calls[1]![0]!).toBeInstanceOf(\n ProvideTLVDescriptorCommand,\n );\n });\n });\n\n // basic context + token metadata\n\n describe(\"basic context + token\", () => {\n it(\"when token metadata present, sends token certificate then TLV transaction-instruction descriptor\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI certificate\n .mockResolvedValueOnce(success) // TLV descriptor\n .mockResolvedValueOnce(success) // token metadata certificate\n .mockResolvedValueOnce(success); // token descriptor via TLVTransactionInstructionDescriptor\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: {\n solanaTokenDescriptor: tokenDescriptor,\n },\n certificate: tokenCert,\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0x1a]), // unused in this path\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(api.sendCommand).toHaveBeenCalledTimes(4);\n\n const third = api.sendCommand.mock.calls[2]![0]!;\n expect(third).toBeInstanceOf(LoadCertificateCommand);\n expect(third.args.certificate).toStrictEqual(tokenCert.payload);\n expect(third.args.keyUsage).toBe(tokenCert.keyUsageNumber);\n\n const fourth = api.sendCommand.mock.calls[3]![0]!;\n expect(fourth).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(fourth.args.kind).toBe(\"descriptor\");\n expect(fourth.args.dataHex).toBe(tokenDescriptor.data);\n expect(fourth.args.signatureHex).toBe(tokenDescriptor.signature);\n expect(fourth.args.isFirstMessage).toBe(true);\n expect(fourth.args.swapSignatureTag).toBe(false);\n\n expect(result).toStrictEqual(Nothing);\n });\n\n it(\"does not send token commands if token payload is missing\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // PKI\n .mockResolvedValueOnce(success); // TLV\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: undefined,\n certificate: tokenCert,\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xf0]),\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(api.sendCommand).toHaveBeenCalledTimes(2);\n expect(result).toStrictEqual(Nothing);\n });\n\n it(\"does not send token commands if token certificate is missing\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // PKI\n .mockResolvedValueOnce(success); // TLV\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: undefined,\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xca]),\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(api.sendCommand).toHaveBeenCalledTimes(2);\n expect(result).toStrictEqual(Nothing);\n });\n\n it(\"throws a mapped error when sending token certificate returns a CommandErrorResult\", async () => {\n // given\n const errorResult = CommandResultFactory({\n error: { _tag: \"SomeError\", errorCode: 0x6a80, message: \"bad\" },\n });\n\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(errorResult); // token certificate -> error\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xcc]),\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n // when + then\n await expect(task.run()).rejects.toThrow(\n \"[SignerSolana] ProvideSolanaTransactionContextTask: Failed to send tokenMetadataCertificate to device, latest firmware version required\",\n );\n\n // ensure the TLVTransactionInstructionDescriptor was NOT attempted\n expect(api.sendCommand).toHaveBeenCalledTimes(3);\n const third = api.sendCommand.mock.calls[2]![0]!;\n expect(third).toBeInstanceOf(LoadCertificateCommand);\n });\n\n it(\"does not send swap APDUs when SOLANA_LIFI context is missing (token present)\", async () => {\n // given: base + token succeed, but no LIFI in loadersResults\n api.sendCommand\n .mockResolvedValueOnce(success) // PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success); // token TLVTransactionInstructionDescriptor\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n // no SOLANA_LIFI entry\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0x1a]),\n normaliser: { normaliseMessage: vi.fn() } as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token only\n expect(api.sendCommand).toHaveBeenCalledTimes(4);\n expect(api.sendCommand.mock.calls[0]![0]!).toBeInstanceOf(\n LoadCertificateCommand,\n );\n expect(api.sendCommand.mock.calls[1]![0]!).toBeInstanceOf(\n ProvideTLVDescriptorCommand,\n );\n expect(api.sendCommand.mock.calls[2]![0]!).toBeInstanceOf(\n LoadCertificateCommand,\n );\n const tokenCmd = api.sendCommand.mock.calls[3]![0]!;\n expect(tokenCmd).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(tokenCmd.args.swapSignatureTag).toBe(false);\n expect(tokenCmd.args.isFirstMessage).toBe(true);\n });\n });\n\n // basic context + token + lifi (swap)\n describe(\"basic context + token + lifi\", () => {\n it(\"sends one APDU per instruction in order (descriptor/empty/descriptor) after base + token are sent\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success); // swap APDUs\n\n const message = {\n compiledInstructions: [\n { programIdIndex: 0 },\n { programIdIndex: 1 },\n { programIdIndex: 2 },\n ],\n allKeys: [makeKey(\"A_PID\"), makeKey(\"B_PID\"), makeKey(\"C_PID\")],\n };\n const normaliser = buildNormaliser(message);\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n A_PID: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n // B missing -> empty\n C_PID: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xf0]),\n normaliser: normaliser as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n // when\n const result = await task.run();\n\n // then\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token + 3 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(7);\n\n // swap calls start at index 4\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"descriptor\");\n expect(c0.args.dataHex).toBe(SIG);\n expect(c0.args.signatureHex).toBe(SIG);\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n\n const c1 = api.sendCommand.mock.calls[5]![0]!;\n expect(c1).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c1.args.kind).toBe(\"empty\");\n expect(c1.args.isFirstMessage).toBe(false);\n expect(c1.args.swapSignatureTag).toBe(true);\n\n const c2 = api.sendCommand.mock.calls[6]![0]!;\n expect(c2).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c2.args.kind).toBe(\"descriptor\");\n expect(c2.args.dataHex).toBe(SIG);\n expect(c2.args.signatureHex).toBe(SIG);\n expect(c2.args.isFirstMessage).toBe(false);\n expect(c2.args.swapSignatureTag).toBe(true);\n\n expect((normaliser as any).normaliseMessage).toHaveBeenCalledOnce();\n });\n\n it(\"sends empty when descriptor exists but signatures[SWAP_MODE] is missing\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success);\n\n const message = {\n compiledInstructions: [{ programIdIndex: 0 }],\n allKeys: [makeKey(\"ONLY_PID\")],\n };\n const normaliser = buildNormaliser(message);\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n ONLY_PID: {\n data: SIG,\n signatures: {\n // no [SWAP_MODE] key\n },\n },\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xca]),\n normaliser: normaliser as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token + 1 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(5);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"empty\");\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n });\n\n it(\"sends empty when programId is missing for an instruction\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success);\n\n const message = {\n compiledInstructions: [{ programIdIndex: 5 }], // out-of-range\n allKeys: [makeKey(\"X\")],\n };\n const normaliser = buildNormaliser(message);\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n { type: SolanaContextTypes.SOLANA_LIFI, payload: {} },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xcc]),\n normaliser: normaliser as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token + 1 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(5);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"empty\");\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n });\n\n it(\"propagates a rejection thrown by InternalApi.sendCommand on the second swap APDU (after base + token succeed)\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValueOnce(success) // 1st swap ok\n .mockRejectedValueOnce(new Error(\"err\")); // 2nd swap fails\n\n const message = {\n compiledInstructions: [\n { programIdIndex: 0 }, // descriptor\n { programIdIndex: 1 }, // empty -> rejects\n { programIdIndex: 2 }, // not reached\n ],\n allKeys: [makeKey(\"A_PID\"), makeKey(\"B_PID\"), makeKey(\"C_PID\")],\n };\n const normaliser = buildNormaliser(message);\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n A_PID: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n // B missing -> empty\n C_PID: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0x1a]),\n normaliser: normaliser as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n await expect(task.run()).rejects.toThrow(\"err\");\n // 2 base + 2 token + 2 swap (failed on 2nd)\n expect(api.sendCommand).toHaveBeenCalledTimes(6);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"descriptor\");\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n\n const c1 = api.sendCommand.mock.calls[5]![0]!;\n expect(c1).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c1.args.kind).toBe(\"empty\");\n expect(c1.args.isFirstMessage).toBe(false);\n expect(c1.args.swapSignatureTag).toBe(true);\n });\n\n it(\"uses signatures[SWAP_MODE] specifically when present\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success);\n\n const message = {\n compiledInstructions: [{ programIdIndex: 0 }],\n allKeys: [makeKey(\"SIG_PID\")],\n };\n const normaliser = buildNormaliser(message);\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n SIG_PID: {\n data: SIG,\n signatures: { prod: \"deadbeef\", [SWAP_MODE]: SIG },\n },\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: new Uint8Array([0xf0]),\n normaliser: normaliser as any,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token + 1 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(5);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"descriptor\");\n expect(c0.args.dataHex).toBe(SIG);\n expect(c0.args.signatureHex).toBe(SIG);\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n });\n\n it(\"parses a real *legacy* tx via DefaultSolanaMessageNormaliser and preserves APDU order (descriptor, empty, descriptor) after base + token\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success);\n\n const payer = Keypair.generate();\n const dest1 = Keypair.generate().publicKey;\n const ix1 = SystemProgram.transfer({\n fromPubkey: payer.publicKey,\n toPubkey: dest1,\n lamports: 1234,\n });\n\n const owner = Keypair.generate();\n const srcToken = Keypair.generate().publicKey;\n const dstToken = Keypair.generate().publicKey;\n const ix2 = createTransferInstruction(\n srcToken,\n dstToken,\n owner.publicKey,\n 42n,\n [],\n TOKEN_PROGRAM_ID,\n );\n\n const MEMO_PROGRAM_ID = new PublicKey(\n \"MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr\",\n );\n const ix3 = new TransactionInstruction({\n programId: MEMO_PROGRAM_ID,\n keys: [],\n data: Buffer.from(\"hi\"),\n });\n\n const { raw } = makeSignedRawLegacy(\n [ix1, ix2, ix3],\n [payer, owner],\n payer,\n );\n\n const SYSTEM_PID = SystemProgram.programId.toBase58();\n const MEMO_PID = MEMO_PROGRAM_ID.toBase58();\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n [SYSTEM_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n // Tokenkeg missing -> empty\n [MEMO_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: raw,\n normaliser: DefaultSolanaMessageNormaliser,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as unknown as any,\n context as any,\n );\n\n const result = await task.run();\n\n expect(result).toStrictEqual(Nothing);\n // 2 base + 2 token + 3 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(7);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0.args.kind).toBe(\"descriptor\");\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n\n const c1 = api.sendCommand.mock.calls[5]![0]!;\n expect(c1.args.kind).toBe(\"empty\");\n expect(c1.args.isFirstMessage).toBe(false);\n expect(c1.args.swapSignatureTag).toBe(true);\n\n const c2 = api.sendCommand.mock.calls[6]![0]!;\n expect(c2.args.kind).toBe(\"descriptor\");\n expect(c2.args.isFirstMessage).toBe(false);\n expect(c2.args.swapSignatureTag).toBe(true);\n });\n\n it(\"parses a real *v0* tx via DefaultSolanaMessageNormaliser (no ALTs) and preserves APDU order (descriptor, descriptor, empty) after base + token\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success);\n\n const payer = Keypair.generate();\n const sysDest = Keypair.generate().publicKey;\n const sysIx = SystemProgram.transfer({\n fromPubkey: payer.publicKey,\n toPubkey: sysDest,\n lamports: 5_678,\n });\n\n const owner = Keypair.generate().publicKey;\n const mint = Keypair.generate().publicKey;\n const ata = getAssociatedTokenAddressSync(\n mint,\n owner,\n true,\n TOKEN_PROGRAM_ID,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n );\n const ataIx = createAssociatedTokenAccountInstruction(\n payer.publicKey,\n ata,\n owner,\n mint,\n TOKEN_PROGRAM_ID,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n );\n\n const MEMO_PROGRAM_ID = new PublicKey(\n \"MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr\",\n );\n const memoIx = new TransactionInstruction({\n programId: MEMO_PROGRAM_ID,\n keys: [],\n data: Buffer.from(\"hello\"),\n });\n\n // IMPORTANT: sign only with the payer (no PublicKey in signers array)\n const { raw } = makeSignedRawV0([sysIx, ataIx, memoIx], [], payer);\n\n const SYSTEM_PID = SystemProgram.programId.toBase58();\n const ATA_PID = ASSOCIATED_TOKEN_PROGRAM_ID.toBase58();\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n [SYSTEM_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n [ATA_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n // Memo intentionally missing -> empty\n },\n },\n ];\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: raw,\n normaliser: DefaultSolanaMessageNormaliser,\n loggerFactory: NullLoggerPublisherService,\n };\n\n const task = new ProvideSolanaTransactionContextTask(\n api as any,\n context as any,\n );\n\n const res = await task.run();\n\n expect(res).toEqual(Nothing);\n // 2 base + 2 token + 3 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(7);\n\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"descriptor\"); // System\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n\n const c1 = api.sendCommand.mock.calls[5]![0]!;\n expect(c1).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c1.args.kind).toBe(\"descriptor\"); // ATA\n expect(c1.args.isFirstMessage).toBe(false);\n expect(c1.args.swapSignatureTag).toBe(true);\n\n const c2 = api.sendCommand.mock.calls[6]![0]!;\n expect(c2).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c2.args.kind).toBe(\"empty\"); // Memo missing\n expect(c2.args.isFirstMessage).toBe(false);\n expect(c2.args.swapSignatureTag).toBe(true);\n });\n\n it(\"parses a real *v0* tx via DefaultSolanaMessageNormaliser and preserves APDU order System, createATA, token transfer (descriptor, descriptor, empty) after base + token\", async () => {\n // given\n api.sendCommand\n .mockResolvedValueOnce(success) // base PKI\n .mockResolvedValueOnce(success) // TLV\n .mockResolvedValueOnce(success) // token cert\n .mockResolvedValueOnce(success) // token TLVTransactionInstructionDescriptor\n .mockResolvedValue(success); // swap APDUs\n\n const payer = Keypair.generate();\n\n const sysDest = Keypair.generate().publicKey;\n const sysIx = SystemProgram.transfer({\n fromPubkey: payer.publicKey,\n toPubkey: sysDest,\n lamports: 7_777,\n });\n\n const tokenOwner = Keypair.generate(); // owner of the source SPL token account (signer)\n const mint = Keypair.generate().publicKey;\n\n const recipientOwner = Keypair.generate().publicKey; // unfunded account (no ATA yet)\n const recipientATA = getAssociatedTokenAddressSync(\n mint,\n recipientOwner,\n true,\n TOKEN_PROGRAM_ID,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n );\n\n const createAtaIx = createAssociatedTokenAccountInstruction(\n payer.publicKey, // funder\n recipientATA, // ata to be created\n recipientOwner, // owner of the ATA\n mint,\n TOKEN_PROGRAM_ID,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n );\n\n const srcTokenAcc = Keypair.generate().publicKey; // pretend this is an existing token account\n const transferIx = createTransferInstruction(\n srcTokenAcc,\n recipientATA,\n tokenOwner.publicKey, // authority of srcTokenAcc (we will sign with tokenOwner)\n 9n,\n [],\n TOKEN_PROGRAM_ID,\n );\n\n // sign v0 with payer + tokenOwner (NO PublicKey objects in the signers array)\n const { raw } = makeSignedRawV0(\n [sysIx, createAtaIx, transferIx],\n [tokenOwner],\n payer,\n );\n\n const SYSTEM_PID = SystemProgram.programId.toBase58();\n const ATA_PID = ASSOCIATED_TOKEN_PROGRAM_ID.toBase58();\n\n const loadersResults = [\n {\n type: SolanaContextTypes.SOLANA_TOKEN,\n payload: { solanaTokenDescriptor: tokenDescriptor },\n certificate: tokenCert,\n },\n {\n type: SolanaContextTypes.SOLANA_LIFI,\n payload: {\n [SYSTEM_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n [ATA_PID]: { data: SIG, signatures: { [SWAP_MODE]: SIG } },\n // Token Program intentionally missing -> \"empty\"\n },\n },\n ];\n\n const context = {\n trustedNamePKICertificate: baseCert,\n tlvDescriptor,\n loadersResults,\n transactionBytes: raw,\n normaliser: DefaultSolanaMessageNormaliser,\n loggerFactory: NullLoggerPublisherService,\n };\n\n // when\n const task = new ProvideSolanaTransactionContextTask(\n api as any,\n context as any,\n );\n\n const res = await task.run();\n\n // then\n expect(res).toEqual(Nothing);\n // 2 base + 2 token + 3 swap\n expect(api.sendCommand).toHaveBeenCalledTimes(7);\n\n // swap calls start at index 4\n const c0 = api.sendCommand.mock.calls[4]![0]!;\n expect(c0).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c0.args.kind).toBe(\"descriptor\"); // System\n expect(c0.args.isFirstMessage).toBe(true);\n expect(c0.args.swapSignatureTag).toBe(true);\n\n const c1 = api.sendCommand.mock.calls[5]![0]!;\n expect(c1).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c1.args.kind).toBe(\"descriptor\"); // ATA\n expect(c1.args.isFirstMessage).toBe(false);\n expect(c1.args.swapSignatureTag).toBe(true);\n\n const c2 = api.sendCommand.mock.calls[6]![0]!;\n expect(c2).toBeInstanceOf(\n ProvideTLVTransactionInstructionDescriptorCommand,\n );\n expect(c2.args.kind).toBe(\"empty\"); // Token Program missing\n expect(c2.args.isFirstMessage).toBe(false);\n expect(c2.args.swapSignatureTag).toBe(true);\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": ["SolanaContextTypes", "CommandResultFactory", "LoadCertificateCommand", "ASSOCIATED_TOKEN_PROGRAM_ID", "createAssociatedTokenAccountInstruction", "createTransferInstruction", "getAssociatedTokenAddressSync", "TOKEN_PROGRAM_ID", "Keypair", "PublicKey", "SystemProgram", "Transaction", "TransactionInstruction", "TransactionMessage", "VersionedTransaction", "bs58", "Buffer", "Nothing", "beforeEach", "describe", "expect", "it", "vi", "ProvideTLVDescriptorCommand", "ProvideTLVTransactionInstructionDescriptorCommand", "DefaultSolanaMessageNormaliser", "NullLoggerPublisherService", "ProvideSolanaTransactionContextTask", "SWAP_MODE", "DUMMY_BLOCKHASH", "makeSignedRawLegacy", "ixs", "signers", "feePayer", "payer", "tx", "seen", "uniq", "kp", "k", "makeSignedRawV0", "messageV0", "vtx", "makeKey", "base58", "buildNormaliser", "message", "api", "success", "baseCert", "tlvDescriptor", "tokenCert", "tokenDescriptor", "SIG", "args", "result", "first", "second", "context", "task", "loadersResults", "third", "fourth", "errorResult", "tokenCmd", "normaliser", "c0", "c1", "c2", "dest1", "ix1", "owner", "srcToken", "dstToken", "ix2", "MEMO_PROGRAM_ID", "ix3", "raw", "SYSTEM_PID", "MEMO_PID", "sysDest", "sysIx", "mint", "ata", "ataIx", "memoIx", "ATA_PID", "res", "tokenOwner", "recipientOwner", "recipientATA", "createAtaIx", "srcTokenAcc", "transferIx"]
7
7
  }
@@ -1,2 +1,2 @@
1
- import{APDU_MAX_PAYLOAD as f,ByteArrayBuilder as m,CommandResultFactory as r,InvalidStatusWordError as i}from"@ledgerhq/device-management-kit";import{DerivationPathUtils as g}from"@ledgerhq/signer-utils";import l from"bs58";import{GetPubKeyCommand as p}from"../../app-binder/command/GetPubKeyCommand";import{SignOffChainMessageCommand as c}from"../../app-binder/command/SignOffChainMessageCommand";const y=65535;class U{constructor(e,t){this.api=e;this.args=t}async run(){const{sendingData:e,derivationPath:t}=this.args;if(e.length===0)return r({error:new i("Message cannot be empty")});if(e.length>y)return r({error:new i(`Message too long: ${e.length} bytes (max is 65535)`)});const d=g.splitPath(t),o=await this.api.sendCommand(new p({derivationPath:t,checkOnDevice:!1}));if(!("data"in o))return r({error:new i("Error getting public key from device")});const s=l.decode(o.data),a=this._buildFullMessage(e,s),n=this._buildApduCommand(a,d);return n.length>f?r({error:new i("The APDU command exceeds the maximum allowable size (255 bytes)")}):this.api.sendCommand(new c({message:n}))}_buildFullMessage(e,t){return new m().add8BitUIntToData(255).addAsciiStringToData("solana offchain").add8BitUIntToData(0).addBufferToData(new Uint8Array(32)).add8BitUIntToData(0).add8BitUIntToData(1).addBufferToData(t).add8BitUIntToData(e.length&255).add8BitUIntToData(e.length>>8&255).addBufferToData(e).build()}_buildApduCommand(e,t){const s=t.length*4,a=new m(e.length+1+1+s);return a.add8BitUIntToData(1),a.add8BitUIntToData(t.length),t.forEach(n=>{const u=new Uint8Array(4);new DataView(u.buffer).setUint32(0,n,!1),a.addBufferToData(u)}),a.addBufferToData(e),a.build()}}export{y as MAX_MESSAGE_LENGTH,U as SendSignMessageTask};
1
+ import{ByteArrayBuilder as g,CommandResultFactory as i,InvalidStatusWordError as s,isSuccessCommandResult as h}from"@ledgerhq/device-management-kit";import{DerivationPathUtils as I}from"@ledgerhq/signer-utils";import{GetPubKeyCommand as S}from"../../app-binder/command/GetPubKeyCommand";import{SignOffChainMessageCommand as b}from"../../app-binder/command/SignOffChainMessageCommand";import{DefaultBs58Encoder as U}from"../../app-binder/services/bs58Encoder";import{SendCommandInChunksTask as T}from"./SendCommandInChunksTask";const R=15*1024,v=1280,m=40,E=8,D=R-m-E,p=v-m-E,u=65515,w=126,B=32,M=10;var F=(n=>(n[n.Ascii=0]="Ascii",n[n.Utf8=1]="Utf8",n[n.Utf8LongV0=2]="Utf8LongV0",n))(F||{});const A=u;class V{constructor(t,e,n=U){this.api=t;this.args=e;this.bs58Encoder=n}async run(){const{sendingData:t,derivationPath:e}=this.args;if(t.length===0)return i({error:new s("Message cannot be empty")});if(t.length>A)return i({error:new s(`Message too long: ${t.length} bytes (max is ${A})`)});const n=I.splitPath(e),r=await this.api.sendCommand(new S({derivationPath:e,checkOnDevice:!1}));if(!("data"in r))return i({error:new s("Error getting public key from device")});const a=this.bs58Encoder.decode(r.data),f=this._buildFullMessage(t,a,!1),_=this._buildApduCommand(f,n),d=await this._sendInChunks(_);if(h(d))try{const o=this._buildEnvelopeBase58(d.data,f);return i({data:{signature:o}})}catch(o){return i({error:new s(o instanceof Error?o.message:String(o))})}const C="error"in d?d.error:void 0;if(this._isInvalidOffchainHeaderError(C)){if(t.length>p)return d;const o=this._buildFullMessage(t,a,!0),y=this._buildApduCommand(o,n),c=await this._sendInChunks(y);if(h(c))try{const l=this._buildEnvelopeBase58(c.data,o);return i({data:{signature:l}})}catch(l){return i({error:new s(l instanceof Error?l.message:String(l))})}return c}return d}_isUTF8(t){try{return new TextDecoder("utf-8",{fatal:!0}).decode(t),!0}catch{return!1}}_findMessageFormat(t,e){const n=e?p:D;if(t.length<=n){if(this._isPrintableASCII(t,e))return 0;if(this._isUTF8(t))return 1}else if(t.length<=u){if(this._isUTF8(t))return 2}else throw new s(`Message too long: ${t.length} bytes (max is ${u})`);return 0}_isPrintableASCII(t,e){for(let n=0;n<t.length;n++){const r=t[n];if(!(!e&&r===M)&&(r<B||r>w))return!1}return!0}_buildFullMessage(t,e,n){const r=this._findMessageFormat(t,n),a=new g;return a.add8BitUIntToData(255).addAsciiStringToData("solana offchain"),a.add8BitUIntToData(0),n||a.addBufferToData(new Uint8Array(32)),a.add8BitUIntToData(r),n||(a.add8BitUIntToData(1),a.addBufferToData(e)),a.add8BitUIntToData(t.length&255),a.add8BitUIntToData(t.length>>8&255),a.addBufferToData(t),a.build()}_isInvalidOffchainHeaderError(t){if(!t||typeof t!="object")return!1;const e=t,n=e._tag,r=e.errorCode;return typeof n=="string"&&typeof r=="string"&&r.toLowerCase()==="6a81"}_buildApduCommand(t,e){const n=new g(2+e.length*4+t.length);return n.add8BitUIntToData(1),n.add8BitUIntToData(e.length),e.forEach(r=>n.add32BitUIntToData(r)),n.addBufferToData(t),n.build()}async _sendInChunks(t){const e=n=>new b(n);return await new T(this.api,{data:t,commandFactory:e}).run()}_buildEnvelopeBase58(t,e){if(t.length!==64)throw new s(`Invalid signature length: ${t.length} (expected 64)`);const n=Uint8Array.of(1),r=new Uint8Array(n.length+t.length+e.length);return r.set(n,0),r.set(t,n.length),r.set(e,n.length+t.length),this.bs58Encoder.encode(r)}}export{A as MAX_MESSAGE_LENGTH,F as MessageFormat,V as SendSignMessageTask};
2
2
  //# sourceMappingURL=SendSignMessageTask.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/internal/app-binder/task/SendSignMessageTask.ts"],
4
- "sourcesContent": ["import {\n APDU_MAX_PAYLOAD,\n ByteArrayBuilder,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n} from \"@ledgerhq/device-management-kit\";\nimport { DerivationPathUtils } from \"@ledgerhq/signer-utils\";\nimport bs58 from \"bs58\";\n\nimport { type Signature } from \"@api/index\";\nimport { GetPubKeyCommand } from \"@internal/app-binder/command/GetPubKeyCommand\";\nimport { SignOffChainMessageCommand } from \"@internal/app-binder/command/SignOffChainMessageCommand\";\nimport { type SolanaAppErrorCodes } from \"@internal/app-binder/command/utils/SolanaApplicationErrors\";\n\nexport type SendSignMessageTaskArgs = {\n sendingData: Uint8Array;\n derivationPath: string;\n};\n\nexport type SendSignMessageTaskRunFunctionReturn = Promise<\n CommandResult<Signature, SolanaAppErrorCodes>\n>;\n\nexport const MAX_MESSAGE_LENGTH = 0xffff;\n\nexport class SendSignMessageTask {\n constructor(\n private api: InternalApi,\n private args: SendSignMessageTaskArgs,\n ) {}\n\n async run(): SendSignMessageTaskRunFunctionReturn {\n const { sendingData, derivationPath } = this.args;\n\n if (sendingData.length === 0) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\"Message cannot be empty\"),\n });\n }\n\n if (sendingData.length > MAX_MESSAGE_LENGTH) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n `Message too long: ${sendingData.length} bytes (max is 65535)`,\n ),\n });\n }\n\n const pathIndexes = DerivationPathUtils.splitPath(derivationPath);\n\n const pubkeyResult = await this.api.sendCommand(\n new GetPubKeyCommand({ derivationPath, checkOnDevice: false }),\n );\n\n if (!(\"data\" in pubkeyResult)) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n \"Error getting public key from device\",\n ),\n });\n }\n\n const signerPubkey = bs58.decode(pubkeyResult.data);\n const fullMessage = this._buildFullMessage(sendingData, signerPubkey);\n const commandBuffer = this._buildApduCommand(fullMessage, pathIndexes);\n\n if (commandBuffer.length > APDU_MAX_PAYLOAD) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n \"The APDU command exceeds the maximum allowable size (255 bytes)\",\n ),\n });\n }\n\n return this.api.sendCommand(\n new SignOffChainMessageCommand({ message: commandBuffer }),\n );\n }\n\n /**\n * builds the serialised off-chain message header and body\n */\n private _buildFullMessage(\n sendingData: Uint8Array,\n signerPubkey: Uint8Array,\n ): Uint8Array {\n return (\n new ByteArrayBuilder()\n // 0xFF + prefix\n .add8BitUIntToData(0xff)\n .addAsciiStringToData(\"solana offchain\")\n // version = 0\n .add8BitUIntToData(0)\n // domain = 32 zeros\n .addBufferToData(new Uint8Array(32))\n // format = 0\n .add8BitUIntToData(0)\n // signer count = 1\n .add8BitUIntToData(1)\n // signer pubkey (32 bytes)\n .addBufferToData(signerPubkey)\n // message length (2 bytes, little endian)\n .add8BitUIntToData(sendingData.length & 0xff)\n .add8BitUIntToData((sendingData.length >> 8) & 0xff)\n // message body\n .addBufferToData(sendingData)\n .build()\n );\n }\n\n /**\n * builds the APDU command to send to the device\n */\n private _buildApduCommand(\n fullMessage: Uint8Array,\n paths: number[],\n ): Uint8Array {\n const numberOfSigners = 1;\n const derivationCount = 1;\n const pathBytes = paths.length * 4;\n const builder = new ByteArrayBuilder(\n fullMessage.length + numberOfSigners + derivationCount + pathBytes,\n );\n\n // number of signers\n builder.add8BitUIntToData(numberOfSigners);\n // number of BIP32 derivations\n builder.add8BitUIntToData(paths.length);\n // each derivation index\n paths.forEach((idx) => {\n const buf = new Uint8Array(4);\n new DataView(buf.buffer).setUint32(0, idx, false);\n builder.addBufferToData(buf);\n });\n // serialised off-chain message\n builder.addBufferToData(fullMessage);\n\n return builder.build();\n }\n}\n"],
5
- "mappings": "AAAA,OACE,oBAAAA,EACA,oBAAAC,EAEA,wBAAAC,EAEA,0BAAAC,MACK,kCACP,OAAS,uBAAAC,MAA2B,yBACpC,OAAOC,MAAU,OAGjB,OAAS,oBAAAC,MAAwB,gDACjC,OAAS,8BAAAC,MAAkC,0DAYpC,MAAMC,EAAqB,MAE3B,MAAMC,CAAoB,CAC/B,YACUC,EACAC,EACR,CAFQ,SAAAD,EACA,UAAAC,CACP,CAEH,MAAM,KAA4C,CAChD,KAAM,CAAE,YAAAC,EAAa,eAAAC,CAAe,EAAI,KAAK,KAE7C,GAAID,EAAY,SAAW,EACzB,OAAOV,EAAqB,CAC1B,MAAO,IAAIC,EAAuB,yBAAyB,CAC7D,CAAC,EAGH,GAAIS,EAAY,OAASJ,EACvB,OAAON,EAAqB,CAC1B,MAAO,IAAIC,EACT,qBAAqBS,EAAY,MAAM,uBACzC,CACF,CAAC,EAGH,MAAME,EAAcV,EAAoB,UAAUS,CAAc,EAE1DE,EAAe,MAAM,KAAK,IAAI,YAClC,IAAIT,EAAiB,CAAE,eAAAO,EAAgB,cAAe,EAAM,CAAC,CAC/D,EAEA,GAAI,EAAE,SAAUE,GACd,OAAOb,EAAqB,CAC1B,MAAO,IAAIC,EACT,sCACF,CACF,CAAC,EAGH,MAAMa,EAAeX,EAAK,OAAOU,EAAa,IAAI,EAC5CE,EAAc,KAAK,kBAAkBL,EAAaI,CAAY,EAC9DE,EAAgB,KAAK,kBAAkBD,EAAaH,CAAW,EAErE,OAAII,EAAc,OAASlB,EAClBE,EAAqB,CAC1B,MAAO,IAAIC,EACT,iEACF,CACF,CAAC,EAGI,KAAK,IAAI,YACd,IAAII,EAA2B,CAAE,QAASW,CAAc,CAAC,CAC3D,CACF,CAKQ,kBACNN,EACAI,EACY,CACZ,OACE,IAAIf,EAAiB,EAElB,kBAAkB,GAAI,EACtB,qBAAqB,iBAAiB,EAEtC,kBAAkB,CAAC,EAEnB,gBAAgB,IAAI,WAAW,EAAE,CAAC,EAElC,kBAAkB,CAAC,EAEnB,kBAAkB,CAAC,EAEnB,gBAAgBe,CAAY,EAE5B,kBAAkBJ,EAAY,OAAS,GAAI,EAC3C,kBAAmBA,EAAY,QAAU,EAAK,GAAI,EAElD,gBAAgBA,CAAW,EAC3B,MAAM,CAEb,CAKQ,kBACNK,EACAE,EACY,CAGZ,MAAMC,EAAYD,EAAM,OAAS,EAC3BE,EAAU,IAAIpB,EAClBgB,EAAY,OAAS,EAAkB,EAAkBG,CAC3D,EAGA,OAAAC,EAAQ,kBAAkB,CAAe,EAEzCA,EAAQ,kBAAkBF,EAAM,MAAM,EAEtCA,EAAM,QAASG,GAAQ,CACrB,MAAMC,EAAM,IAAI,WAAW,CAAC,EAC5B,IAAI,SAASA,EAAI,MAAM,EAAE,UAAU,EAAGD,EAAK,EAAK,EAChDD,EAAQ,gBAAgBE,CAAG,CAC7B,CAAC,EAEDF,EAAQ,gBAAgBJ,CAAW,EAE5BI,EAAQ,MAAM,CACvB,CACF",
6
- "names": ["APDU_MAX_PAYLOAD", "ByteArrayBuilder", "CommandResultFactory", "InvalidStatusWordError", "DerivationPathUtils", "bs58", "GetPubKeyCommand", "SignOffChainMessageCommand", "MAX_MESSAGE_LENGTH", "SendSignMessageTask", "api", "args", "sendingData", "derivationPath", "pathIndexes", "pubkeyResult", "signerPubkey", "fullMessage", "commandBuffer", "paths", "pathBytes", "builder", "idx", "buf"]
4
+ "sourcesContent": ["import {\n ByteArrayBuilder,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { DerivationPathUtils } from \"@ledgerhq/signer-utils\";\n\nimport { GetPubKeyCommand } from \"@internal/app-binder/command/GetPubKeyCommand\";\nimport {\n SignOffChainMessageCommand,\n type SignOffChainRawResponse,\n} from \"@internal/app-binder/command/SignOffChainMessageCommand\";\nimport { type SolanaAppErrorCodes } from \"@internal/app-binder/command/utils/SolanaApplicationErrors\";\nimport {\n type Bs58Encoder,\n DefaultBs58Encoder,\n} from \"@internal/app-binder/services/bs58Encoder\";\n\nimport {\n type CommandFactory,\n SendCommandInChunksTask,\n} from \"./SendCommandInChunksTask\";\n\nconst DEVICE_V0_PAYLOAD_CEILING = 15 * 1024; // 15360\nconst DEVICE_LEGACY_PAYLOAD_CEILING = 1280;\n\n// bytes reserved by app/header and transport\nconst RESERVED_HEADER_BYTES = 40;\nconst RESERVED_TRANSPORT_BYTES = 8;\n\n// derived usable body sizes\nconst OFFCHAINMSG_MAX_LEN =\n DEVICE_V0_PAYLOAD_CEILING - RESERVED_HEADER_BYTES - RESERVED_TRANSPORT_BYTES; // 15312\n\nconst LEGACY_OFFCHAINMSG_MAX_LEN =\n DEVICE_LEGACY_PAYLOAD_CEILING -\n RESERVED_HEADER_BYTES -\n RESERVED_TRANSPORT_BYTES; // 1232\n\n// device cap for v0 long UTF-8\nconst OFFCHAINMSG_MAX_V0_LEN = 65515;\n\nconst MAX_PRINTABLE_ASCII = 0x7e;\nconst MIN_PRINTABLE_ASCII = 0x20;\nconst LINE_FEED_ASCII = 0x0a;\n\nexport enum MessageFormat {\n Ascii = 0,\n Utf8 = 1,\n Utf8LongV0 = 2,\n}\n\nexport const MAX_MESSAGE_LENGTH = OFFCHAINMSG_MAX_V0_LEN;\n\nexport type SendSignMessageTaskArgs = {\n sendingData: Uint8Array;\n derivationPath: string;\n};\n\nexport type SendSignMessageTaskRunFunctionReturn = Promise<\n CommandResult<{ signature: string }, SolanaAppErrorCodes>\n>;\n\nexport class SendSignMessageTask {\n constructor(\n private api: InternalApi,\n private args: SendSignMessageTaskArgs,\n private readonly bs58Encoder: Bs58Encoder = DefaultBs58Encoder,\n ) {}\n\n async run(): SendSignMessageTaskRunFunctionReturn {\n const { sendingData, derivationPath } = this.args;\n\n if (sendingData.length === 0) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\"Message cannot be empty\"),\n });\n }\n if (sendingData.length > MAX_MESSAGE_LENGTH) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n `Message too long: ${sendingData.length} bytes (max is ${MAX_MESSAGE_LENGTH})`,\n ),\n });\n }\n\n const paths = DerivationPathUtils.splitPath(derivationPath);\n\n const pubkeyResult = await this.api.sendCommand(\n new GetPubKeyCommand({ derivationPath, checkOnDevice: false }),\n );\n if (!(\"data\" in pubkeyResult)) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n \"Error getting public key from device\",\n ),\n });\n }\n const signerPubkey = this.bs58Encoder.decode(pubkeyResult.data);\n\n // try v0 first\n const v0OCM = this._buildFullMessage(sendingData, signerPubkey, false);\n const v0Payload = this._buildApduCommand(v0OCM, paths);\n const v0Res = await this._sendInChunks(v0Payload);\n\n if (isSuccessCommandResult(v0Res)) {\n try {\n const sigB58 = this._buildEnvelopeBase58(v0Res.data, v0OCM);\n return CommandResultFactory({ data: { signature: sigB58 } });\n } catch (e) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n e instanceof Error ? e.message : String(e),\n ),\n });\n }\n }\n\n // if the app says header invalid, try legacy\n const v0Error: unknown =\n \"error\" in v0Res ? (v0Res as { error: unknown }).error : undefined;\n\n if (this._isInvalidOffchainHeaderError(v0Error)) {\n if (sendingData.length > LEGACY_OFFCHAINMSG_MAX_LEN) {\n return v0Res;\n }\n\n const legacyOCM = this._buildFullMessage(sendingData, signerPubkey, true);\n const legacyPayload = this._buildApduCommand(legacyOCM, paths);\n const legacyRes = await this._sendInChunks(legacyPayload);\n\n if (isSuccessCommandResult(legacyRes)) {\n try {\n const sigB58 = this._buildEnvelopeBase58(legacyRes.data, legacyOCM);\n return CommandResultFactory({ data: { signature: sigB58 } });\n } catch (e) {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n e instanceof Error ? e.message : String(e),\n ),\n });\n }\n }\n return legacyRes;\n }\n\n return v0Res;\n }\n\n private _isUTF8(buf: Uint8Array): boolean {\n try {\n new TextDecoder(\"utf-8\", { fatal: true }).decode(buf);\n return true;\n } catch {\n return false;\n }\n }\n\n private _findMessageFormat(\n message: Uint8Array,\n isLegacy: boolean,\n ): MessageFormat {\n const maxLedgerLen = isLegacy\n ? LEGACY_OFFCHAINMSG_MAX_LEN\n : OFFCHAINMSG_MAX_LEN;\n\n if (message.length <= maxLedgerLen) {\n if (this._isPrintableASCII(message, isLegacy)) return MessageFormat.Ascii;\n if (this._isUTF8(message)) return MessageFormat.Utf8;\n } else if (message.length <= OFFCHAINMSG_MAX_V0_LEN) {\n if (this._isUTF8(message)) return MessageFormat.Utf8LongV0;\n } else {\n // unreachable if run() guards length\n throw new InvalidStatusWordError(\n `Message too long: ${message.length} bytes (max is ${OFFCHAINMSG_MAX_V0_LEN})`,\n );\n }\n // default to ASCII like legacy\n return MessageFormat.Ascii;\n }\n\n private _isPrintableASCII(buf: Uint8Array, isLegacy: boolean): boolean {\n for (let i = 0; i < buf.length; i++) {\n const ch: number = buf[i]!;\n if (!isLegacy && ch === LINE_FEED_ASCII) continue; // newline allowed only for non-legacy\n if (ch < MIN_PRINTABLE_ASCII || ch > MAX_PRINTABLE_ASCII) return false;\n }\n return true;\n }\n\n /**\n * build serialised off-chain message header + body\n * when `isLegacy` is true, build the short legacy header (no app-domain or signers).\n */\n private _buildFullMessage(\n messageBody: Uint8Array,\n signerPubkey: Uint8Array,\n isLegacy: boolean,\n ): Uint8Array {\n const format: MessageFormat = this._findMessageFormat(\n messageBody,\n isLegacy,\n );\n\n const builder = new ByteArrayBuilder();\n\n // signing domain: 0xFF + \"solana offchain\" (16 bytes)\n builder.add8BitUIntToData(0xff).addAsciiStringToData(\"solana offchain\");\n\n // header version = 0\n builder.add8BitUIntToData(0);\n\n if (!isLegacy) {\n // application domain = 32 zeros\n builder.addBufferToData(new Uint8Array(32));\n }\n\n // message format\n builder.add8BitUIntToData(format);\n\n if (!isLegacy) {\n // signer count = 1\n builder.add8BitUIntToData(1);\n // signer pubkey (32 bytes)\n builder.addBufferToData(signerPubkey);\n }\n\n // message length (LE, 2 bytes)\n builder.add8BitUIntToData(messageBody.length & 0xff);\n builder.add8BitUIntToData((messageBody.length >> 8) & 0xff);\n\n // message body\n builder.addBufferToData(messageBody);\n\n return builder.build();\n }\n\n // guard for the device\u2019s 0x6A81 \u201CInvalid off-chain message header\u201D error\n private _isInvalidOffchainHeaderError(\n e: unknown,\n ): e is { _tag: string; errorCode: string } {\n if (!e || typeof e !== \"object\") return false;\n const obj = e as Record<string, unknown>;\n const tag = obj[\"_tag\"];\n const code = obj[\"errorCode\"];\n return (\n typeof tag === \"string\" &&\n typeof code === \"string\" &&\n code.toLowerCase() === \"6a81\"\n );\n }\n\n /**\n * build APDU payload:\n * [signerCount=1][derivationsCount][each 4-byte index][OCM message]\n */\n private _buildApduCommand(\n fullMessage: Uint8Array,\n paths: number[],\n ): Uint8Array {\n const builder = new ByteArrayBuilder(\n 1 + 1 + paths.length * 4 + fullMessage.length,\n );\n\n builder.add8BitUIntToData(1); // number of signers\n builder.add8BitUIntToData(paths.length); // number of derivations\n paths.forEach((idx) => builder.add32BitUIntToData(idx)); // big-endian\n builder.addBufferToData(fullMessage);\n\n return builder.build(); // larger than 255 is ok, SendCommandInChunksTask will chunk it\n }\n\n // send APDU payload using chunk task, return raw 64-byte signature (last chunk)\n private async _sendInChunks(\n apduPayload: Uint8Array,\n ): Promise<CommandResult<SignOffChainRawResponse, SolanaAppErrorCodes>> {\n const commandFactory: CommandFactory<SignOffChainRawResponse> = (\n chunkArgs,\n ) => new SignOffChainMessageCommand(chunkArgs);\n\n return await new SendCommandInChunksTask<SignOffChainRawResponse>(\n this.api,\n {\n data: apduPayload,\n commandFactory,\n },\n ).run();\n }\n\n // build base58 OCM envelope: [signatureCount=1][signature(64)][serialized OCM]\n private _buildEnvelopeBase58(\n rawSignature: Uint8Array,\n serializedOCM: Uint8Array,\n ): string {\n if (rawSignature.length !== 64) {\n throw new InvalidStatusWordError(\n `Invalid signature length: ${rawSignature.length} (expected 64)`,\n );\n }\n const sigCount = Uint8Array.of(1);\n const envelope = new Uint8Array(\n sigCount.length + rawSignature.length + serializedOCM.length,\n );\n envelope.set(sigCount, 0);\n envelope.set(rawSignature, sigCount.length);\n envelope.set(serializedOCM, sigCount.length + rawSignature.length);\n return this.bs58Encoder.encode(envelope);\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["ByteArrayBuilder", "CommandResultFactory", "InvalidStatusWordError", "isSuccessCommandResult", "DerivationPathUtils", "GetPubKeyCommand", "SignOffChainMessageCommand", "DefaultBs58Encoder", "SendCommandInChunksTask", "DEVICE_V0_PAYLOAD_CEILING", "DEVICE_LEGACY_PAYLOAD_CEILING", "RESERVED_HEADER_BYTES", "RESERVED_TRANSPORT_BYTES", "OFFCHAINMSG_MAX_LEN", "LEGACY_OFFCHAINMSG_MAX_LEN", "OFFCHAINMSG_MAX_V0_LEN", "MAX_PRINTABLE_ASCII", "MIN_PRINTABLE_ASCII", "LINE_FEED_ASCII", "MessageFormat", "MAX_MESSAGE_LENGTH", "SendSignMessageTask", "api", "args", "bs58Encoder", "sendingData", "derivationPath", "paths", "pubkeyResult", "signerPubkey", "v0OCM", "v0Payload", "v0Res", "sigB58", "e", "v0Error", "legacyOCM", "legacyPayload", "legacyRes", "buf", "message", "isLegacy", "maxLedgerLen", "i", "ch", "messageBody", "format", "builder", "obj", "tag", "code", "fullMessage", "idx", "apduPayload", "commandFactory", "chunkArgs", "rawSignature", "serializedOCM", "sigCount", "envelope"]
7
7
  }