@ledgerhq/coin-solana 0.7.0-nightly.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (521) hide show
  1. package/.eslintrc.js +20 -0
  2. package/.turbo/turbo-build.log +4 -0
  3. package/.unimportedrc.json +16 -0
  4. package/CHANGELOG.md +13 -0
  5. package/LICENSE.txt +21 -0
  6. package/jest.config.js +9 -0
  7. package/lib/api/cached.d.ts +3 -0
  8. package/lib/api/cached.d.ts.map +1 -0
  9. package/lib/api/cached.js +40 -0
  10. package/lib/api/cached.js.map +1 -0
  11. package/lib/api/chain/account/index.d.ts +2 -0
  12. package/lib/api/chain/account/index.d.ts.map +1 -0
  13. package/lib/api/chain/account/index.js +8 -0
  14. package/lib/api/chain/account/index.js.map +1 -0
  15. package/lib/api/chain/account/parser.d.ts +10 -0
  16. package/lib/api/chain/account/parser.d.ts.map +1 -0
  17. package/lib/api/chain/account/parser.js +56 -0
  18. package/lib/api/chain/account/parser.js.map +1 -0
  19. package/lib/api/chain/account/stake.d.ts +237 -0
  20. package/lib/api/chain/account/stake.d.ts.map +1 -0
  21. package/lib/api/chain/account/stake.js +38 -0
  22. package/lib/api/chain/account/stake.js.map +1 -0
  23. package/lib/api/chain/account/token.d.ts +116 -0
  24. package/lib/api/chain/account/token.d.ts.map +1 -0
  25. package/lib/api/chain/account/token.js +42 -0
  26. package/lib/api/chain/account/token.js.map +1 -0
  27. package/lib/api/chain/account/vote.d.ts +252 -0
  28. package/lib/api/chain/account/vote.d.ts.map +1 -0
  29. package/lib/api/chain/account/vote.js +44 -0
  30. package/lib/api/chain/account/vote.js.map +1 -0
  31. package/lib/api/chain/index.d.ts +29 -0
  32. package/lib/api/chain/index.d.ts.map +1 -0
  33. package/lib/api/chain/index.js +99 -0
  34. package/lib/api/chain/index.js.map +1 -0
  35. package/lib/api/chain/instruction/associated-token-account/index.d.ts +15 -0
  36. package/lib/api/chain/instruction/associated-token-account/index.d.ts.map +1 -0
  37. package/lib/api/chain/instruction/associated-token-account/index.js +21 -0
  38. package/lib/api/chain/instruction/associated-token-account/index.js.map +1 -0
  39. package/lib/api/chain/instruction/associated-token-account/types.d.ts +30 -0
  40. package/lib/api/chain/instruction/associated-token-account/types.d.ts.map +1 -0
  41. package/lib/api/chain/instruction/associated-token-account/types.js +19 -0
  42. package/lib/api/chain/instruction/associated-token-account/types.js.map +1 -0
  43. package/lib/api/chain/instruction/memo/index.d.ts +15 -0
  44. package/lib/api/chain/instruction/memo/index.d.ts.map +1 -0
  45. package/lib/api/chain/instruction/memo/index.js +14 -0
  46. package/lib/api/chain/instruction/memo/index.js.map +1 -0
  47. package/lib/api/chain/instruction/memo/types.d.ts +21 -0
  48. package/lib/api/chain/instruction/memo/types.d.ts.map +1 -0
  49. package/lib/api/chain/instruction/memo/types.js +16 -0
  50. package/lib/api/chain/instruction/memo/types.js.map +1 -0
  51. package/lib/api/chain/instruction/stake/index.d.ts +15 -0
  52. package/lib/api/chain/instruction/stake/index.d.ts.map +1 -0
  53. package/lib/api/chain/instruction/stake/index.js +20 -0
  54. package/lib/api/chain/instruction/stake/index.js.map +1 -0
  55. package/lib/api/chain/instruction/stake/types.d.ts +215 -0
  56. package/lib/api/chain/instruction/stake/types.d.ts.map +1 -0
  57. package/lib/api/chain/instruction/stake/types.js +80 -0
  58. package/lib/api/chain/instruction/stake/types.js.map +1 -0
  59. package/lib/api/chain/instruction/system/index.d.ts +15 -0
  60. package/lib/api/chain/instruction/system/index.d.ts.map +1 -0
  61. package/lib/api/chain/instruction/system/index.js +20 -0
  62. package/lib/api/chain/instruction/system/index.js.map +1 -0
  63. package/lib/api/chain/instruction/system/types.d.ts +298 -0
  64. package/lib/api/chain/instruction/system/types.d.ts.map +1 -0
  65. package/lib/api/chain/instruction/system/types.js +117 -0
  66. package/lib/api/chain/instruction/system/types.js.map +1 -0
  67. package/lib/api/chain/instruction/token/index.d.ts +15 -0
  68. package/lib/api/chain/instruction/token/index.d.ts.map +1 -0
  69. package/lib/api/chain/instruction/token/index.js +20 -0
  70. package/lib/api/chain/instruction/token/index.js.map +1 -0
  71. package/lib/api/chain/instruction/token/types.d.ts +497 -0
  72. package/lib/api/chain/instruction/token/types.d.ts.map +1 -0
  73. package/lib/api/chain/instruction/token/types.js +200 -0
  74. package/lib/api/chain/instruction/token/types.js.map +1 -0
  75. package/lib/api/chain/program/constants.d.ts +11 -0
  76. package/lib/api/chain/program/constants.d.ts.map +1 -0
  77. package/lib/api/chain/program/constants.js +14 -0
  78. package/lib/api/chain/program/constants.js.map +1 -0
  79. package/lib/api/chain/program/index.d.ts +2 -0
  80. package/lib/api/chain/program/index.d.ts.map +1 -0
  81. package/lib/api/chain/program/index.js +7 -0
  82. package/lib/api/chain/program/index.js.map +1 -0
  83. package/lib/api/chain/program/parser.d.ts +35 -0
  84. package/lib/api/chain/program/parser.d.ts.map +1 -0
  85. package/lib/api/chain/program/parser.js +66 -0
  86. package/lib/api/chain/program/parser.js.map +1 -0
  87. package/lib/api/chain/validators/bignum.d.ts +3 -0
  88. package/lib/api/chain/validators/bignum.d.ts.map +1 -0
  89. package/lib/api/chain/validators/bignum.js +11 -0
  90. package/lib/api/chain/validators/bignum.js.map +1 -0
  91. package/lib/api/chain/validators/index.d.ts +10 -0
  92. package/lib/api/chain/validators/index.d.ts.map +1 -0
  93. package/lib/api/chain/validators/index.js +10 -0
  94. package/lib/api/chain/validators/index.js.map +1 -0
  95. package/lib/api/chain/validators/pubkey.d.ts +3 -0
  96. package/lib/api/chain/validators/pubkey.d.ts.map +1 -0
  97. package/lib/api/chain/validators/pubkey.js +7 -0
  98. package/lib/api/chain/validators/pubkey.js.map +1 -0
  99. package/lib/api/chain/web3.d.ts +43 -0
  100. package/lib/api/chain/web3.d.ts.map +1 -0
  101. package/lib/api/chain/web3.js +274 -0
  102. package/lib/api/chain/web3.js.map +1 -0
  103. package/lib/api/index.d.ts +5 -0
  104. package/lib/api/index.d.ts.map +1 -0
  105. package/lib/api/index.js +25 -0
  106. package/lib/api/index.js.map +1 -0
  107. package/lib/api/logged.d.ts +3 -0
  108. package/lib/api/logged.d.ts.map +1 -0
  109. package/lib/api/logged.js +69 -0
  110. package/lib/api/logged.js.map +1 -0
  111. package/lib/api/queued.d.ts +3 -0
  112. package/lib/api/queued.d.ts.map +1 -0
  113. package/lib/api/queued.js +27 -0
  114. package/lib/api/queued.js.map +1 -0
  115. package/lib/api/traced.d.ts +3 -0
  116. package/lib/api/traced.d.ts.map +1 -0
  117. package/lib/api/traced.js +80 -0
  118. package/lib/api/traced.js.map +1 -0
  119. package/lib/bridge/bridge.d.ts +15 -0
  120. package/lib/bridge/bridge.d.ts.map +1 -0
  121. package/lib/bridge/bridge.js +139 -0
  122. package/lib/bridge/bridge.js.map +1 -0
  123. package/lib/bridge/js.d.ts +7 -0
  124. package/lib/bridge/js.d.ts.map +1 -0
  125. package/lib/bridge/js.js +28 -0
  126. package/lib/bridge/js.js.map +1 -0
  127. package/lib/bridge.integration.test.d.ts +4 -0
  128. package/lib/bridge.integration.test.d.ts.map +1 -0
  129. package/lib/bridge.integration.test.js +990 -0
  130. package/lib/bridge.integration.test.js.map +1 -0
  131. package/lib/cli-transaction.d.ts +19 -0
  132. package/lib/cli-transaction.d.ts.map +1 -0
  133. package/lib/cli-transaction.js +196 -0
  134. package/lib/cli-transaction.js.map +1 -0
  135. package/lib/datasets/solana.scanAccounts.1.d.ts +6 -0
  136. package/lib/datasets/solana.scanAccounts.1.d.ts.map +1 -0
  137. package/lib/datasets/solana.scanAccounts.1.js +12 -0
  138. package/lib/datasets/solana.scanAccounts.1.js.map +1 -0
  139. package/lib/deviceTransactionConfig.d.ts +10 -0
  140. package/lib/deviceTransactionConfig.d.ts.map +1 -0
  141. package/lib/deviceTransactionConfig.js +228 -0
  142. package/lib/deviceTransactionConfig.js.map +1 -0
  143. package/lib/errors.d.ts +61 -0
  144. package/lib/errors.d.ts.map +1 -0
  145. package/lib/errors.js +25 -0
  146. package/lib/errors.js.map +1 -0
  147. package/lib/hw-getAddress.d.ts +6 -0
  148. package/lib/hw-getAddress.d.ts.map +1 -0
  149. package/lib/hw-getAddress.js +28 -0
  150. package/lib/hw-getAddress.js.map +1 -0
  151. package/lib/js-broadcast.d.ts +7 -0
  152. package/lib/js-broadcast.d.ts.map +1 -0
  153. package/lib/js-broadcast.js +37 -0
  154. package/lib/js-broadcast.js.map +1 -0
  155. package/lib/js-buildTransaction.d.ts +5 -0
  156. package/lib/js-buildTransaction.d.ts.map +1 -0
  157. package/lib/js-buildTransaction.js +67 -0
  158. package/lib/js-buildTransaction.js.map +1 -0
  159. package/lib/js-createTransaction.d.ts +5 -0
  160. package/lib/js-createTransaction.d.ts.map +1 -0
  161. package/lib/js-createTransaction.js +19 -0
  162. package/lib/js-createTransaction.js.map +1 -0
  163. package/lib/js-estimateMaxSpendable.d.ts +11 -0
  164. package/lib/js-estimateMaxSpendable.d.ts.map +1 -0
  165. package/lib/js-estimateMaxSpendable.js +62 -0
  166. package/lib/js-estimateMaxSpendable.js.map +1 -0
  167. package/lib/js-getTransactionStatus.d.ts +5 -0
  168. package/lib/js-getTransactionStatus.d.ts.map +1 -0
  169. package/lib/js-getTransactionStatus.js +71 -0
  170. package/lib/js-getTransactionStatus.js.map +1 -0
  171. package/lib/js-preload-data.d.ts +7 -0
  172. package/lib/js-preload-data.d.ts.map +1 -0
  173. package/lib/js-preload-data.js +45 -0
  174. package/lib/js-preload-data.js.map +1 -0
  175. package/lib/js-preload.d.ts +7 -0
  176. package/lib/js-preload.d.ts.map +1 -0
  177. package/lib/js-preload.js +67 -0
  178. package/lib/js-preload.js.map +1 -0
  179. package/lib/js-preload.test.d.ts +2 -0
  180. package/lib/js-preload.test.d.ts.map +1 -0
  181. package/lib/js-preload.test.js +9 -0
  182. package/lib/js-preload.test.js.map +1 -0
  183. package/lib/js-prepareTransaction.d.ts +5 -0
  184. package/lib/js-prepareTransaction.d.ts.map +1 -0
  185. package/lib/js-prepareTransaction.js +500 -0
  186. package/lib/js-prepareTransaction.js.map +1 -0
  187. package/lib/js-signOperation.d.ts +7 -0
  188. package/lib/js-signOperation.d.ts.map +1 -0
  189. package/lib/js-signOperation.js +153 -0
  190. package/lib/js-signOperation.js.map +1 -0
  191. package/lib/js-synchronization.d.ts +5 -0
  192. package/lib/js-synchronization.d.ts.map +1 -0
  193. package/lib/js-synchronization.js +464 -0
  194. package/lib/js-synchronization.js.map +1 -0
  195. package/lib/logic.d.ts +29 -0
  196. package/lib/logic.d.ts.map +1 -0
  197. package/lib/logic.js +102 -0
  198. package/lib/logic.js.map +1 -0
  199. package/lib/serialization.d.ts +9 -0
  200. package/lib/serialization.d.ts.map +1 -0
  201. package/lib/serialization.js +69 -0
  202. package/lib/serialization.js.map +1 -0
  203. package/lib/signer.d.ts +11 -0
  204. package/lib/signer.d.ts.map +1 -0
  205. package/lib/signer.js +3 -0
  206. package/lib/signer.js.map +1 -0
  207. package/lib/specs.d.ts +7 -0
  208. package/lib/specs.d.ts.map +1 -0
  209. package/lib/specs.js +409 -0
  210. package/lib/specs.js.map +1 -0
  211. package/lib/speculos-deviceActions.d.ts +8 -0
  212. package/lib/speculos-deviceActions.d.ts.map +1 -0
  213. package/lib/speculos-deviceActions.js +217 -0
  214. package/lib/speculos-deviceActions.js.map +1 -0
  215. package/lib/transaction.d.ts +15 -0
  216. package/lib/transaction.d.ts.map +1 -0
  217. package/lib/transaction.js +153 -0
  218. package/lib/transaction.js.map +1 -0
  219. package/lib/tx-fees.d.ts +4 -0
  220. package/lib/tx-fees.d.ts.map +1 -0
  221. package/lib/tx-fees.js +167 -0
  222. package/lib/tx-fees.js.map +1 -0
  223. package/lib/types.d.ts +222 -0
  224. package/lib/types.d.ts.map +1 -0
  225. package/lib/types.js +3 -0
  226. package/lib/types.js.map +1 -0
  227. package/lib/utils.d.ts +24 -0
  228. package/lib/utils.d.ts.map +1 -0
  229. package/lib/utils.js +172 -0
  230. package/lib/utils.js.map +1 -0
  231. package/lib/validator-app/index.d.ts +22 -0
  232. package/lib/validator-app/index.d.ts.map +1 -0
  233. package/lib/validator-app/index.js +62 -0
  234. package/lib/validator-app/index.js.map +1 -0
  235. package/lib-es/api/cached.d.ts +3 -0
  236. package/lib-es/api/cached.d.ts.map +1 -0
  237. package/lib-es/api/cached.js +33 -0
  238. package/lib-es/api/cached.js.map +1 -0
  239. package/lib-es/api/chain/account/index.d.ts +2 -0
  240. package/lib-es/api/chain/account/index.d.ts.map +1 -0
  241. package/lib-es/api/chain/account/index.js +2 -0
  242. package/lib-es/api/chain/account/index.js.map +1 -0
  243. package/lib-es/api/chain/account/parser.d.ts +10 -0
  244. package/lib-es/api/chain/account/parser.d.ts.map +1 -0
  245. package/lib-es/api/chain/account/parser.js +48 -0
  246. package/lib-es/api/chain/account/parser.js.map +1 -0
  247. package/lib-es/api/chain/account/stake.d.ts +237 -0
  248. package/lib-es/api/chain/account/stake.d.ts.map +1 -0
  249. package/lib-es/api/chain/account/stake.js +35 -0
  250. package/lib-es/api/chain/account/stake.js.map +1 -0
  251. package/lib-es/api/chain/account/token.d.ts +116 -0
  252. package/lib-es/api/chain/account/token.d.ts.map +1 -0
  253. package/lib-es/api/chain/account/token.js +39 -0
  254. package/lib-es/api/chain/account/token.js.map +1 -0
  255. package/lib-es/api/chain/account/vote.d.ts +252 -0
  256. package/lib-es/api/chain/account/vote.d.ts.map +1 -0
  257. package/lib-es/api/chain/account/vote.js +41 -0
  258. package/lib-es/api/chain/account/vote.js.map +1 -0
  259. package/lib-es/api/chain/index.d.ts +29 -0
  260. package/lib-es/api/chain/index.d.ts.map +1 -0
  261. package/lib-es/api/chain/index.js +95 -0
  262. package/lib-es/api/chain/index.js.map +1 -0
  263. package/lib-es/api/chain/instruction/associated-token-account/index.d.ts +15 -0
  264. package/lib-es/api/chain/instruction/associated-token-account/index.d.ts.map +1 -0
  265. package/lib-es/api/chain/instruction/associated-token-account/index.js +17 -0
  266. package/lib-es/api/chain/instruction/associated-token-account/index.js.map +1 -0
  267. package/lib-es/api/chain/instruction/associated-token-account/types.d.ts +30 -0
  268. package/lib-es/api/chain/instruction/associated-token-account/types.d.ts.map +1 -0
  269. package/lib-es/api/chain/instruction/associated-token-account/types.js +16 -0
  270. package/lib-es/api/chain/instruction/associated-token-account/types.js.map +1 -0
  271. package/lib-es/api/chain/instruction/memo/index.d.ts +15 -0
  272. package/lib-es/api/chain/instruction/memo/index.d.ts.map +1 -0
  273. package/lib-es/api/chain/instruction/memo/index.js +10 -0
  274. package/lib-es/api/chain/instruction/memo/index.js.map +1 -0
  275. package/lib-es/api/chain/instruction/memo/types.d.ts +21 -0
  276. package/lib-es/api/chain/instruction/memo/types.d.ts.map +1 -0
  277. package/lib-es/api/chain/instruction/memo/types.js +13 -0
  278. package/lib-es/api/chain/instruction/memo/types.js.map +1 -0
  279. package/lib-es/api/chain/instruction/stake/index.d.ts +15 -0
  280. package/lib-es/api/chain/instruction/stake/index.d.ts.map +1 -0
  281. package/lib-es/api/chain/instruction/stake/index.js +16 -0
  282. package/lib-es/api/chain/instruction/stake/index.js.map +1 -0
  283. package/lib-es/api/chain/instruction/stake/types.d.ts +215 -0
  284. package/lib-es/api/chain/instruction/stake/types.d.ts.map +1 -0
  285. package/lib-es/api/chain/instruction/stake/types.js +77 -0
  286. package/lib-es/api/chain/instruction/stake/types.js.map +1 -0
  287. package/lib-es/api/chain/instruction/system/index.d.ts +15 -0
  288. package/lib-es/api/chain/instruction/system/index.d.ts.map +1 -0
  289. package/lib-es/api/chain/instruction/system/index.js +16 -0
  290. package/lib-es/api/chain/instruction/system/index.js.map +1 -0
  291. package/lib-es/api/chain/instruction/system/types.d.ts +298 -0
  292. package/lib-es/api/chain/instruction/system/types.d.ts.map +1 -0
  293. package/lib-es/api/chain/instruction/system/types.js +114 -0
  294. package/lib-es/api/chain/instruction/system/types.js.map +1 -0
  295. package/lib-es/api/chain/instruction/token/index.d.ts +15 -0
  296. package/lib-es/api/chain/instruction/token/index.d.ts.map +1 -0
  297. package/lib-es/api/chain/instruction/token/index.js +16 -0
  298. package/lib-es/api/chain/instruction/token/index.js.map +1 -0
  299. package/lib-es/api/chain/instruction/token/types.d.ts +497 -0
  300. package/lib-es/api/chain/instruction/token/types.d.ts.map +1 -0
  301. package/lib-es/api/chain/instruction/token/types.js +197 -0
  302. package/lib-es/api/chain/instruction/token/types.js.map +1 -0
  303. package/lib-es/api/chain/program/constants.d.ts +11 -0
  304. package/lib-es/api/chain/program/constants.d.ts.map +1 -0
  305. package/lib-es/api/chain/program/constants.js +11 -0
  306. package/lib-es/api/chain/program/constants.js.map +1 -0
  307. package/lib-es/api/chain/program/index.d.ts +2 -0
  308. package/lib-es/api/chain/program/index.d.ts.map +1 -0
  309. package/lib-es/api/chain/program/index.js +2 -0
  310. package/lib-es/api/chain/program/index.js.map +1 -0
  311. package/lib-es/api/chain/program/parser.d.ts +35 -0
  312. package/lib-es/api/chain/program/parser.d.ts.map +1 -0
  313. package/lib-es/api/chain/program/parser.js +61 -0
  314. package/lib-es/api/chain/program/parser.js.map +1 -0
  315. package/lib-es/api/chain/validators/bignum.d.ts +3 -0
  316. package/lib-es/api/chain/validators/bignum.d.ts.map +1 -0
  317. package/lib-es/api/chain/validators/bignum.js +8 -0
  318. package/lib-es/api/chain/validators/bignum.js.map +1 -0
  319. package/lib-es/api/chain/validators/index.d.ts +10 -0
  320. package/lib-es/api/chain/validators/index.d.ts.map +1 -0
  321. package/lib-es/api/chain/validators/index.js +7 -0
  322. package/lib-es/api/chain/validators/index.js.map +1 -0
  323. package/lib-es/api/chain/validators/pubkey.d.ts +3 -0
  324. package/lib-es/api/chain/validators/pubkey.d.ts.map +1 -0
  325. package/lib-es/api/chain/validators/pubkey.js +4 -0
  326. package/lib-es/api/chain/validators/pubkey.js.map +1 -0
  327. package/lib-es/api/chain/web3.d.ts +43 -0
  328. package/lib-es/api/chain/web3.d.ts.map +1 -0
  329. package/lib-es/api/chain/web3.js +251 -0
  330. package/lib-es/api/chain/web3.js.map +1 -0
  331. package/lib-es/api/index.d.ts +5 -0
  332. package/lib-es/api/index.d.ts.map +1 -0
  333. package/lib-es/api/index.js +5 -0
  334. package/lib-es/api/index.js.map +1 -0
  335. package/lib-es/api/logged.d.ts +3 -0
  336. package/lib-es/api/logged.d.ts.map +1 -0
  337. package/lib-es/api/logged.js +65 -0
  338. package/lib-es/api/logged.js.map +1 -0
  339. package/lib-es/api/queued.d.ts +3 -0
  340. package/lib-es/api/queued.d.ts.map +1 -0
  341. package/lib-es/api/queued.js +23 -0
  342. package/lib-es/api/queued.js.map +1 -0
  343. package/lib-es/api/traced.d.ts +3 -0
  344. package/lib-es/api/traced.d.ts.map +1 -0
  345. package/lib-es/api/traced.js +76 -0
  346. package/lib-es/api/traced.js.map +1 -0
  347. package/lib-es/bridge/bridge.d.ts +15 -0
  348. package/lib-es/bridge/bridge.d.ts.map +1 -0
  349. package/lib-es/bridge/bridge.js +132 -0
  350. package/lib-es/bridge/bridge.js.map +1 -0
  351. package/lib-es/bridge/js.d.ts +7 -0
  352. package/lib-es/bridge/js.d.ts.map +1 -0
  353. package/lib-es/bridge/js.js +24 -0
  354. package/lib-es/bridge/js.js.map +1 -0
  355. package/lib-es/bridge.integration.test.d.ts +4 -0
  356. package/lib-es/bridge.integration.test.d.ts.map +1 -0
  357. package/lib-es/bridge.integration.test.js +988 -0
  358. package/lib-es/bridge.integration.test.js.map +1 -0
  359. package/lib-es/cli-transaction.d.ts +19 -0
  360. package/lib-es/cli-transaction.d.ts.map +1 -0
  361. package/lib-es/cli-transaction.js +190 -0
  362. package/lib-es/cli-transaction.js.map +1 -0
  363. package/lib-es/datasets/solana.scanAccounts.1.d.ts +6 -0
  364. package/lib-es/datasets/solana.scanAccounts.1.d.ts.map +1 -0
  365. package/lib-es/datasets/solana.scanAccounts.1.js +10 -0
  366. package/lib-es/datasets/solana.scanAccounts.1.js.map +1 -0
  367. package/lib-es/deviceTransactionConfig.d.ts +10 -0
  368. package/lib-es/deviceTransactionConfig.d.ts.map +1 -0
  369. package/lib-es/deviceTransactionConfig.js +223 -0
  370. package/lib-es/deviceTransactionConfig.js.map +1 -0
  371. package/lib-es/errors.d.ts +61 -0
  372. package/lib-es/errors.d.ts.map +1 -0
  373. package/lib-es/errors.js +22 -0
  374. package/lib-es/errors.js.map +1 -0
  375. package/lib-es/hw-getAddress.d.ts +6 -0
  376. package/lib-es/hw-getAddress.d.ts.map +1 -0
  377. package/lib-es/hw-getAddress.js +23 -0
  378. package/lib-es/hw-getAddress.js.map +1 -0
  379. package/lib-es/js-broadcast.d.ts +7 -0
  380. package/lib-es/js-broadcast.d.ts.map +1 -0
  381. package/lib-es/js-broadcast.js +33 -0
  382. package/lib-es/js-broadcast.js.map +1 -0
  383. package/lib-es/js-buildTransaction.d.ts +5 -0
  384. package/lib-es/js-buildTransaction.d.ts.map +1 -0
  385. package/lib-es/js-buildTransaction.js +63 -0
  386. package/lib-es/js-buildTransaction.js.map +1 -0
  387. package/lib-es/js-createTransaction.d.ts +5 -0
  388. package/lib-es/js-createTransaction.d.ts.map +1 -0
  389. package/lib-es/js-createTransaction.js +17 -0
  390. package/lib-es/js-createTransaction.js.map +1 -0
  391. package/lib-es/js-estimateMaxSpendable.d.ts +11 -0
  392. package/lib-es/js-estimateMaxSpendable.d.ts.map +1 -0
  393. package/lib-es/js-estimateMaxSpendable.js +55 -0
  394. package/lib-es/js-estimateMaxSpendable.js.map +1 -0
  395. package/lib-es/js-getTransactionStatus.d.ts +5 -0
  396. package/lib-es/js-getTransactionStatus.d.ts.map +1 -0
  397. package/lib-es/js-getTransactionStatus.js +69 -0
  398. package/lib-es/js-getTransactionStatus.js.map +1 -0
  399. package/lib-es/js-preload-data.d.ts +7 -0
  400. package/lib-es/js-preload-data.d.ts.map +1 -0
  401. package/lib-es/js-preload-data.js +39 -0
  402. package/lib-es/js-preload-data.js.map +1 -0
  403. package/lib-es/js-preload.d.ts +7 -0
  404. package/lib-es/js-preload.d.ts.map +1 -0
  405. package/lib-es/js-preload.js +62 -0
  406. package/lib-es/js-preload.js.map +1 -0
  407. package/lib-es/js-preload.test.d.ts +2 -0
  408. package/lib-es/js-preload.test.d.ts.map +1 -0
  409. package/lib-es/js-preload.test.js +7 -0
  410. package/lib-es/js-preload.test.js.map +1 -0
  411. package/lib-es/js-prepareTransaction.d.ts +5 -0
  412. package/lib-es/js-prepareTransaction.d.ts.map +1 -0
  413. package/lib-es/js-prepareTransaction.js +497 -0
  414. package/lib-es/js-prepareTransaction.js.map +1 -0
  415. package/lib-es/js-signOperation.d.ts +7 -0
  416. package/lib-es/js-signOperation.d.ts.map +1 -0
  417. package/lib-es/js-signOperation.js +146 -0
  418. package/lib-es/js-signOperation.js.map +1 -0
  419. package/lib-es/js-synchronization.d.ts +5 -0
  420. package/lib-es/js-synchronization.d.ts.map +1 -0
  421. package/lib-es/js-synchronization.js +457 -0
  422. package/lib-es/js-synchronization.js.map +1 -0
  423. package/lib-es/logic.d.ts +29 -0
  424. package/lib-es/logic.d.ts.map +1 -0
  425. package/lib-es/logic.js +87 -0
  426. package/lib-es/logic.js.map +1 -0
  427. package/lib-es/serialization.d.ts +9 -0
  428. package/lib-es/serialization.d.ts.map +1 -0
  429. package/lib-es/serialization.js +60 -0
  430. package/lib-es/serialization.js.map +1 -0
  431. package/lib-es/signer.d.ts +11 -0
  432. package/lib-es/signer.d.ts.map +1 -0
  433. package/lib-es/signer.js +2 -0
  434. package/lib-es/signer.js.map +1 -0
  435. package/lib-es/specs.d.ts +7 -0
  436. package/lib-es/specs.d.ts.map +1 -0
  437. package/lib-es/specs.js +404 -0
  438. package/lib-es/specs.js.map +1 -0
  439. package/lib-es/speculos-deviceActions.d.ts +8 -0
  440. package/lib-es/speculos-deviceActions.d.ts.map +1 -0
  441. package/lib-es/speculos-deviceActions.js +211 -0
  442. package/lib-es/speculos-deviceActions.js.map +1 -0
  443. package/lib-es/transaction.d.ts +15 -0
  444. package/lib-es/transaction.d.ts.map +1 -0
  445. package/lib-es/transaction.js +147 -0
  446. package/lib-es/transaction.js.map +1 -0
  447. package/lib-es/tx-fees.d.ts +4 -0
  448. package/lib-es/tx-fees.d.ts.map +1 -0
  449. package/lib-es/tx-fees.js +160 -0
  450. package/lib-es/tx-fees.js.map +1 -0
  451. package/lib-es/types.d.ts +222 -0
  452. package/lib-es/types.d.ts.map +1 -0
  453. package/lib-es/types.js +2 -0
  454. package/lib-es/types.js.map +1 -0
  455. package/lib-es/utils.d.ts +24 -0
  456. package/lib-es/utils.d.ts.map +1 -0
  457. package/lib-es/utils.js +157 -0
  458. package/lib-es/utils.js.map +1 -0
  459. package/lib-es/validator-app/index.d.ts +22 -0
  460. package/lib-es/validator-app/index.d.ts.map +1 -0
  461. package/lib-es/validator-app/index.js +55 -0
  462. package/lib-es/validator-app/index.js.map +1 -0
  463. package/package.json +89 -0
  464. package/src/api/cached.ts +87 -0
  465. package/src/api/chain/account/index.ts +1 -0
  466. package/src/api/chain/account/parser.ts +63 -0
  467. package/src/api/chain/account/stake.ts +45 -0
  468. package/src/api/chain/account/token.ts +63 -0
  469. package/src/api/chain/account/vote.ts +55 -0
  470. package/src/api/chain/index.ts +203 -0
  471. package/src/api/chain/instruction/associated-token-account/index.ts +33 -0
  472. package/src/api/chain/instruction/associated-token-account/types.ts +23 -0
  473. package/src/api/chain/instruction/memo/index.ts +24 -0
  474. package/src/api/chain/instruction/memo/types.ts +18 -0
  475. package/src/api/chain/instruction/stake/index.ts +29 -0
  476. package/src/api/chain/instruction/stake/types.ts +95 -0
  477. package/src/api/chain/instruction/system/index.ts +30 -0
  478. package/src/api/chain/instruction/system/types.ts +141 -0
  479. package/src/api/chain/instruction/token/index.ts +30 -0
  480. package/src/api/chain/instruction/token/types.ts +222 -0
  481. package/src/api/chain/program/constants.ts +10 -0
  482. package/src/api/chain/program/index.ts +1 -0
  483. package/src/api/chain/program/parser.ts +120 -0
  484. package/src/api/chain/validators/bignum.ts +7 -0
  485. package/src/api/chain/validators/index.ts +9 -0
  486. package/src/api/chain/validators/pubkey.ts +8 -0
  487. package/src/api/chain/web3.ts +399 -0
  488. package/src/api/index.ts +4 -0
  489. package/src/api/logged.ts +70 -0
  490. package/src/api/queued.ts +25 -0
  491. package/src/api/traced.ts +89 -0
  492. package/src/bridge/bridge.ts +195 -0
  493. package/src/bridge/js.ts +44 -0
  494. package/src/bridge.integration.test.ts +1106 -0
  495. package/src/cli-transaction.ts +246 -0
  496. package/src/datasets/solana.scanAccounts.1.ts +9 -0
  497. package/src/deviceTransactionConfig.ts +302 -0
  498. package/src/errors.ts +61 -0
  499. package/src/hw-getAddress.ts +26 -0
  500. package/src/js-broadcast.ts +38 -0
  501. package/src/js-buildTransaction.ts +81 -0
  502. package/src/js-createTransaction.ts +20 -0
  503. package/src/js-estimateMaxSpendable.ts +72 -0
  504. package/src/js-getTransactionStatus.ts +72 -0
  505. package/src/js-preload-data.ts +46 -0
  506. package/src/js-preload.test.ts +14 -0
  507. package/src/js-preload.ts +74 -0
  508. package/src/js-prepareTransaction.ts +686 -0
  509. package/src/js-signOperation.ts +329 -0
  510. package/src/js-synchronization.ts +729 -0
  511. package/src/logic.ts +123 -0
  512. package/src/serialization.ts +81 -0
  513. package/src/signer.ts +21 -0
  514. package/src/specs.ts +514 -0
  515. package/src/speculos-deviceActions.ts +229 -0
  516. package/src/transaction.ts +194 -0
  517. package/src/tx-fees.ts +206 -0
  518. package/src/types.ts +284 -0
  519. package/src/utils.ts +176 -0
  520. package/src/validator-app/index.ts +79 -0
  521. package/tsconfig.json +12 -0
package/src/specs.ts ADDED
@@ -0,0 +1,514 @@
1
+ import invariant from "invariant";
2
+ import expect from "expect";
3
+ import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets";
4
+ import { DeviceModelId } from "@ledgerhq/devices";
5
+ import {
6
+ botTest,
7
+ expectSiblingsHaveSpendablePartGreaterThan,
8
+ genericTestDestination,
9
+ pickSiblings,
10
+ } from "@ledgerhq/coin-framework/bot/specs";
11
+ import { AppSpec, TransactionTestInput } from "@ledgerhq/coin-framework/bot/types";
12
+ import { SolanaAccount, SolanaOperation, Transaction } from "./types";
13
+ import {
14
+ acceptStakeCreateAccountTransaction,
15
+ acceptStakeDelegateTransaction,
16
+ acceptStakeUndelegateTransaction,
17
+ acceptStakeWithdrawTransaction,
18
+ acceptTransferTransaction,
19
+ } from "./speculos-deviceActions";
20
+ import { assertUnreachable } from "./utils";
21
+ import { getCurrentSolanaPreloadData } from "./js-preload-data";
22
+ import { sample } from "lodash/fp";
23
+ import BigNumber from "bignumber.js";
24
+
25
+ const maxAccount = 9;
26
+
27
+ const solana: AppSpec<Transaction> = {
28
+ name: "Solana",
29
+ scanAccountsRetries: 3,
30
+ appQuery: {
31
+ model: DeviceModelId.nanoS,
32
+ firmware: "2",
33
+ appVersion: "1.2.0",
34
+ appName: "solana",
35
+ },
36
+ genericDeviceAction: acceptTransferTransaction,
37
+ testTimeout: 2 * 60 * 1000,
38
+ currency: getCryptoCurrencyById("solana"),
39
+ mutations: [
40
+ {
41
+ name: "Transfer ~50%",
42
+ maxRun: 2,
43
+ testDestination: genericTestDestination,
44
+ deviceAction: acceptTransferTransaction,
45
+ transaction: ({ account, siblings, bridge, maxSpendable }) => {
46
+ invariant(maxSpendable.gt(0), "balance is 0");
47
+ const transaction = bridge.createTransaction(account);
48
+ const sibling = pickSiblings(siblings, maxAccount);
49
+ const recipient = sibling.freshAddress;
50
+ const amount = account.spendableBalance.div(1.9 + 0.2 * Math.random()).integerValue();
51
+ return {
52
+ transaction,
53
+ updates: [{ recipient }, { amount }, maybeTransferMemo()],
54
+ };
55
+ },
56
+ test: input => {
57
+ expectCorrectBalanceChange(input);
58
+ expectCorrectMemo(input);
59
+ },
60
+ },
61
+ {
62
+ name: "Transfer Max",
63
+ maxRun: 1,
64
+ deviceAction: acceptTransferTransaction,
65
+ transaction: ({ account, siblings, bridge, maxSpendable }) => {
66
+ invariant(maxSpendable.gt(0), "balance is 0");
67
+ const transaction = bridge.createTransaction(account);
68
+ const sibling = pickSiblings(siblings, maxAccount);
69
+ const recipient = sibling.freshAddress;
70
+ return {
71
+ transaction,
72
+ updates: [{ recipient }, { useAllAmount: true }, maybeTransferMemo()],
73
+ };
74
+ },
75
+ test: input => {
76
+ const { account } = input;
77
+ botTest("account balance should be zero", () =>
78
+ expect(account.spendableBalance.toNumber()).toBe(0),
79
+ );
80
+ expectCorrectBalanceChange(input);
81
+ expectCorrectMemo(input);
82
+ },
83
+ },
84
+ {
85
+ name: "Delegate",
86
+ maxRun: 1,
87
+ deviceAction: acceptStakeCreateAccountTransaction,
88
+ transaction: ({ account, bridge, siblings }) => {
89
+ expectSiblingsHaveSpendablePartGreaterThan(siblings, 0.5);
90
+
91
+ const { solanaResources } = account as SolanaAccount;
92
+ if (solanaResources === undefined) {
93
+ throw new Error("solana resources required");
94
+ }
95
+ invariant(solanaResources.stakes.length < 10, "already enough delegations");
96
+
97
+ invariant(account.spendableBalance.gte(3000000), "not enough balance");
98
+
99
+ const { validators } = getCurrentSolanaPreloadData(account.currency);
100
+
101
+ const notUsedValidators = validators.filter(v =>
102
+ solanaResources.stakes.every(s => s.delegation?.voteAccAddr !== v.voteAccount),
103
+ );
104
+
105
+ const validator = sample(notUsedValidators);
106
+
107
+ if (validator === undefined) {
108
+ throw new Error("no not used validators found");
109
+ }
110
+
111
+ const transaction = bridge.createTransaction(account);
112
+
113
+ return {
114
+ transaction,
115
+ updates: [
116
+ {
117
+ model: {
118
+ kind: "stake.createAccount",
119
+ uiState: {
120
+ delegate: { voteAccAddress: validator.voteAccount },
121
+ },
122
+ },
123
+ },
124
+ {
125
+ amount: new BigNumber(100000),
126
+ },
127
+ ],
128
+ };
129
+ },
130
+ test: ({ account, transaction }) => {
131
+ const { solanaResources } = account as SolanaAccount;
132
+
133
+ if (solanaResources === undefined) {
134
+ throw new Error("solana resources required");
135
+ }
136
+
137
+ if (transaction.model.kind !== "stake.createAccount") {
138
+ throw new Error("wrong transaction");
139
+ }
140
+
141
+ const voteAccAddrUsedInTx = transaction.model.uiState.delegate.voteAccAddress;
142
+
143
+ const { stakes } = solanaResources;
144
+ const stake = stakes.find(s => s.delegation?.voteAccAddr === voteAccAddrUsedInTx);
145
+ if (stake === undefined) {
146
+ throw new Error("expected delegation not found in account resources");
147
+ }
148
+
149
+ botTest("transaction amount is the stake amount", () =>
150
+ expect(transaction.amount.toNumber()).toBe(stake.delegation?.stake),
151
+ );
152
+ },
153
+ },
154
+ {
155
+ name: "Deactivate Activating Delegation",
156
+ maxRun: 1,
157
+ deviceAction: acceptStakeUndelegateTransaction,
158
+ transaction: ({ account, bridge }) => {
159
+ invariant(account.spendableBalance.gt(0), "not enough balance");
160
+ const { solanaResources } = account as SolanaAccount;
161
+
162
+ if (solanaResources === undefined) {
163
+ throw new Error("solana resources required");
164
+ }
165
+
166
+ const activatingStakes = solanaResources.stakes.filter(
167
+ s => s.activation.state === "activating",
168
+ );
169
+
170
+ const stake = sample(activatingStakes);
171
+
172
+ if (stake === undefined) {
173
+ throw new Error("no activating stakes found");
174
+ }
175
+
176
+ const transaction = bridge.createTransaction(account);
177
+
178
+ return {
179
+ transaction,
180
+ updates: [
181
+ {
182
+ model: {
183
+ kind: "stake.undelegate",
184
+ uiState: {
185
+ stakeAccAddr: stake.stakeAccAddr,
186
+ },
187
+ },
188
+ },
189
+ ],
190
+ };
191
+ },
192
+ test: ({ account, transaction }) => {
193
+ const { solanaResources } = account as SolanaAccount;
194
+
195
+ if (solanaResources === undefined) {
196
+ throw new Error("solana resources required");
197
+ }
198
+
199
+ if (transaction.model.kind !== "stake.undelegate") {
200
+ throw new Error("wrong transaction");
201
+ }
202
+
203
+ const stakeAccAddrUsedInTx = transaction.model.uiState.stakeAccAddr;
204
+
205
+ const stake = solanaResources.stakes.find(s => s.stakeAccAddr === stakeAccAddrUsedInTx);
206
+
207
+ if (stake === undefined) {
208
+ throw new Error("expected stake not found in account resources");
209
+ }
210
+
211
+ botTest("activation state", () => expect(stake.activation.state).toBe("inactive"));
212
+ },
213
+ },
214
+ {
215
+ name: "Deactivate Active Delegation",
216
+ maxRun: 1,
217
+ deviceAction: acceptStakeUndelegateTransaction,
218
+ transaction: ({ account, bridge }) => {
219
+ invariant(account.spendableBalance.gt(0), "not enough balance");
220
+ const { solanaResources } = account as SolanaAccount;
221
+
222
+ if (solanaResources === undefined) {
223
+ throw new Error("solana resources required");
224
+ }
225
+
226
+ const activeStakes = solanaResources.stakes.filter(s => s.activation.state === "active");
227
+
228
+ const stake = sample(activeStakes);
229
+
230
+ if (stake === undefined) {
231
+ throw new Error("no active stakes found");
232
+ }
233
+
234
+ const transaction = bridge.createTransaction(account);
235
+
236
+ return {
237
+ transaction,
238
+ updates: [
239
+ {
240
+ model: {
241
+ kind: "stake.undelegate",
242
+ uiState: {
243
+ stakeAccAddr: stake.stakeAccAddr,
244
+ },
245
+ },
246
+ },
247
+ ],
248
+ };
249
+ },
250
+ test: ({ account, transaction }) => {
251
+ const { solanaResources } = account as SolanaAccount;
252
+
253
+ if (solanaResources === undefined) {
254
+ throw new Error("solana resources required");
255
+ }
256
+
257
+ if (transaction.model.kind !== "stake.undelegate") {
258
+ throw new Error("wrong transaction");
259
+ }
260
+
261
+ const stakeAccAddrUsedInTx = transaction.model.uiState.stakeAccAddr;
262
+
263
+ const stake = solanaResources.stakes.find(s => s.stakeAccAddr === stakeAccAddrUsedInTx);
264
+
265
+ if (stake === undefined) {
266
+ throw new Error("expected stake not found in account resources");
267
+ }
268
+ botTest("activation state", () => expect(stake.activation.state).toBe("deactivating"));
269
+ },
270
+ },
271
+ {
272
+ name: "Reactivate Deactivating Delegation",
273
+ maxRun: 1,
274
+ deviceAction: acceptStakeDelegateTransaction,
275
+ transaction: ({ account, bridge }) => {
276
+ invariant(account.spendableBalance.gt(0), "not enough balance");
277
+ const { solanaResources } = account as SolanaAccount;
278
+
279
+ if (solanaResources === undefined) {
280
+ throw new Error("solana resources required");
281
+ }
282
+
283
+ const deactivatingStakes = solanaResources.stakes.filter(
284
+ s => s.activation.state === "deactivating",
285
+ );
286
+
287
+ const stake = sample(deactivatingStakes);
288
+
289
+ if (stake === undefined) {
290
+ throw new Error("no deactivating stakes found");
291
+ }
292
+
293
+ if (stake.delegation === undefined) {
294
+ throw new Error("unexpected undefined delegation");
295
+ }
296
+
297
+ const transaction = bridge.createTransaction(account);
298
+
299
+ return {
300
+ transaction,
301
+ updates: [
302
+ {
303
+ model: {
304
+ kind: "stake.delegate",
305
+ uiState: {
306
+ stakeAccAddr: stake.stakeAccAddr,
307
+ voteAccAddr: stake.delegation.voteAccAddr,
308
+ },
309
+ },
310
+ },
311
+ ],
312
+ };
313
+ },
314
+ test: ({ account, transaction }) => {
315
+ const { solanaResources } = account as SolanaAccount;
316
+
317
+ if (solanaResources === undefined) {
318
+ throw new Error("solana resources required");
319
+ }
320
+
321
+ if (transaction.model.kind !== "stake.delegate") {
322
+ throw new Error("wrong transaction");
323
+ }
324
+
325
+ const dataUsedInTx = transaction.model.uiState;
326
+
327
+ const stake = solanaResources.stakes.find(
328
+ s =>
329
+ s.stakeAccAddr === dataUsedInTx.stakeAccAddr &&
330
+ s.delegation?.voteAccAddr === dataUsedInTx.voteAccAddr,
331
+ );
332
+
333
+ if (stake === undefined) {
334
+ throw new Error("expected stake not found in account resources");
335
+ }
336
+
337
+ botTest("activation state", () => expect(stake.activation.state).toBe("active"));
338
+ },
339
+ },
340
+ {
341
+ name: "Activate Inactive Delegation",
342
+ maxRun: 1,
343
+ deviceAction: acceptStakeDelegateTransaction,
344
+ transaction: ({ account, bridge }) => {
345
+ invariant(account.spendableBalance.gt(0), "not enough balance");
346
+ const { solanaResources } = account as SolanaAccount;
347
+
348
+ if (solanaResources === undefined) {
349
+ throw new Error("solana resources required");
350
+ }
351
+
352
+ const inactiveStakes = solanaResources.stakes.filter(
353
+ s => s.activation.state === "inactive",
354
+ );
355
+
356
+ const stake = sample(inactiveStakes);
357
+
358
+ if (stake === undefined) {
359
+ throw new Error("no inactive stakes found");
360
+ }
361
+
362
+ if (stake.delegation === undefined) {
363
+ throw new Error("unexpected undefined delegation");
364
+ }
365
+
366
+ const transaction = bridge.createTransaction(account);
367
+
368
+ return {
369
+ transaction,
370
+ updates: [
371
+ {
372
+ model: {
373
+ kind: "stake.delegate",
374
+ uiState: {
375
+ stakeAccAddr: stake.stakeAccAddr,
376
+ voteAccAddr: stake.delegation.voteAccAddr,
377
+ },
378
+ },
379
+ },
380
+ ],
381
+ };
382
+ },
383
+ test: ({ account, transaction }) => {
384
+ const { solanaResources } = account as SolanaAccount;
385
+
386
+ if (solanaResources === undefined) {
387
+ throw new Error("solana resources required");
388
+ }
389
+
390
+ if (transaction.model.kind !== "stake.delegate") {
391
+ throw new Error("wrong transaction");
392
+ }
393
+
394
+ const dataUsedInTx = transaction.model.uiState;
395
+
396
+ const stake = solanaResources.stakes.find(
397
+ s =>
398
+ s.stakeAccAddr === dataUsedInTx.stakeAccAddr &&
399
+ s.delegation?.voteAccAddr === dataUsedInTx.voteAccAddr,
400
+ );
401
+
402
+ if (stake === undefined) {
403
+ throw new Error("expected stake not found in account resources");
404
+ }
405
+ botTest("activation state", () => expect(stake.activation.state).toBe("activating"));
406
+ },
407
+ },
408
+ {
409
+ name: "Withdraw Delegation",
410
+ maxRun: 1,
411
+ deviceAction: acceptStakeWithdrawTransaction,
412
+ transaction: ({ account, bridge }) => {
413
+ invariant(account.spendableBalance.gt(0), "not enough balance");
414
+ const { solanaResources } = account as SolanaAccount;
415
+
416
+ if (solanaResources === undefined) {
417
+ throw new Error("solana resources required");
418
+ }
419
+
420
+ const withdrawableStakes = solanaResources.stakes.filter(s => s.withdrawable > 0);
421
+
422
+ const stake = sample(withdrawableStakes);
423
+
424
+ if (stake === undefined) {
425
+ throw new Error("no withdrawable stakes found");
426
+ }
427
+
428
+ const transaction = bridge.createTransaction(account);
429
+
430
+ return {
431
+ transaction,
432
+ updates: [
433
+ {
434
+ model: {
435
+ kind: "stake.withdraw",
436
+ uiState: {
437
+ stakeAccAddr: stake.stakeAccAddr,
438
+ },
439
+ },
440
+ },
441
+ ],
442
+ };
443
+ },
444
+ test: ({ account, transaction }) => {
445
+ const { solanaResources } = account as SolanaAccount;
446
+
447
+ if (solanaResources === undefined) {
448
+ throw new Error("solana resources required");
449
+ }
450
+
451
+ if (transaction.model.kind !== "stake.withdraw") {
452
+ throw new Error("wrong transaction");
453
+ }
454
+
455
+ const stakeAccAddrUsedInTx = transaction.model.uiState.stakeAccAddr;
456
+
457
+ const delegationExists = solanaResources.stakes.some(
458
+ s => s.stakeAccAddr === stakeAccAddrUsedInTx,
459
+ );
460
+
461
+ botTest("delegation exists", () => expect(delegationExists).toBe(false));
462
+ },
463
+ },
464
+ ],
465
+ };
466
+
467
+ function maybeTransferMemo(threshold = 0.5): Partial<Transaction> | undefined {
468
+ return Math.random() > threshold
469
+ ? {
470
+ model: {
471
+ kind: "transfer",
472
+ uiState: {
473
+ memo: "a memo",
474
+ },
475
+ },
476
+ }
477
+ : undefined;
478
+ }
479
+
480
+ function expectCorrectMemo(input: TransactionTestInput<Transaction>) {
481
+ const { transaction, operation } = input;
482
+ switch (transaction.model.kind) {
483
+ case "transfer":
484
+ case "token.transfer": {
485
+ const memo = transaction.model.uiState.memo;
486
+ botTest("memo matches in op extra", () =>
487
+ expect((operation as SolanaOperation).extra.memo).toBe(memo),
488
+ );
489
+ break;
490
+ }
491
+ case "token.createATA":
492
+ case "stake.createAccount":
493
+ case "stake.delegate":
494
+ case "stake.undelegate":
495
+ case "stake.withdraw":
496
+ case "stake.split":
497
+ break;
498
+ default:
499
+ return assertUnreachable(transaction.model);
500
+ }
501
+ }
502
+
503
+ function expectCorrectBalanceChange(input: TransactionTestInput<Transaction>) {
504
+ const { account, operation, accountBeforeTransaction } = input;
505
+ botTest("account balance decreased with operation value", () =>
506
+ expect(account.balance.toNumber()).toBe(
507
+ accountBeforeTransaction.balance.minus(operation.value).toNumber(),
508
+ ),
509
+ );
510
+ }
511
+
512
+ export default {
513
+ solana,
514
+ };