@ledgerhq/coin-aptos 2.0.0-nightly.5 → 2.1.0-next.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 (533) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/.unimportedrc.json +18 -6
  3. package/CHANGELOG.md +178 -34
  4. package/jest.config.js +2 -1
  5. package/jest.integ.config.js +8 -0
  6. package/lib/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
  7. package/lib/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
  8. package/lib/__tests__/api/craftTransaction.unit.test.js +187 -0
  9. package/lib/__tests__/api/craftTransaction.unit.test.js.map +1 -0
  10. package/lib/__tests__/api/getBalance.unit.test.d.ts +2 -0
  11. package/lib/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
  12. package/lib/__tests__/api/getBalance.unit.test.js +41 -0
  13. package/lib/__tests__/api/getBalance.unit.test.js.map +1 -0
  14. package/lib/__tests__/api/index.integ.test.d.ts +2 -0
  15. package/lib/__tests__/api/index.integ.test.d.ts.map +1 -0
  16. package/lib/__tests__/api/index.integ.test.js +319 -0
  17. package/lib/__tests__/api/index.integ.test.js.map +1 -0
  18. package/lib/__tests__/api/index.test.js +48 -404
  19. package/lib/__tests__/api/index.test.js.map +1 -1
  20. package/lib/__tests__/bridge/broadcast.test.js +5 -5
  21. package/lib/__tests__/bridge/broadcast.test.js.map +1 -1
  22. package/lib/__tests__/bridge/getFeesForTransaction.test.js +115 -14
  23. package/lib/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
  24. package/lib/__tests__/bridge/getTransactionStatus.test.js +175 -37
  25. package/lib/__tests__/bridge/getTransactionStatus.test.js.map +1 -1
  26. package/lib/__tests__/bridge/logic.test.js +703 -479
  27. package/lib/__tests__/bridge/logic.test.js.map +1 -1
  28. package/lib/__tests__/bridge/prepareTransaction.test.js +3 -3
  29. package/lib/__tests__/bridge/prepareTransaction.test.js.map +1 -1
  30. package/lib/__tests__/bridge/signOperation.test.js +137 -14
  31. package/lib/__tests__/bridge/signOperation.test.js.map +1 -1
  32. package/lib/__tests__/bridge/synchronisation.test.js +1215 -68
  33. package/lib/__tests__/bridge/synchronisation.test.js.map +1 -1
  34. package/lib/__tests__/index.test.js +1 -1
  35. package/lib/__tests__/index.test.js.map +1 -1
  36. package/lib/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
  37. package/lib/__tests__/logic/buildTransaction.test.js +114 -0
  38. package/lib/__tests__/logic/buildTransaction.test.js.map +1 -0
  39. package/lib/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
  40. package/lib/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
  41. package/lib/__tests__/logic/calculateAmount.unit.test.js +45 -0
  42. package/lib/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
  43. package/lib/__tests__/logic/combine.unit.test.d.ts +2 -0
  44. package/lib/__tests__/logic/combine.unit.test.d.ts.map +1 -0
  45. package/lib/__tests__/logic/combine.unit.test.js +47 -0
  46. package/lib/__tests__/logic/combine.unit.test.js.map +1 -0
  47. package/lib/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
  48. package/lib/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
  49. package/lib/__tests__/logic/compareAddress.unit.test.js +26 -0
  50. package/lib/__tests__/logic/compareAddress.unit.test.js.map +1 -0
  51. package/lib/__tests__/logic/createTransaction.test.d.ts.map +1 -0
  52. package/lib/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
  53. package/lib/__tests__/logic/createTransaction.test.js.map +1 -0
  54. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
  55. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
  56. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js +186 -0
  57. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
  58. package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
  59. package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
  60. package/lib/__tests__/logic/getFunctionAddress.unit.test.js +29 -0
  61. package/lib/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
  62. package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
  63. package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
  64. package/lib/__tests__/logic/getResourceAddress.unit.test.js +218 -0
  65. package/lib/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
  66. package/lib/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
  67. package/lib/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
  68. package/lib/__tests__/logic/isTestnet.unit.test.js +12 -0
  69. package/lib/__tests__/logic/isTestnet.unit.test.js.map +1 -0
  70. package/lib/__tests__/logic/normalizeAddress.unit.test.d.ts +2 -0
  71. package/lib/__tests__/logic/normalizeAddress.unit.test.d.ts.map +1 -0
  72. package/lib/__tests__/logic/normalizeAddress.unit.test.js +12 -0
  73. package/lib/__tests__/logic/normalizeAddress.unit.test.js.map +1 -0
  74. package/lib/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
  75. package/lib/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
  76. package/lib/__tests__/logic/processRecipients.unit.test.js +79 -0
  77. package/lib/__tests__/logic/processRecipients.unit.test.js.map +1 -0
  78. package/lib/__tests__/network/client.test.d.ts +2 -0
  79. package/lib/__tests__/network/client.test.d.ts.map +1 -0
  80. package/lib/__tests__/network/client.test.js +1124 -0
  81. package/lib/__tests__/network/client.test.js.map +1 -0
  82. package/lib/api/index.d.ts +4 -30
  83. package/lib/api/index.d.ts.map +1 -1
  84. package/lib/api/index.js +19 -170
  85. package/lib/api/index.js.map +1 -1
  86. package/lib/bridge/bridge.fixture.d.ts +2 -0
  87. package/lib/bridge/bridge.fixture.d.ts.map +1 -1
  88. package/lib/bridge/bridge.fixture.js +85 -13
  89. package/lib/bridge/bridge.fixture.js.map +1 -1
  90. package/lib/bridge/broadcast.d.ts +3 -2
  91. package/lib/bridge/broadcast.d.ts.map +1 -1
  92. package/lib/bridge/broadcast.js +4 -3
  93. package/lib/bridge/broadcast.js.map +1 -1
  94. package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -1
  95. package/lib/bridge/estimateMaxSpendable.js +6 -5
  96. package/lib/bridge/estimateMaxSpendable.js.map +1 -1
  97. package/lib/bridge/getFeesForTransaction.d.ts +1 -1
  98. package/lib/bridge/getFeesForTransaction.d.ts.map +1 -1
  99. package/lib/bridge/getFeesForTransaction.js +20 -14
  100. package/lib/bridge/getFeesForTransaction.js.map +1 -1
  101. package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
  102. package/lib/bridge/getTransactionStatus.js +28 -14
  103. package/lib/bridge/getTransactionStatus.js.map +1 -1
  104. package/lib/bridge/index.d.ts +1 -1
  105. package/lib/bridge/index.d.ts.map +1 -1
  106. package/lib/bridge/index.js +1 -1
  107. package/lib/bridge/index.js.map +1 -1
  108. package/lib/bridge/logic.d.ts +5 -19
  109. package/lib/bridge/logic.d.ts.map +1 -1
  110. package/lib/bridge/logic.js +50 -147
  111. package/lib/bridge/logic.js.map +1 -1
  112. package/lib/bridge/prepareTransaction.d.ts.map +1 -1
  113. package/lib/bridge/prepareTransaction.js +5 -4
  114. package/lib/bridge/prepareTransaction.js.map +1 -1
  115. package/lib/bridge/signOperation.d.ts.map +1 -1
  116. package/lib/bridge/signOperation.js +21 -7
  117. package/lib/bridge/signOperation.js.map +1 -1
  118. package/lib/bridge/synchronisation.d.ts +15 -0
  119. package/lib/bridge/synchronisation.d.ts.map +1 -1
  120. package/lib/bridge/synchronisation.js +129 -6
  121. package/lib/bridge/synchronisation.js.map +1 -1
  122. package/lib/config.d.ts +13 -0
  123. package/lib/config.d.ts.map +1 -0
  124. package/lib/config.js +9 -0
  125. package/lib/config.js.map +1 -0
  126. package/lib/constants.d.ts +13 -2
  127. package/lib/constants.d.ts.map +1 -1
  128. package/lib/constants.js +17 -2
  129. package/lib/constants.js.map +1 -1
  130. package/lib/logic/buildTransaction.d.ts +9 -0
  131. package/lib/logic/buildTransaction.d.ts.map +1 -0
  132. package/lib/logic/buildTransaction.js +47 -0
  133. package/lib/logic/buildTransaction.js.map +1 -0
  134. package/lib/logic/calculateAmount.d.ts +3 -0
  135. package/lib/logic/calculateAmount.d.ts.map +1 -0
  136. package/lib/logic/calculateAmount.js +13 -0
  137. package/lib/logic/calculateAmount.js.map +1 -0
  138. package/lib/logic/combine.d.ts +4 -0
  139. package/lib/logic/combine.d.ts.map +1 -0
  140. package/lib/logic/combine.js +34 -0
  141. package/lib/logic/combine.js.map +1 -0
  142. package/lib/logic/craftTransaction.d.ts +5 -0
  143. package/lib/logic/craftTransaction.d.ts.map +1 -0
  144. package/lib/logic/craftTransaction.js +68 -0
  145. package/lib/logic/craftTransaction.js.map +1 -0
  146. package/lib/logic/createTransaction.d.ts.map +1 -0
  147. package/lib/{bridge → logic}/createTransaction.js +3 -3
  148. package/lib/logic/createTransaction.js.map +1 -0
  149. package/lib/logic/getBalance.d.ts +5 -0
  150. package/lib/logic/getBalance.d.ts.map +1 -0
  151. package/lib/logic/getBalance.js +12 -0
  152. package/lib/logic/getBalance.js.map +1 -0
  153. package/lib/logic/getCoinAndAmounts.d.ts +13 -0
  154. package/lib/logic/getCoinAndAmounts.d.ts.map +1 -0
  155. package/lib/logic/getCoinAndAmounts.js +112 -0
  156. package/lib/logic/getCoinAndAmounts.js.map +1 -0
  157. package/lib/logic/getFunctionAddress.d.ts +3 -0
  158. package/lib/logic/getFunctionAddress.d.ts.map +1 -0
  159. package/lib/logic/getFunctionAddress.js +12 -0
  160. package/lib/logic/getFunctionAddress.js.map +1 -0
  161. package/lib/logic/getResourceAddress.d.ts +4 -0
  162. package/lib/logic/getResourceAddress.d.ts.map +1 -0
  163. package/lib/logic/getResourceAddress.js +17 -0
  164. package/lib/logic/getResourceAddress.js.map +1 -0
  165. package/lib/logic/isTestnet.d.ts +2 -0
  166. package/lib/logic/isTestnet.d.ts.map +1 -0
  167. package/lib/logic/isTestnet.js +9 -0
  168. package/lib/logic/isTestnet.js.map +1 -0
  169. package/lib/logic/isWriteSetChangeWriteResource.d.ts +3 -0
  170. package/lib/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
  171. package/lib/logic/isWriteSetChangeWriteResource.js +8 -0
  172. package/lib/logic/isWriteSetChangeWriteResource.js.map +1 -0
  173. package/lib/logic/normalizeAddress.d.ts +2 -0
  174. package/lib/logic/normalizeAddress.d.ts.map +1 -0
  175. package/lib/logic/normalizeAddress.js +12 -0
  176. package/lib/logic/normalizeAddress.js.map +1 -0
  177. package/lib/logic/normalizeTransactionOptions.d.ts +3 -0
  178. package/lib/logic/normalizeTransactionOptions.d.ts.map +1 -0
  179. package/lib/logic/normalizeTransactionOptions.js +21 -0
  180. package/lib/logic/normalizeTransactionOptions.js.map +1 -0
  181. package/lib/logic/processRecipients.d.ts +6 -0
  182. package/lib/logic/processRecipients.d.ts.map +1 -0
  183. package/lib/logic/processRecipients.js +58 -0
  184. package/lib/logic/processRecipients.js.map +1 -0
  185. package/lib/logic/transactionsToOperations.d.ts +7 -0
  186. package/lib/logic/transactionsToOperations.d.ts.map +1 -0
  187. package/lib/logic/transactionsToOperations.js +89 -0
  188. package/lib/logic/transactionsToOperations.js.map +1 -0
  189. package/lib/network/client.d.ts +38 -0
  190. package/lib/network/client.d.ts.map +1 -0
  191. package/lib/network/client.js +283 -0
  192. package/lib/network/client.js.map +1 -0
  193. package/lib/network/graphql/queries.d.ts.map +1 -0
  194. package/lib/{api → network}/graphql/queries.js +6 -6
  195. package/lib/network/graphql/queries.js.map +1 -0
  196. package/lib/{api → network}/graphql/types.d.ts +9 -9
  197. package/lib/network/graphql/types.d.ts.map +1 -0
  198. package/lib/{api → network}/graphql/types.js.map +1 -1
  199. package/lib/network/index.d.ts +2 -1
  200. package/lib/network/index.d.ts.map +1 -1
  201. package/lib/network/index.js +19 -7
  202. package/lib/network/index.js.map +1 -1
  203. package/lib/test/bot-specs.d.ts.map +1 -1
  204. package/lib/test/bot-specs.js +40 -1
  205. package/lib/test/bot-specs.js.map +1 -1
  206. package/lib/test/bridgeDatasetTest.d.ts.map +1 -1
  207. package/lib/test/bridgeDatasetTest.js +44 -62
  208. package/lib/test/bridgeDatasetTest.js.map +1 -1
  209. package/lib/test/speculos-deviceActions.d.ts +1 -0
  210. package/lib/test/speculos-deviceActions.d.ts.map +1 -1
  211. package/lib/test/speculos-deviceActions.js +37 -5
  212. package/lib/test/speculos-deviceActions.js.map +1 -1
  213. package/lib/types/assets.d.ts +16 -0
  214. package/lib/types/assets.d.ts.map +1 -0
  215. package/lib/types/assets.js +3 -0
  216. package/lib/types/assets.js.map +1 -0
  217. package/lib/types/index.d.ts +22 -7
  218. package/lib/types/index.d.ts.map +1 -1
  219. package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
  220. package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
  221. package/lib-es/__tests__/api/craftTransaction.unit.test.js +185 -0
  222. package/lib-es/__tests__/api/craftTransaction.unit.test.js.map +1 -0
  223. package/lib-es/__tests__/api/getBalance.unit.test.d.ts +2 -0
  224. package/lib-es/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
  225. package/lib-es/__tests__/api/getBalance.unit.test.js +36 -0
  226. package/lib-es/__tests__/api/getBalance.unit.test.js.map +1 -0
  227. package/lib-es/__tests__/api/index.integ.test.d.ts +2 -0
  228. package/lib-es/__tests__/api/index.integ.test.d.ts.map +1 -0
  229. package/lib-es/__tests__/api/index.integ.test.js +317 -0
  230. package/lib-es/__tests__/api/index.integ.test.js.map +1 -0
  231. package/lib-es/__tests__/api/index.test.js +52 -408
  232. package/lib-es/__tests__/api/index.test.js.map +1 -1
  233. package/lib-es/__tests__/bridge/broadcast.test.js +2 -2
  234. package/lib-es/__tests__/bridge/broadcast.test.js.map +1 -1
  235. package/lib-es/__tests__/bridge/getFeesForTransaction.test.js +112 -11
  236. package/lib-es/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
  237. package/lib-es/__tests__/bridge/getTransactionStatus.test.js +177 -39
  238. package/lib-es/__tests__/bridge/getTransactionStatus.test.js.map +1 -1
  239. package/lib-es/__tests__/bridge/logic.test.js +703 -479
  240. package/lib-es/__tests__/bridge/logic.test.js.map +1 -1
  241. package/lib-es/__tests__/bridge/prepareTransaction.test.js +2 -2
  242. package/lib-es/__tests__/bridge/prepareTransaction.test.js.map +1 -1
  243. package/lib-es/__tests__/bridge/signOperation.test.js +137 -14
  244. package/lib-es/__tests__/bridge/signOperation.test.js.map +1 -1
  245. package/lib-es/__tests__/bridge/synchronisation.test.js +1213 -69
  246. package/lib-es/__tests__/bridge/synchronisation.test.js.map +1 -1
  247. package/lib-es/__tests__/index.test.js +1 -1
  248. package/lib-es/__tests__/index.test.js.map +1 -1
  249. package/lib-es/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
  250. package/lib-es/__tests__/logic/buildTransaction.test.js +109 -0
  251. package/lib-es/__tests__/logic/buildTransaction.test.js.map +1 -0
  252. package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
  253. package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
  254. package/lib-es/__tests__/logic/calculateAmount.unit.test.js +40 -0
  255. package/lib-es/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
  256. package/lib-es/__tests__/logic/combine.unit.test.d.ts +2 -0
  257. package/lib-es/__tests__/logic/combine.unit.test.d.ts.map +1 -0
  258. package/lib-es/__tests__/logic/combine.unit.test.js +45 -0
  259. package/lib-es/__tests__/logic/combine.unit.test.js.map +1 -0
  260. package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
  261. package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
  262. package/lib-es/__tests__/logic/compareAddress.unit.test.js +24 -0
  263. package/lib-es/__tests__/logic/compareAddress.unit.test.js.map +1 -0
  264. package/lib-es/__tests__/logic/createTransaction.test.d.ts.map +1 -0
  265. package/lib-es/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
  266. package/lib-es/__tests__/logic/createTransaction.test.js.map +1 -0
  267. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
  268. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
  269. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js +181 -0
  270. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
  271. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
  272. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
  273. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js +27 -0
  274. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
  275. package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
  276. package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
  277. package/lib-es/__tests__/logic/getResourceAddress.unit.test.js +216 -0
  278. package/lib-es/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
  279. package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
  280. package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
  281. package/lib-es/__tests__/logic/isTestnet.unit.test.js +10 -0
  282. package/lib-es/__tests__/logic/isTestnet.unit.test.js.map +1 -0
  283. package/lib-es/__tests__/logic/normalizeAddress.unit.test.d.ts +2 -0
  284. package/lib-es/__tests__/logic/normalizeAddress.unit.test.d.ts.map +1 -0
  285. package/lib-es/__tests__/logic/normalizeAddress.unit.test.js +10 -0
  286. package/lib-es/__tests__/logic/normalizeAddress.unit.test.js.map +1 -0
  287. package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
  288. package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
  289. package/lib-es/__tests__/logic/processRecipients.unit.test.js +74 -0
  290. package/lib-es/__tests__/logic/processRecipients.unit.test.js.map +1 -0
  291. package/lib-es/__tests__/network/client.test.d.ts +2 -0
  292. package/lib-es/__tests__/network/client.test.d.ts.map +1 -0
  293. package/lib-es/__tests__/network/client.test.js +1119 -0
  294. package/lib-es/__tests__/network/client.test.js.map +1 -0
  295. package/lib-es/api/index.d.ts +4 -30
  296. package/lib-es/api/index.d.ts.map +1 -1
  297. package/lib-es/api/index.js +17 -168
  298. package/lib-es/api/index.js.map +1 -1
  299. package/lib-es/bridge/bridge.fixture.d.ts +2 -0
  300. package/lib-es/bridge/bridge.fixture.d.ts.map +1 -1
  301. package/lib-es/bridge/bridge.fixture.js +82 -12
  302. package/lib-es/bridge/bridge.fixture.js.map +1 -1
  303. package/lib-es/bridge/broadcast.d.ts +3 -2
  304. package/lib-es/bridge/broadcast.d.ts.map +1 -1
  305. package/lib-es/bridge/broadcast.js +4 -3
  306. package/lib-es/bridge/broadcast.js.map +1 -1
  307. package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -1
  308. package/lib-es/bridge/estimateMaxSpendable.js +4 -3
  309. package/lib-es/bridge/estimateMaxSpendable.js.map +1 -1
  310. package/lib-es/bridge/getFeesForTransaction.d.ts +1 -1
  311. package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -1
  312. package/lib-es/bridge/getFeesForTransaction.js +15 -9
  313. package/lib-es/bridge/getFeesForTransaction.js.map +1 -1
  314. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
  315. package/lib-es/bridge/getTransactionStatus.js +28 -14
  316. package/lib-es/bridge/getTransactionStatus.js.map +1 -1
  317. package/lib-es/bridge/index.d.ts +1 -1
  318. package/lib-es/bridge/index.d.ts.map +1 -1
  319. package/lib-es/bridge/index.js +1 -1
  320. package/lib-es/bridge/index.js.map +1 -1
  321. package/lib-es/bridge/logic.d.ts +5 -19
  322. package/lib-es/bridge/logic.d.ts.map +1 -1
  323. package/lib-es/bridge/logic.js +44 -134
  324. package/lib-es/bridge/logic.js.map +1 -1
  325. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
  326. package/lib-es/bridge/prepareTransaction.js +5 -4
  327. package/lib-es/bridge/prepareTransaction.js.map +1 -1
  328. package/lib-es/bridge/signOperation.d.ts.map +1 -1
  329. package/lib-es/bridge/signOperation.js +19 -5
  330. package/lib-es/bridge/signOperation.js.map +1 -1
  331. package/lib-es/bridge/synchronisation.d.ts +15 -0
  332. package/lib-es/bridge/synchronisation.d.ts.map +1 -1
  333. package/lib-es/bridge/synchronisation.js +124 -4
  334. package/lib-es/bridge/synchronisation.js.map +1 -1
  335. package/lib-es/config.d.ts +13 -0
  336. package/lib-es/config.d.ts.map +1 -0
  337. package/lib-es/config.js +4 -0
  338. package/lib-es/config.js.map +1 -0
  339. package/lib-es/constants.d.ts +13 -2
  340. package/lib-es/constants.d.ts.map +1 -1
  341. package/lib-es/constants.js +13 -1
  342. package/lib-es/constants.js.map +1 -1
  343. package/lib-es/logic/buildTransaction.d.ts +9 -0
  344. package/lib-es/logic/buildTransaction.d.ts.map +1 -0
  345. package/lib-es/logic/buildTransaction.js +43 -0
  346. package/lib-es/logic/buildTransaction.js.map +1 -0
  347. package/lib-es/logic/calculateAmount.d.ts +3 -0
  348. package/lib-es/logic/calculateAmount.d.ts.map +1 -0
  349. package/lib-es/logic/calculateAmount.js +9 -0
  350. package/lib-es/logic/calculateAmount.js.map +1 -0
  351. package/lib-es/logic/combine.d.ts +4 -0
  352. package/lib-es/logic/combine.d.ts.map +1 -0
  353. package/lib-es/logic/combine.js +29 -0
  354. package/lib-es/logic/combine.js.map +1 -0
  355. package/lib-es/logic/craftTransaction.d.ts +5 -0
  356. package/lib-es/logic/craftTransaction.d.ts.map +1 -0
  357. package/lib-es/logic/craftTransaction.js +38 -0
  358. package/lib-es/logic/craftTransaction.js.map +1 -0
  359. package/lib-es/logic/createTransaction.d.ts.map +1 -0
  360. package/lib-es/{bridge → logic}/createTransaction.js +1 -1
  361. package/lib-es/logic/createTransaction.js.map +1 -0
  362. package/lib-es/logic/getBalance.d.ts +5 -0
  363. package/lib-es/logic/getBalance.d.ts.map +1 -0
  364. package/lib-es/logic/getBalance.js +8 -0
  365. package/lib-es/logic/getBalance.js.map +1 -0
  366. package/lib-es/logic/getCoinAndAmounts.d.ts +13 -0
  367. package/lib-es/logic/getCoinAndAmounts.d.ts.map +1 -0
  368. package/lib-es/logic/getCoinAndAmounts.js +101 -0
  369. package/lib-es/logic/getCoinAndAmounts.js.map +1 -0
  370. package/lib-es/logic/getFunctionAddress.d.ts +3 -0
  371. package/lib-es/logic/getFunctionAddress.d.ts.map +1 -0
  372. package/lib-es/logic/getFunctionAddress.js +8 -0
  373. package/lib-es/logic/getFunctionAddress.js.map +1 -0
  374. package/lib-es/logic/getResourceAddress.d.ts +4 -0
  375. package/lib-es/logic/getResourceAddress.d.ts.map +1 -0
  376. package/lib-es/logic/getResourceAddress.js +13 -0
  377. package/lib-es/logic/getResourceAddress.js.map +1 -0
  378. package/lib-es/logic/isTestnet.d.ts +2 -0
  379. package/lib-es/logic/isTestnet.d.ts.map +1 -0
  380. package/lib-es/logic/isTestnet.js +5 -0
  381. package/lib-es/logic/isTestnet.js.map +1 -0
  382. package/lib-es/logic/isWriteSetChangeWriteResource.d.ts +3 -0
  383. package/lib-es/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
  384. package/lib-es/logic/isWriteSetChangeWriteResource.js +4 -0
  385. package/lib-es/logic/isWriteSetChangeWriteResource.js.map +1 -0
  386. package/lib-es/logic/normalizeAddress.d.ts +2 -0
  387. package/lib-es/logic/normalizeAddress.d.ts.map +1 -0
  388. package/lib-es/logic/normalizeAddress.js +8 -0
  389. package/lib-es/logic/normalizeAddress.js.map +1 -0
  390. package/lib-es/logic/normalizeTransactionOptions.d.ts +3 -0
  391. package/lib-es/logic/normalizeTransactionOptions.d.ts.map +1 -0
  392. package/lib-es/logic/normalizeTransactionOptions.js +17 -0
  393. package/lib-es/logic/normalizeTransactionOptions.js.map +1 -0
  394. package/lib-es/logic/processRecipients.d.ts +6 -0
  395. package/lib-es/logic/processRecipients.d.ts.map +1 -0
  396. package/lib-es/logic/processRecipients.js +54 -0
  397. package/lib-es/logic/processRecipients.js.map +1 -0
  398. package/lib-es/logic/transactionsToOperations.d.ts +7 -0
  399. package/lib-es/logic/transactionsToOperations.d.ts.map +1 -0
  400. package/lib-es/logic/transactionsToOperations.js +81 -0
  401. package/lib-es/logic/transactionsToOperations.js.map +1 -0
  402. package/lib-es/network/client.d.ts +38 -0
  403. package/lib-es/network/client.d.ts.map +1 -0
  404. package/lib-es/network/client.js +276 -0
  405. package/lib-es/network/client.js.map +1 -0
  406. package/lib-es/network/graphql/queries.d.ts.map +1 -0
  407. package/lib-es/{api → network}/graphql/queries.js +6 -6
  408. package/lib-es/network/graphql/queries.js.map +1 -0
  409. package/lib-es/{api → network}/graphql/types.d.ts +9 -9
  410. package/lib-es/network/graphql/types.d.ts.map +1 -0
  411. package/lib-es/{api → network}/graphql/types.js.map +1 -1
  412. package/lib-es/network/index.d.ts +2 -1
  413. package/lib-es/network/index.d.ts.map +1 -1
  414. package/lib-es/network/index.js +6 -8
  415. package/lib-es/network/index.js.map +1 -1
  416. package/lib-es/test/bot-specs.d.ts.map +1 -1
  417. package/lib-es/test/bot-specs.js +41 -2
  418. package/lib-es/test/bot-specs.js.map +1 -1
  419. package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -1
  420. package/lib-es/test/bridgeDatasetTest.js +44 -59
  421. package/lib-es/test/bridgeDatasetTest.js.map +1 -1
  422. package/lib-es/test/speculos-deviceActions.d.ts +1 -0
  423. package/lib-es/test/speculos-deviceActions.d.ts.map +1 -1
  424. package/lib-es/test/speculos-deviceActions.js +36 -4
  425. package/lib-es/test/speculos-deviceActions.js.map +1 -1
  426. package/lib-es/types/assets.d.ts +16 -0
  427. package/lib-es/types/assets.d.ts.map +1 -0
  428. package/lib-es/types/assets.js +2 -0
  429. package/lib-es/types/assets.js.map +1 -0
  430. package/lib-es/types/index.d.ts +22 -7
  431. package/lib-es/types/index.d.ts.map +1 -1
  432. package/package.json +16 -13
  433. package/src/__tests__/api/craftTransaction.unit.test.ts +243 -0
  434. package/src/__tests__/api/getBalance.unit.test.ts +44 -0
  435. package/src/__tests__/api/index.integ.test.ts +401 -0
  436. package/src/__tests__/api/index.test.ts +60 -477
  437. package/src/__tests__/bridge/broadcast.test.ts +2 -2
  438. package/src/__tests__/bridge/getFeesForTransaction.test.ts +146 -11
  439. package/src/__tests__/bridge/getTransactionStatus.test.ts +217 -38
  440. package/src/__tests__/bridge/logic.test.ts +728 -569
  441. package/src/__tests__/bridge/prepareTransaction.test.ts +2 -2
  442. package/src/__tests__/bridge/signOperation.test.ts +153 -15
  443. package/src/__tests__/bridge/synchronisation.test.ts +1265 -71
  444. package/src/__tests__/index.test.ts +1 -1
  445. package/src/__tests__/logic/buildTransaction.test.ts +150 -0
  446. package/src/__tests__/logic/calculateAmount.unit.test.ts +51 -0
  447. package/src/__tests__/logic/combine.unit.test.ts +65 -0
  448. package/src/__tests__/logic/compareAddress.unit.test.ts +27 -0
  449. package/src/__tests__/{bridge → logic}/createTransaction.test.ts +2 -2
  450. package/src/__tests__/logic/getCoinAndAmounts.unit.test.ts +195 -0
  451. package/src/__tests__/logic/getFunctionAddress.unit.test.ts +33 -0
  452. package/src/__tests__/logic/getResourceAddress.unit.test.ts +241 -0
  453. package/src/__tests__/logic/isTestnet.unit.test.ts +11 -0
  454. package/src/__tests__/logic/normalizeAddress.unit.test.ts +15 -0
  455. package/src/__tests__/logic/processRecipients.unit.test.ts +95 -0
  456. package/src/__tests__/network/client.test.ts +1257 -0
  457. package/src/api/index.ts +29 -224
  458. package/src/bridge/bridge.fixture.ts +91 -12
  459. package/src/bridge/broadcast.ts +7 -7
  460. package/src/bridge/estimateMaxSpendable.ts +4 -3
  461. package/src/bridge/getFeesForTransaction.ts +17 -11
  462. package/src/bridge/getTransactionStatus.ts +35 -13
  463. package/src/bridge/index.ts +2 -2
  464. package/src/bridge/logic.ts +58 -194
  465. package/src/bridge/prepareTransaction.ts +7 -4
  466. package/src/bridge/signOperation.ts +21 -5
  467. package/src/bridge/synchronisation.ts +171 -4
  468. package/src/config.ts +19 -0
  469. package/src/constants.ts +22 -2
  470. package/src/logic/buildTransaction.ts +70 -0
  471. package/src/logic/calculateAmount.ts +15 -0
  472. package/src/logic/combine.ts +51 -0
  473. package/src/logic/craftTransaction.ts +65 -0
  474. package/src/{bridge → logic}/createTransaction.ts +1 -1
  475. package/src/logic/getBalance.ts +15 -0
  476. package/src/logic/getCoinAndAmounts.ts +141 -0
  477. package/src/logic/getFunctionAddress.ts +9 -0
  478. package/src/logic/getResourceAddress.ts +24 -0
  479. package/src/logic/isTestnet.ts +5 -0
  480. package/src/logic/isWriteSetChangeWriteResource.ts +7 -0
  481. package/src/logic/normalizeAddress.ts +8 -0
  482. package/src/logic/normalizeTransactionOptions.ts +18 -0
  483. package/src/logic/processRecipients.ts +88 -0
  484. package/src/logic/transactionsToOperations.ts +106 -0
  485. package/src/network/client.ts +374 -0
  486. package/src/{api → network}/graphql/queries.ts +6 -6
  487. package/src/{api → network}/graphql/types.ts +9 -9
  488. package/src/network/index.ts +6 -14
  489. package/src/test/bot-specs.ts +63 -3
  490. package/src/test/bridgeDatasetTest.ts +46 -59
  491. package/src/test/speculos-deviceActions.ts +40 -4
  492. package/src/types/assets.ts +20 -0
  493. package/src/types/index.ts +20 -1
  494. package/lib/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
  495. package/lib/__tests__/bridge/buildTransaction.test.js +0 -53
  496. package/lib/__tests__/bridge/buildTransaction.test.js.map +0 -1
  497. package/lib/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
  498. package/lib/__tests__/bridge/createTransaction.test.js.map +0 -1
  499. package/lib/api/graphql/queries.d.ts.map +0 -1
  500. package/lib/api/graphql/queries.js.map +0 -1
  501. package/lib/api/graphql/types.d.ts.map +0 -1
  502. package/lib/bridge/buildTransaction.d.ts +0 -7
  503. package/lib/bridge/buildTransaction.d.ts.map +0 -1
  504. package/lib/bridge/buildTransaction.js +0 -19
  505. package/lib/bridge/buildTransaction.js.map +0 -1
  506. package/lib/bridge/createTransaction.d.ts.map +0 -1
  507. package/lib/bridge/createTransaction.js.map +0 -1
  508. package/lib-es/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
  509. package/lib-es/__tests__/bridge/buildTransaction.test.js +0 -48
  510. package/lib-es/__tests__/bridge/buildTransaction.test.js.map +0 -1
  511. package/lib-es/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
  512. package/lib-es/__tests__/bridge/createTransaction.test.js.map +0 -1
  513. package/lib-es/api/graphql/queries.d.ts.map +0 -1
  514. package/lib-es/api/graphql/queries.js.map +0 -1
  515. package/lib-es/api/graphql/types.d.ts.map +0 -1
  516. package/lib-es/bridge/buildTransaction.d.ts +0 -7
  517. package/lib-es/bridge/buildTransaction.d.ts.map +0 -1
  518. package/lib-es/bridge/buildTransaction.js +0 -17
  519. package/lib-es/bridge/buildTransaction.js.map +0 -1
  520. package/lib-es/bridge/createTransaction.d.ts.map +0 -1
  521. package/lib-es/bridge/createTransaction.js.map +0 -1
  522. package/src/__tests__/bridge/buildTransaction.test.ts +0 -61
  523. package/src/bridge/buildTransaction.ts +0 -29
  524. /package/lib/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
  525. /package/lib/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
  526. /package/lib/{bridge → logic}/createTransaction.d.ts +0 -0
  527. /package/lib/{api → network}/graphql/queries.d.ts +0 -0
  528. /package/lib/{api → network}/graphql/types.js +0 -0
  529. /package/lib-es/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
  530. /package/lib-es/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
  531. /package/lib-es/{bridge → logic}/createTransaction.d.ts +0 -0
  532. /package/lib-es/{api → network}/graphql/queries.d.ts +0 -0
  533. /package/lib-es/{api → network}/graphql/types.js +0 -0
@@ -0,0 +1,374 @@
1
+ import { ApolloClient, InMemoryCache } from "@apollo/client";
2
+
3
+ import {
4
+ type AccountData,
5
+ Aptos,
6
+ AptosConfig,
7
+ Ed25519PublicKey,
8
+ type GasEstimation,
9
+ type InputEntryFunctionData,
10
+ type InputGenerateTransactionOptions,
11
+ MimeType,
12
+ type RawTransaction,
13
+ type SimpleTransaction,
14
+ type TransactionResponse,
15
+ type UserTransactionResponse,
16
+ type Block,
17
+ type AptosSettings,
18
+ Hex,
19
+ postAptosFullNode,
20
+ type PendingTransactionResponse,
21
+ } from "@aptos-labs/ts-sdk";
22
+ import { getEnv } from "@ledgerhq/live-env";
23
+ import network from "@ledgerhq/live-network";
24
+ import BigNumber from "bignumber.js";
25
+ import isUndefined from "lodash/isUndefined";
26
+ import {
27
+ APTOS_ASSET_ID,
28
+ DEFAULT_GAS,
29
+ DEFAULT_GAS_PRICE,
30
+ ESTIMATE_GAS_MUL,
31
+ TOKEN_TYPE,
32
+ } from "../constants";
33
+ import type { AptosBalance, AptosTransaction, TransactionOptions } from "../types";
34
+ import { GetAccountTransactionsData, GetAccountTransactionsDataGt } from "./graphql/queries";
35
+ import type {
36
+ GetAccountTransactionsDataQuery,
37
+ GetAccountTransactionsDataGtQueryVariables,
38
+ } from "./graphql/types";
39
+ import { TokenCurrency } from "@ledgerhq/types-cryptoassets";
40
+ import {
41
+ BlockInfo,
42
+ FeeEstimation,
43
+ Operation,
44
+ Pagination,
45
+ TransactionIntent,
46
+ } from "@ledgerhq/coin-framework/api/types";
47
+ import { AptosAsset, AptosExtra, AptosFeeParameters, AptosSender } from "../types/assets";
48
+ import { log } from "@ledgerhq/logs";
49
+ import { transactionsToOperations } from "../logic/transactionsToOperations";
50
+ import { isTestnet } from "../logic/isTestnet";
51
+ import { normalizeAddress } from "../logic/normalizeAddress";
52
+
53
+ const getApiEndpoint = (currencyId: string) =>
54
+ isTestnet(currencyId) ? getEnv("APTOS_TESTNET_API_ENDPOINT") : getEnv("APTOS_API_ENDPOINT");
55
+ const getIndexerEndpoint = (currencyId: string) =>
56
+ isTestnet(currencyId)
57
+ ? getEnv("APTOS_TESTNET_INDEXER_ENDPOINT")
58
+ : getEnv("APTOS_INDEXER_ENDPOINT");
59
+
60
+ export class AptosAPI {
61
+ private readonly aptosConfig: AptosConfig;
62
+ private readonly aptosClient: Aptos;
63
+ private readonly apolloClient: ApolloClient<object>;
64
+
65
+ constructor(currencyIdOrSettings: AptosSettings | string) {
66
+ if (typeof currencyIdOrSettings === "string") {
67
+ this.aptosConfig = new AptosConfig({
68
+ fullnode: getApiEndpoint(currencyIdOrSettings),
69
+ indexer: getIndexerEndpoint(currencyIdOrSettings),
70
+ });
71
+ } else {
72
+ this.aptosConfig = new AptosConfig(currencyIdOrSettings);
73
+ }
74
+
75
+ this.aptosClient = new Aptos(this.aptosConfig);
76
+ this.apolloClient = new ApolloClient({
77
+ uri: this.aptosConfig.indexer ?? "",
78
+ cache: new InMemoryCache(),
79
+ headers: {
80
+ "x-client": "ledger-live",
81
+ },
82
+ });
83
+ }
84
+
85
+ async getAccount(address: string): Promise<AccountData> {
86
+ return this.aptosClient.getAccountInfo({ accountAddress: address });
87
+ }
88
+
89
+ async getAccountInfo(address: string, startAt?: string) {
90
+ const [balance, transactions, blockHeight] = await Promise.all([
91
+ this.getCoinBalance(address, APTOS_ASSET_ID),
92
+ this.fetchTransactions(address, startAt),
93
+ this.getHeight(),
94
+ ]);
95
+
96
+ return {
97
+ balance,
98
+ transactions,
99
+ blockHeight,
100
+ };
101
+ }
102
+
103
+ async estimateGasPrice(): Promise<GasEstimation> {
104
+ return this.aptosClient.getGasPriceEstimation();
105
+ }
106
+
107
+ async generateTransaction(
108
+ address: string,
109
+ payload: InputEntryFunctionData,
110
+ options: TransactionOptions,
111
+ ): Promise<RawTransaction> {
112
+ const opts: Partial<InputGenerateTransactionOptions> = {};
113
+ if (!isUndefined(options.maxGasAmount)) {
114
+ opts.maxGasAmount = Number(options.maxGasAmount);
115
+ }
116
+
117
+ if (!isUndefined(options.gasUnitPrice)) {
118
+ opts.gasUnitPrice = Number(options.gasUnitPrice);
119
+ }
120
+
121
+ try {
122
+ const { ledger_timestamp } = await this.aptosClient.getLedgerInfo();
123
+ opts.expireTimestamp = Number(Math.ceil(+ledger_timestamp / 1_000_000 + 2 * 60)); // in milliseconds
124
+ } catch {
125
+ // skip
126
+ }
127
+
128
+ return this.aptosClient.transaction.build
129
+ .simple({
130
+ sender: address,
131
+ data: payload,
132
+ options: opts,
133
+ })
134
+ .then(t => t.rawTransaction)
135
+ .catch(error => {
136
+ throw error;
137
+ });
138
+ }
139
+
140
+ async simulateTransaction(
141
+ address: Ed25519PublicKey,
142
+ tx: RawTransaction,
143
+ options = {
144
+ estimateGasUnitPrice: true,
145
+ estimateMaxGasAmount: true,
146
+ estimatePrioritizedGasUnitPrice: false,
147
+ },
148
+ ): Promise<UserTransactionResponse[]> {
149
+ return this.aptosClient.transaction.simulate.simple({
150
+ signerPublicKey: address,
151
+ transaction: { rawTransaction: tx } as SimpleTransaction,
152
+ options,
153
+ });
154
+ }
155
+
156
+ async broadcast(tx: string): Promise<string> {
157
+ const txBytes = Hex.fromHexString(tx).toUint8Array();
158
+
159
+ const pendingTx = await postAptosFullNode<Uint8Array, PendingTransactionResponse>({
160
+ aptosConfig: this.aptosClient.config,
161
+ body: txBytes,
162
+ path: "transactions",
163
+ originMethod: "",
164
+ contentType: MimeType.BCS_SIGNED_TRANSACTION,
165
+ });
166
+
167
+ return pendingTx.data.hash;
168
+ }
169
+
170
+ async getBalance(address: string, token: TokenCurrency): Promise<BigNumber> {
171
+ if (token.tokenType === "coin") {
172
+ return await this.getCoinBalance(address, token.contractAddress);
173
+ }
174
+
175
+ return await this.getFABalance(address, token.contractAddress);
176
+ }
177
+
178
+ async getLastBlock(): Promise<BlockInfo> {
179
+ const { block_height } = await this.aptosClient.getLedgerInfo();
180
+ const block = await this.aptosClient.getBlockByHeight({ blockHeight: Number(block_height) });
181
+ return {
182
+ height: Number(block.block_height),
183
+ hash: block.block_hash,
184
+ time: new Date(Number(block.block_timestamp) / 1_000),
185
+ };
186
+ }
187
+
188
+ async getCoinBalance(address: string, contract_address: string): Promise<BigNumber> {
189
+ try {
190
+ const [balanceStr] = await this.aptosClient.view<[string]>({
191
+ payload: {
192
+ function: "0x1::coin::balance",
193
+ typeArguments: [contract_address],
194
+ functionArguments: [address],
195
+ },
196
+ });
197
+ const balance = parseInt(balanceStr, 10);
198
+ return new BigNumber(balance);
199
+ } catch (error) {
200
+ log("error", "getCoinBalance", {
201
+ error,
202
+ });
203
+ return new BigNumber(0);
204
+ }
205
+ }
206
+
207
+ async getFABalance(address: string, contract_address: string): Promise<BigNumber> {
208
+ try {
209
+ const [balanceStr] = await this.aptosClient.view<[string]>({
210
+ payload: {
211
+ function: "0x1::primary_fungible_store::balance",
212
+ typeArguments: ["0x1::object::ObjectCore"],
213
+ functionArguments: [address, contract_address],
214
+ },
215
+ });
216
+ const balance = parseInt(balanceStr, 10);
217
+ return new BigNumber(balance);
218
+ } catch (error) {
219
+ log("error", "getFABalance", {
220
+ error,
221
+ });
222
+ return new BigNumber(0);
223
+ }
224
+ }
225
+
226
+ async estimateFees(
227
+ transactionIntent: TransactionIntent<AptosAsset, AptosExtra, AptosSender>,
228
+ ): Promise<FeeEstimation<AptosFeeParameters>> {
229
+ const publicKeyEd = new Ed25519PublicKey(transactionIntent.sender.xpub);
230
+
231
+ const txPayload: InputEntryFunctionData = {
232
+ function: "0x1::aptos_account::transfer_coins",
233
+ typeArguments: [APTOS_ASSET_ID],
234
+ functionArguments: [transactionIntent.recipient, transactionIntent.amount],
235
+ };
236
+
237
+ if (transactionIntent.asset.type === "token") {
238
+ const { standard } = transactionIntent.asset;
239
+
240
+ if (standard === TOKEN_TYPE.FUNGIBLE_ASSET) {
241
+ txPayload.function = "0x1::primary_fungible_store::transfer";
242
+ txPayload.typeArguments = ["0x1::fungible_asset::Metadata"];
243
+ txPayload.functionArguments = [
244
+ transactionIntent.asset.contractAddress,
245
+ transactionIntent.recipient,
246
+ transactionIntent.amount,
247
+ ];
248
+ } else if (standard === TOKEN_TYPE.COIN) {
249
+ txPayload.function = "0x1::aptos_account::transfer_coins";
250
+ txPayload.typeArguments = [transactionIntent.asset.contractAddress];
251
+ }
252
+ }
253
+
254
+ const txOptions: TransactionOptions = {
255
+ maxGasAmount: DEFAULT_GAS.toString(),
256
+ gasUnitPrice: DEFAULT_GAS_PRICE.toString(),
257
+ };
258
+
259
+ const tx = await this.generateTransaction(
260
+ transactionIntent.sender.freshAddress,
261
+ txPayload,
262
+ txOptions,
263
+ );
264
+
265
+ const simulation = await this.simulateTransaction(publicKeyEd, tx);
266
+ const completedTx = simulation[0];
267
+
268
+ const gasLimit = new BigNumber(completedTx.gas_used).multipliedBy(ESTIMATE_GAS_MUL);
269
+ const gasPrice = new BigNumber(completedTx.gas_unit_price);
270
+
271
+ const expectedGas = gasPrice.multipliedBy(gasLimit);
272
+
273
+ return {
274
+ value: BigInt(expectedGas.toString()),
275
+ parameters: {
276
+ gasLimit: BigInt(gasLimit.toString()),
277
+ gasPrice: BigInt(gasPrice.toString()),
278
+ },
279
+ };
280
+ }
281
+
282
+ async listOperations(
283
+ rawAddress: string,
284
+ pagination: Pagination,
285
+ ): Promise<[Operation<AptosAsset>[], string]> {
286
+ const address = normalizeAddress(rawAddress);
287
+ const transactions = await this.getAccountInfo(address, pagination.minHeight.toString());
288
+ const newOperations = transactionsToOperations(address, transactions.transactions);
289
+
290
+ return [newOperations, ""];
291
+ }
292
+
293
+ private async fetchTransactions(address: string, gt?: string) {
294
+ if (!address) {
295
+ return [];
296
+ }
297
+
298
+ let query = GetAccountTransactionsData;
299
+ if (gt) {
300
+ query = GetAccountTransactionsDataGt;
301
+ }
302
+
303
+ const queryResponse = await this.apolloClient.query<
304
+ GetAccountTransactionsDataQuery,
305
+ GetAccountTransactionsDataGtQueryVariables
306
+ >({
307
+ query,
308
+ variables: {
309
+ address,
310
+ limit: 1000,
311
+ gt,
312
+ },
313
+ fetchPolicy: "network-only",
314
+ });
315
+
316
+ return Promise.all(
317
+ queryResponse.data.account_transactions.map(({ transaction_version }) => {
318
+ return this.richItemByVersion(transaction_version);
319
+ }),
320
+ );
321
+ }
322
+
323
+ private async richItemByVersion(version: number): Promise<AptosTransaction | null> {
324
+ try {
325
+ const tx: TransactionResponse = await this.aptosClient.getTransactionByVersion({
326
+ ledgerVersion: version,
327
+ });
328
+ const block = await this.getBlock(version);
329
+ return {
330
+ ...tx,
331
+ block,
332
+ } as AptosTransaction;
333
+ } catch (error) {
334
+ log("error", "richItemByVersion", {
335
+ error,
336
+ });
337
+ return null;
338
+ }
339
+ }
340
+
341
+ private async getHeight(): Promise<number> {
342
+ const { data } = await network<Block>({
343
+ method: "GET",
344
+ url: this.aptosConfig.fullnode ?? "",
345
+ });
346
+ return parseInt(data.block_height);
347
+ }
348
+
349
+ private async getBlock(version: number) {
350
+ const block = await this.aptosClient.getBlockByVersion({ ledgerVersion: version });
351
+ return {
352
+ height: parseInt(block.block_height),
353
+ hash: block.block_hash,
354
+ };
355
+ }
356
+
357
+ async getBalances(address: string): Promise<AptosBalance[]> {
358
+ const response = await this.aptosClient.getCurrentFungibleAssetBalances({
359
+ options: {
360
+ offset: 0,
361
+ limit: 1000,
362
+ where: {
363
+ asset_type: { _eq: APTOS_ASSET_ID }, // to return all asset balances (native / token) we should remove this filter
364
+ owner_address: { _eq: address },
365
+ },
366
+ },
367
+ });
368
+
369
+ return response.map(x => ({
370
+ contractAddress: x.asset_type ?? "-",
371
+ amount: BigNumber(x.amount),
372
+ }));
373
+ }
374
+ }
@@ -18,8 +18,8 @@ export const GetDelegatedStakingActivities = gql`
18
18
  `;
19
19
  export const GetAccountTransactionsData = gql`
20
20
  query GetAccountTransactionsData($address: String, $limit: Int) {
21
- address_version_from_move_resources(
22
- where: { address: { _eq: $address } }
21
+ account_transactions(
22
+ where: { account_address: { _eq: $address } }
23
23
  order_by: { transaction_version: desc }
24
24
  limit: $limit
25
25
  ) {
@@ -30,8 +30,8 @@ export const GetAccountTransactionsData = gql`
30
30
  `;
31
31
  export const GetAccountTransactionsDataGt = gql`
32
32
  query GetAccountTransactionsDataGt($address: String, $limit: Int, $gt: bigint) {
33
- address_version_from_move_resources(
34
- where: { address: { _eq: $address }, transaction_version: { _gt: $gt } }
33
+ account_transactions(
34
+ where: { account_address: { _eq: $address }, transaction_version: { _gt: $gt } }
35
35
  order_by: { transaction_version: desc }
36
36
  limit: $limit
37
37
  ) {
@@ -42,8 +42,8 @@ export const GetAccountTransactionsDataGt = gql`
42
42
  `;
43
43
  export const GetAccountTransactionsDataLt = gql`
44
44
  query GetAccountTransactionsDataLt($address: String, $limit: Int, $lt: bigint) {
45
- address_version_from_move_resources(
46
- where: { address: { _eq: $address }, transaction_version: { _lt: $lt } }
45
+ account_transactions(
46
+ where: { account_address: { _eq: $address }, transaction_version: { _lt: $lt } }
47
47
  order_by: { transaction_version: desc }
48
48
  limit: $limit
49
49
  ) {
@@ -22,9 +22,9 @@ export type GetAccountTransactionsDataQueryVariables = Exact<{
22
22
 
23
23
  export type GetAccountTransactionsDataQuery = {
24
24
  __typename?: "query_root";
25
- address_version_from_move_resources: Array<{
26
- __typename: "address_version_from_move_resources";
27
- transaction_version?: any | null;
25
+ account_transactions: Array<{
26
+ __typename?: "account_transactions";
27
+ transaction_version: number;
28
28
  }>;
29
29
  };
30
30
 
@@ -36,9 +36,9 @@ export type GetAccountTransactionsDataGtQueryVariables = Exact<{
36
36
 
37
37
  export type GetAccountTransactionsDataGtQuery = {
38
38
  __typename?: "query_root";
39
- address_version_from_move_resources: Array<{
40
- __typename: "address_version_from_move_resources";
41
- transaction_version?: any | null;
39
+ account_transactions: Array<{
40
+ __typename?: "account_transactions";
41
+ transaction_version: number;
42
42
  }>;
43
43
  };
44
44
 
@@ -50,9 +50,9 @@ export type GetAccountTransactionsDataLtQueryVariables = Exact<{
50
50
 
51
51
  export type GetAccountTransactionsDataLtQuery = {
52
52
  __typename?: "query_root";
53
- address_version_from_move_resources: Array<{
54
- __typename: "address_version_from_move_resources";
55
- transaction_version?: any | null;
53
+ account_transactions: Array<{
54
+ __typename?: "account_transactions";
55
+ transaction_version: number;
56
56
  }>;
57
57
  };
58
58
 
@@ -1,18 +1,17 @@
1
1
  import {
2
2
  AccountAddress,
3
- AccountAuthenticatorEd25519,
4
3
  Ed25519PublicKey,
5
4
  Ed25519Signature,
6
- generateSignedTransaction,
7
5
  generateSigningMessageForTransaction,
8
- Hex,
9
6
  RawTransaction,
10
7
  SimpleTransaction,
11
8
  } from "@aptos-labs/ts-sdk";
12
- import { SignerContext } from "@ledgerhq/coin-framework/lib/signer";
9
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
13
10
  import { Account } from "@ledgerhq/types-live";
14
11
  import { AptosSigner } from "../types";
15
12
  import { sha3_256 as sha3Hash } from "@noble/hashes/sha3";
13
+ import { combineSignedTransaction } from "../logic/combine";
14
+ export * from "./client";
16
15
 
17
16
  export async function signTransaction(
18
17
  signerContext: SignerContext<AptosSigner>,
@@ -40,15 +39,8 @@ export async function signTransaction(
40
39
  async signer => await signer.signTransaction(derivationPath, Buffer.from(signingMessage)),
41
40
  );
42
41
 
43
- const sigHexStr = Hex.fromHexString(response.signature.toString("hex"));
44
- const signature = new Ed25519Signature(sigHexStr.toUint8Array());
45
- const authenticator = new AccountAuthenticatorEd25519(
46
- new Ed25519PublicKey(publicKey.toString("hex")),
47
- signature,
48
- );
42
+ const signature = new Ed25519Signature(response.signature.toString("hex"));
43
+ const pubkey = new Ed25519PublicKey(publicKey.toString("hex"));
49
44
 
50
- return generateSignedTransaction({
51
- transaction: { rawTransaction: rawTxn } as SimpleTransaction,
52
- senderAuthenticator: authenticator,
53
- });
45
+ return combineSignedTransaction(rawTxn, signature, pubkey);
54
46
  }
@@ -5,8 +5,9 @@ import BigNumber from "bignumber.js";
5
5
  import type { Transaction } from "../types";
6
6
  import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets/currencies";
7
7
  import { genericTestDestination, pickSiblings, botTest } from "@ledgerhq/coin-framework/bot/specs";
8
- import type { AppSpec } from "@ledgerhq/coin-framework/bot/types";
9
- import { acceptTransaction } from "./speculos-deviceActions";
8
+ import type { AppSpec, TransactionTestInput } from "@ledgerhq/coin-framework/bot/types";
9
+ import { acceptTokenTransaction, acceptTransaction } from "./speculos-deviceActions";
10
+ import { Account, TokenAccount } from "@ledgerhq/types-live";
10
11
 
11
12
  const MIN_SAFE = new BigNumber(0.0001);
12
13
  const maxAccount = 6;
@@ -19,7 +20,7 @@ const aptosSpecs: AppSpec<Transaction> = {
19
20
  appName: "Aptos",
20
21
  },
21
22
  genericDeviceAction: acceptTransaction,
22
- testTimeout: 6 * 60 * 1000,
23
+ testTimeout: 2 * 60 * 1000,
23
24
  minViableAmount: MIN_SAFE,
24
25
  transactionCheck: ({ maxSpendable }) => {
25
26
  invariant(maxSpendable.gt(MIN_SAFE), "balance is too low");
@@ -84,9 +85,68 @@ const aptosSpecs: AppSpec<Transaction> = {
84
85
  );
85
86
  },
86
87
  },
88
+ {
89
+ name: "Send ~50% of token amount",
90
+ feature: "tokens",
91
+ maxRun: 1,
92
+ deviceAction: acceptTokenTransaction,
93
+ transaction: ({ account, bridge, siblings, maxSpendable }) => {
94
+ invariant(maxSpendable.gt(MIN_SAFE), "Balance is too low");
95
+
96
+ const senderTokenAcc = findTokenSubAccountWithBalance(account);
97
+ invariant(senderTokenAcc, "Sender token account with available balance not found");
98
+
99
+ const sibling = pickSiblings(siblings, maxAccount);
100
+
101
+ const recipientTokenAcc = findTokenSubAccountWithBalance(sibling);
102
+ invariant(recipientTokenAcc, "Receiver token account with available balance not found");
103
+
104
+ const amount = senderTokenAcc.spendableBalance.div(2).integerValue();
105
+ const recipient = sibling.freshAddress;
106
+ const transaction = bridge.createTransaction(account);
107
+ const subAccountId = senderTokenAcc.id;
108
+
109
+ return {
110
+ transaction,
111
+ updates: [{ subAccountId }, { recipient }, { amount }],
112
+ };
113
+ },
114
+ test: input => {
115
+ expectTokenAccountCorrectBalanceChange(input);
116
+ },
117
+ },
87
118
  ],
88
119
  };
89
120
 
121
+ function findTokenSubAccountWithBalance(account: Account) {
122
+ return account.subAccounts?.find(acc => acc.type === "TokenAccount" && acc.balance.gt(0)) as
123
+ | TokenAccount
124
+ | undefined;
125
+ }
126
+
127
+ function expectTokenAccountCorrectBalanceChange({
128
+ account,
129
+ accountBeforeTransaction,
130
+ status,
131
+ transaction,
132
+ }: TransactionTestInput<Transaction>) {
133
+ const tokenAccId = transaction.subAccountId;
134
+ if (!tokenAccId) throw new Error("Wrong subAccountId");
135
+
136
+ const tokenAccAfterTx = account.subAccounts?.find(acc => acc.id === tokenAccId);
137
+ const tokenAccBeforeTx = accountBeforeTransaction.subAccounts?.find(acc => acc.id === tokenAccId);
138
+
139
+ if (!tokenAccAfterTx || !tokenAccBeforeTx) {
140
+ throw new Error("Token sub accounts not found!");
141
+ }
142
+
143
+ botTest("Token balance decreased with operation", () =>
144
+ expect(tokenAccAfterTx.balance.toString()).toBe(
145
+ tokenAccBeforeTx.balance.minus(status.amount).toString(),
146
+ ),
147
+ );
148
+ }
149
+
90
150
  export default {
91
151
  aptosSpecs,
92
152
  };