@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,70 @@
1
+ import type { InputEntryFunctionData, RawTransaction } from "@aptos-labs/ts-sdk";
2
+ import type { Account } from "@ledgerhq/types-live";
3
+ import { findSubAccountById } from "@ledgerhq/coin-framework/account/index";
4
+ import { APTOS_ASSET_ID, TOKEN_TYPE } from "../constants";
5
+ import type { AptosAPI } from "../network";
6
+ import { normalizeTransactionOptions } from "./normalizeTransactionOptions";
7
+ import type { Transaction } from "../types";
8
+ import type BigNumber from "bignumber.js";
9
+
10
+ const buildTransaction = async (
11
+ account: Account,
12
+ transaction: Transaction,
13
+ aptosClient: AptosAPI,
14
+ contractAddress?: string,
15
+ tokenType?: TOKEN_TYPE,
16
+ ): Promise<RawTransaction> => {
17
+ const subAccount = findSubAccountById(account, transaction.subAccountId ?? "");
18
+
19
+ const payloadContracAddress = subAccount ? subAccount.token.contractAddress : contractAddress;
20
+ const payloadTokenType = (subAccount?.token?.tokenType as TOKEN_TYPE) ?? tokenType;
21
+
22
+ const txPayload = getPayload({
23
+ amount: transaction.amount,
24
+ recipient: transaction.recipient,
25
+ contractAddress: payloadContracAddress,
26
+ tokenType: payloadTokenType,
27
+ });
28
+
29
+ const txOptions = normalizeTransactionOptions(transaction.options);
30
+
31
+ const tx = await aptosClient.generateTransaction(account.freshAddress, txPayload, txOptions);
32
+
33
+ return tx;
34
+ };
35
+
36
+ const getPayload = (args: {
37
+ amount: BigNumber;
38
+ recipient: string;
39
+ contractAddress?: string | undefined;
40
+ tokenType?: string;
41
+ }): InputEntryFunctionData => {
42
+ if (args.tokenType !== undefined && !isTokenType(args.tokenType)) {
43
+ throw new Error(`Token type ${args.tokenType} not supported`);
44
+ }
45
+
46
+ if (args.tokenType === TOKEN_TYPE.FUNGIBLE_ASSET) {
47
+ return {
48
+ function: "0x1::primary_fungible_store::transfer",
49
+ typeArguments: ["0x1::fungible_asset::Metadata"],
50
+ functionArguments: [args.contractAddress, args.recipient, args.amount.toString()],
51
+ };
52
+ }
53
+
54
+ let address = args.contractAddress ?? "";
55
+ if (address === "") {
56
+ address = APTOS_ASSET_ID;
57
+ }
58
+
59
+ return {
60
+ function: "0x1::aptos_account::transfer_coins",
61
+ typeArguments: [address],
62
+ functionArguments: [args.recipient, args.amount.toString()],
63
+ };
64
+ };
65
+
66
+ export const isTokenType = (value: string): boolean => {
67
+ return Object.values(TOKEN_TYPE).includes(value as TOKEN_TYPE);
68
+ };
69
+
70
+ export default buildTransaction;
@@ -0,0 +1,15 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { compareAddress } from "./getCoinAndAmounts";
3
+
4
+ export function calculateAmount(
5
+ sender: string,
6
+ address: string,
7
+ amount_in: BigNumber,
8
+ amount_out: BigNumber,
9
+ ): BigNumber {
10
+ const is_sender: boolean = compareAddress(sender, address);
11
+ // LL negates the amount for SEND transactions
12
+ // to show positive amount on the send transaction (ex: in "cancel" tx, when amount will be returned to our account)
13
+ // we need to make it negative
14
+ return is_sender ? amount_out.minus(amount_in) : amount_in.minus(amount_out);
15
+ }
@@ -0,0 +1,51 @@
1
+ import {
2
+ AccountAuthenticatorEd25519,
3
+ Deserializer,
4
+ Ed25519PublicKey,
5
+ Ed25519Signature,
6
+ Hex,
7
+ RawTransaction,
8
+ type SimpleTransaction,
9
+ generateSignedTransaction,
10
+ } from "@aptos-labs/ts-sdk";
11
+
12
+ export function combineSignedTransaction(
13
+ txRaw: RawTransaction,
14
+ signature: Ed25519Signature,
15
+ pubkey: Ed25519PublicKey,
16
+ ): Uint8Array {
17
+ const authenticator = new AccountAuthenticatorEd25519(pubkey, signature);
18
+
19
+ return generateSignedTransaction({
20
+ transaction: { rawTransaction: txRaw } as SimpleTransaction,
21
+ senderAuthenticator: authenticator,
22
+ });
23
+ }
24
+
25
+ export function combine(tx: string, signature: string, pubkey?: string) {
26
+ if (!Hex.isValid(tx).valid) {
27
+ throw new Error("tx must be a valid hex value");
28
+ }
29
+
30
+ if (!Hex.isValid(signature).valid) {
31
+ throw new Error("signature must be a valid hex value");
32
+ }
33
+
34
+ if (pubkey === undefined) {
35
+ throw new Error("account must have a public key");
36
+ }
37
+
38
+ if (!Hex.isValid(pubkey).valid) {
39
+ throw new Error("pubkey must be a valid hex value");
40
+ }
41
+
42
+ const ed25519Signature = new Ed25519Signature(signature);
43
+ const ed25519PubKey = new Ed25519PublicKey(pubkey);
44
+
45
+ const txBytes = Hex.fromHexString(tx).toUint8Array();
46
+ const txRaw = RawTransaction.deserialize(new Deserializer(txBytes));
47
+
48
+ const signedTxBytes = combineSignedTransaction(txRaw, ed25519Signature, ed25519PubKey);
49
+
50
+ return Hex.fromHexInput(signedTxBytes).toString();
51
+ }
@@ -0,0 +1,65 @@
1
+ import type { TransactionIntent } from "@ledgerhq/coin-framework/lib/api/types";
2
+ import type { AptosAsset, AptosExtra, AptosSender } from "../types/assets";
3
+ import type { Account, TokenAccount } from "@ledgerhq/types-live";
4
+ import type { AptosAPI } from "../network";
5
+ import buildTransaction, { isTokenType } from "./buildTransaction";
6
+ import createTransaction from "./createTransaction";
7
+ import BigNumber from "bignumber.js";
8
+ import { APTOS_ASSET_ID, type TOKEN_TYPE } from "../constants";
9
+ import type { AptosBalance } from "../types";
10
+
11
+ export async function craftTransaction(
12
+ aptosClient: AptosAPI,
13
+ transactionIntent: TransactionIntent<AptosAsset, AptosExtra, AptosSender>,
14
+ ): Promise<string> {
15
+ const newTx = createTransaction();
16
+ newTx.amount = BigNumber(transactionIntent.amount.toString());
17
+ newTx.recipient = transactionIntent.recipient;
18
+ newTx.mode = transactionIntent.type;
19
+ newTx.useAllAmount = transactionIntent.amount === BigInt(0);
20
+
21
+ const account = {
22
+ freshAddress: transactionIntent.sender.freshAddress,
23
+ xpub: transactionIntent.sender.xpub,
24
+ subAccounts: new Array<TokenAccount>(),
25
+ } as Account;
26
+
27
+ let tokenType: TOKEN_TYPE | undefined;
28
+ const contractAddress = getContractAddress(transactionIntent);
29
+ let balance: AptosBalance | undefined;
30
+
31
+ if (newTx.useAllAmount === true) {
32
+ const balances = await aptosClient.getBalances(transactionIntent.sender.freshAddress);
33
+ balance = balances?.find(
34
+ b => b.contractAddress.toLowerCase() === contractAddress?.toLowerCase(),
35
+ );
36
+
37
+ if (balance !== undefined) {
38
+ newTx.amount = BigNumber(balance.amount.toString());
39
+ }
40
+ }
41
+
42
+ if (transactionIntent.asset.type === "token") {
43
+ tokenType = transactionIntent.asset.standard as TOKEN_TYPE;
44
+ }
45
+
46
+ const aptosTx = await buildTransaction(
47
+ account,
48
+ newTx,
49
+ aptosClient,
50
+ contractAddress,
51
+ tokenType ?? undefined,
52
+ );
53
+
54
+ return aptosTx.bcsToHex().toString();
55
+ }
56
+
57
+ function getContractAddress(
58
+ txIntent: TransactionIntent<AptosAsset, AptosExtra, AptosSender>,
59
+ ): string {
60
+ if (txIntent.asset.type === "token" && isTokenType(txIntent.asset.standard)) {
61
+ return txIntent.asset.contractAddress;
62
+ }
63
+
64
+ return APTOS_ASSET_ID;
65
+ }
@@ -1,6 +1,6 @@
1
1
  import BigNumber from "bignumber.js";
2
2
  import type { Transaction } from "../types";
3
- import { DEFAULT_GAS, DEFAULT_GAS_PRICE } from "./logic";
3
+ import { DEFAULT_GAS, DEFAULT_GAS_PRICE } from "../constants";
4
4
 
5
5
  const createTransaction = (): Transaction => ({
6
6
  family: "aptos",
@@ -0,0 +1,15 @@
1
+ import type { Balance } from "@ledgerhq/coin-framework/lib/api/types";
2
+ import type { AptosAsset } from "../types/assets";
3
+ import type { AptosAPI } from "../network";
4
+
5
+ export async function getBalance(
6
+ aptosClient: AptosAPI,
7
+ address: string,
8
+ ): Promise<Balance<AptosAsset>[]> {
9
+ const balance = await aptosClient.getBalances(address);
10
+
11
+ return balance.map(x => ({
12
+ value: BigInt(x.amount.toString()),
13
+ asset: { type: "native" },
14
+ }));
15
+ }
@@ -0,0 +1,141 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { APTOS_ASSET_ID, APTOS_FUNGIBLE_STORE, APTOS_OBJECT_CORE } from "../constants";
3
+ import {
4
+ AptosFungibleoObjectCoreResourceData,
5
+ AptosFungibleStoreResourceData,
6
+ AptosMoveResource,
7
+ AptosTransaction,
8
+ } from "../types";
9
+ import { MoveResource, WriteSetChangeWriteResource, Event } from "@aptos-labs/ts-sdk";
10
+ import { getResourceAddress } from "./getResourceAddress";
11
+ import { isWriteSetChangeWriteResource } from "./isWriteSetChangeWriteResource";
12
+
13
+ const CLEAN_HEX_REGEXP = /^0x0*|^0+/;
14
+
15
+ export function compareAddress(addressA: string, addressB: string) {
16
+ return (
17
+ addressA.replace(CLEAN_HEX_REGEXP, "").toLowerCase() ===
18
+ addressB.replace(CLEAN_HEX_REGEXP, "").toLowerCase()
19
+ );
20
+ }
21
+
22
+ export function checkFAOwner(tx: AptosTransaction, event: Event, user_address: string): boolean {
23
+ for (const change of tx.changes) {
24
+ if (isWriteSetChangeWriteResource(change)) {
25
+ const storeData = change.data as MoveResource<AptosFungibleoObjectCoreResourceData>;
26
+ if (
27
+ change.address == event.data.store &&
28
+ storeData.type == APTOS_OBJECT_CORE &&
29
+ storeData.data.owner == user_address
30
+ ) {
31
+ return true;
32
+ }
33
+ }
34
+ }
35
+ return false;
36
+ }
37
+
38
+ /**
39
+ * Extracts the address from a string like "0x1::coin::CoinStore<address::module::type>"
40
+ * @param {string} str - The input string containing the address.
41
+ * @returns {string | null} - The extracted address or null if not found.
42
+ */
43
+ function extractAddress(str: string): string | null {
44
+ const match = /<([^<>]+)>$/.exec(str);
45
+ return match ? match[1] : null;
46
+ }
47
+
48
+ export function getEventCoinAddress(
49
+ change: WriteSetChangeWriteResource,
50
+ event: Event,
51
+ event_name: string,
52
+ ): string | null {
53
+ const change_data = change.data;
54
+
55
+ const mr = change_data as MoveResource<AptosMoveResource>; // -> this is data that we want to parse
56
+
57
+ if (!(event_name in mr.data)) {
58
+ return null;
59
+ }
60
+
61
+ const change_event_data = mr.data[event_name];
62
+ if (
63
+ change_event_data.guid.id.addr !== event.guid.account_address ||
64
+ change_event_data.guid.id.creation_num !== event.guid.creation_number
65
+ ) {
66
+ return null;
67
+ }
68
+
69
+ const address = extractAddress(mr.type);
70
+
71
+ return address;
72
+ }
73
+
74
+ export function getEventFAAddress(
75
+ change: WriteSetChangeWriteResource,
76
+ event: Event,
77
+ _event_name: string,
78
+ ): string | null {
79
+ const change_data = change.data;
80
+
81
+ if (change_data.type !== APTOS_FUNGIBLE_STORE) {
82
+ return null;
83
+ }
84
+
85
+ const mr = change_data as MoveResource<AptosFungibleStoreResourceData>;
86
+
87
+ if (change.address !== event.data.store) {
88
+ return null;
89
+ }
90
+
91
+ return mr.data.metadata.inner;
92
+ }
93
+
94
+ export function getCoinAndAmounts(
95
+ tx: AptosTransaction,
96
+ address: string,
97
+ ): { coin_id: string | null; amount_in: BigNumber; amount_out: BigNumber } {
98
+ let coin_id: string | null = null;
99
+ let amount_in = BigNumber(0);
100
+ let amount_out = BigNumber(0);
101
+
102
+ // collect all events related to the address and calculate the overall amounts
103
+ tx.events.forEach(event => {
104
+ switch (event.type) {
105
+ case "0x1::coin::WithdrawEvent":
106
+ if (compareAddress(event.guid.account_address, address)) {
107
+ coin_id = getResourceAddress(tx, event, "withdraw_events", getEventCoinAddress);
108
+ amount_out = amount_out.plus(event.data.amount);
109
+ }
110
+ break;
111
+ case "0x1::coin::DepositEvent":
112
+ if (compareAddress(event.guid.account_address, address)) {
113
+ coin_id = getResourceAddress(tx, event, "deposit_events", getEventCoinAddress);
114
+ amount_in = amount_in.plus(event.data.amount);
115
+ }
116
+ break;
117
+ case "0x1::fungible_asset::Withdraw":
118
+ if (checkFAOwner(tx, event, address)) {
119
+ coin_id = getResourceAddress(tx, event, "withdraw_events", getEventFAAddress);
120
+ amount_out = amount_out.plus(event.data.amount);
121
+ }
122
+ break;
123
+ case "0x1::fungible_asset::Deposit":
124
+ if (checkFAOwner(tx, event, address)) {
125
+ coin_id = getResourceAddress(tx, event, "deposit_events", getEventFAAddress);
126
+ amount_in = amount_in.plus(event.data.amount);
127
+ }
128
+ break;
129
+ case "0x1::transaction_fee::FeeStatement":
130
+ if (tx.sender === address) {
131
+ coin_id ??= APTOS_ASSET_ID;
132
+ if (coin_id === APTOS_ASSET_ID) {
133
+ const fees = BigNumber(tx.gas_unit_price).times(BigNumber(tx.gas_used));
134
+ amount_out = amount_out.plus(fees);
135
+ }
136
+ }
137
+ break;
138
+ }
139
+ });
140
+ return { coin_id, amount_in, amount_out };
141
+ }
@@ -0,0 +1,9 @@
1
+ import { InputEntryFunctionData } from "@aptos-labs/ts-sdk";
2
+
3
+ export function getFunctionAddress(payload: InputEntryFunctionData): string | undefined {
4
+ if (payload.function) {
5
+ const parts = payload.function.split("::");
6
+ return parts.length === 3 && parts[0].length ? parts[0] : undefined;
7
+ }
8
+ return undefined;
9
+ }
@@ -0,0 +1,24 @@
1
+ import { WriteSetChangeWriteResource, Event } from "@aptos-labs/ts-sdk";
2
+ import { AptosTransaction } from "../types";
3
+ import { isWriteSetChangeWriteResource } from "./isWriteSetChangeWriteResource";
4
+
5
+ export function getResourceAddress(
6
+ tx: AptosTransaction,
7
+ event: Event,
8
+ event_name: string,
9
+ getAddressProcessor: (
10
+ change: WriteSetChangeWriteResource,
11
+ event: Event,
12
+ event_name: string,
13
+ ) => string | null,
14
+ ): string | null {
15
+ for (const change of tx.changes) {
16
+ if (isWriteSetChangeWriteResource(change)) {
17
+ const address = getAddressProcessor(change, event, event_name);
18
+ if (address !== null) {
19
+ return address;
20
+ }
21
+ }
22
+ }
23
+ return null;
24
+ }
@@ -0,0 +1,5 @@
1
+ import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets/currencies";
2
+
3
+ export function isTestnet(currencyId: string): boolean {
4
+ return !!getCryptoCurrencyById(currencyId).isTestnetFor;
5
+ }
@@ -0,0 +1,7 @@
1
+ import { WriteSetChange, WriteSetChangeWriteResource } from "@aptos-labs/ts-sdk";
2
+
3
+ export function isWriteSetChangeWriteResource(
4
+ change: WriteSetChange,
5
+ ): change is WriteSetChangeWriteResource {
6
+ return (change as WriteSetChangeWriteResource).data !== undefined;
7
+ }
@@ -0,0 +1,8 @@
1
+ export const normalizeAddress = (address: string): string => {
2
+ const rawAddresss = address.slice(2);
3
+ if (rawAddresss.length === 64) {
4
+ return address;
5
+ }
6
+
7
+ return "0x" + rawAddresss.padStart(64, "0");
8
+ };
@@ -0,0 +1,18 @@
1
+ import type { TransactionOptions } from "../types";
2
+
3
+ export function normalizeTransactionOptions(options: TransactionOptions): TransactionOptions {
4
+ // FIXME: this is wrong. TransactionOptions is
5
+ // {
6
+ // maxGasAmount: string;
7
+ // gasUnitPrice: string;
8
+ // sequenceNumber?: string;
9
+ // expirationTimestampSecs?: string;
10
+ // }
11
+ // meaning we can't return undefined in check method.
12
+ // This method is useless, not deleting as it breaks code and this iteration is coin modularisation.
13
+ const check = (v: any) => ((v ?? "").toString().trim() ? v : undefined);
14
+ return {
15
+ maxGasAmount: check(options.maxGasAmount),
16
+ gasUnitPrice: check(options.gasUnitPrice),
17
+ };
18
+ }
@@ -0,0 +1,88 @@
1
+ import { InputEntryFunctionData } from "@aptos-labs/ts-sdk";
2
+ import { Operation } from "@ledgerhq/types-live";
3
+ import { Operation as APIOperation } from "@ledgerhq/coin-framework/api/types";
4
+ import { AptosAsset } from "../types/assets";
5
+ import {
6
+ BATCH_TRANSFER_TYPES,
7
+ COIN_TRANSFER_TYPES,
8
+ DELEGATION_POOL_TYPES,
9
+ FA_TRANSFER_TYPES,
10
+ } from "../constants";
11
+ import { compareAddress } from "./getCoinAndAmounts";
12
+ import { normalizeAddress } from "./normalizeAddress";
13
+
14
+ const transferLikeFunctions = (payload: InputEntryFunctionData) =>
15
+ COIN_TRANSFER_TYPES.includes(payload.function) ||
16
+ DELEGATION_POOL_TYPES.includes(payload.function);
17
+
18
+ const addLikeFunctionsToRecipients = (
19
+ op: Operation | APIOperation<AptosAsset>,
20
+ payload: InputEntryFunctionData,
21
+ ) => {
22
+ if (
23
+ payload.functionArguments &&
24
+ payload.functionArguments.length > 0 &&
25
+ typeof payload.functionArguments[0] === "string"
26
+ ) {
27
+ op.recipients.push(normalizeAddress(payload.functionArguments[0]));
28
+ }
29
+ };
30
+
31
+ const addFungibleToRecipients = (
32
+ op: Operation | APIOperation<AptosAsset>,
33
+ payload: InputEntryFunctionData,
34
+ ) => {
35
+ if (
36
+ payload.functionArguments &&
37
+ payload.functionArguments.length > 1 &&
38
+ typeof payload.functionArguments[0] === "object" &&
39
+ typeof payload.functionArguments[1] === "string"
40
+ ) {
41
+ op.recipients.push(normalizeAddress(payload.functionArguments[1].toString()));
42
+ }
43
+ };
44
+
45
+ const addBatchedFunctions = (
46
+ op: Operation | APIOperation<AptosAsset>,
47
+ payload: InputEntryFunctionData,
48
+ address: string,
49
+ ) => {
50
+ if (
51
+ !(
52
+ payload.functionArguments &&
53
+ payload.functionArguments.length > 0 &&
54
+ Array.isArray(payload.functionArguments[0])
55
+ )
56
+ ) {
57
+ return;
58
+ }
59
+ for (const recipient of payload.functionArguments[0]) {
60
+ if (recipient && compareAddress(recipient.toString(), address)) {
61
+ op.recipients.push(normalizeAddress(recipient.toString()));
62
+ }
63
+ }
64
+ };
65
+
66
+ export function processRecipients(
67
+ payload: InputEntryFunctionData,
68
+ address: string,
69
+ op: Operation | APIOperation<AptosAsset>,
70
+ function_address: string,
71
+ ): void {
72
+ // get recipients by 3 groups
73
+ if (transferLikeFunctions(payload)) {
74
+ // 1. Transfer like functions (includes some delegation pool functions)
75
+ addLikeFunctionsToRecipients(op, payload);
76
+ } else if (FA_TRANSFER_TYPES.includes(payload.function)) {
77
+ // 1. Transfer like functions (includes some delegation pool functions)
78
+ addFungibleToRecipients(op, payload);
79
+ } else if (BATCH_TRANSFER_TYPES.includes(payload.function)) {
80
+ // 2. Batch function, to validate we are in the recipients list
81
+ if (!compareAddress(op.senders[0], address)) {
82
+ addBatchedFunctions(op, payload, address);
83
+ }
84
+ } else {
85
+ // 3. other smart contracts, in this case smart contract will be treated as a recipient
86
+ op.recipients.push(function_address);
87
+ }
88
+ }
@@ -0,0 +1,106 @@
1
+ import { AptosTransaction } from "../types";
2
+ import { Operation } from "@ledgerhq/coin-framework/api/types";
3
+ import { AptosAsset } from "../types/assets";
4
+ import BigNumber from "bignumber.js";
5
+ import { EntryFunctionPayloadResponse, InputEntryFunctionData } from "@aptos-labs/ts-sdk";
6
+ import { APTOS_ASSET_ID, DIRECTION } from "../constants";
7
+ import { compareAddress, getCoinAndAmounts } from "./getCoinAndAmounts";
8
+ import { calculateAmount } from "./calculateAmount";
9
+ import { processRecipients } from "./processRecipients";
10
+ import { getFunctionAddress } from "./getFunctionAddress";
11
+ import { normalizeAddress } from "./normalizeAddress";
12
+
13
+ export const convertFunctionPayloadResponseToInputEntryFunctionData = (
14
+ payload: EntryFunctionPayloadResponse,
15
+ ): InputEntryFunctionData => ({
16
+ function: payload.function,
17
+ typeArguments: payload.type_arguments,
18
+ functionArguments: payload.arguments,
19
+ });
20
+
21
+ const detectType = (address: string, tx: AptosTransaction, value: BigNumber): DIRECTION => {
22
+ let type = compareAddress(tx.sender, address) ? DIRECTION.OUT : DIRECTION.IN;
23
+
24
+ if (!value) {
25
+ // skip transaction that result no Aptos change
26
+ type = DIRECTION.UNKNOWN;
27
+ }
28
+
29
+ return type;
30
+ };
31
+
32
+ const getTokenStandard = (coin_id: string): string => {
33
+ const parts = coin_id.split("::");
34
+ if (parts.length === 3) {
35
+ return "coin";
36
+ }
37
+ return "fungible_asset";
38
+ };
39
+
40
+ export function transactionsToOperations(
41
+ address: string,
42
+ txs: (AptosTransaction | null)[],
43
+ ): Operation<AptosAsset>[] {
44
+ const operations: Operation<AptosAsset>[] = [];
45
+
46
+ return txs.reduce((acc, tx) => {
47
+ if (tx === null) {
48
+ return acc;
49
+ }
50
+
51
+ const payload = convertFunctionPayloadResponseToInputEntryFunctionData(
52
+ tx.payload as EntryFunctionPayloadResponse,
53
+ );
54
+
55
+ const function_address = getFunctionAddress(payload);
56
+
57
+ if (!function_address) {
58
+ return acc; // skip transaction without functions in payload
59
+ }
60
+
61
+ const { coin_id, amount_in, amount_out } = getCoinAndAmounts(tx, address);
62
+ const value = calculateAmount(tx.sender, address, amount_in, amount_out);
63
+ const type = detectType(address, tx, value);
64
+
65
+ const op: Operation<AptosAsset> = {
66
+ id: tx.hash,
67
+ type,
68
+ senders: [],
69
+ recipients: [],
70
+ value: BigInt(0),
71
+ asset: { type: "native" },
72
+ details: {
73
+ hasFailed: !tx.success,
74
+ },
75
+ tx: {
76
+ hash: tx.hash,
77
+ block: { height: 0 },
78
+ fees: BigInt(0),
79
+ date: new Date(parseInt(tx.timestamp) / 1000),
80
+ },
81
+ };
82
+
83
+ const fees = new BigNumber(tx.gas_used).multipliedBy(new BigNumber(tx.gas_unit_price));
84
+ op.tx.fees = BigInt(fees.toString());
85
+
86
+ op.value = BigInt(value.isNaN() ? 0 : value.toString());
87
+ op.senders.push(normalizeAddress(tx.sender));
88
+
89
+ processRecipients(payload, address, op, function_address);
90
+
91
+ if (op.type !== DIRECTION.UNKNOWN && coin_id !== null) {
92
+ if (coin_id === APTOS_ASSET_ID) {
93
+ acc.push(op);
94
+ return acc;
95
+ } else {
96
+ op.asset = {
97
+ type: "token",
98
+ standard: getTokenStandard(coin_id),
99
+ contractAddress: coin_id,
100
+ };
101
+ acc.push(op);
102
+ }
103
+ }
104
+ return acc;
105
+ }, operations);
106
+ }