@bitgo-beta/sdk-coin-sol 7.6.4-beta.31 → 7.6.4-beta.310

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 (395) hide show
  1. package/dist/cjs/src/bigint-buffer-guard.d.ts.map +1 -0
  2. package/dist/cjs/src/bigint-buffer-guard.js +29 -0
  3. package/dist/cjs/src/config/token2022StaticConfig.d.ts.map +1 -0
  4. package/dist/cjs/src/config/token2022StaticConfig.js +50 -0
  5. package/dist/cjs/src/index.d.ts.map +1 -0
  6. package/dist/{src → cjs/src}/index.js +1 -1
  7. package/dist/cjs/src/lib/ataInitializationBuilder.d.ts.map +1 -0
  8. package/dist/cjs/src/lib/ataInitializationBuilder.js +196 -0
  9. package/dist/cjs/src/lib/closeAtaBuilder.d.ts.map +1 -0
  10. package/dist/cjs/src/lib/closeAtaBuilder.js +69 -0
  11. package/dist/{src → cjs/src}/lib/constants.d.ts +24 -0
  12. package/dist/cjs/src/lib/constants.d.ts.map +1 -0
  13. package/dist/cjs/src/lib/constants.js +196 -0
  14. package/dist/cjs/src/lib/customInstructionBuilder.d.ts.map +1 -0
  15. package/dist/cjs/src/lib/customInstructionBuilder.js +289 -0
  16. package/dist/cjs/src/lib/explainTransactionWasm.d.ts +21 -0
  17. package/dist/cjs/src/lib/explainTransactionWasm.d.ts.map +1 -0
  18. package/dist/cjs/src/lib/explainTransactionWasm.js +264 -0
  19. package/dist/{src → cjs/src}/lib/iface.d.ts +20 -2
  20. package/dist/cjs/src/lib/iface.d.ts.map +1 -0
  21. package/dist/cjs/src/lib/iface.js +7 -0
  22. package/dist/{src → cjs/src}/lib/index.d.ts +1 -0
  23. package/dist/cjs/src/lib/index.d.ts.map +1 -0
  24. package/dist/{src → cjs/src}/lib/index.js +4 -2
  25. package/dist/{src → cjs/src}/lib/instructionParamsFactory.d.ts +1 -0
  26. package/dist/cjs/src/lib/instructionParamsFactory.d.ts.map +1 -0
  27. package/dist/cjs/src/lib/instructionParamsFactory.js +1059 -0
  28. package/dist/cjs/src/lib/jitoStakePoolOperations.d.ts.map +1 -0
  29. package/dist/cjs/src/lib/jitoStakePoolOperations.js +200 -0
  30. package/dist/cjs/src/lib/keyPair.d.ts.map +1 -0
  31. package/dist/cjs/src/lib/keyPair.js +63 -0
  32. package/dist/cjs/src/lib/messages/index.d.ts.map +1 -0
  33. package/dist/{src → cjs/src}/lib/messages/index.js +1 -1
  34. package/dist/cjs/src/lib/messages/messageBuilderFactory.d.ts.map +1 -0
  35. package/dist/cjs/src/lib/messages/messageBuilderFactory.js +19 -0
  36. package/dist/cjs/src/lib/recoverNestedAtaBuilder.d.ts +25 -0
  37. package/dist/cjs/src/lib/recoverNestedAtaBuilder.d.ts.map +1 -0
  38. package/dist/cjs/src/lib/recoverNestedAtaBuilder.js +90 -0
  39. package/dist/cjs/src/lib/solInstructionFactory.d.ts.map +1 -0
  40. package/dist/cjs/src/lib/solInstructionFactory.js +595 -0
  41. package/dist/cjs/src/lib/stakingActivateBuilder.d.ts.map +1 -0
  42. package/dist/cjs/src/lib/stakingActivateBuilder.js +120 -0
  43. package/dist/cjs/src/lib/stakingAuthorizeBuilder.d.ts.map +1 -0
  44. package/dist/cjs/src/lib/stakingAuthorizeBuilder.js +89 -0
  45. package/dist/cjs/src/lib/stakingDeactivateBuilder.d.ts.map +1 -0
  46. package/dist/cjs/src/lib/stakingDeactivateBuilder.js +208 -0
  47. package/dist/cjs/src/lib/stakingDelegateBuilder.d.ts.map +1 -0
  48. package/dist/cjs/src/lib/stakingDelegateBuilder.js +120 -0
  49. package/dist/cjs/src/lib/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -0
  50. package/dist/cjs/src/lib/stakingRawMsgAuthorizeBuilder.js +110 -0
  51. package/dist/cjs/src/lib/stakingWithdrawBuilder.d.ts.map +1 -0
  52. package/dist/cjs/src/lib/stakingWithdrawBuilder.js +78 -0
  53. package/dist/cjs/src/lib/token2022Config.d.ts.map +1 -0
  54. package/dist/cjs/src/lib/token2022Config.js +27 -0
  55. package/dist/cjs/src/lib/tokenTransferBuilder.d.ts.map +1 -0
  56. package/dist/cjs/src/lib/tokenTransferBuilder.js +188 -0
  57. package/dist/cjs/src/lib/transaction.d.ts.map +1 -0
  58. package/dist/cjs/src/lib/transaction.js +612 -0
  59. package/dist/cjs/src/lib/transactionBuilder.d.ts.map +1 -0
  60. package/dist/cjs/src/lib/transactionBuilder.js +380 -0
  61. package/dist/{src → cjs/src}/lib/transactionBuilderFactory.d.ts +5 -0
  62. package/dist/cjs/src/lib/transactionBuilderFactory.d.ts.map +1 -0
  63. package/dist/cjs/src/lib/transactionBuilderFactory.js +209 -0
  64. package/dist/cjs/src/lib/transferBuilder.d.ts.map +1 -0
  65. package/dist/cjs/src/lib/transferBuilder.js +70 -0
  66. package/dist/cjs/src/lib/transferBuilderV2.d.ts.map +1 -0
  67. package/dist/cjs/src/lib/transferBuilderV2.js +210 -0
  68. package/dist/cjs/src/lib/utils.d.ts.map +1 -0
  69. package/dist/cjs/src/lib/utils.js +595 -0
  70. package/dist/cjs/src/lib/walletInitializationBuilder.d.ts.map +1 -0
  71. package/dist/cjs/src/lib/walletInitializationBuilder.js +71 -0
  72. package/dist/cjs/src/register.d.ts.map +1 -0
  73. package/dist/cjs/src/register.js +15 -0
  74. package/dist/{src → cjs/src}/sol.d.ts +40 -0
  75. package/dist/cjs/src/sol.d.ts.map +1 -0
  76. package/dist/cjs/src/sol.js +1402 -0
  77. package/dist/cjs/src/solToken.d.ts.map +1 -0
  78. package/dist/cjs/src/solToken.js +69 -0
  79. package/dist/cjs/src/tsol.d.ts.map +1 -0
  80. package/dist/cjs/src/tsol.js +24 -0
  81. package/dist/{test → cjs/test}/fixtures/sol.d.ts.map +1 -1
  82. package/dist/cjs/test/fixtures/sol.js +1433 -0
  83. package/dist/{test → cjs/test}/resources/sol.d.ts +27 -27
  84. package/dist/cjs/test/resources/sol.d.ts.map +1 -0
  85. package/dist/cjs/test/resources/sol.js +320 -0
  86. package/dist/cjs/test/unit/explainTransactionWasm.d.ts +5 -0
  87. package/dist/cjs/test/unit/explainTransactionWasm.d.ts.map +1 -0
  88. package/dist/cjs/test/unit/explainTransactionWasm.js +26 -0
  89. package/dist/cjs/test/unit/fixtures/solBackupKey.d.ts.map +1 -0
  90. package/dist/cjs/test/unit/fixtures/solBackupKey.js +8 -0
  91. package/dist/cjs/test/unit/getBuilderFactory.d.ts.map +1 -0
  92. package/dist/cjs/test/unit/getBuilderFactory.js +10 -0
  93. package/dist/cjs/test/unit/instructionParamsFactory.d.ts.map +1 -0
  94. package/dist/cjs/test/unit/instructionParamsFactory.js +412 -0
  95. package/dist/cjs/test/unit/instructionParamsFactory.staking.d.ts.map +1 -0
  96. package/dist/cjs/test/unit/instructionParamsFactory.staking.js +1059 -0
  97. package/dist/cjs/test/unit/jitoWasmVerification.d.ts +2 -0
  98. package/dist/cjs/test/unit/jitoWasmVerification.d.ts.map +1 -0
  99. package/dist/cjs/test/unit/jitoWasmVerification.js +78 -0
  100. package/dist/{test → cjs/test}/unit/keyPair.d.ts.map +1 -1
  101. package/dist/cjs/test/unit/keyPair.js +177 -0
  102. package/dist/cjs/test/unit/messages/messageBuilderFactory.d.ts.map +1 -0
  103. package/dist/cjs/test/unit/messages/messageBuilderFactory.js +118 -0
  104. package/dist/cjs/test/unit/messages/simpleMessageBuilder.d.ts.map +1 -0
  105. package/dist/cjs/test/unit/messages/simpleMessageBuilder.js +194 -0
  106. package/dist/{test → cjs/test}/unit/sol.d.ts.map +1 -1
  107. package/dist/cjs/test/unit/sol.js +3326 -0
  108. package/dist/cjs/test/unit/solInstructionFactory.d.ts.map +1 -0
  109. package/dist/cjs/test/unit/solInstructionFactory.js +454 -0
  110. package/dist/cjs/test/unit/solToken.d.ts.map +1 -0
  111. package/dist/cjs/test/unit/solToken.js +31 -0
  112. package/dist/cjs/test/unit/transaction.d.ts.map +1 -0
  113. package/dist/cjs/test/unit/transaction.js +1108 -0
  114. package/dist/cjs/test/unit/transactionBuilder/StakingWithdrawBuilder.d.ts.map +1 -0
  115. package/dist/cjs/test/unit/transactionBuilder/StakingWithdrawBuilder.js +202 -0
  116. package/dist/cjs/test/unit/transactionBuilder/ataInitBuilder.d.ts.map +1 -0
  117. package/dist/cjs/test/unit/transactionBuilder/ataInitBuilder.js +471 -0
  118. package/dist/cjs/test/unit/transactionBuilder/customInstructionBuilder.d.ts.map +1 -0
  119. package/dist/cjs/test/unit/transactionBuilder/customInstructionBuilder.js +413 -0
  120. package/dist/cjs/test/unit/transactionBuilder/stakingActivateBuilder.d.ts.map +1 -0
  121. package/dist/cjs/test/unit/transactionBuilder/stakingActivateBuilder.js +430 -0
  122. package/dist/cjs/test/unit/transactionBuilder/stakingAuthorizeBuilder.d.ts.map +1 -0
  123. package/dist/cjs/test/unit/transactionBuilder/stakingAuthorizeBuilder.js +157 -0
  124. package/dist/cjs/test/unit/transactionBuilder/stakingDeactivateBuilder.d.ts.map +1 -0
  125. package/dist/cjs/test/unit/transactionBuilder/stakingDeactivateBuilder.js +384 -0
  126. package/dist/cjs/test/unit/transactionBuilder/stakingDelegateBuilder.d.ts.map +1 -0
  127. package/dist/cjs/test/unit/transactionBuilder/stakingDelegateBuilder.js +224 -0
  128. package/dist/cjs/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -0
  129. package/dist/cjs/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.js +259 -0
  130. package/dist/cjs/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
  131. package/dist/cjs/test/unit/transactionBuilder/tokenTransferBuilder.js +787 -0
  132. package/dist/cjs/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  133. package/dist/cjs/test/unit/transactionBuilder/transactionBuilder.js +495 -0
  134. package/dist/cjs/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  135. package/dist/cjs/test/unit/transactionBuilder/transferBuilder.js +286 -0
  136. package/dist/cjs/test/unit/transactionBuilder/transferBuilderV2.d.ts.map +1 -0
  137. package/dist/cjs/test/unit/transactionBuilder/transferBuilderV2.js +862 -0
  138. package/dist/cjs/test/unit/transactionBuilder/walletInitBuilder.d.ts.map +1 -0
  139. package/dist/cjs/test/unit/transactionBuilder/walletInitBuilder.js +259 -0
  140. package/dist/{test → cjs/test}/unit/utils.d.ts.map +1 -1
  141. package/dist/cjs/test/unit/utils.js +517 -0
  142. package/dist/cjs/test/unit/versionedTransaction.d.ts.map +1 -0
  143. package/dist/cjs/test/unit/versionedTransaction.js +207 -0
  144. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  145. package/dist/esm/bigint-buffer-guard.d.ts +1 -0
  146. package/dist/esm/config/token2022StaticConfig.d.ts +3 -0
  147. package/dist/esm/config/token2022StaticConfig.js +47 -0
  148. package/dist/esm/index.d.ts +7 -0
  149. package/dist/esm/index.js +7 -0
  150. package/dist/esm/lib/ataInitializationBuilder.d.ts +47 -0
  151. package/dist/esm/lib/ataInitializationBuilder.js +156 -0
  152. package/dist/esm/lib/closeAtaBuilder.d.ts +19 -0
  153. package/dist/esm/lib/closeAtaBuilder.js +62 -0
  154. package/dist/esm/lib/constants.d.ts +164 -0
  155. package/dist/esm/lib/constants.d.ts.map +1 -0
  156. package/dist/esm/lib/constants.js +193 -0
  157. package/dist/esm/lib/customInstructionBuilder.d.ts +72 -0
  158. package/dist/esm/lib/customInstructionBuilder.js +282 -0
  159. package/dist/esm/lib/explainTransactionWasm.d.ts +21 -0
  160. package/dist/esm/lib/explainTransactionWasm.d.ts.map +1 -0
  161. package/dist/esm/lib/explainTransactionWasm.js +261 -0
  162. package/dist/esm/lib/iface.d.ts +262 -0
  163. package/dist/esm/lib/iface.d.ts.map +1 -0
  164. package/dist/esm/lib/iface.js +3 -0
  165. package/dist/esm/lib/index.d.ts +23 -0
  166. package/dist/{src → esm}/lib/index.d.ts.map +1 -1
  167. package/dist/esm/lib/index.js +23 -0
  168. package/dist/esm/lib/instructionParamsFactory.d.ts +13 -0
  169. package/dist/{src → esm}/lib/instructionParamsFactory.d.ts.map +1 -1
  170. package/dist/esm/lib/instructionParamsFactory.js +1052 -0
  171. package/dist/esm/lib/jitoStakePoolOperations.d.ts +113 -0
  172. package/dist/esm/lib/jitoStakePoolOperations.js +189 -0
  173. package/dist/esm/lib/keyPair.d.ts +26 -0
  174. package/dist/esm/lib/keyPair.js +59 -0
  175. package/dist/esm/lib/messages/index.d.ts +2 -0
  176. package/dist/esm/lib/messages/index.js +2 -0
  177. package/dist/esm/lib/messages/messageBuilderFactory.d.ts +7 -0
  178. package/dist/{src → esm}/lib/messages/messageBuilderFactory.js +5 -9
  179. package/dist/esm/lib/recoverNestedAtaBuilder.d.ts +25 -0
  180. package/dist/esm/lib/recoverNestedAtaBuilder.d.ts.map +1 -0
  181. package/dist/esm/lib/recoverNestedAtaBuilder.js +83 -0
  182. package/dist/esm/lib/solInstructionFactory.d.ts +10 -0
  183. package/dist/esm/lib/solInstructionFactory.d.ts.map +1 -0
  184. package/dist/esm/lib/solInstructionFactory.js +589 -0
  185. package/dist/esm/lib/stakingActivateBuilder.d.ts +59 -0
  186. package/dist/esm/lib/stakingActivateBuilder.js +113 -0
  187. package/dist/esm/lib/stakingAuthorizeBuilder.d.ts +43 -0
  188. package/dist/esm/lib/stakingAuthorizeBuilder.js +82 -0
  189. package/dist/esm/lib/stakingDeactivateBuilder.d.ts +81 -0
  190. package/dist/{src → esm}/lib/stakingDeactivateBuilder.js +31 -38
  191. package/dist/esm/lib/stakingDelegateBuilder.d.ts +42 -0
  192. package/dist/esm/lib/stakingDelegateBuilder.js +113 -0
  193. package/dist/esm/lib/stakingRawMsgAuthorizeBuilder.d.ts +33 -0
  194. package/dist/esm/lib/stakingRawMsgAuthorizeBuilder.js +103 -0
  195. package/dist/esm/lib/stakingWithdrawBuilder.d.ts +31 -0
  196. package/dist/esm/lib/stakingWithdrawBuilder.js +71 -0
  197. package/dist/esm/lib/token2022Config.d.ts +44 -0
  198. package/dist/esm/lib/token2022Config.js +23 -0
  199. package/dist/esm/lib/tokenTransferBuilder.d.ts +41 -0
  200. package/dist/esm/lib/tokenTransferBuilder.js +181 -0
  201. package/dist/esm/lib/transaction.d.ts +103 -0
  202. package/dist/esm/lib/transaction.d.ts.map +1 -0
  203. package/dist/esm/lib/transaction.js +605 -0
  204. package/dist/esm/lib/transactionBuilder.d.ts +128 -0
  205. package/dist/esm/lib/transactionBuilder.js +373 -0
  206. package/dist/esm/lib/transactionBuilderFactory.d.ts +120 -0
  207. package/dist/esm/lib/transactionBuilderFactory.d.ts.map +1 -0
  208. package/dist/esm/lib/transactionBuilderFactory.js +205 -0
  209. package/dist/esm/lib/transferBuilder.d.ts +26 -0
  210. package/dist/esm/lib/transferBuilder.js +63 -0
  211. package/dist/esm/lib/transferBuilderV2.d.ts +43 -0
  212. package/dist/esm/lib/transferBuilderV2.js +203 -0
  213. package/dist/esm/lib/utils.d.ts +200 -0
  214. package/dist/{src → esm}/lib/utils.d.ts.map +1 -1
  215. package/dist/esm/lib/utils.js +558 -0
  216. package/dist/esm/lib/walletInitializationBuilder.d.ts +26 -0
  217. package/dist/esm/lib/walletInitializationBuilder.js +64 -0
  218. package/dist/esm/register.d.ts +3 -0
  219. package/dist/esm/register.js +11 -0
  220. package/dist/esm/sol.d.ts +267 -0
  221. package/dist/esm/sol.d.ts.map +1 -0
  222. package/dist/esm/sol.js +1361 -0
  223. package/dist/esm/solToken.d.ts +37 -0
  224. package/dist/esm/solToken.js +65 -0
  225. package/dist/esm/tsol.d.ts +11 -0
  226. package/dist/esm/tsol.js +20 -0
  227. package/package.json +34 -15
  228. package/dist/src/config/token2022StaticConfig.js +0 -50
  229. package/dist/src/lib/ataInitializationBuilder.js +0 -196
  230. package/dist/src/lib/closeAtaBuilder.js +0 -69
  231. package/dist/src/lib/constants.d.ts.map +0 -1
  232. package/dist/src/lib/constants.js +0 -171
  233. package/dist/src/lib/customInstructionBuilder.js +0 -289
  234. package/dist/src/lib/iface.d.ts.map +0 -1
  235. package/dist/src/lib/iface.js +0 -7
  236. package/dist/src/lib/instructionParamsFactory.js +0 -1036
  237. package/dist/src/lib/jitoStakePoolOperations.js +0 -200
  238. package/dist/src/lib/keyPair.js +0 -63
  239. package/dist/src/lib/solInstructionFactory.d.ts.map +0 -1
  240. package/dist/src/lib/solInstructionFactory.js +0 -572
  241. package/dist/src/lib/stakingActivateBuilder.js +0 -120
  242. package/dist/src/lib/stakingAuthorizeBuilder.js +0 -89
  243. package/dist/src/lib/stakingDelegateBuilder.js +0 -120
  244. package/dist/src/lib/stakingRawMsgAuthorizeBuilder.js +0 -110
  245. package/dist/src/lib/stakingWithdrawBuilder.js +0 -78
  246. package/dist/src/lib/token2022Config.js +0 -27
  247. package/dist/src/lib/tokenTransferBuilder.js +0 -188
  248. package/dist/src/lib/transaction.d.ts.map +0 -1
  249. package/dist/src/lib/transaction.js +0 -595
  250. package/dist/src/lib/transactionBuilder.js +0 -380
  251. package/dist/src/lib/transactionBuilderFactory.d.ts.map +0 -1
  252. package/dist/src/lib/transactionBuilderFactory.js +0 -202
  253. package/dist/src/lib/transferBuilder.js +0 -70
  254. package/dist/src/lib/transferBuilderV2.js +0 -210
  255. package/dist/src/lib/utils.js +0 -589
  256. package/dist/src/lib/walletInitializationBuilder.js +0 -71
  257. package/dist/src/register.js +0 -15
  258. package/dist/src/sol.d.ts.map +0 -1
  259. package/dist/src/sol.js +0 -1285
  260. package/dist/src/solToken.js +0 -69
  261. package/dist/src/tsol.js +0 -24
  262. package/dist/test/fixtures/sol.js +0 -1433
  263. package/dist/test/resources/sol.d.ts.map +0 -1
  264. package/dist/test/resources/sol.js +0 -320
  265. package/dist/test/unit/fixtures/solBackupKey.d.ts.map +0 -1
  266. package/dist/test/unit/fixtures/solBackupKey.js +0 -8
  267. package/dist/test/unit/getBuilderFactory.d.ts.map +0 -1
  268. package/dist/test/unit/getBuilderFactory.js +0 -10
  269. package/dist/test/unit/instructionParamsFactory.d.ts.map +0 -1
  270. package/dist/test/unit/instructionParamsFactory.js +0 -412
  271. package/dist/test/unit/instructionParamsFactory.staking.d.ts.map +0 -1
  272. package/dist/test/unit/instructionParamsFactory.staking.js +0 -1059
  273. package/dist/test/unit/keyPair.js +0 -177
  274. package/dist/test/unit/messages/messageBuilderFactory.d.ts.map +0 -1
  275. package/dist/test/unit/messages/messageBuilderFactory.js +0 -118
  276. package/dist/test/unit/messages/simpleMessageBuilder.d.ts.map +0 -1
  277. package/dist/test/unit/messages/simpleMessageBuilder.js +0 -194
  278. package/dist/test/unit/sol.js +0 -3108
  279. package/dist/test/unit/solInstructionFactory.d.ts.map +0 -1
  280. package/dist/test/unit/solInstructionFactory.js +0 -454
  281. package/dist/test/unit/solToken.d.ts.map +0 -1
  282. package/dist/test/unit/solToken.js +0 -31
  283. package/dist/test/unit/transaction.d.ts.map +0 -1
  284. package/dist/test/unit/transaction.js +0 -983
  285. package/dist/test/unit/transactionBuilder/StakingWithdrawBuilder.d.ts.map +0 -1
  286. package/dist/test/unit/transactionBuilder/StakingWithdrawBuilder.js +0 -202
  287. package/dist/test/unit/transactionBuilder/ataInitBuilder.d.ts.map +0 -1
  288. package/dist/test/unit/transactionBuilder/ataInitBuilder.js +0 -471
  289. package/dist/test/unit/transactionBuilder/customInstructionBuilder.d.ts.map +0 -1
  290. package/dist/test/unit/transactionBuilder/customInstructionBuilder.js +0 -413
  291. package/dist/test/unit/transactionBuilder/stakingActivateBuilder.d.ts.map +0 -1
  292. package/dist/test/unit/transactionBuilder/stakingActivateBuilder.js +0 -430
  293. package/dist/test/unit/transactionBuilder/stakingAuthorizeBuilder.d.ts.map +0 -1
  294. package/dist/test/unit/transactionBuilder/stakingAuthorizeBuilder.js +0 -157
  295. package/dist/test/unit/transactionBuilder/stakingDeactivateBuilder.d.ts.map +0 -1
  296. package/dist/test/unit/transactionBuilder/stakingDeactivateBuilder.js +0 -384
  297. package/dist/test/unit/transactionBuilder/stakingDelegateBuilder.d.ts.map +0 -1
  298. package/dist/test/unit/transactionBuilder/stakingDelegateBuilder.js +0 -224
  299. package/dist/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.d.ts.map +0 -1
  300. package/dist/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.js +0 -259
  301. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +0 -1
  302. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +0 -787
  303. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +0 -1
  304. package/dist/test/unit/transactionBuilder/transactionBuilder.js +0 -495
  305. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +0 -1
  306. package/dist/test/unit/transactionBuilder/transferBuilder.js +0 -286
  307. package/dist/test/unit/transactionBuilder/transferBuilderV2.d.ts.map +0 -1
  308. package/dist/test/unit/transactionBuilder/transferBuilderV2.js +0 -862
  309. package/dist/test/unit/transactionBuilder/walletInitBuilder.d.ts.map +0 -1
  310. package/dist/test/unit/transactionBuilder/walletInitBuilder.js +0 -259
  311. package/dist/test/unit/utils.js +0 -517
  312. package/dist/test/unit/versionedTransaction.d.ts.map +0 -1
  313. package/dist/test/unit/versionedTransaction.js +0 -207
  314. package/dist/tsconfig.tsbuildinfo +0 -1
  315. /package/dist/{src → cjs/src}/bigint-buffer-guard.d.ts +0 -0
  316. /package/dist/{src → cjs/src}/config/token2022StaticConfig.d.ts +0 -0
  317. /package/dist/{src → cjs/src}/index.d.ts +0 -0
  318. /package/dist/{src → cjs/src}/lib/ataInitializationBuilder.d.ts +0 -0
  319. /package/dist/{src → cjs/src}/lib/closeAtaBuilder.d.ts +0 -0
  320. /package/dist/{src → cjs/src}/lib/customInstructionBuilder.d.ts +0 -0
  321. /package/dist/{src → cjs/src}/lib/jitoStakePoolOperations.d.ts +0 -0
  322. /package/dist/{src → cjs/src}/lib/keyPair.d.ts +0 -0
  323. /package/dist/{src → cjs/src}/lib/messages/index.d.ts +0 -0
  324. /package/dist/{src → cjs/src}/lib/messages/messageBuilderFactory.d.ts +0 -0
  325. /package/dist/{src → cjs/src}/lib/solInstructionFactory.d.ts +0 -0
  326. /package/dist/{src → cjs/src}/lib/stakingActivateBuilder.d.ts +0 -0
  327. /package/dist/{src → cjs/src}/lib/stakingAuthorizeBuilder.d.ts +0 -0
  328. /package/dist/{src → cjs/src}/lib/stakingDeactivateBuilder.d.ts +0 -0
  329. /package/dist/{src → cjs/src}/lib/stakingDelegateBuilder.d.ts +0 -0
  330. /package/dist/{src → cjs/src}/lib/stakingRawMsgAuthorizeBuilder.d.ts +0 -0
  331. /package/dist/{src → cjs/src}/lib/stakingWithdrawBuilder.d.ts +0 -0
  332. /package/dist/{src → cjs/src}/lib/token2022Config.d.ts +0 -0
  333. /package/dist/{src → cjs/src}/lib/tokenTransferBuilder.d.ts +0 -0
  334. /package/dist/{src → cjs/src}/lib/transaction.d.ts +0 -0
  335. /package/dist/{src → cjs/src}/lib/transactionBuilder.d.ts +0 -0
  336. /package/dist/{src → cjs/src}/lib/transferBuilder.d.ts +0 -0
  337. /package/dist/{src → cjs/src}/lib/transferBuilderV2.d.ts +0 -0
  338. /package/dist/{src → cjs/src}/lib/utils.d.ts +0 -0
  339. /package/dist/{src → cjs/src}/lib/walletInitializationBuilder.d.ts +0 -0
  340. /package/dist/{src → cjs/src}/register.d.ts +0 -0
  341. /package/dist/{src → cjs/src}/solToken.d.ts +0 -0
  342. /package/dist/{src → cjs/src}/tsol.d.ts +0 -0
  343. /package/dist/{test → cjs/test}/fixtures/sol.d.ts +0 -0
  344. /package/dist/{test → cjs/test}/unit/fixtures/solBackupKey.d.ts +0 -0
  345. /package/dist/{test → cjs/test}/unit/getBuilderFactory.d.ts +0 -0
  346. /package/dist/{test → cjs/test}/unit/instructionParamsFactory.d.ts +0 -0
  347. /package/dist/{test → cjs/test}/unit/instructionParamsFactory.staking.d.ts +0 -0
  348. /package/dist/{test → cjs/test}/unit/keyPair.d.ts +0 -0
  349. /package/dist/{test → cjs/test}/unit/messages/messageBuilderFactory.d.ts +0 -0
  350. /package/dist/{test → cjs/test}/unit/messages/simpleMessageBuilder.d.ts +0 -0
  351. /package/dist/{test → cjs/test}/unit/sol.d.ts +0 -0
  352. /package/dist/{test → cjs/test}/unit/solInstructionFactory.d.ts +0 -0
  353. /package/dist/{test → cjs/test}/unit/solToken.d.ts +0 -0
  354. /package/dist/{test → cjs/test}/unit/transaction.d.ts +0 -0
  355. /package/dist/{test → cjs/test}/unit/transactionBuilder/StakingWithdrawBuilder.d.ts +0 -0
  356. /package/dist/{test → cjs/test}/unit/transactionBuilder/ataInitBuilder.d.ts +0 -0
  357. /package/dist/{test → cjs/test}/unit/transactionBuilder/customInstructionBuilder.d.ts +0 -0
  358. /package/dist/{test → cjs/test}/unit/transactionBuilder/stakingActivateBuilder.d.ts +0 -0
  359. /package/dist/{test → cjs/test}/unit/transactionBuilder/stakingAuthorizeBuilder.d.ts +0 -0
  360. /package/dist/{test → cjs/test}/unit/transactionBuilder/stakingDeactivateBuilder.d.ts +0 -0
  361. /package/dist/{test → cjs/test}/unit/transactionBuilder/stakingDelegateBuilder.d.ts +0 -0
  362. /package/dist/{test → cjs/test}/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.d.ts +0 -0
  363. /package/dist/{test → cjs/test}/unit/transactionBuilder/tokenTransferBuilder.d.ts +0 -0
  364. /package/dist/{test → cjs/test}/unit/transactionBuilder/transactionBuilder.d.ts +0 -0
  365. /package/dist/{test → cjs/test}/unit/transactionBuilder/transferBuilder.d.ts +0 -0
  366. /package/dist/{test → cjs/test}/unit/transactionBuilder/transferBuilderV2.d.ts +0 -0
  367. /package/dist/{test → cjs/test}/unit/transactionBuilder/walletInitBuilder.d.ts +0 -0
  368. /package/dist/{test → cjs/test}/unit/utils.d.ts +0 -0
  369. /package/dist/{test → cjs/test}/unit/versionedTransaction.d.ts +0 -0
  370. /package/dist/{src → esm}/bigint-buffer-guard.d.ts.map +0 -0
  371. /package/dist/{src → esm}/bigint-buffer-guard.js +0 -0
  372. /package/dist/{src → esm}/config/token2022StaticConfig.d.ts.map +0 -0
  373. /package/dist/{src → esm}/index.d.ts.map +0 -0
  374. /package/dist/{src → esm}/lib/ataInitializationBuilder.d.ts.map +0 -0
  375. /package/dist/{src → esm}/lib/closeAtaBuilder.d.ts.map +0 -0
  376. /package/dist/{src → esm}/lib/customInstructionBuilder.d.ts.map +0 -0
  377. /package/dist/{src → esm}/lib/jitoStakePoolOperations.d.ts.map +0 -0
  378. /package/dist/{src → esm}/lib/keyPair.d.ts.map +0 -0
  379. /package/dist/{src → esm}/lib/messages/index.d.ts.map +0 -0
  380. /package/dist/{src → esm}/lib/messages/messageBuilderFactory.d.ts.map +0 -0
  381. /package/dist/{src → esm}/lib/stakingActivateBuilder.d.ts.map +0 -0
  382. /package/dist/{src → esm}/lib/stakingAuthorizeBuilder.d.ts.map +0 -0
  383. /package/dist/{src → esm}/lib/stakingDeactivateBuilder.d.ts.map +0 -0
  384. /package/dist/{src → esm}/lib/stakingDelegateBuilder.d.ts.map +0 -0
  385. /package/dist/{src → esm}/lib/stakingRawMsgAuthorizeBuilder.d.ts.map +0 -0
  386. /package/dist/{src → esm}/lib/stakingWithdrawBuilder.d.ts.map +0 -0
  387. /package/dist/{src → esm}/lib/token2022Config.d.ts.map +0 -0
  388. /package/dist/{src → esm}/lib/tokenTransferBuilder.d.ts.map +0 -0
  389. /package/dist/{src → esm}/lib/transactionBuilder.d.ts.map +0 -0
  390. /package/dist/{src → esm}/lib/transferBuilder.d.ts.map +0 -0
  391. /package/dist/{src → esm}/lib/transferBuilderV2.d.ts.map +0 -0
  392. /package/dist/{src → esm}/lib/walletInitializationBuilder.d.ts.map +0 -0
  393. /package/dist/{src → esm}/register.d.ts.map +0 -0
  394. /package/dist/{src → esm}/solToken.d.ts.map +0 -0
  395. /package/dist/{src → esm}/tsol.d.ts.map +0 -0
@@ -0,0 +1,1402 @@
1
+ "use strict";
2
+ /**
3
+ * @prettier
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.Sol = exports.DEFAULT_SCAN_FACTOR = void 0;
43
+ exports.getAmountBasedOnEndianness = getAmountBasedOnEndianness;
44
+ const spl_token_1 = require("@solana/spl-token");
45
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
46
+ const base58 = __importStar(require("bs58"));
47
+ const _ = __importStar(require("lodash"));
48
+ const request = __importStar(require("superagent"));
49
+ const logger_1 = require("@bitgo-beta/logger");
50
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
51
+ const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
52
+ const statics_1 = require("@bitgo-beta/statics");
53
+ const lib_1 = require("./lib");
54
+ const utils_1 = require("./lib/utils");
55
+ exports.DEFAULT_SCAN_FACTOR = 20; // default number of receive addresses to scan for funds
56
+ const HEX_REGEX = /^[0-9a-fA-F]+$/;
57
+ const BLIND_SIGNING_TX_TYPES_TO_CHECK = { enabletoken: 'AssociatedTokenAccountInitialization' };
58
+ /**
59
+ * Get amount string corrected for architecture-specific endianness issues.
60
+ *
61
+ * On s390x (big-endian) architecture, the Solana transaction parser (via @solana/web3.js)
62
+ * incorrectly reads little-endian u64 amounts as big-endian, resulting in corrupted values.
63
+ *
64
+ * This function corrects all amounts on s390x by swapping byte order to undo
65
+ * the incorrect byte order that happened during transaction parsing.
66
+ *
67
+ * @param amount - The amount to check and potentially fix
68
+ * @returns The corrected amount as a string
69
+ */
70
+ function getAmountBasedOnEndianness(amount) {
71
+ const amountStr = String(amount);
72
+ // Only s390x architecture has this endianness issue
73
+ const isS390x = process.arch === 's390x';
74
+ if (!isS390x) {
75
+ return amountStr;
76
+ }
77
+ try {
78
+ const amountBN = BigInt(amountStr);
79
+ // On s390x, the parser ALWAYS reads u64 as big-endian when it's actually little-endian
80
+ // So we ALWAYS need to swap bytes to get the correct value
81
+ const buf = Buffer.alloc(8);
82
+ buf.writeBigUInt64BE(amountBN, 0);
83
+ const fixed = buf.readBigUInt64LE(0);
84
+ return fixed.toString();
85
+ }
86
+ catch (e) {
87
+ // If conversion fails, return original value
88
+ return amountStr;
89
+ }
90
+ }
91
+ class Sol extends sdk_core_1.BaseCoin {
92
+ constructor(bitgo, staticsCoin) {
93
+ super(bitgo);
94
+ if (!staticsCoin) {
95
+ throw new Error('missing required constructor parameter staticsCoin');
96
+ }
97
+ this._staticsCoin = staticsCoin;
98
+ }
99
+ static createInstance(bitgo, staticsCoin) {
100
+ return new Sol(bitgo, staticsCoin);
101
+ }
102
+ allowsAccountConsolidations() {
103
+ return true;
104
+ }
105
+ supportsTss() {
106
+ return true;
107
+ }
108
+ /** @inheritDoc */
109
+ supportsMessageSigning() {
110
+ return true;
111
+ }
112
+ /** inherited doc */
113
+ getDefaultMultisigType() {
114
+ return sdk_core_1.multisigTypes.tss;
115
+ }
116
+ getMPCAlgorithm() {
117
+ return 'eddsa';
118
+ }
119
+ getChain() {
120
+ return this._staticsCoin.name;
121
+ }
122
+ getFamily() {
123
+ return this._staticsCoin.family;
124
+ }
125
+ getFullName() {
126
+ return this._staticsCoin.fullName;
127
+ }
128
+ getNetwork() {
129
+ return this._staticsCoin.network;
130
+ }
131
+ getBaseFactor() {
132
+ return Math.pow(10, this._staticsCoin.decimalPlaces);
133
+ }
134
+ verifyTxType(expectedTypeFromUserParams, actualTypeFromDecoded) {
135
+ const matchFromUserToDecodedType = BLIND_SIGNING_TX_TYPES_TO_CHECK[expectedTypeFromUserParams];
136
+ if (matchFromUserToDecodedType !== actualTypeFromDecoded) {
137
+ throw new Error(`Invalid transaction type on token enablement: expected "${matchFromUserToDecodedType}", got "${actualTypeFromDecoded}".`);
138
+ }
139
+ }
140
+ throwIfMissingTokenEnablementsOrReturn(explanation) {
141
+ if (!explanation.tokenEnablements || explanation.tokenEnablements.length === 0)
142
+ throw new Error('Missing tx token enablements data on token enablement tx prebuild');
143
+ return explanation.tokenEnablements;
144
+ }
145
+ throwIfMissingEnableTokenConfigOrReturn(txParams) {
146
+ if (!txParams.enableTokens || txParams.enableTokens.length === 0)
147
+ throw new Error('Missing enable token config');
148
+ return txParams.enableTokens;
149
+ }
150
+ verifyTokenName(tokenEnablementsPrebuild, enableTokensConfig) {
151
+ enableTokensConfig.forEach((enableTokenConfig) => {
152
+ const expectedTokenName = enableTokenConfig.name;
153
+ tokenEnablementsPrebuild.forEach((tokenEnablement) => {
154
+ if (!tokenEnablement.tokenName)
155
+ throw new Error('Missing token name on token enablement tx');
156
+ if (tokenEnablement.tokenName !== expectedTokenName)
157
+ throw new Error(`Invalid token name: expected ${expectedTokenName}, got ${tokenEnablement.tokenName} on token enablement tx`);
158
+ });
159
+ });
160
+ }
161
+ async verifyTokenAddress(tokenEnablementsPrebuild, enableTokensConfig) {
162
+ for (const enableTokenConfig of enableTokensConfig) {
163
+ const expectedTokenAddress = enableTokenConfig.address;
164
+ const expectedTokenName = enableTokenConfig.name;
165
+ if (!expectedTokenAddress)
166
+ throw new Error('Missing token address on token enablement tx');
167
+ if (!expectedTokenName)
168
+ throw new Error('Missing token name on token enablement tx');
169
+ for (const tokenEnablement of tokenEnablementsPrebuild) {
170
+ let tokenMintAddress;
171
+ try {
172
+ tokenMintAddress = (0, utils_1.getSolTokenFromTokenName)(expectedTokenName);
173
+ }
174
+ catch {
175
+ throw new Error(`Unable to derive ATA for token address: ${expectedTokenAddress}`);
176
+ }
177
+ if (!tokenMintAddress ||
178
+ tokenMintAddress.tokenAddress === undefined ||
179
+ tokenMintAddress.programId === undefined) {
180
+ throw new Error(`Unable to get token mint address for ${expectedTokenName}`);
181
+ }
182
+ let ata;
183
+ try {
184
+ ata = await (0, utils_1.getAssociatedTokenAccountAddress)(tokenMintAddress.tokenAddress, expectedTokenAddress, true, tokenMintAddress.programId);
185
+ }
186
+ catch {
187
+ throw new Error(`Unable to derive ATA for token address: ${expectedTokenAddress}`);
188
+ }
189
+ if (ata !== tokenEnablement.address) {
190
+ throw new Error(`Invalid token address: expected ${ata}, got ${tokenEnablement.address} on token enablement tx`);
191
+ }
192
+ }
193
+ }
194
+ }
195
+ hasSolVersionedTransactionData(txParams) {
196
+ return 'solVersionedTransactionData' in txParams && txParams.solVersionedTransactionData !== undefined;
197
+ }
198
+ /**
199
+ * Verify a versioned Solana transaction with basic structural validation
200
+ * @param params - verification parameters
201
+ * @returns true if verification passes
202
+ */
203
+ async verifyVersionedTransaction(params) {
204
+ const { txParams, txPrebuild } = params;
205
+ const rawTx = txPrebuild.txBase64 || txPrebuild.txHex;
206
+ if (!rawTx) {
207
+ throw new Error('missing required tx prebuild property txBase64 or txHex');
208
+ }
209
+ // Validate that the versioned transaction data is well-formed
210
+ if (!this.hasSolVersionedTransactionData(txParams)) {
211
+ throw new Error('solVersionedTransactionData is required for versioned transaction verification');
212
+ }
213
+ const versionedData = txParams.solVersionedTransactionData;
214
+ if (!versionedData.versionedInstructions || versionedData.versionedInstructions.length === 0) {
215
+ throw new Error('versioned transaction must have at least one instruction');
216
+ }
217
+ if (!versionedData.staticAccountKeys || versionedData.staticAccountKeys.length === 0) {
218
+ throw new Error('versioned transaction must have at least one static account key');
219
+ }
220
+ if (!versionedData.messageHeader) {
221
+ throw new Error('versioned transaction must have a message header');
222
+ }
223
+ // Validate that we can deserialize the transaction
224
+ let rawTxBase64 = rawTx;
225
+ if (HEX_REGEX.test(rawTx)) {
226
+ rawTxBase64 = Buffer.from(rawTx, 'hex').toString('base64');
227
+ }
228
+ try {
229
+ const txBytes = Buffer.from(rawTxBase64, 'base64');
230
+ if (txBytes.length < 1) {
231
+ throw new Error('transaction bytes are empty');
232
+ }
233
+ // Check version byte (after signatures)
234
+ const numSignatures = txBytes[0];
235
+ const signatureSize = 64;
236
+ const versionByteOffset = 1 + numSignatures * signatureSize;
237
+ if (txBytes.length <= versionByteOffset) {
238
+ throw new Error('transaction bytes are too short to contain version byte');
239
+ }
240
+ const versionByte = txBytes[versionByteOffset];
241
+ const isVersioned = (versionByte & 0x80) !== 0;
242
+ if (!isVersioned) {
243
+ throw new Error('transaction does not have versioned format');
244
+ }
245
+ }
246
+ catch (error) {
247
+ throw new Error(`failed to validate versioned transaction format: ${error.message}`);
248
+ }
249
+ return true;
250
+ }
251
+ async verifyTransaction(params) {
252
+ // asset name to transfer amount map
253
+ const totalAmount = {};
254
+ const coinConfig = statics_1.coins.get(this.getChain());
255
+ const { txParams: txParams, txPrebuild: txPrebuild, memo: memo, durableNonce: durableNonce, verification: verificationOptions, } = params;
256
+ if (this.hasSolVersionedTransactionData(txParams)) {
257
+ return this.verifyVersionedTransaction(params);
258
+ }
259
+ const transaction = new lib_1.Transaction(coinConfig);
260
+ const rawTx = txPrebuild.txBase64 || txPrebuild.txHex;
261
+ const consolidateId = txPrebuild.consolidateId;
262
+ const walletRootAddress = params.wallet.coinSpecific()?.rootAddress;
263
+ if (!rawTx) {
264
+ throw new Error('missing required tx prebuild property txBase64 or txHex');
265
+ }
266
+ let rawTxBase64 = rawTx;
267
+ if (HEX_REGEX.test(rawTx)) {
268
+ rawTxBase64 = Buffer.from(rawTx, 'hex').toString('base64');
269
+ }
270
+ transaction.fromRawTransaction(rawTxBase64);
271
+ const explainedTx = transaction.explainTransaction();
272
+ if (txParams.type === 'enabletoken' && verificationOptions?.verifyTokenEnablement) {
273
+ this.verifyTxType(txParams.type, explainedTx.type);
274
+ const tokenEnablementsPrebuild = this.throwIfMissingTokenEnablementsOrReturn(explainedTx);
275
+ const enableTokensConfig = this.throwIfMissingEnableTokenConfigOrReturn(txParams);
276
+ this.verifyTokenName(tokenEnablementsPrebuild, enableTokensConfig);
277
+ await this.verifyTokenAddress(tokenEnablementsPrebuild, enableTokensConfig);
278
+ }
279
+ // users do not input recipients for consolidation requests as they are generated by the server
280
+ if (txParams.recipients !== undefined) {
281
+ const filteredRecipients = txParams.recipients?.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));
282
+ const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));
283
+ if (filteredRecipients.length !== filteredOutputs.length) {
284
+ throw new Error('Number of tx outputs does not match with number of txParams recipients');
285
+ }
286
+ // For each recipient, check if it's a token tx (tokenName will exist if so)
287
+ // If it is a token tx, verify that the recipient address equals the derived address from explainedTx
288
+ // Derive the ATA if it is a native address and confirm it is equal to the explained tx recipient
289
+ const recipientChecks = await Promise.all(filteredRecipients.map(async (recipientFromUser, index) => {
290
+ const recipientFromTx = filteredOutputs[index]; // This address should be an ATA
291
+ // Compare the BigNumber values because amount is (string | number)
292
+ // Apply s390x endianness fix if needed
293
+ const userAmountStr = String(recipientFromUser.amount);
294
+ const txAmountStr = getAmountBasedOnEndianness(recipientFromTx.amount);
295
+ const userAmount = new bignumber_js_1.default(userAmountStr);
296
+ const txAmount = new bignumber_js_1.default(txAmountStr);
297
+ if (!userAmount.isEqualTo(txAmount)) {
298
+ return false;
299
+ }
300
+ // Compare the addresses and tokenNames
301
+ // Else if the addresses are not the same, check the derived ATA for parity
302
+ if (recipientFromUser.address === recipientFromTx.address &&
303
+ recipientFromUser.tokenName === recipientFromTx.tokenName) {
304
+ return true;
305
+ }
306
+ else if (recipientFromUser.address !== recipientFromTx.address && recipientFromUser.tokenName) {
307
+ // Try to check if the user's derived ATA is equal to the tx recipient address
308
+ // If getAssociatedTokenAccountAddress throws an error, then we are unable to derive the ATA for that address.
309
+ // Return false and throw an error if that is the case.
310
+ try {
311
+ const tokenMintAddress = (0, utils_1.getSolTokenFromTokenName)(recipientFromUser.tokenName);
312
+ return (0, utils_1.getAssociatedTokenAccountAddress)(tokenMintAddress.tokenAddress, recipientFromUser.address, true, tokenMintAddress.programId).then((ata) => {
313
+ return ata === recipientFromTx.address;
314
+ });
315
+ }
316
+ catch {
317
+ // Unable to derive ATA
318
+ return false;
319
+ }
320
+ }
321
+ return false;
322
+ }));
323
+ if (recipientChecks.includes(false)) {
324
+ throw new Error('Tx outputs does not match with expected txParams recipients');
325
+ }
326
+ }
327
+ else if (verificationOptions?.consolidationToBaseAddress) {
328
+ //verify funds are sent to walletRootAddress for a consolidation
329
+ const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));
330
+ // Cache to store already derived ATA addresses
331
+ const ataAddressCache = {};
332
+ for (const output of filteredOutputs) {
333
+ if (output.tokenName) {
334
+ // Check cache first before deriving ATA address
335
+ if (!ataAddressCache[output.tokenName]) {
336
+ const tokenMintAddress = (0, utils_1.getSolTokenFromTokenName)(output.tokenName);
337
+ if (tokenMintAddress?.tokenAddress && tokenMintAddress?.programId) {
338
+ ataAddressCache[output.tokenName] = await (0, utils_1.getAssociatedTokenAccountAddress)(tokenMintAddress.tokenAddress, walletRootAddress, true, tokenMintAddress.programId);
339
+ }
340
+ else {
341
+ throw new Error(`Unable to get token information for ${output.tokenName}`);
342
+ }
343
+ }
344
+ if (ataAddressCache[output.tokenName] !== output.address) {
345
+ throw new Error('tx outputs does not match with expected address');
346
+ }
347
+ }
348
+ else if (output.address !== walletRootAddress) {
349
+ throw new Error('tx outputs does not match with expected address');
350
+ }
351
+ }
352
+ }
353
+ const transactionJson = transaction.toJson();
354
+ if (memo && memo.value !== explainedTx.memo) {
355
+ throw new Error('Tx memo does not match with expected txParams recipient memo');
356
+ }
357
+ if (txParams.recipients) {
358
+ for (const recipients of txParams.recipients) {
359
+ // totalAmount based on each token
360
+ const assetName = recipients.tokenName || this.getChain();
361
+ const amount = totalAmount[assetName] || new bignumber_js_1.default(0);
362
+ totalAmount[assetName] = amount.plus(recipients.amount);
363
+ }
364
+ // total output amount from explainedTx
365
+ const explainedTxTotal = {};
366
+ for (const output of explainedTx.outputs) {
367
+ // Apply s390x endianness fix to output amounts before summing
368
+ const outputAmountStr = getAmountBasedOnEndianness(output.amount);
369
+ // total output amount based on each token
370
+ const assetName = output.tokenName || this.getChain();
371
+ const amount = explainedTxTotal[assetName] || new bignumber_js_1.default(0);
372
+ explainedTxTotal[assetName] = amount.plus(outputAmountStr);
373
+ }
374
+ if (!_.isEqual(explainedTxTotal, totalAmount)) {
375
+ throw new Error('Tx total amount does not match with expected total amount field');
376
+ }
377
+ }
378
+ // For non-consolidate transactions, feePayer must be the wallet's root address
379
+ if (consolidateId === undefined && transactionJson.feePayer !== walletRootAddress) {
380
+ throw new Error('Tx fee payer is not the wallet root address');
381
+ }
382
+ if (durableNonce && !_.isEqual(explainedTx.durableNonce, durableNonce)) {
383
+ throw new Error('Tx durableNonce does not match with param durableNonce');
384
+ }
385
+ return true;
386
+ }
387
+ async isWalletAddress(params) {
388
+ const result = await (0, sdk_core_1.verifyEddsaTssWalletAddress)(params, (address) => this.isValidAddress(address), (publicKey) => this.getAddressFromPublicKey(publicKey));
389
+ if (!result) {
390
+ throw new sdk_core_1.UnexpectedAddressError(`address validation failure: ${params.address} is not a wallet address`);
391
+ }
392
+ return true;
393
+ }
394
+ /**
395
+ * Converts a Solana public key to an address
396
+ * @param publicKey Hex-encoded public key (64 hex characters = 32 bytes)
397
+ * @returns Base58-encoded Solana address
398
+ */
399
+ getAddressFromPublicKey(publicKey) {
400
+ const publicKeyBuffer = Buffer.from(publicKey, 'hex');
401
+ return base58.encode(publicKeyBuffer);
402
+ }
403
+ /**
404
+ * Generate Solana key pair
405
+ *
406
+ * @param {Buffer} seed - Seed from which the new SolKeyPair should be generated, otherwise a random seed is used
407
+ * @returns {Object} object with generated pub and prv
408
+ */
409
+ generateKeyPair(seed) {
410
+ const result = seed ? new lib_1.KeyPair({ seed }).getKeys() : new lib_1.KeyPair().getKeys();
411
+ return result;
412
+ }
413
+ /**
414
+ * Return boolean indicating whether input is valid public key for the coin
415
+ *
416
+ * @param {string} pub the prv to be checked
417
+ * @returns is it valid?
418
+ */
419
+ isValidPub(pub) {
420
+ return (0, utils_1.isValidPublicKey)(pub);
421
+ }
422
+ /**
423
+ * Return boolean indicating whether input is valid private key for the coin
424
+ *
425
+ * @param {string} prv the prv to be checked
426
+ * @returns is it valid?
427
+ */
428
+ isValidPrv(prv) {
429
+ return (0, utils_1.isValidPrivateKey)(prv);
430
+ }
431
+ isValidAddress(address) {
432
+ return (0, utils_1.isValidAddress)(address);
433
+ }
434
+ async signMessage(key, message) {
435
+ const solKeypair = new lib_1.KeyPair({ prv: key.prv });
436
+ if (Buffer.isBuffer(message)) {
437
+ message = base58.encode(message);
438
+ }
439
+ return Buffer.from(solKeypair.signMessage(message));
440
+ }
441
+ /**
442
+ * Signs Solana transaction
443
+ * @param params
444
+ * @param callback
445
+ */
446
+ async signTransaction(params) {
447
+ const factory = this.getBuilder();
448
+ const rawTx = params.txPrebuild.txHex || params.txPrebuild.txBase64;
449
+ const txBuilder = factory.from(rawTx);
450
+ txBuilder.sign({ key: params.prv });
451
+ const transaction = await txBuilder.build();
452
+ if (!transaction) {
453
+ throw new Error('Invalid transaction');
454
+ }
455
+ const serializedTx = transaction.toBroadcastFormat();
456
+ return {
457
+ txHex: serializedTx,
458
+ };
459
+ }
460
+ async parseTransaction(params) {
461
+ // explainTransaction now uses WASM for testnet automatically
462
+ const transactionExplanation = await this.explainTransaction({
463
+ txBase64: params.txBase64,
464
+ feeInfo: params.feeInfo,
465
+ tokenAccountRentExemptAmount: params.tokenAccountRentExemptAmount,
466
+ });
467
+ if (!transactionExplanation) {
468
+ throw new Error('Invalid transaction');
469
+ }
470
+ const solTransaction = transactionExplanation;
471
+ if (solTransaction.outputs.length <= 0) {
472
+ return {
473
+ inputs: [],
474
+ outputs: [],
475
+ };
476
+ }
477
+ const senderAddress = solTransaction.outputs[0].address;
478
+ const feeAmount = new bignumber_js_1.default(solTransaction.fee.fee);
479
+ // assume 1 sender, who is also the fee payer
480
+ const inputs = [
481
+ {
482
+ address: senderAddress,
483
+ amount: new bignumber_js_1.default(solTransaction.outputAmount).plus(feeAmount).toNumber(),
484
+ },
485
+ ];
486
+ const outputs = solTransaction.outputs.map(({ address, amount, tokenName }) => {
487
+ const output = { address, amount };
488
+ if (tokenName) {
489
+ output.tokenName = tokenName;
490
+ }
491
+ return output;
492
+ });
493
+ return {
494
+ inputs,
495
+ outputs,
496
+ };
497
+ }
498
+ /**
499
+ * Explain a Solana transaction from txBase64
500
+ * Uses WASM-based parsing for testnet, with fallback to legacy builder approach.
501
+ * @param params
502
+ */
503
+ async explainTransaction(params) {
504
+ // Use WASM-based parsing for testnet (simpler, faster, no @solana/web3.js rebuild)
505
+ if (this.getChain() === 'tsol') {
506
+ return this.explainTransactionWithWasm(params);
507
+ }
508
+ // Legacy approach for mainnet (until WASM is fully validated)
509
+ const factory = this.getBuilder();
510
+ let rebuiltTransaction;
511
+ try {
512
+ const transactionBuilder = factory.from(params.txBase64);
513
+ if (transactionBuilder instanceof lib_1.TransactionBuilder) {
514
+ const txBuilder = transactionBuilder;
515
+ txBuilder.fee({ amount: params.feeInfo.fee });
516
+ if (params.tokenAccountRentExemptAmount) {
517
+ txBuilder.associatedTokenAccountRent(params.tokenAccountRentExemptAmount);
518
+ }
519
+ }
520
+ rebuiltTransaction = await transactionBuilder.build();
521
+ }
522
+ catch (e) {
523
+ logger_1.logger.error(e);
524
+ throw new Error('Invalid transaction');
525
+ }
526
+ const explainedTransaction = rebuiltTransaction.explainTransaction();
527
+ return explainedTransaction;
528
+ }
529
+ /**
530
+ * Explain a Solana transaction using WASM parsing (bypasses @solana/web3.js rebuild).
531
+ * Delegates to standalone explainSolTransaction().
532
+ */
533
+ explainTransactionWithWasm(params) {
534
+ return (0, lib_1.explainSolTransaction)({ ...params, coinName: params.coinName ?? this.getChain() });
535
+ }
536
+ /** @inheritDoc */
537
+ async getSignablePayload(serializedTx) {
538
+ const factory = this.getBuilder();
539
+ const rebuiltTransaction = await factory.from(serializedTx).build();
540
+ return rebuiltTransaction.signablePayload;
541
+ }
542
+ /** @inheritDoc */
543
+ async presignTransaction(params) {
544
+ // Hot wallet txns are only valid for 1-2 minutes.
545
+ // To buy more time, we rebuild the transaction with a new blockhash right before we sign.
546
+ if (params.walletData.type !== 'hot') {
547
+ return Promise.resolve(params);
548
+ }
549
+ const txRequestId = params.txPrebuild?.txRequestId;
550
+ if (txRequestId === undefined) {
551
+ throw new Error('Missing txRequestId');
552
+ }
553
+ const { tssUtils } = params;
554
+ await tssUtils.deleteSignatureShares(txRequestId);
555
+ const recreated = await tssUtils.getTxRequest(txRequestId);
556
+ let txHex = '';
557
+ if (recreated.unsignedTxs) {
558
+ txHex = recreated.unsignedTxs[0]?.serializedTxHex;
559
+ }
560
+ else {
561
+ txHex = recreated.transactions ? recreated.transactions[0]?.unsignedTx.serializedTxHex : '';
562
+ }
563
+ if (!txHex) {
564
+ throw new Error('Missing serialized tx hex');
565
+ }
566
+ return Promise.resolve({
567
+ ...params,
568
+ txPrebuild: recreated,
569
+ txHex,
570
+ });
571
+ }
572
+ getPublicNodeUrl(apiKey) {
573
+ if (apiKey) {
574
+ return sdk_core_1.Environments[this.bitgo.getEnv()].solAlchemyNodeUrl + `/${apiKey}`;
575
+ }
576
+ return sdk_core_1.Environments[this.bitgo.getEnv()].solNodeUrl;
577
+ }
578
+ /**
579
+ * Make a request to one of the public SOL nodes available
580
+ * @param params.payload
581
+ */
582
+ async getDataFromNode(params, apiKey) {
583
+ const nodeUrl = this.getPublicNodeUrl(apiKey);
584
+ try {
585
+ return await request.post(nodeUrl).send(params.payload);
586
+ }
587
+ catch (e) {
588
+ console.debug(e);
589
+ }
590
+ throw new Error(`Unable to call endpoint: '/' from node: ${nodeUrl}`);
591
+ }
592
+ async getBlockhash(apiKey) {
593
+ const response = await this.getDataFromNode({
594
+ payload: {
595
+ id: '1',
596
+ jsonrpc: '2.0',
597
+ method: 'getLatestBlockhash',
598
+ params: [
599
+ {
600
+ commitment: 'finalized',
601
+ },
602
+ ],
603
+ },
604
+ }, apiKey);
605
+ if (response.status !== 200) {
606
+ throw new Error('Account not found');
607
+ }
608
+ return response.body.result.value.blockhash;
609
+ }
610
+ async getFeeForMessage(message, apiKey) {
611
+ const response = await this.getDataFromNode({
612
+ payload: {
613
+ id: '1',
614
+ jsonrpc: '2.0',
615
+ method: 'getFeeForMessage',
616
+ params: [
617
+ message,
618
+ {
619
+ commitment: 'finalized',
620
+ },
621
+ ],
622
+ },
623
+ }, apiKey);
624
+ if (response.status !== 200) {
625
+ throw new Error('Account not found');
626
+ }
627
+ return response.body.result.value;
628
+ }
629
+ async getRentExemptAmount(apiKey) {
630
+ const response = await this.getDataFromNode({
631
+ payload: {
632
+ jsonrpc: '2.0',
633
+ id: '1',
634
+ method: 'getMinimumBalanceForRentExemption',
635
+ params: [165],
636
+ },
637
+ }, apiKey);
638
+ if (response.status !== 200 || response.error) {
639
+ throw new Error(JSON.stringify(response.error));
640
+ }
641
+ return response.body.result;
642
+ }
643
+ async getAccountBalance(pubKey, apiKey) {
644
+ const response = await this.getDataFromNode({
645
+ payload: {
646
+ id: '1',
647
+ jsonrpc: '2.0',
648
+ method: 'getBalance',
649
+ params: [pubKey],
650
+ },
651
+ }, apiKey);
652
+ if (response.status !== 200) {
653
+ throw new Error('Account not found');
654
+ }
655
+ return response.body.result.value;
656
+ }
657
+ async getAccountInfo(pubKey, apiKey) {
658
+ const response = await this.getDataFromNode({
659
+ payload: {
660
+ id: '1',
661
+ jsonrpc: '2.0',
662
+ method: 'getAccountInfo',
663
+ params: [
664
+ pubKey,
665
+ {
666
+ encoding: 'jsonParsed',
667
+ },
668
+ ],
669
+ },
670
+ }, apiKey);
671
+ if (response.status !== 200) {
672
+ throw new Error('Account not found');
673
+ }
674
+ return {
675
+ authority: response.body.result.value.data.parsed.info.authority,
676
+ blockhash: response.body.result.value.data.parsed.info.blockhash,
677
+ };
678
+ }
679
+ async getTokenAccountsByOwner(pubKey = '', programId = '', apiKey) {
680
+ const response = await this.getDataFromNode({
681
+ payload: {
682
+ id: '1',
683
+ jsonrpc: '2.0',
684
+ method: 'getTokenAccountsByOwner',
685
+ params: [
686
+ pubKey,
687
+ {
688
+ programId: programId.toString().toLowerCase() === spl_token_1.TOKEN_2022_PROGRAM_ID.toString().toLowerCase()
689
+ ? spl_token_1.TOKEN_2022_PROGRAM_ID.toString()
690
+ : spl_token_1.TOKEN_PROGRAM_ID.toString(),
691
+ },
692
+ {
693
+ encoding: 'jsonParsed',
694
+ },
695
+ ],
696
+ },
697
+ }, apiKey);
698
+ if (response.status !== 200) {
699
+ throw new Error('Account not found');
700
+ }
701
+ if (response.body.result.value.length !== 0) {
702
+ const tokenAccounts = [];
703
+ for (const tokenAccount of response.body.result.value) {
704
+ tokenAccounts.push({ info: tokenAccount.account.data.parsed.info, pubKey: tokenAccount.pubKey });
705
+ }
706
+ return tokenAccounts;
707
+ }
708
+ return [];
709
+ }
710
+ async getTokenAccountInfo(pubKey, apiKey) {
711
+ const response = await this.getDataFromNode({
712
+ payload: {
713
+ id: '1',
714
+ jsonrpc: '2.0',
715
+ method: 'getAccountInfo',
716
+ params: [
717
+ pubKey,
718
+ {
719
+ encoding: 'jsonParsed',
720
+ },
721
+ ],
722
+ },
723
+ }, apiKey);
724
+ if (response.status !== 200) {
725
+ throw new Error('Account not found');
726
+ }
727
+ return {
728
+ pubKey: pubKey,
729
+ info: response.body.result.value.data.parsed.info,
730
+ };
731
+ }
732
+ /** inherited doc */
733
+ async createBroadcastableSweepTransaction(params) {
734
+ if (!params.signatureShares) {
735
+ ('Missing transaction(s)');
736
+ }
737
+ const req = params.signatureShares;
738
+ const broadcastableTransactions = [];
739
+ let lastScanIndex = 0;
740
+ for (let i = 0; i < req.length; i++) {
741
+ const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
742
+ const transaction = req[i].txRequest.transactions[0].unsignedTx;
743
+ if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {
744
+ throw new Error('Missing signature(s)');
745
+ }
746
+ const signature = req[i].ovc[0].eddsaSignature;
747
+ if (!transaction.signableHex) {
748
+ throw new Error('Missing signable hex');
749
+ }
750
+ const messageBuffer = Buffer.from(transaction.signableHex, 'hex');
751
+ const result = MPC.verify(messageBuffer, signature);
752
+ if (!result) {
753
+ throw new Error('Invalid signature');
754
+ }
755
+ const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
756
+ const txBuilder = this.getBuilder().from(transaction.serializedTx);
757
+ if (!transaction.coinSpecific?.commonKeychain) {
758
+ throw new Error('Missing common keychain');
759
+ }
760
+ const commonKeychain = transaction.coinSpecific.commonKeychain;
761
+ if (!transaction.derivationPath) {
762
+ throw new Error('Missing derivation path');
763
+ }
764
+ const derivationPath = transaction.derivationPath;
765
+ const accountId = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
766
+ const bs58EncodedPublicKey = new lib_1.KeyPair({ pub: accountId }).getAddress();
767
+ // add combined signature from ovc
768
+ const publicKeyObj = { pub: bs58EncodedPublicKey };
769
+ txBuilder.addSignature(publicKeyObj, signatureHex);
770
+ const signedTransaction = await txBuilder.build();
771
+ const serializedTx = signedTransaction.toBroadcastFormat();
772
+ broadcastableTransactions.push({
773
+ serializedTx: serializedTx,
774
+ scanIndex: transaction.scanIndex,
775
+ });
776
+ if (i === req.length - 1 && transaction.coinSpecific.lastScanIndex) {
777
+ lastScanIndex = transaction.coinSpecific.lastScanIndex;
778
+ }
779
+ }
780
+ return { transactions: broadcastableTransactions, lastScanIndex };
781
+ }
782
+ /**
783
+ * Builds a funds recovery transaction without BitGo
784
+ * @param {SolRecoveryOptions} params parameters needed to construct and
785
+ * (maybe) sign the transaction
786
+ *
787
+ * @returns {MPCTx | MPCSweepTxs} the serialized transaction hex string and index
788
+ * of the address being swept
789
+ */
790
+ async recover(params) {
791
+ if (!params.bitgoKey) {
792
+ throw new Error('missing bitgoKey');
793
+ }
794
+ if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
795
+ throw new Error('invalid recoveryDestination');
796
+ }
797
+ const bitgoKey = params.bitgoKey.replace(/\s/g, '');
798
+ const isUnsignedSweep = !params.walletPassphrase;
799
+ // Build the transaction
800
+ const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
801
+ let balance = 0;
802
+ const index = params.index || 0;
803
+ const currPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
804
+ const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);
805
+ const bs58EncodedPublicKey = new lib_1.KeyPair({ pub: accountId }).getAddress();
806
+ balance = await this.getAccountBalance(bs58EncodedPublicKey, params.apiKey);
807
+ const factory = this.getBuilder();
808
+ const walletCoin = this.getChain();
809
+ let txBuilder;
810
+ let blockhash = await this.getBlockhash(params.apiKey);
811
+ let rentExemptAmount;
812
+ let authority = '';
813
+ let totalFee = new bignumber_js_1.default(0);
814
+ let totalFeeForTokenRecovery = new bignumber_js_1.default(0);
815
+ // check for possible token recovery, recover the token provide by user
816
+ if (params.tokenContractAddress) {
817
+ let isUnsupportedToken = false;
818
+ const tokenAccounts = await this.getTokenAccountsByOwner(bs58EncodedPublicKey, params.programId, params.apiKey);
819
+ if (tokenAccounts.length !== 0) {
820
+ // there exists token accounts on the given address, but need to check certain conditions:
821
+ // 1. if there is a recoverable balance
822
+ // 2. if the token is supported by bitgo
823
+ const recovereableTokenAccounts = [];
824
+ for (const tokenAccount of tokenAccounts) {
825
+ if (params.tokenContractAddress === tokenAccount.info.mint) {
826
+ const tokenAmount = new bignumber_js_1.default(tokenAccount.info.tokenAmount.amount);
827
+ const network = this.getNetwork();
828
+ const token = (0, utils_1.getSolTokenFromAddress)(tokenAccount.info.mint, network); // todo(WIN-5894) fix for ams
829
+ if (!token) {
830
+ isUnsupportedToken = true;
831
+ }
832
+ if (tokenAmount.gt(new bignumber_js_1.default(0))) {
833
+ tokenAccount.tokenName = token?.name || 'Unsupported Token';
834
+ recovereableTokenAccounts.push(tokenAccount);
835
+ }
836
+ break;
837
+ }
838
+ }
839
+ if (recovereableTokenAccounts.length !== 0) {
840
+ rentExemptAmount = await this.getRentExemptAmount(params.apiKey);
841
+ txBuilder = factory
842
+ .getTokenTransferBuilder()
843
+ .nonce(blockhash)
844
+ .sender(bs58EncodedPublicKey)
845
+ .associatedTokenAccountRent(rentExemptAmount.toString())
846
+ .feePayer(bs58EncodedPublicKey);
847
+ // need to get all token accounts of the recipient address and need to create them if they do not exist
848
+ const recipientTokenAccounts = await this.getTokenAccountsByOwner(params.recoveryDestination, params.programId, params.apiKey);
849
+ for (const tokenAccount of recovereableTokenAccounts) {
850
+ let recipientTokenAccountExists = false;
851
+ for (const recipientTokenAccount of recipientTokenAccounts) {
852
+ if (recipientTokenAccount.info.mint === tokenAccount.info.mint) {
853
+ recipientTokenAccountExists = true;
854
+ break;
855
+ }
856
+ }
857
+ const recipientTokenAccount = await (0, utils_1.getAssociatedTokenAccountAddress)(tokenAccount.info.mint, params.recoveryDestination, false, params.programId?.toString());
858
+ const tokenName = tokenAccount.tokenName;
859
+ const sendParams = {
860
+ address: recipientTokenAccount,
861
+ amount: tokenAccount.info.tokenAmount.amount,
862
+ tokenName,
863
+ ...(isUnsupportedToken
864
+ ? {
865
+ tokenAddress: tokenAccount.info.mint,
866
+ programId: params.programId?.toString(),
867
+ decimalPlaces: tokenAccount.info.tokenAmount.decimals,
868
+ }
869
+ : {}),
870
+ };
871
+ txBuilder.send(sendParams);
872
+ if (!recipientTokenAccountExists) {
873
+ // recipient token account does not exist for token and must be created
874
+ txBuilder.createAssociatedTokenAccount({
875
+ ownerAddress: params.recoveryDestination,
876
+ tokenName: tokenName,
877
+ ...(isUnsupportedToken ? { tokenAddress: tokenAccount.info.mint } : {}),
878
+ programId: params.programId?.toString().toLowerCase() === spl_token_1.TOKEN_2022_PROGRAM_ID.toString().toLowerCase()
879
+ ? spl_token_1.TOKEN_2022_PROGRAM_ID.toString()
880
+ : spl_token_1.TOKEN_PROGRAM_ID.toString(),
881
+ });
882
+ // add rent exempt amount to total fee for each token account that has to be created
883
+ totalFeeForTokenRecovery = totalFeeForTokenRecovery.plus(rentExemptAmount);
884
+ }
885
+ }
886
+ }
887
+ else {
888
+ throw Error('Not enough token funds to recover');
889
+ }
890
+ }
891
+ else {
892
+ // there are no recoverable token accounts , need to check if there are tokens to recover
893
+ throw Error('Did not find token account to recover tokens, please check token account');
894
+ }
895
+ }
896
+ else {
897
+ txBuilder = factory
898
+ .getTransferBuilder()
899
+ .nonce(blockhash)
900
+ .sender(bs58EncodedPublicKey)
901
+ .send({ address: params.recoveryDestination, amount: balance.toString() })
902
+ .feePayer(bs58EncodedPublicKey);
903
+ }
904
+ if (params.durableNonce) {
905
+ const durableNonceInfo = await this.getAccountInfo(params.durableNonce.publicKey, params.apiKey);
906
+ blockhash = durableNonceInfo.blockhash;
907
+ authority = durableNonceInfo.authority;
908
+ txBuilder.nonce(blockhash, {
909
+ walletNonceAddress: params.durableNonce.publicKey,
910
+ authWalletAddress: authority,
911
+ });
912
+ }
913
+ // build the transaction without fee
914
+ const unsignedTransactionWithoutFee = (await txBuilder.build());
915
+ const serializedMessage = unsignedTransactionWithoutFee.solTransaction.serializeMessage().toString('base64');
916
+ const baseFee = await this.getFeeForMessage(serializedMessage, params.apiKey);
917
+ const feePerSignature = params.durableNonce ? baseFee / 2 : baseFee;
918
+ totalFee = totalFee.plus(new bignumber_js_1.default(baseFee));
919
+ totalFeeForTokenRecovery = totalFeeForTokenRecovery.plus(new bignumber_js_1.default(baseFee));
920
+ if (totalFee.gt(balance)) {
921
+ throw Error('Did not find address with funds to recover');
922
+ }
923
+ if (params.tokenContractAddress) {
924
+ // Check if there is sufficient native solana to recover tokens
925
+ if (new bignumber_js_1.default(balance).lt(totalFeeForTokenRecovery)) {
926
+ throw Error('Not enough funds to pay for recover tokens fees, have: ' +
927
+ balance +
928
+ ' need: ' +
929
+ totalFeeForTokenRecovery.toString());
930
+ }
931
+ txBuilder.fee({ amount: feePerSignature });
932
+ }
933
+ else {
934
+ const netAmount = new bignumber_js_1.default(balance).minus(totalFee);
935
+ txBuilder = factory
936
+ .getTransferBuilder()
937
+ .nonce(blockhash)
938
+ .sender(bs58EncodedPublicKey)
939
+ .send({ address: params.recoveryDestination, amount: netAmount.toString() })
940
+ .feePayer(bs58EncodedPublicKey)
941
+ .fee({ amount: feePerSignature });
942
+ if (params.durableNonce) {
943
+ txBuilder.nonce(blockhash, {
944
+ walletNonceAddress: params.durableNonce.publicKey,
945
+ authWalletAddress: authority,
946
+ });
947
+ }
948
+ }
949
+ if (!isUnsignedSweep) {
950
+ // Sign the txn
951
+ if (!params.userKey) {
952
+ throw new Error('missing userKey');
953
+ }
954
+ if (!params.backupKey) {
955
+ throw new Error('missing backupKey');
956
+ }
957
+ if (!params.walletPassphrase) {
958
+ throw new Error('missing wallet passphrase');
959
+ }
960
+ // build the transaction with fee
961
+ const unsignedTransaction = (await txBuilder.build());
962
+ const userKey = params.userKey.replace(/\s/g, '');
963
+ const backupKey = params.backupKey.replace(/\s/g, '');
964
+ // Decrypt private keys from KeyCard values
965
+ let userPrv;
966
+ try {
967
+ userPrv = this.bitgo.decrypt({
968
+ input: userKey,
969
+ password: params.walletPassphrase,
970
+ });
971
+ }
972
+ catch (e) {
973
+ throw new Error(`Error decrypting user keychain: ${e.message}`);
974
+ }
975
+ const userSigningMaterial = JSON.parse(userPrv);
976
+ let backupPrv;
977
+ try {
978
+ backupPrv = this.bitgo.decrypt({
979
+ input: backupKey,
980
+ password: params.walletPassphrase,
981
+ });
982
+ }
983
+ catch (e) {
984
+ throw new Error(`Error decrypting backup keychain: ${e.message}`);
985
+ }
986
+ const backupSigningMaterial = JSON.parse(backupPrv);
987
+ const signatureHex = await sdk_core_1.EDDSAMethods.getTSSSignature(userSigningMaterial, backupSigningMaterial, currPath, unsignedTransaction);
988
+ const publicKeyObj = { pub: bs58EncodedPublicKey };
989
+ txBuilder.addSignature(publicKeyObj, signatureHex);
990
+ }
991
+ if (params.durableNonce) {
992
+ // add durable nonce account signature
993
+ txBuilder.sign({ key: params.durableNonce.secretKey });
994
+ }
995
+ const completedTransaction = await txBuilder.build();
996
+ const serializedTx = completedTransaction.toBroadcastFormat();
997
+ const derivationPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
998
+ const inputs = [];
999
+ for (const input of completedTransaction.inputs) {
1000
+ inputs.push({
1001
+ address: input.address,
1002
+ valueString: input.value,
1003
+ value: new bignumber_js_1.default(input.value).toNumber(),
1004
+ });
1005
+ }
1006
+ const outputs = [];
1007
+ for (const output of completedTransaction.outputs) {
1008
+ outputs.push({
1009
+ address: output.address,
1010
+ valueString: output.value,
1011
+ coinName: output.coin ? output.coin : walletCoin,
1012
+ });
1013
+ }
1014
+ const spendAmount = completedTransaction.inputs.length === 1 ? completedTransaction.inputs[0].value : 0;
1015
+ const parsedTx = { inputs: inputs, outputs: outputs, spendAmount: spendAmount, type: '' };
1016
+ const feeInfo = { fee: totalFeeForTokenRecovery.toNumber(), feeString: totalFee.toString() };
1017
+ const coinSpecific = { commonKeychain: bitgoKey };
1018
+ if (isUnsignedSweep) {
1019
+ const transaction = {
1020
+ serializedTx: serializedTx,
1021
+ scanIndex: index,
1022
+ coin: walletCoin,
1023
+ signableHex: completedTransaction.signablePayload.toString('hex'),
1024
+ derivationPath: derivationPath,
1025
+ parsedTx: parsedTx,
1026
+ feeInfo: feeInfo,
1027
+ coinSpecific: coinSpecific,
1028
+ };
1029
+ const unsignedTx = { unsignedTx: transaction, signatureShares: [] };
1030
+ const transactions = [unsignedTx];
1031
+ const txRequest = {
1032
+ transactions: transactions,
1033
+ walletCoin: walletCoin,
1034
+ };
1035
+ const txRequests = { txRequests: [txRequest] };
1036
+ return txRequests;
1037
+ }
1038
+ const transaction = {
1039
+ serializedTx: serializedTx,
1040
+ scanIndex: index,
1041
+ };
1042
+ return transaction;
1043
+ }
1044
+ /**
1045
+ * Builds a funds recovery transaction without BitGo
1046
+ * @param {SolRecoveryOptions} params parameters needed to construct and
1047
+ * (maybe) sign the transaction
1048
+ *
1049
+ * @returns {BaseBroadcastTransactionResult[]} the serialized transaction hex string and index
1050
+ * of the address being swept
1051
+ */
1052
+ async recoverCloseATA(params) {
1053
+ if (!params.bitgoKey) {
1054
+ throw new Error('missing bitgoKey');
1055
+ }
1056
+ if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
1057
+ throw new Error('invalid recoveryDestination');
1058
+ }
1059
+ if (!params.closeAtaAddress || !this.isValidAddress(params.closeAtaAddress)) {
1060
+ throw new Error('invalid closeAtaAddress');
1061
+ }
1062
+ const bitgoKey = params.bitgoKey.replace(/\s/g, '');
1063
+ // Build the transaction
1064
+ const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
1065
+ let balance = 0;
1066
+ const index = params.index || 0;
1067
+ const currPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
1068
+ const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);
1069
+ const bs58EncodedPublicKey = new lib_1.KeyPair({ pub: accountId }).getAddress();
1070
+ const accountBalance = await this.getAccountBalance(bs58EncodedPublicKey);
1071
+ balance = await this.getAccountBalance(params.closeAtaAddress);
1072
+ if (balance <= 0) {
1073
+ throw Error('Did not find closeAtaAddress with sol funds to recover');
1074
+ }
1075
+ const factory = this.getBuilder();
1076
+ let txBuilder;
1077
+ let blockhash;
1078
+ const recovertTxns = [];
1079
+ const rentExemptAmount = await this.getRentExemptAmount();
1080
+ // do token recovery before closing ATA address
1081
+ // check if any token is present on the closeAtaAddress
1082
+ const tokenInfo = await this.getTokenAccountInfo(params.closeAtaAddress);
1083
+ const tokenBalance = Number(tokenInfo.info.tokenAmount.amount);
1084
+ if (tokenBalance > 0) {
1085
+ // closeATA address has some token balance, it needs to be withdrawn before closing ATA
1086
+ console.log(`closeATA address ${params.closeAtaAddress} has token balance ${tokenBalance}, it needs to be withdrawn before closing ATA address`);
1087
+ if (!params.recoveryDestinationAtaAddress || !this.isValidAddress(params.recoveryDestinationAtaAddress)) {
1088
+ throw new Error('invalid recoveryDestinationAtaAddress');
1089
+ }
1090
+ blockhash = await this.getBlockhash(params.apiKey);
1091
+ txBuilder = factory
1092
+ .getTokenTransferBuilder()
1093
+ .nonce(blockhash)
1094
+ .sender(bs58EncodedPublicKey)
1095
+ .associatedTokenAccountRent(rentExemptAmount.toString())
1096
+ .feePayer(bs58EncodedPublicKey);
1097
+ const unsignedTransaction = (await txBuilder.build());
1098
+ const serializedMessage = unsignedTransaction.solTransaction.serializeMessage().toString('base64');
1099
+ const feePerSignature = await this.getFeeForMessage(serializedMessage, params.apiKey);
1100
+ const baseFee = params.durableNonce ? feePerSignature * 2 : feePerSignature;
1101
+ const totalFee = new bignumber_js_1.default(baseFee);
1102
+ if (totalFee.gt(accountBalance)) {
1103
+ throw Error('Did not find address with funds to recover');
1104
+ }
1105
+ txBuilder.fee({ amount: feePerSignature });
1106
+ const network = this.getNetwork();
1107
+ const token = (0, utils_1.getSolTokenFromAddress)(tokenInfo.info.mint, network); // todo(WIN-5894) fix for ams
1108
+ txBuilder.send({
1109
+ address: params.recoveryDestinationAtaAddress,
1110
+ amount: tokenBalance,
1111
+ tokenName: token?.name,
1112
+ });
1113
+ const tokenRecoveryTxn = await this.signAndGenerateBroadcastableTransaction(params, txBuilder, bs58EncodedPublicKey);
1114
+ const serializedTokenRecoveryTxn = (await tokenRecoveryTxn).serializedTx;
1115
+ const broadcastTokenRecoveryTxn = await this.broadcastTransaction({
1116
+ serializedSignedTransaction: serializedTokenRecoveryTxn,
1117
+ });
1118
+ logger_1.logger.log(broadcastTokenRecoveryTxn);
1119
+ recovertTxns.push(broadcastTokenRecoveryTxn);
1120
+ }
1121
+ // after recovering the token amount, attempting to close the ATA address
1122
+ if (params.closeAtaAddress) {
1123
+ blockhash = await this.getBlockhash(params.apiKey);
1124
+ const ataCloseBuilder = () => {
1125
+ const txBuilder = factory.getCloseAtaInitializationBuilder();
1126
+ txBuilder.nonce(blockhash);
1127
+ txBuilder.sender(bs58EncodedPublicKey);
1128
+ txBuilder.accountAddress(params.closeAtaAddress ?? '');
1129
+ txBuilder.destinationAddress(params.recoveryDestination);
1130
+ txBuilder.authorityAddress(bs58EncodedPublicKey);
1131
+ txBuilder.associatedTokenAccountRent(rentExemptAmount.toString());
1132
+ return txBuilder;
1133
+ };
1134
+ txBuilder = ataCloseBuilder();
1135
+ }
1136
+ const closeATARecoveryTxn = await this.signAndGenerateBroadcastableTransaction(params, txBuilder, bs58EncodedPublicKey);
1137
+ const serializedCloseATARecoveryTxn = (await closeATARecoveryTxn).serializedTx;
1138
+ const broadcastCloseATARecoveryTxn = await this.broadcastTransaction({
1139
+ serializedSignedTransaction: serializedCloseATARecoveryTxn,
1140
+ });
1141
+ logger_1.logger.log(broadcastCloseATARecoveryTxn);
1142
+ recovertTxns.push(broadcastCloseATARecoveryTxn);
1143
+ return recovertTxns;
1144
+ }
1145
+ /**
1146
+ * Recovers tokens from a nested ATA — an ATA whose owner is another ATA rather than a wallet address.
1147
+ *
1148
+ * This situation occurs when an external sender mistakenly calls createAssociatedTokenAccount with
1149
+ * an ATA address as the owner instead of the root wallet address. The result is a "nested ATA"
1150
+ * (ATA-2) owned by the wallet's normal ATA (ATA-1). Because ATA-1 is a PDA with no private key,
1151
+ * the standard recoverCloseATA flow cannot sign for ATA-2.
1152
+ *
1153
+ * This method uses the Associated Token Account program's RecoverNested instruction, which allows
1154
+ * the root wallet owner to sign and atomically move tokens from ATA-2 → ATA-1 and close ATA-2,
1155
+ * returning the rent-exempt SOL to the wallet address.
1156
+ *
1157
+ * @param {SolRecoveryOptions} params - recovery params, requires nestedAtaAddress, ownerAtaAddress,
1158
+ * and tokenMintAddress in addition to the standard keychain fields
1159
+ */
1160
+ async recoverNestedAta(params) {
1161
+ if (!params.bitgoKey) {
1162
+ throw new Error('missing bitgoKey');
1163
+ }
1164
+ if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
1165
+ throw new Error('invalid recoveryDestination');
1166
+ }
1167
+ if (!params.nestedAtaAddress || !this.isValidAddress(params.nestedAtaAddress)) {
1168
+ throw new Error('invalid nestedAtaAddress');
1169
+ }
1170
+ if (!params.ownerAtaAddress || !this.isValidAddress(params.ownerAtaAddress)) {
1171
+ throw new Error('invalid ownerAtaAddress');
1172
+ }
1173
+ if (!params.tokenMintAddress || !this.isValidAddress(params.tokenMintAddress)) {
1174
+ throw new Error('invalid tokenMintAddress');
1175
+ }
1176
+ const bitgoKey = params.bitgoKey.replace(/\s/g, '');
1177
+ const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
1178
+ const index = params.index || 0;
1179
+ const currPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
1180
+ const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);
1181
+ const bs58EncodedPublicKey = new lib_1.KeyPair({ pub: accountId }).getAddress();
1182
+ const blockhash = await this.getBlockhash(params.apiKey);
1183
+ const rentExemptAmount = await this.getRentExemptAmount();
1184
+ const factory = this.getBuilder();
1185
+ const txBuilder = factory.getRecoverNestedAtaBuilder();
1186
+ txBuilder.nonce(blockhash);
1187
+ txBuilder.sender(bs58EncodedPublicKey);
1188
+ txBuilder.feePayer(bs58EncodedPublicKey);
1189
+ txBuilder.associatedTokenAccountRent(rentExemptAmount.toString());
1190
+ txBuilder.nestedAccountAddress(params.nestedAtaAddress);
1191
+ txBuilder.nestedMintAddress(params.tokenMintAddress);
1192
+ txBuilder.destinationAccountAddress(params.ownerAtaAddress);
1193
+ txBuilder.ownerAccountAddress(params.ownerAtaAddress);
1194
+ txBuilder.ownerMintAddress(params.tokenMintAddress);
1195
+ txBuilder.walletAddress(bs58EncodedPublicKey);
1196
+ const recoverNestedTxn = await this.signAndGenerateBroadcastableTransaction(params, txBuilder, bs58EncodedPublicKey);
1197
+ const serializedTxn = (await recoverNestedTxn).serializedTx;
1198
+ const broadcastResult = await this.broadcastTransaction({
1199
+ serializedSignedTransaction: serializedTxn,
1200
+ });
1201
+ logger_1.logger.log(broadcastResult);
1202
+ return broadcastResult;
1203
+ }
1204
+ async signAndGenerateBroadcastableTransaction(params, txBuilder, bs58EncodedPublicKey) {
1205
+ // Sign the txn
1206
+ if (!params.userKey) {
1207
+ throw new Error('missing userKey');
1208
+ }
1209
+ if (!params.backupKey) {
1210
+ throw new Error('missing backupKey');
1211
+ }
1212
+ if (!params.walletPassphrase) {
1213
+ throw new Error('missing wallet passphrase');
1214
+ }
1215
+ const unsignedTransaction = (await txBuilder.build());
1216
+ const userKey = params.userKey.replace(/\s/g, '');
1217
+ const backupKey = params.backupKey.replace(/\s/g, '');
1218
+ // Decrypt private keys from KeyCard values
1219
+ let userPrv;
1220
+ try {
1221
+ userPrv = this.bitgo.decrypt({
1222
+ input: userKey,
1223
+ password: params.walletPassphrase,
1224
+ });
1225
+ }
1226
+ catch (e) {
1227
+ throw new Error(`Error decrypting user keychain: ${e.message}`);
1228
+ }
1229
+ const userSigningMaterial = JSON.parse(userPrv);
1230
+ let backupPrv;
1231
+ try {
1232
+ backupPrv = this.bitgo.decrypt({
1233
+ input: backupKey,
1234
+ password: params.walletPassphrase,
1235
+ });
1236
+ }
1237
+ catch (e) {
1238
+ throw new Error(`Error decrypting backup keychain: ${e.message}`);
1239
+ }
1240
+ const backupSigningMaterial = JSON.parse(backupPrv);
1241
+ const index = params.index || 0;
1242
+ const currPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
1243
+ const signatureHex = await sdk_core_1.EDDSAMethods.getTSSSignature(userSigningMaterial, backupSigningMaterial, currPath, unsignedTransaction);
1244
+ const publicKeyObj = { pub: bs58EncodedPublicKey };
1245
+ txBuilder.addSignature(publicKeyObj, signatureHex);
1246
+ const completedTransaction = await txBuilder.build();
1247
+ const serializedTx = completedTransaction.toBroadcastFormat();
1248
+ const transaction = {
1249
+ serializedTx: serializedTx,
1250
+ scanIndex: index,
1251
+ };
1252
+ return transaction;
1253
+ }
1254
+ /**
1255
+ * Builds native SOL recoveries of receive addresses in batch without BitGo.
1256
+ * Funds will be recovered to base address first. You need to initiate another sweep txn after that.
1257
+ *
1258
+ * @param {SolConsolidationRecoveryOptions} params - options for consolidation recovery.
1259
+ * @param {string} [params.startingScanIndex] - receive address index to start scanning from. default to 1 (inclusive).
1260
+ * @param {string} [params.endingScanIndex] - receive address index to end scanning at. default to startingScanIndex + 20 (exclusive).
1261
+ */
1262
+ async recoverConsolidations(params) {
1263
+ const isUnsignedSweep = !params.walletPassphrase;
1264
+ const startIdx = params.startingScanIndex || 1;
1265
+ const endIdx = params.endingScanIndex || startIdx + exports.DEFAULT_SCAN_FACTOR;
1266
+ if (startIdx < 1 || endIdx <= startIdx || endIdx - startIdx > 10 * exports.DEFAULT_SCAN_FACTOR) {
1267
+ throw new Error(`Invalid starting or ending index to scan for addresses. startingScanIndex: ${startIdx}, endingScanIndex: ${endIdx}.`);
1268
+ }
1269
+ // validate durable nonces array
1270
+ if (!params.durableNonces) {
1271
+ throw new Error('Missing durable nonces');
1272
+ }
1273
+ if (!params.durableNonces.publicKeys) {
1274
+ throw new Error('Invalid durable nonces: missing public keys');
1275
+ }
1276
+ if (!params.durableNonces.secretKey) {
1277
+ throw new Error('Invalid durable nonces array: missing secret key');
1278
+ }
1279
+ const bitgoKey = params.bitgoKey.replace(/\s/g, '');
1280
+ const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
1281
+ const baseAddressIndex = 0;
1282
+ const baseAddressPath = params.seed
1283
+ ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${baseAddressIndex}`
1284
+ : `m/${baseAddressIndex}`;
1285
+ const accountId = MPC.deriveUnhardened(bitgoKey, baseAddressPath).slice(0, 64);
1286
+ const baseAddress = new lib_1.KeyPair({ pub: accountId }).getAddress();
1287
+ let durableNoncePubKeysIndex = 0;
1288
+ const durableNoncePubKeysLength = params.durableNonces.publicKeys.length;
1289
+ const consolidationTransactions = [];
1290
+ let lastScanIndex = startIdx;
1291
+ for (let i = startIdx; i < endIdx; i++) {
1292
+ const recoverParams = {
1293
+ userKey: params.userKey,
1294
+ backupKey: params.backupKey,
1295
+ bitgoKey: params.bitgoKey,
1296
+ walletPassphrase: params.walletPassphrase,
1297
+ recoveryDestination: baseAddress,
1298
+ seed: params.seed,
1299
+ index: i,
1300
+ durableNonce: {
1301
+ publicKey: params.durableNonces.publicKeys[durableNoncePubKeysIndex],
1302
+ secretKey: params.durableNonces.secretKey,
1303
+ },
1304
+ tokenContractAddress: params.tokenContractAddress,
1305
+ apiKey: params.apiKey,
1306
+ programId: params.programId,
1307
+ };
1308
+ let recoveryTransaction;
1309
+ try {
1310
+ recoveryTransaction = await this.recover(recoverParams);
1311
+ }
1312
+ catch (e) {
1313
+ if (e.message === 'Did not find address with funds to recover' ||
1314
+ e.message === 'Did not find token account to recover tokens, please check token account' ||
1315
+ e.message === 'Not enough token funds to recover') {
1316
+ lastScanIndex = i;
1317
+ continue;
1318
+ }
1319
+ throw e;
1320
+ }
1321
+ if (isUnsignedSweep) {
1322
+ consolidationTransactions.push(recoveryTransaction.txRequests[0]);
1323
+ }
1324
+ else {
1325
+ consolidationTransactions.push(recoveryTransaction);
1326
+ }
1327
+ lastScanIndex = i;
1328
+ durableNoncePubKeysIndex++;
1329
+ if (durableNoncePubKeysIndex >= durableNoncePubKeysLength) {
1330
+ // no more available nonce accounts to create transactions
1331
+ break;
1332
+ }
1333
+ }
1334
+ if (consolidationTransactions.length === 0) {
1335
+ throw new Error('Did not find an address with funds to recover');
1336
+ }
1337
+ if (isUnsignedSweep) {
1338
+ // lastScanIndex will be used to inform user the last address index scanned for available funds (so they can
1339
+ // appropriately adjust the scan range on the next iteration of consolidation recoveries). In the case of unsigned
1340
+ // sweep consolidations, this lastScanIndex will be provided in the coinSpecific of the last txn made.
1341
+ const lastTransactionCoinSpecific = {
1342
+ commonKeychain: consolidationTransactions[consolidationTransactions.length - 1].transactions[0].unsignedTx.coinSpecific
1343
+ .commonKeychain,
1344
+ lastScanIndex: lastScanIndex,
1345
+ };
1346
+ consolidationTransactions[consolidationTransactions.length - 1].transactions[0].unsignedTx.coinSpecific =
1347
+ lastTransactionCoinSpecific;
1348
+ const consolidationSweepTransactions = { txRequests: consolidationTransactions };
1349
+ return consolidationSweepTransactions;
1350
+ }
1351
+ return { transactions: consolidationTransactions, lastScanIndex };
1352
+ }
1353
+ getTokenEnablementConfig() {
1354
+ return {
1355
+ requiresTokenEnablement: true,
1356
+ supportsMultipleTokenEnablements: true,
1357
+ };
1358
+ }
1359
+ getBuilder() {
1360
+ return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
1361
+ }
1362
+ async broadcastTransaction({ serializedSignedTransaction, }) {
1363
+ (0, utils_1.validateRawTransaction)(serializedSignedTransaction, true, true);
1364
+ const response = await this.getDataFromNode({
1365
+ payload: {
1366
+ id: '1',
1367
+ jsonrpc: '2.0',
1368
+ method: 'sendTransaction',
1369
+ params: [
1370
+ serializedSignedTransaction,
1371
+ {
1372
+ encoding: 'base64',
1373
+ },
1374
+ ],
1375
+ },
1376
+ });
1377
+ if (response.body.error) {
1378
+ throw new Error('Error broadcasting transaction: ' + response.body.error.message);
1379
+ }
1380
+ return { txId: response.body.result };
1381
+ }
1382
+ /** @inheritDoc */
1383
+ auditDecryptedKey({ prv, publicKey, multiSigType }) {
1384
+ if (multiSigType !== 'tss') {
1385
+ throw new Error('Unsupported multiSigType');
1386
+ }
1387
+ (0, sdk_lib_mpc_1.auditEddsaPrivateKey)(prv, publicKey ?? '');
1388
+ }
1389
+ /** @inheritDoc */
1390
+ setCoinSpecificFieldsInIntent(intent, params) {
1391
+ // Handle custom instructions for Solana
1392
+ if (params.solInstructions) {
1393
+ intent.solInstructions = params.solInstructions;
1394
+ }
1395
+ // Handle versioned transaction data for Solana
1396
+ if (params.solVersionedTransactionData) {
1397
+ intent.solVersionedTransactionData = params.solVersionedTransactionData;
1398
+ }
1399
+ }
1400
+ }
1401
+ exports.Sol = Sol;
1402
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sol.js","sourceRoot":"","sources":["../../../src/sol.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\n\nimport { TOKEN_2022_PROGRAM_ID, TOKEN_PROGRAM_ID } from '@solana/spl-token';\nimport BigNumber from 'bignumber.js';\nimport * as base58 from 'bs58';\nimport * as _ from 'lodash';\nimport * as request from 'superagent';\nimport { logger } from '@bitgo-beta/logger';\n\nimport {\n  AuditDecryptedKeyParams,\n  BaseBroadcastTransactionOptions,\n  BaseBroadcastTransactionResult,\n  BaseCoin,\n  ParseTransactionOptions as BaseParseTransactionOptions,\n  BaseTransaction,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  BitGoBase,\n  EDDSAMethods,\n  EDDSAMethodTypes,\n  Environments,\n  ITokenEnablement,\n  KeyPair,\n  Memo,\n  MPCAlgorithm,\n  MPCConsolidationRecoveryOptions,\n  MPCRecoveryOptions,\n  MPCSweepRecoveryOptions,\n  MPCSweepTxs,\n  MPCTx,\n  MPCTxs,\n  MPCUnsignedTx,\n  MultisigType,\n  multisigTypes,\n  OvcInput,\n  OvcOutput,\n  ParsedTransaction,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  PresignTransactionOptions,\n  PublicKey,\n  RecoveryTxRequest,\n  SignedTransaction,\n  SignTransactionOptions,\n  SolVersionedTransactionData,\n  TokenEnablement,\n  TokenEnablementConfig,\n  TransactionExplanation,\n  TransactionParams,\n  TransactionRecipient,\n  VerifyTransactionOptions,\n  TssVerifyAddressOptions,\n  verifyEddsaTssWalletAddress,\n  UnexpectedAddressError,\n} from '@bitgo-beta/sdk-core';\nimport { auditEddsaPrivateKey, getDerivationPath } from '@bitgo-beta/sdk-lib-mpc';\nimport { BaseNetwork, CoinFamily, coins, SolCoin, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';\nimport {\n  KeyPair as SolKeyPair,\n  Transaction,\n  TransactionBuilder,\n  TransactionBuilderFactory,\n  explainSolTransaction,\n} from './lib';\nimport { TransactionExplanation as SolLibTransactionExplanation } from './lib/iface';\nimport {\n  getAssociatedTokenAccountAddress,\n  getSolTokenFromAddress,\n  getSolTokenFromTokenName,\n  isValidAddress,\n  isValidPrivateKey,\n  isValidPublicKey,\n  validateRawTransaction,\n} from './lib/utils';\n\nexport const DEFAULT_SCAN_FACTOR = 20; // default number of receive addresses to scan for funds\n\nexport interface TransactionFee {\n  fee: string;\n}\n\nexport type SolTransactionExplanation = TransactionExplanation;\n\nexport interface ExplainTransactionOptions {\n  txBase64: string;\n  feeInfo: TransactionFee;\n  tokenAccountRentExemptAmount?: string;\n  coinName?: string;\n}\n\nexport interface TxInfo {\n  recipients: TransactionRecipient[];\n  from: string;\n  txid: string;\n}\n\nexport interface SolSignTransactionOptions extends SignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string | string[];\n  pubKeys?: string[];\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txBase64: string;\n  txInfo: TxInfo;\n  source: string;\n}\n\nexport interface SolVerifyTransactionOptions extends VerifyTransactionOptions {\n  memo?: Memo;\n  feePayer: string;\n  blockhash: string;\n  durableNonce?: { walletNonceAddress: string; authWalletAddress: number };\n}\n\ninterface TransactionOutput {\n  address: string;\n  amount: number | string;\n  tokenName?: string;\n}\n\ntype TransactionInput = TransactionOutput;\n\nexport interface SolParsedTransaction extends ParsedTransaction {\n  // total assets being moved, including fees\n  inputs: TransactionInput[];\n\n  // where assets are moved to\n  outputs: TransactionOutput[];\n}\n\nexport interface SolParseTransactionOptions extends BaseParseTransactionOptions {\n  txBase64: string;\n  feeInfo: TransactionFee;\n  tokenAccountRentExemptAmount?: string;\n}\n\ninterface SolDurableNonceFromNode {\n  authority: string;\n  blockhash: string;\n}\n\ninterface TokenAmount {\n  amount: string;\n  decimals: number;\n  uiAmount: number;\n  uiAmountString: string;\n}\n\ninterface TokenAccountInfo {\n  isNative: boolean;\n  mint: string;\n  owner: string;\n  state: string;\n  tokenAmount: TokenAmount;\n}\n\ninterface TokenAccount {\n  info: TokenAccountInfo;\n  pubKey: string;\n  tokenName?: string;\n}\n\nexport interface SolRecoveryOptions extends MPCRecoveryOptions {\n  durableNonce?: {\n    publicKey: string;\n    secretKey: string;\n  };\n  tokenContractAddress?: string;\n  closeAtaAddress?: string;\n  // destination address where token should be sent before closing the ATA address\n  recoveryDestinationAtaAddress?: string;\n  // nested ATA address (ATA whose owner is another ATA) to recover tokens from\n  nestedAtaAddress?: string;\n  // the ATA that owns the nested ATA (and where recovered tokens will be sent)\n  ownerAtaAddress?: string;\n  // the token mint address for both ATAs (required when recovering from nested ATA)\n  tokenMintAddress?: string;\n  programId?: string; // programId of the token\n  apiKey?: string; // API key for node requests\n}\n\nexport interface SolConsolidationRecoveryOptions extends MPCConsolidationRecoveryOptions {\n  durableNonces: {\n    publicKeys: string[];\n    secretKey: string;\n  };\n  tokenContractAddress?: string;\n  apiKey?: string; // API key for node requests\n  programId?: string; // programId of the token\n}\n\nconst HEX_REGEX = /^[0-9a-fA-F]+$/;\nconst BLIND_SIGNING_TX_TYPES_TO_CHECK = { enabletoken: 'AssociatedTokenAccountInitialization' };\n\n/**\n * Get amount string corrected for architecture-specific endianness issues.\n *\n * On s390x (big-endian) architecture, the Solana transaction parser (via @solana/web3.js)\n * incorrectly reads little-endian u64 amounts as big-endian, resulting in corrupted values.\n *\n * This function corrects all amounts on s390x by swapping byte order to undo\n * the incorrect byte order that happened during transaction parsing.\n *\n * @param amount - The amount to check and potentially fix\n * @returns The corrected amount as a string\n */\nexport function getAmountBasedOnEndianness(amount: string | number): string {\n  const amountStr = String(amount);\n\n  // Only s390x architecture has this endianness issue\n  const isS390x = process.arch === 's390x';\n  if (!isS390x) {\n    return amountStr;\n  }\n\n  try {\n    const amountBN = BigInt(amountStr);\n    // On s390x, the parser ALWAYS reads u64 as big-endian when it's actually little-endian\n    // So we ALWAYS need to swap bytes to get the correct value\n    const buf = Buffer.alloc(8);\n    buf.writeBigUInt64BE(amountBN, 0);\n    const fixed = buf.readBigUInt64LE(0);\n    return fixed.toString();\n  } catch (e) {\n    // If conversion fails, return original value\n    return amountStr;\n  }\n}\n\nexport class Sol extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Sol(bitgo, staticsCoin);\n  }\n\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc */\n  supportsMessageSigning(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'eddsa';\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  getNetwork(): BaseNetwork {\n    return this._staticsCoin.network;\n  }\n\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  verifyTxType(expectedTypeFromUserParams: string, actualTypeFromDecoded: string | undefined): void {\n    const matchFromUserToDecodedType = BLIND_SIGNING_TX_TYPES_TO_CHECK[expectedTypeFromUserParams];\n    if (matchFromUserToDecodedType !== actualTypeFromDecoded) {\n      throw new Error(\n        `Invalid transaction type on token enablement: expected \"${matchFromUserToDecodedType}\", got \"${actualTypeFromDecoded}\".`\n      );\n    }\n  }\n\n  throwIfMissingTokenEnablementsOrReturn(explanation: TransactionExplanation): ITokenEnablement[] {\n    if (!explanation.tokenEnablements || explanation.tokenEnablements.length === 0)\n      throw new Error('Missing tx token enablements data on token enablement tx prebuild');\n    return explanation.tokenEnablements;\n  }\n\n  throwIfMissingEnableTokenConfigOrReturn(txParams: TransactionParams): TokenEnablement[] {\n    if (!txParams.enableTokens || txParams.enableTokens.length === 0) throw new Error('Missing enable token config');\n    return txParams.enableTokens;\n  }\n\n  verifyTokenName(tokenEnablementsPrebuild: ITokenEnablement[], enableTokensConfig: TokenEnablement[]): void {\n    enableTokensConfig.forEach((enableTokenConfig) => {\n      const expectedTokenName = enableTokenConfig.name;\n      tokenEnablementsPrebuild.forEach((tokenEnablement) => {\n        if (!tokenEnablement.tokenName) throw new Error('Missing token name on token enablement tx');\n        if (tokenEnablement.tokenName !== expectedTokenName)\n          throw new Error(\n            `Invalid token name: expected ${expectedTokenName}, got ${tokenEnablement.tokenName} on token enablement tx`\n          );\n      });\n    });\n  }\n\n  async verifyTokenAddress(\n    tokenEnablementsPrebuild: ITokenEnablement[],\n    enableTokensConfig: TokenEnablement[]\n  ): Promise<void> {\n    for (const enableTokenConfig of enableTokensConfig) {\n      const expectedTokenAddress = enableTokenConfig.address;\n      const expectedTokenName = enableTokenConfig.name;\n\n      if (!expectedTokenAddress) throw new Error('Missing token address on token enablement tx');\n      if (!expectedTokenName) throw new Error('Missing token name on token enablement tx');\n\n      for (const tokenEnablement of tokenEnablementsPrebuild) {\n        let tokenMintAddress: Readonly<SolCoin> | undefined;\n        try {\n          tokenMintAddress = getSolTokenFromTokenName(expectedTokenName);\n        } catch {\n          throw new Error(`Unable to derive ATA for token address: ${expectedTokenAddress}`);\n        }\n        if (\n          !tokenMintAddress ||\n          tokenMintAddress.tokenAddress === undefined ||\n          tokenMintAddress.programId === undefined\n        ) {\n          throw new Error(`Unable to get token mint address for ${expectedTokenName}`);\n        }\n        let ata: string;\n        try {\n          ata = await getAssociatedTokenAccountAddress(\n            tokenMintAddress.tokenAddress,\n            expectedTokenAddress,\n            true,\n            tokenMintAddress.programId\n          );\n        } catch {\n          throw new Error(`Unable to derive ATA for token address: ${expectedTokenAddress}`);\n        }\n        if (ata !== tokenEnablement.address) {\n          throw new Error(\n            `Invalid token address: expected ${ata}, got ${tokenEnablement.address} on token enablement tx`\n          );\n        }\n      }\n    }\n  }\n\n  private hasSolVersionedTransactionData(\n    txParams: TransactionParams\n  ): txParams is TransactionParams & { solVersionedTransactionData: SolVersionedTransactionData } {\n    return 'solVersionedTransactionData' in txParams && txParams.solVersionedTransactionData !== undefined;\n  }\n\n  /**\n   * Verify a versioned Solana transaction with basic structural validation\n   * @param params - verification parameters\n   * @returns true if verification passes\n   */\n  private async verifyVersionedTransaction(params: SolVerifyTransactionOptions): Promise<boolean> {\n    const { txParams, txPrebuild } = params;\n    const rawTx = txPrebuild.txBase64 || txPrebuild.txHex;\n\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txBase64 or txHex');\n    }\n\n    // Validate that the versioned transaction data is well-formed\n    if (!this.hasSolVersionedTransactionData(txParams)) {\n      throw new Error('solVersionedTransactionData is required for versioned transaction verification');\n    }\n\n    const versionedData = txParams.solVersionedTransactionData;\n\n    if (!versionedData.versionedInstructions || versionedData.versionedInstructions.length === 0) {\n      throw new Error('versioned transaction must have at least one instruction');\n    }\n\n    if (!versionedData.staticAccountKeys || versionedData.staticAccountKeys.length === 0) {\n      throw new Error('versioned transaction must have at least one static account key');\n    }\n\n    if (!versionedData.messageHeader) {\n      throw new Error('versioned transaction must have a message header');\n    }\n\n    // Validate that we can deserialize the transaction\n    let rawTxBase64 = rawTx;\n    if (HEX_REGEX.test(rawTx)) {\n      rawTxBase64 = Buffer.from(rawTx, 'hex').toString('base64');\n    }\n\n    try {\n      const txBytes = Buffer.from(rawTxBase64, 'base64');\n      if (txBytes.length < 1) {\n        throw new Error('transaction bytes are empty');\n      }\n\n      // Check version byte (after signatures)\n      const numSignatures = txBytes[0];\n      const signatureSize = 64;\n      const versionByteOffset = 1 + numSignatures * signatureSize;\n\n      if (txBytes.length <= versionByteOffset) {\n        throw new Error('transaction bytes are too short to contain version byte');\n      }\n\n      const versionByte = txBytes[versionByteOffset];\n      const isVersioned = (versionByte & 0x80) !== 0;\n\n      if (!isVersioned) {\n        throw new Error('transaction does not have versioned format');\n      }\n    } catch (error) {\n      throw new Error(`failed to validate versioned transaction format: ${error.message}`);\n    }\n\n    return true;\n  }\n\n  async verifyTransaction(params: SolVerifyTransactionOptions): Promise<boolean> {\n    // asset name to transfer amount map\n    const totalAmount: Record<string, BigNumber> = {};\n    const coinConfig = coins.get(this.getChain());\n    const {\n      txParams: txParams,\n      txPrebuild: txPrebuild,\n      memo: memo,\n      durableNonce: durableNonce,\n      verification: verificationOptions,\n    } = params;\n\n    if (this.hasSolVersionedTransactionData(txParams)) {\n      return this.verifyVersionedTransaction(params);\n    }\n\n    const transaction = new Transaction(coinConfig);\n    const rawTx = txPrebuild.txBase64 || txPrebuild.txHex;\n    const consolidateId = txPrebuild.consolidateId;\n\n    const walletRootAddress = params.wallet.coinSpecific()?.rootAddress;\n\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txBase64 or txHex');\n    }\n\n    let rawTxBase64 = rawTx;\n    if (HEX_REGEX.test(rawTx)) {\n      rawTxBase64 = Buffer.from(rawTx, 'hex').toString('base64');\n    }\n    transaction.fromRawTransaction(rawTxBase64);\n    const explainedTx = transaction.explainTransaction();\n\n    if (txParams.type === 'enabletoken' && verificationOptions?.verifyTokenEnablement) {\n      this.verifyTxType(txParams.type, explainedTx.type);\n      const tokenEnablementsPrebuild = this.throwIfMissingTokenEnablementsOrReturn(explainedTx);\n      const enableTokensConfig = this.throwIfMissingEnableTokenConfigOrReturn(txParams);\n\n      this.verifyTokenName(tokenEnablementsPrebuild, enableTokensConfig);\n      await this.verifyTokenAddress(tokenEnablementsPrebuild, enableTokensConfig);\n    }\n\n    // users do not input recipients for consolidation requests as they are generated by the server\n    if (txParams.recipients !== undefined) {\n      const filteredRecipients = txParams.recipients?.map((recipient) =>\n        _.pick(recipient, ['address', 'amount', 'tokenName'])\n      );\n      const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));\n\n      if (filteredRecipients.length !== filteredOutputs.length) {\n        throw new Error('Number of tx outputs does not match with number of txParams recipients');\n      }\n\n      // For each recipient, check if it's a token tx (tokenName will exist if so)\n      // If it is a token tx, verify that the recipient address equals the derived address from explainedTx\n      // Derive the ATA if it is a native address and confirm it is equal to the explained tx recipient\n      const recipientChecks = await Promise.all(\n        filteredRecipients.map(async (recipientFromUser, index) => {\n          const recipientFromTx = filteredOutputs[index]; // This address should be an ATA\n\n          // Compare the BigNumber values because amount is (string | number)\n          // Apply s390x endianness fix if needed\n          const userAmountStr = String(recipientFromUser.amount);\n          const txAmountStr = getAmountBasedOnEndianness(recipientFromTx.amount);\n\n          const userAmount = new BigNumber(userAmountStr);\n          const txAmount = new BigNumber(txAmountStr);\n          if (!userAmount.isEqualTo(txAmount)) {\n            return false;\n          }\n\n          // Compare the addresses and tokenNames\n          // Else if the addresses are not the same, check the derived ATA for parity\n          if (\n            recipientFromUser.address === recipientFromTx.address &&\n            recipientFromUser.tokenName === recipientFromTx.tokenName\n          ) {\n            return true;\n          } else if (recipientFromUser.address !== recipientFromTx.address && recipientFromUser.tokenName) {\n            // Try to check if the user's derived ATA is equal to the tx recipient address\n            // If getAssociatedTokenAccountAddress throws an error, then we are unable to derive the ATA for that address.\n            // Return false and throw an error if that is the case.\n            try {\n              const tokenMintAddress = getSolTokenFromTokenName(recipientFromUser.tokenName);\n              return getAssociatedTokenAccountAddress(\n                tokenMintAddress!.tokenAddress,\n                recipientFromUser.address,\n                true,\n                tokenMintAddress!.programId\n              ).then((ata: string) => {\n                return ata === recipientFromTx.address;\n              });\n            } catch {\n              // Unable to derive ATA\n              return false;\n            }\n          }\n          return false;\n        })\n      );\n\n      if (recipientChecks.includes(false)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n    } else if (verificationOptions?.consolidationToBaseAddress) {\n      //verify funds are sent to walletRootAddress for a consolidation\n      const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));\n\n      // Cache to store already derived ATA addresses\n      const ataAddressCache: Record<string, string> = {};\n\n      for (const output of filteredOutputs) {\n        if (output.tokenName) {\n          // Check cache first before deriving ATA address\n          if (!ataAddressCache[output.tokenName]) {\n            const tokenMintAddress = getSolTokenFromTokenName(output.tokenName);\n            if (tokenMintAddress?.tokenAddress && tokenMintAddress?.programId) {\n              ataAddressCache[output.tokenName] = await getAssociatedTokenAccountAddress(\n                tokenMintAddress.tokenAddress,\n                walletRootAddress as string,\n                true,\n                tokenMintAddress.programId\n              );\n            } else {\n              throw new Error(`Unable to get token information for ${output.tokenName}`);\n            }\n          }\n\n          if (ataAddressCache[output.tokenName] !== output.address) {\n            throw new Error('tx outputs does not match with expected address');\n          }\n        } else if (output.address !== walletRootAddress) {\n          throw new Error('tx outputs does not match with expected address');\n        }\n      }\n    }\n\n    const transactionJson = transaction.toJson();\n    if (memo && memo.value !== explainedTx.memo) {\n      throw new Error('Tx memo does not match with expected txParams recipient memo');\n    }\n    if (txParams.recipients) {\n      for (const recipients of txParams.recipients) {\n        // totalAmount based on each token\n        const assetName = recipients.tokenName || this.getChain();\n        const amount = totalAmount[assetName] || new BigNumber(0);\n        totalAmount[assetName] = amount.plus(recipients.amount);\n      }\n\n      // total output amount from explainedTx\n      const explainedTxTotal: Record<string, BigNumber> = {};\n\n      for (const output of explainedTx.outputs) {\n        // Apply s390x endianness fix to output amounts before summing\n        const outputAmountStr = getAmountBasedOnEndianness(output.amount);\n\n        // total output amount based on each token\n        const assetName = output.tokenName || this.getChain();\n        const amount = explainedTxTotal[assetName] || new BigNumber(0);\n        explainedTxTotal[assetName] = amount.plus(outputAmountStr);\n      }\n\n      if (!_.isEqual(explainedTxTotal, totalAmount)) {\n        throw new Error('Tx total amount does not match with expected total amount field');\n      }\n    }\n\n    // For non-consolidate transactions, feePayer must be the wallet's root address\n    if (consolidateId === undefined && transactionJson.feePayer !== walletRootAddress) {\n      throw new Error('Tx fee payer is not the wallet root address');\n    }\n\n    if (durableNonce && !_.isEqual(explainedTx.durableNonce, durableNonce)) {\n      throw new Error('Tx durableNonce does not match with param durableNonce');\n    }\n\n    return true;\n  }\n\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    const result = await verifyEddsaTssWalletAddress(\n      params,\n      (address) => this.isValidAddress(address),\n      (publicKey) => this.getAddressFromPublicKey(publicKey)\n    );\n\n    if (!result) {\n      throw new UnexpectedAddressError(`address validation failure: ${params.address} is not a wallet address`);\n    }\n\n    return true;\n  }\n\n  /**\n   * Converts a Solana public key to an address\n   * @param publicKey Hex-encoded public key (64 hex characters = 32 bytes)\n   * @returns Base58-encoded Solana address\n   */\n  getAddressFromPublicKey(publicKey: string): string {\n    const publicKeyBuffer = Buffer.from(publicKey, 'hex');\n    return base58.encode(publicKeyBuffer);\n  }\n\n  /**\n   * Generate Solana key pair\n   *\n   * @param {Buffer} seed - Seed from which the new SolKeyPair should be generated, otherwise a random seed is used\n   * @returns {Object} object with generated pub and prv\n   */\n  generateKeyPair(seed?: Buffer | undefined): KeyPair {\n    const result = seed ? new SolKeyPair({ seed }).getKeys() : new SolKeyPair().getKeys();\n    return result as KeyPair;\n  }\n\n  /**\n   * Return boolean indicating whether input is valid public key for the coin\n   *\n   * @param {string} pub the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPub(pub: string): boolean {\n    return isValidPublicKey(pub);\n  }\n\n  /**\n   * Return boolean indicating whether input is valid private key for the coin\n   *\n   * @param {string} prv the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPrv(prv: string): boolean {\n    return isValidPrivateKey(prv);\n  }\n\n  isValidAddress(address: string): boolean {\n    return isValidAddress(address);\n  }\n\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const solKeypair = new SolKeyPair({ prv: key.prv });\n    if (Buffer.isBuffer(message)) {\n      message = base58.encode(message);\n    }\n\n    return Buffer.from(solKeypair.signMessage(message));\n  }\n\n  /**\n   * Signs Solana transaction\n   * @param params\n   * @param callback\n   */\n  async signTransaction(params: SolSignTransactionOptions): Promise<SignedTransaction> {\n    const factory = this.getBuilder();\n    const rawTx = params.txPrebuild.txHex || params.txPrebuild.txBase64;\n    const txBuilder = factory.from(rawTx);\n    txBuilder.sign({ key: params.prv });\n    const transaction: BaseTransaction = await txBuilder.build();\n\n    if (!transaction) {\n      throw new Error('Invalid transaction');\n    }\n\n    const serializedTx = (transaction as BaseTransaction).toBroadcastFormat();\n\n    return {\n      txHex: serializedTx,\n    } as any;\n  }\n\n  async parseTransaction(params: SolParseTransactionOptions): Promise<SolParsedTransaction> {\n    // explainTransaction now uses WASM for testnet automatically\n    const transactionExplanation = await this.explainTransaction({\n      txBase64: params.txBase64,\n      feeInfo: params.feeInfo,\n      tokenAccountRentExemptAmount: params.tokenAccountRentExemptAmount,\n    });\n\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    const solTransaction = transactionExplanation as SolTransactionExplanation;\n    if (solTransaction.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n      };\n    }\n\n    const senderAddress = solTransaction.outputs[0].address;\n    const feeAmount = new BigNumber(solTransaction.fee.fee);\n\n    // assume 1 sender, who is also the fee payer\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(solTransaction.outputAmount).plus(feeAmount).toNumber(),\n      },\n    ];\n\n    const outputs: TransactionOutput[] = solTransaction.outputs.map(({ address, amount, tokenName }) => {\n      const output: TransactionOutput = { address, amount };\n      if (tokenName) {\n        output.tokenName = tokenName;\n      }\n      return output;\n    });\n\n    return {\n      inputs,\n      outputs,\n    };\n  }\n\n  /**\n   * Explain a Solana transaction from txBase64\n   * Uses WASM-based parsing for testnet, with fallback to legacy builder approach.\n   * @param params\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<SolTransactionExplanation> {\n    // Use WASM-based parsing for testnet (simpler, faster, no @solana/web3.js rebuild)\n    if (this.getChain() === 'tsol') {\n      return this.explainTransactionWithWasm(params) as SolTransactionExplanation;\n    }\n\n    // Legacy approach for mainnet (until WASM is fully validated)\n    const factory = this.getBuilder();\n    let rebuiltTransaction;\n\n    try {\n      const transactionBuilder = factory.from(params.txBase64);\n      if (transactionBuilder instanceof TransactionBuilder) {\n        const txBuilder = transactionBuilder as TransactionBuilder;\n        txBuilder.fee({ amount: params.feeInfo.fee });\n        if (params.tokenAccountRentExemptAmount) {\n          txBuilder.associatedTokenAccountRent(params.tokenAccountRentExemptAmount);\n        }\n      }\n      rebuiltTransaction = await transactionBuilder.build();\n    } catch (e) {\n      logger.error(e);\n      throw new Error('Invalid transaction');\n    }\n\n    const explainedTransaction = (rebuiltTransaction as BaseTransaction).explainTransaction();\n\n    return explainedTransaction as SolTransactionExplanation;\n  }\n\n  /**\n   * Explain a Solana transaction using WASM parsing (bypasses @solana/web3.js rebuild).\n   * Delegates to standalone explainSolTransaction().\n   */\n  explainTransactionWithWasm(params: ExplainTransactionOptions): SolLibTransactionExplanation {\n    return explainSolTransaction({ ...params, coinName: params.coinName ?? this.getChain() });\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const factory = this.getBuilder();\n    const rebuiltTransaction = await factory.from(serializedTx).build();\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /** @inheritDoc */\n  async presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions> {\n    // Hot wallet txns are only valid for 1-2 minutes.\n    // To buy more time, we rebuild the transaction with a new blockhash right before we sign.\n    if (params.walletData.type !== 'hot') {\n      return Promise.resolve(params);\n    }\n\n    const txRequestId = params.txPrebuild?.txRequestId;\n    if (txRequestId === undefined) {\n      throw new Error('Missing txRequestId');\n    }\n\n    const { tssUtils } = params;\n\n    await tssUtils!.deleteSignatureShares(txRequestId);\n    const recreated = await tssUtils!.getTxRequest(txRequestId);\n    let txHex = '';\n    if (recreated.unsignedTxs) {\n      txHex = recreated.unsignedTxs[0]?.serializedTxHex;\n    } else {\n      txHex = recreated.transactions ? recreated.transactions[0]?.unsignedTx.serializedTxHex : '';\n    }\n\n    if (!txHex) {\n      throw new Error('Missing serialized tx hex');\n    }\n\n    return Promise.resolve({\n      ...params,\n      txPrebuild: recreated,\n      txHex,\n    });\n  }\n\n  protected getPublicNodeUrl(apiKey?: string): string {\n    if (apiKey) {\n      return Environments[this.bitgo.getEnv()].solAlchemyNodeUrl + `/${apiKey}`;\n    }\n    return Environments[this.bitgo.getEnv()].solNodeUrl;\n  }\n\n  /**\n   * Make a request to one of the public SOL nodes available\n   * @param params.payload\n   */\n  protected async getDataFromNode(\n    params: { payload?: Record<string, unknown> },\n    apiKey?: string\n  ): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl(apiKey);\n    try {\n      return await request.post(nodeUrl).send(params.payload);\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint: '/' from node: ${nodeUrl}`);\n  }\n\n  protected async getBlockhash(apiKey?: string): Promise<string> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getLatestBlockhash',\n          params: [\n            {\n              commitment: 'finalized',\n            },\n          ],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n\n    return response.body.result.value.blockhash;\n  }\n\n  protected async getFeeForMessage(message: string, apiKey?: string): Promise<number> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getFeeForMessage',\n          params: [\n            message,\n            {\n              commitment: 'finalized',\n            },\n          ],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n\n    return response.body.result.value;\n  }\n\n  protected async getRentExemptAmount(apiKey?: string): Promise<number> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          jsonrpc: '2.0',\n          id: '1',\n          method: 'getMinimumBalanceForRentExemption',\n          params: [165],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200 || response.error) {\n      throw new Error(JSON.stringify(response.error));\n    }\n\n    return response.body.result;\n  }\n\n  protected async getAccountBalance(pubKey: string, apiKey?: string): Promise<number> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getBalance',\n          params: [pubKey],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return response.body.result.value;\n  }\n\n  protected async getAccountInfo(pubKey: string, apiKey?: string): Promise<SolDurableNonceFromNode> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getAccountInfo',\n          params: [\n            pubKey,\n            {\n              encoding: 'jsonParsed',\n            },\n          ],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return {\n      authority: response.body.result.value.data.parsed.info.authority,\n      blockhash: response.body.result.value.data.parsed.info.blockhash,\n    };\n  }\n\n  protected async getTokenAccountsByOwner(pubKey = '', programId = '', apiKey?: string): Promise<[] | TokenAccount[]> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getTokenAccountsByOwner',\n          params: [\n            pubKey,\n            {\n              programId:\n                programId.toString().toLowerCase() === TOKEN_2022_PROGRAM_ID.toString().toLowerCase()\n                  ? TOKEN_2022_PROGRAM_ID.toString()\n                  : TOKEN_PROGRAM_ID.toString(),\n            },\n            {\n              encoding: 'jsonParsed',\n            },\n          ],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n\n    if (response.body.result.value.length !== 0) {\n      const tokenAccounts: TokenAccount[] = [];\n      for (const tokenAccount of response.body.result.value) {\n        tokenAccounts.push({ info: tokenAccount.account.data.parsed.info, pubKey: tokenAccount.pubKey });\n      }\n      return tokenAccounts;\n    }\n\n    return [];\n  }\n\n  protected async getTokenAccountInfo(pubKey: string, apiKey?: string): Promise<TokenAccount> {\n    const response = await this.getDataFromNode(\n      {\n        payload: {\n          id: '1',\n          jsonrpc: '2.0',\n          method: 'getAccountInfo',\n          params: [\n            pubKey,\n            {\n              encoding: 'jsonParsed',\n            },\n          ],\n        },\n      },\n      apiKey\n    );\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return {\n      pubKey: pubKey,\n      info: response.body.result.value.data.parsed.info,\n    };\n  }\n\n  /** inherited doc */\n  async createBroadcastableSweepTransaction(params: MPCSweepRecoveryOptions): Promise<MPCTxs> {\n    if (!params.signatureShares) {\n      ('Missing transaction(s)');\n    }\n    const req = params.signatureShares;\n    const broadcastableTransactions: MPCTx[] = [];\n    let lastScanIndex = 0;\n\n    for (let i = 0; i < req.length; i++) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const transaction = req[i].txRequest.transactions[0].unsignedTx;\n      if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {\n        throw new Error('Missing signature(s)');\n      }\n      const signature = req[i].ovc[0].eddsaSignature;\n      if (!transaction.signableHex) {\n        throw new Error('Missing signable hex');\n      }\n      const messageBuffer = Buffer.from(transaction.signableHex!, 'hex');\n      const result = MPC.verify(messageBuffer, signature);\n      if (!result) {\n        throw new Error('Invalid signature');\n      }\n      const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      const txBuilder = this.getBuilder().from(transaction.serializedTx as string);\n      if (!transaction.coinSpecific?.commonKeychain) {\n        throw new Error('Missing common keychain');\n      }\n      const commonKeychain = transaction.coinSpecific!.commonKeychain! as string;\n      if (!transaction.derivationPath) {\n        throw new Error('Missing derivation path');\n      }\n      const derivationPath = transaction.derivationPath as string;\n      const accountId = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const bs58EncodedPublicKey = new SolKeyPair({ pub: accountId }).getAddress();\n\n      // add combined signature from ovc\n      const publicKeyObj = { pub: bs58EncodedPublicKey };\n      txBuilder.addSignature(publicKeyObj as PublicKey, signatureHex);\n\n      const signedTransaction = await txBuilder.build();\n      const serializedTx = signedTransaction.toBroadcastFormat();\n\n      broadcastableTransactions.push({\n        serializedTx: serializedTx,\n        scanIndex: transaction.scanIndex,\n      });\n\n      if (i === req.length - 1 && transaction.coinSpecific!.lastScanIndex) {\n        lastScanIndex = transaction.coinSpecific!.lastScanIndex as number;\n      }\n    }\n\n    return { transactions: broadcastableTransactions, lastScanIndex };\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo\n   * @param {SolRecoveryOptions} params parameters needed to construct and\n   * (maybe) sign the transaction\n   *\n   * @returns {MPCTx | MPCSweepTxs} the serialized transaction hex string and index\n   * of the address being swept\n   */\n  async recover(params: SolRecoveryOptions): Promise<MPCTx | MPCSweepTxs> {\n    if (!params.bitgoKey) {\n      throw new Error('missing bitgoKey');\n    }\n\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const isUnsignedSweep = !params.walletPassphrase;\n\n    // Build the transaction\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n    let balance = 0;\n\n    const index = params.index || 0;\n    const currPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n    const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);\n    const bs58EncodedPublicKey = new SolKeyPair({ pub: accountId }).getAddress();\n\n    balance = await this.getAccountBalance(bs58EncodedPublicKey, params.apiKey);\n\n    const factory = this.getBuilder();\n    const walletCoin = this.getChain();\n\n    let txBuilder;\n    let blockhash = await this.getBlockhash(params.apiKey);\n    let rentExemptAmount;\n    let authority = '';\n    let totalFee = new BigNumber(0);\n    let totalFeeForTokenRecovery = new BigNumber(0);\n\n    // check for possible token recovery, recover the token provide by user\n    if (params.tokenContractAddress) {\n      let isUnsupportedToken = false;\n      const tokenAccounts = await this.getTokenAccountsByOwner(bs58EncodedPublicKey, params.programId, params.apiKey);\n      if (tokenAccounts.length !== 0) {\n        // there exists token accounts on the given address, but need to check certain conditions:\n        // 1. if there is a recoverable balance\n        // 2. if the token is supported by bitgo\n        const recovereableTokenAccounts: TokenAccount[] = [];\n        for (const tokenAccount of tokenAccounts) {\n          if (params.tokenContractAddress === tokenAccount.info.mint) {\n            const tokenAmount = new BigNumber(tokenAccount.info.tokenAmount.amount);\n            const network = this.getNetwork();\n            const token = getSolTokenFromAddress(tokenAccount.info.mint, network); // todo(WIN-5894) fix for ams\n\n            if (!token) {\n              isUnsupportedToken = true;\n            }\n            if (tokenAmount.gt(new BigNumber(0))) {\n              tokenAccount.tokenName = token?.name || 'Unsupported Token';\n              recovereableTokenAccounts.push(tokenAccount);\n            }\n            break;\n          }\n        }\n\n        if (recovereableTokenAccounts.length !== 0) {\n          rentExemptAmount = await this.getRentExemptAmount(params.apiKey);\n\n          txBuilder = factory\n            .getTokenTransferBuilder()\n            .nonce(blockhash)\n            .sender(bs58EncodedPublicKey)\n            .associatedTokenAccountRent(rentExemptAmount.toString())\n            .feePayer(bs58EncodedPublicKey);\n\n          // need to get all token accounts of the recipient address and need to create them if they do not exist\n          const recipientTokenAccounts = await this.getTokenAccountsByOwner(\n            params.recoveryDestination,\n            params.programId,\n            params.apiKey\n          );\n\n          for (const tokenAccount of recovereableTokenAccounts) {\n            let recipientTokenAccountExists = false;\n            for (const recipientTokenAccount of recipientTokenAccounts as TokenAccount[]) {\n              if (recipientTokenAccount.info.mint === tokenAccount.info.mint) {\n                recipientTokenAccountExists = true;\n                break;\n              }\n            }\n\n            const recipientTokenAccount = await getAssociatedTokenAccountAddress(\n              tokenAccount.info.mint,\n              params.recoveryDestination,\n              false,\n              params.programId?.toString()\n            );\n            const tokenName = tokenAccount.tokenName as string;\n            const sendParams = {\n              address: recipientTokenAccount,\n              amount: tokenAccount.info.tokenAmount.amount,\n              tokenName,\n              ...(isUnsupportedToken\n                ? {\n                    tokenAddress: tokenAccount.info.mint,\n                    programId: params.programId?.toString(),\n                    decimalPlaces: tokenAccount.info.tokenAmount.decimals,\n                  }\n                : {}),\n            };\n            txBuilder.send(sendParams);\n\n            if (!recipientTokenAccountExists) {\n              // recipient token account does not exist for token and must be created\n              txBuilder.createAssociatedTokenAccount({\n                ownerAddress: params.recoveryDestination,\n                tokenName: tokenName,\n                ...(isUnsupportedToken ? { tokenAddress: tokenAccount.info.mint } : {}),\n                programId:\n                  params.programId?.toString().toLowerCase() === TOKEN_2022_PROGRAM_ID.toString().toLowerCase()\n                    ? TOKEN_2022_PROGRAM_ID.toString()\n                    : TOKEN_PROGRAM_ID.toString(),\n              });\n              // add rent exempt amount to total fee for each token account that has to be created\n              totalFeeForTokenRecovery = totalFeeForTokenRecovery.plus(rentExemptAmount);\n            }\n          }\n        } else {\n          throw Error('Not enough token funds to recover');\n        }\n      } else {\n        // there are no recoverable token accounts , need to check if there are tokens to recover\n        throw Error('Did not find token account to recover tokens, please check token account');\n      }\n    } else {\n      txBuilder = factory\n        .getTransferBuilder()\n        .nonce(blockhash)\n        .sender(bs58EncodedPublicKey)\n        .send({ address: params.recoveryDestination, amount: balance.toString() })\n        .feePayer(bs58EncodedPublicKey);\n    }\n\n    if (params.durableNonce) {\n      const durableNonceInfo = await this.getAccountInfo(params.durableNonce.publicKey, params.apiKey);\n      blockhash = durableNonceInfo.blockhash;\n      authority = durableNonceInfo.authority;\n\n      txBuilder.nonce(blockhash, {\n        walletNonceAddress: params.durableNonce.publicKey,\n        authWalletAddress: authority,\n      });\n    }\n\n    // build the transaction without fee\n    const unsignedTransactionWithoutFee = (await txBuilder.build()) as Transaction;\n    const serializedMessage = unsignedTransactionWithoutFee.solTransaction.serializeMessage().toString('base64');\n\n    const baseFee = await this.getFeeForMessage(serializedMessage, params.apiKey);\n    const feePerSignature = params.durableNonce ? baseFee / 2 : baseFee;\n    totalFee = totalFee.plus(new BigNumber(baseFee));\n    totalFeeForTokenRecovery = totalFeeForTokenRecovery.plus(new BigNumber(baseFee));\n    if (totalFee.gt(balance)) {\n      throw Error('Did not find address with funds to recover');\n    }\n\n    if (params.tokenContractAddress) {\n      // Check if there is sufficient native solana to recover tokens\n      if (new BigNumber(balance).lt(totalFeeForTokenRecovery)) {\n        throw Error(\n          'Not enough funds to pay for recover tokens fees, have: ' +\n            balance +\n            ' need: ' +\n            totalFeeForTokenRecovery.toString()\n        );\n      }\n      txBuilder.fee({ amount: feePerSignature });\n    } else {\n      const netAmount = new BigNumber(balance).minus(totalFee);\n      txBuilder = factory\n        .getTransferBuilder()\n        .nonce(blockhash)\n        .sender(bs58EncodedPublicKey)\n        .send({ address: params.recoveryDestination, amount: netAmount.toString() })\n        .feePayer(bs58EncodedPublicKey)\n        .fee({ amount: feePerSignature });\n\n      if (params.durableNonce) {\n        txBuilder.nonce(blockhash, {\n          walletNonceAddress: params.durableNonce.publicKey,\n          authWalletAddress: authority,\n        });\n      }\n    }\n\n    if (!isUnsignedSweep) {\n      // Sign the txn\n      if (!params.userKey) {\n        throw new Error('missing userKey');\n      }\n\n      if (!params.backupKey) {\n        throw new Error('missing backupKey');\n      }\n\n      if (!params.walletPassphrase) {\n        throw new Error('missing wallet passphrase');\n      }\n\n      // build the transaction with fee\n      const unsignedTransaction = (await txBuilder.build()) as Transaction;\n\n      const userKey = params.userKey.replace(/\\s/g, '');\n      const backupKey = params.backupKey.replace(/\\s/g, '');\n\n      // Decrypt private keys from KeyCard values\n      let userPrv;\n\n      try {\n        userPrv = this.bitgo.decrypt({\n          input: userKey,\n          password: params.walletPassphrase,\n        });\n      } catch (e) {\n        throw new Error(`Error decrypting user keychain: ${e.message}`);\n      }\n\n      const userSigningMaterial = JSON.parse(userPrv) as EDDSAMethodTypes.UserSigningMaterial;\n\n      let backupPrv;\n      try {\n        backupPrv = this.bitgo.decrypt({\n          input: backupKey,\n          password: params.walletPassphrase,\n        });\n      } catch (e) {\n        throw new Error(`Error decrypting backup keychain: ${e.message}`);\n      }\n      const backupSigningMaterial = JSON.parse(backupPrv) as EDDSAMethodTypes.BackupSigningMaterial;\n\n      const signatureHex = await EDDSAMethods.getTSSSignature(\n        userSigningMaterial,\n        backupSigningMaterial,\n        currPath,\n        unsignedTransaction\n      );\n\n      const publicKeyObj = { pub: bs58EncodedPublicKey };\n      txBuilder.addSignature(publicKeyObj as PublicKey, signatureHex);\n    }\n\n    if (params.durableNonce) {\n      // add durable nonce account signature\n      txBuilder.sign({ key: params.durableNonce.secretKey });\n    }\n\n    const completedTransaction = await txBuilder.build();\n    const serializedTx = completedTransaction.toBroadcastFormat();\n    const derivationPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n    const inputs: OvcInput[] = [];\n    for (const input of completedTransaction.inputs) {\n      inputs.push({\n        address: input.address,\n        valueString: input.value,\n        value: new BigNumber(input.value).toNumber(),\n      });\n    }\n    const outputs: OvcOutput[] = [];\n    for (const output of completedTransaction.outputs) {\n      outputs.push({\n        address: output.address,\n        valueString: output.value,\n        coinName: output.coin ? output.coin : walletCoin,\n      });\n    }\n    const spendAmount = completedTransaction.inputs.length === 1 ? completedTransaction.inputs[0].value : 0;\n    const parsedTx = { inputs: inputs, outputs: outputs, spendAmount: spendAmount, type: '' };\n    const feeInfo = { fee: totalFeeForTokenRecovery.toNumber(), feeString: totalFee.toString() };\n    const coinSpecific = { commonKeychain: bitgoKey };\n    if (isUnsignedSweep) {\n      const transaction: MPCTx = {\n        serializedTx: serializedTx,\n        scanIndex: index,\n        coin: walletCoin,\n        signableHex: completedTransaction.signablePayload.toString('hex'),\n        derivationPath: derivationPath,\n        parsedTx: parsedTx,\n        feeInfo: feeInfo,\n        coinSpecific: coinSpecific,\n      };\n      const unsignedTx: MPCUnsignedTx = { unsignedTx: transaction, signatureShares: [] };\n      const transactions: MPCUnsignedTx[] = [unsignedTx];\n      const txRequest: RecoveryTxRequest = {\n        transactions: transactions,\n        walletCoin: walletCoin,\n      };\n      const txRequests: MPCSweepTxs = { txRequests: [txRequest] };\n      return txRequests;\n    }\n    const transaction: MPCTx = {\n      serializedTx: serializedTx,\n      scanIndex: index,\n    };\n    return transaction;\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo\n   * @param {SolRecoveryOptions} params parameters needed to construct and\n   * (maybe) sign the transaction\n   *\n   * @returns {BaseBroadcastTransactionResult[]} the serialized transaction hex string and index\n   * of the address being swept\n   */\n  async recoverCloseATA(params: SolRecoveryOptions): Promise<BaseBroadcastTransactionResult[]> {\n    if (!params.bitgoKey) {\n      throw new Error('missing bitgoKey');\n    }\n\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n\n    if (!params.closeAtaAddress || !this.isValidAddress(params.closeAtaAddress)) {\n      throw new Error('invalid closeAtaAddress');\n    }\n\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n\n    // Build the transaction\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n    let balance = 0;\n\n    const index = params.index || 0;\n    const currPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n    const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);\n    const bs58EncodedPublicKey = new SolKeyPair({ pub: accountId }).getAddress();\n\n    const accountBalance = await this.getAccountBalance(bs58EncodedPublicKey);\n\n    balance = await this.getAccountBalance(params.closeAtaAddress);\n    if (balance <= 0) {\n      throw Error('Did not find closeAtaAddress with sol funds to recover');\n    }\n\n    const factory = this.getBuilder();\n\n    let txBuilder;\n    let blockhash;\n    const recovertTxns: BaseBroadcastTransactionResult[] = [];\n\n    const rentExemptAmount = await this.getRentExemptAmount();\n\n    // do token recovery before closing ATA address\n    // check if any token is present on the closeAtaAddress\n    const tokenInfo = await this.getTokenAccountInfo(params.closeAtaAddress);\n    const tokenBalance = Number(tokenInfo.info.tokenAmount.amount);\n\n    if (tokenBalance > 0) {\n      // closeATA address has some token balance, it needs to be withdrawn before closing ATA\n      console.log(\n        `closeATA address ${params.closeAtaAddress} has token balance ${tokenBalance}, it needs to be withdrawn before closing ATA address`\n      );\n\n      if (!params.recoveryDestinationAtaAddress || !this.isValidAddress(params.recoveryDestinationAtaAddress)) {\n        throw new Error('invalid recoveryDestinationAtaAddress');\n      }\n\n      blockhash = await this.getBlockhash(params.apiKey);\n\n      txBuilder = factory\n        .getTokenTransferBuilder()\n        .nonce(blockhash)\n        .sender(bs58EncodedPublicKey)\n        .associatedTokenAccountRent(rentExemptAmount.toString())\n        .feePayer(bs58EncodedPublicKey);\n      const unsignedTransaction = (await txBuilder.build()) as Transaction;\n      const serializedMessage = unsignedTransaction.solTransaction.serializeMessage().toString('base64');\n      const feePerSignature = await this.getFeeForMessage(serializedMessage, params.apiKey);\n      const baseFee = params.durableNonce ? feePerSignature * 2 : feePerSignature;\n      const totalFee = new BigNumber(baseFee);\n      if (totalFee.gt(accountBalance)) {\n        throw Error('Did not find address with funds to recover');\n      }\n      txBuilder.fee({ amount: feePerSignature });\n\n      const network = this.getNetwork();\n      const token = getSolTokenFromAddress(tokenInfo.info.mint, network); // todo(WIN-5894) fix for ams\n      txBuilder.send({\n        address: params.recoveryDestinationAtaAddress,\n        amount: tokenBalance,\n        tokenName: token?.name,\n      });\n\n      const tokenRecoveryTxn = await this.signAndGenerateBroadcastableTransaction(\n        params,\n        txBuilder,\n        bs58EncodedPublicKey\n      );\n      const serializedTokenRecoveryTxn = (await tokenRecoveryTxn).serializedTx;\n      const broadcastTokenRecoveryTxn = await this.broadcastTransaction({\n        serializedSignedTransaction: serializedTokenRecoveryTxn,\n      });\n      logger.log(broadcastTokenRecoveryTxn);\n      recovertTxns.push(broadcastTokenRecoveryTxn);\n    }\n\n    // after recovering the token amount, attempting to close the ATA address\n    if (params.closeAtaAddress) {\n      blockhash = await this.getBlockhash(params.apiKey);\n\n      const ataCloseBuilder = () => {\n        const txBuilder = factory.getCloseAtaInitializationBuilder();\n        txBuilder.nonce(blockhash);\n        txBuilder.sender(bs58EncodedPublicKey);\n        txBuilder.accountAddress(params.closeAtaAddress ?? '');\n        txBuilder.destinationAddress(params.recoveryDestination);\n        txBuilder.authorityAddress(bs58EncodedPublicKey);\n        txBuilder.associatedTokenAccountRent(rentExemptAmount.toString());\n        return txBuilder;\n      };\n      txBuilder = ataCloseBuilder();\n    }\n    const closeATARecoveryTxn = await this.signAndGenerateBroadcastableTransaction(\n      params,\n      txBuilder,\n      bs58EncodedPublicKey\n    );\n    const serializedCloseATARecoveryTxn = (await closeATARecoveryTxn).serializedTx;\n    const broadcastCloseATARecoveryTxn = await this.broadcastTransaction({\n      serializedSignedTransaction: serializedCloseATARecoveryTxn,\n    });\n    logger.log(broadcastCloseATARecoveryTxn);\n    recovertTxns.push(broadcastCloseATARecoveryTxn);\n\n    return recovertTxns;\n  }\n\n  /**\n   * Recovers tokens from a nested ATA — an ATA whose owner is another ATA rather than a wallet address.\n   *\n   * This situation occurs when an external sender mistakenly calls createAssociatedTokenAccount with\n   * an ATA address as the owner instead of the root wallet address. The result is a \"nested ATA\"\n   * (ATA-2) owned by the wallet's normal ATA (ATA-1). Because ATA-1 is a PDA with no private key,\n   * the standard recoverCloseATA flow cannot sign for ATA-2.\n   *\n   * This method uses the Associated Token Account program's RecoverNested instruction, which allows\n   * the root wallet owner to sign and atomically move tokens from ATA-2 → ATA-1 and close ATA-2,\n   * returning the rent-exempt SOL to the wallet address.\n   *\n   * @param {SolRecoveryOptions} params - recovery params, requires nestedAtaAddress, ownerAtaAddress,\n   *   and tokenMintAddress in addition to the standard keychain fields\n   */\n  async recoverNestedAta(params: SolRecoveryOptions): Promise<BaseBroadcastTransactionResult> {\n    if (!params.bitgoKey) {\n      throw new Error('missing bitgoKey');\n    }\n\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n\n    if (!params.nestedAtaAddress || !this.isValidAddress(params.nestedAtaAddress)) {\n      throw new Error('invalid nestedAtaAddress');\n    }\n\n    if (!params.ownerAtaAddress || !this.isValidAddress(params.ownerAtaAddress)) {\n      throw new Error('invalid ownerAtaAddress');\n    }\n\n    if (!params.tokenMintAddress || !this.isValidAddress(params.tokenMintAddress)) {\n      throw new Error('invalid tokenMintAddress');\n    }\n\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n\n    const index = params.index || 0;\n    const currPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n    const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);\n    const bs58EncodedPublicKey = new SolKeyPair({ pub: accountId }).getAddress();\n\n    const blockhash = await this.getBlockhash(params.apiKey);\n    const rentExemptAmount = await this.getRentExemptAmount();\n\n    const factory = this.getBuilder();\n    const txBuilder = factory.getRecoverNestedAtaBuilder();\n    txBuilder.nonce(blockhash);\n    txBuilder.sender(bs58EncodedPublicKey);\n    txBuilder.feePayer(bs58EncodedPublicKey);\n    txBuilder.associatedTokenAccountRent(rentExemptAmount.toString());\n    txBuilder.nestedAccountAddress(params.nestedAtaAddress);\n    txBuilder.nestedMintAddress(params.tokenMintAddress);\n    txBuilder.destinationAccountAddress(params.ownerAtaAddress);\n    txBuilder.ownerAccountAddress(params.ownerAtaAddress);\n    txBuilder.ownerMintAddress(params.tokenMintAddress);\n    txBuilder.walletAddress(bs58EncodedPublicKey);\n\n    const recoverNestedTxn = await this.signAndGenerateBroadcastableTransaction(\n      params,\n      txBuilder,\n      bs58EncodedPublicKey\n    );\n\n    const serializedTxn = (await recoverNestedTxn).serializedTx;\n    const broadcastResult = await this.broadcastTransaction({\n      serializedSignedTransaction: serializedTxn,\n    });\n    logger.log(broadcastResult);\n\n    return broadcastResult;\n  }\n\n  async signAndGenerateBroadcastableTransaction(\n    params: SolRecoveryOptions,\n    txBuilder: any,\n    bs58EncodedPublicKey: string\n  ): Promise<MPCTx> {\n    // Sign the txn\n    if (!params.userKey) {\n      throw new Error('missing userKey');\n    }\n\n    if (!params.backupKey) {\n      throw new Error('missing backupKey');\n    }\n\n    if (!params.walletPassphrase) {\n      throw new Error('missing wallet passphrase');\n    }\n\n    const unsignedTransaction = (await txBuilder.build()) as Transaction;\n\n    const userKey = params.userKey.replace(/\\s/g, '');\n    const backupKey = params.backupKey.replace(/\\s/g, '');\n\n    // Decrypt private keys from KeyCard values\n    let userPrv;\n\n    try {\n      userPrv = this.bitgo.decrypt({\n        input: userKey,\n        password: params.walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting user keychain: ${e.message}`);\n    }\n\n    const userSigningMaterial = JSON.parse(userPrv) as EDDSAMethodTypes.UserSigningMaterial;\n\n    let backupPrv;\n    try {\n      backupPrv = this.bitgo.decrypt({\n        input: backupKey,\n        password: params.walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting backup keychain: ${e.message}`);\n    }\n    const backupSigningMaterial = JSON.parse(backupPrv) as EDDSAMethodTypes.BackupSigningMaterial;\n\n    const index = params.index || 0;\n    const currPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n\n    const signatureHex = await EDDSAMethods.getTSSSignature(\n      userSigningMaterial,\n      backupSigningMaterial,\n      currPath,\n      unsignedTransaction\n    );\n\n    const publicKeyObj = { pub: bs58EncodedPublicKey };\n    txBuilder.addSignature(publicKeyObj as PublicKey, signatureHex);\n\n    const completedTransaction = await txBuilder.build();\n    const serializedTx = completedTransaction.toBroadcastFormat();\n    const transaction: MPCTx = {\n      serializedTx: serializedTx,\n      scanIndex: index,\n    };\n    return transaction;\n  }\n\n  /**\n   * Builds native SOL recoveries of receive addresses in batch without BitGo.\n   * Funds will be recovered to base address first. You need to initiate another sweep txn after that.\n   *\n   * @param {SolConsolidationRecoveryOptions} params - options for consolidation recovery.\n   * @param {string} [params.startingScanIndex] - receive address index to start scanning from. default to 1 (inclusive).\n   * @param {string} [params.endingScanIndex] - receive address index to end scanning at. default to startingScanIndex + 20 (exclusive).\n   */\n  async recoverConsolidations(params: SolConsolidationRecoveryOptions): Promise<MPCTxs | MPCSweepTxs> {\n    const isUnsignedSweep = !params.walletPassphrase;\n    const startIdx = params.startingScanIndex || 1;\n    const endIdx = params.endingScanIndex || startIdx + DEFAULT_SCAN_FACTOR;\n\n    if (startIdx < 1 || endIdx <= startIdx || endIdx - startIdx > 10 * DEFAULT_SCAN_FACTOR) {\n      throw new Error(\n        `Invalid starting or ending index to scan for addresses. startingScanIndex: ${startIdx}, endingScanIndex: ${endIdx}.`\n      );\n    }\n\n    // validate durable nonces array\n    if (!params.durableNonces) {\n      throw new Error('Missing durable nonces');\n    }\n    if (!params.durableNonces.publicKeys) {\n      throw new Error('Invalid durable nonces: missing public keys');\n    }\n    if (!params.durableNonces.secretKey) {\n      throw new Error('Invalid durable nonces array: missing secret key');\n    }\n\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n    const baseAddressIndex = 0;\n    const baseAddressPath = params.seed\n      ? getDerivationPath(params.seed) + `/${baseAddressIndex}`\n      : `m/${baseAddressIndex}`;\n    const accountId = MPC.deriveUnhardened(bitgoKey, baseAddressPath).slice(0, 64);\n    const baseAddress = new SolKeyPair({ pub: accountId }).getAddress();\n\n    let durableNoncePubKeysIndex = 0;\n    const durableNoncePubKeysLength = params.durableNonces.publicKeys.length;\n    const consolidationTransactions: any[] = [];\n    let lastScanIndex = startIdx;\n\n    for (let i = startIdx; i < endIdx; i++) {\n      const recoverParams = {\n        userKey: params.userKey,\n        backupKey: params.backupKey,\n        bitgoKey: params.bitgoKey,\n        walletPassphrase: params.walletPassphrase,\n        recoveryDestination: baseAddress,\n        seed: params.seed,\n        index: i,\n        durableNonce: {\n          publicKey: params.durableNonces.publicKeys[durableNoncePubKeysIndex],\n          secretKey: params.durableNonces.secretKey,\n        },\n        tokenContractAddress: params.tokenContractAddress,\n        apiKey: params.apiKey,\n        programId: params.programId,\n      };\n\n      let recoveryTransaction;\n      try {\n        recoveryTransaction = await this.recover(recoverParams);\n      } catch (e) {\n        if (\n          e.message === 'Did not find address with funds to recover' ||\n          e.message === 'Did not find token account to recover tokens, please check token account' ||\n          e.message === 'Not enough token funds to recover'\n        ) {\n          lastScanIndex = i;\n          continue;\n        }\n        throw e;\n      }\n\n      if (isUnsignedSweep) {\n        consolidationTransactions.push((recoveryTransaction as MPCSweepTxs).txRequests[0]);\n      } else {\n        consolidationTransactions.push(recoveryTransaction);\n      }\n\n      lastScanIndex = i;\n      durableNoncePubKeysIndex++;\n      if (durableNoncePubKeysIndex >= durableNoncePubKeysLength) {\n        // no more available nonce accounts to create transactions\n        break;\n      }\n    }\n\n    if (consolidationTransactions.length === 0) {\n      throw new Error('Did not find an address with funds to recover');\n    }\n\n    if (isUnsignedSweep) {\n      // lastScanIndex will be used to inform user the last address index scanned for available funds (so they can\n      // appropriately adjust the scan range on the next iteration of consolidation recoveries). In the case of unsigned\n      // sweep consolidations, this lastScanIndex will be provided in the coinSpecific of the last txn made.\n      const lastTransactionCoinSpecific = {\n        commonKeychain:\n          consolidationTransactions[consolidationTransactions.length - 1].transactions[0].unsignedTx.coinSpecific\n            .commonKeychain,\n        lastScanIndex: lastScanIndex,\n      };\n      consolidationTransactions[consolidationTransactions.length - 1].transactions[0].unsignedTx.coinSpecific =\n        lastTransactionCoinSpecific;\n      const consolidationSweepTransactions: MPCSweepTxs = { txRequests: consolidationTransactions };\n      return consolidationSweepTransactions;\n    }\n\n    return { transactions: consolidationTransactions, lastScanIndex };\n  }\n\n  getTokenEnablementConfig(): TokenEnablementConfig {\n    return {\n      requiresTokenEnablement: true,\n      supportsMultipleTokenEnablements: true,\n    };\n  }\n\n  private getBuilder(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  async broadcastTransaction({\n    serializedSignedTransaction,\n  }: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult> {\n    validateRawTransaction(serializedSignedTransaction, true, true);\n    const response = await this.getDataFromNode({\n      payload: {\n        id: '1',\n        jsonrpc: '2.0',\n        method: 'sendTransaction',\n        params: [\n          serializedSignedTransaction,\n          {\n            encoding: 'base64',\n          },\n        ],\n      },\n    });\n\n    if (response.body.error) {\n      throw new Error('Error broadcasting transaction: ' + response.body.error.message);\n    }\n\n    return { txId: response.body.result };\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey({ prv, publicKey, multiSigType }: AuditDecryptedKeyParams) {\n    if (multiSigType !== 'tss') {\n      throw new Error('Unsupported multiSigType');\n    }\n    auditEddsaPrivateKey(prv, publicKey ?? '');\n  }\n\n  /** @inheritDoc */\n  setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void {\n    // Handle custom instructions for Solana\n    if (params.solInstructions) {\n      intent.solInstructions = params.solInstructions;\n    }\n\n    // Handle versioned transaction data for Solana\n    if (params.solVersionedTransactionData) {\n      intent.solVersionedTransactionData = params.solVersionedTransactionData;\n    }\n  }\n}\n"]}