@ledgerhq/coin-mina 1.1.0-nightly.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (414) hide show
  1. package/.eslintrc.js +20 -0
  2. package/.turbo/turbo-build.log +4 -0
  3. package/.unimportedrc.json +24 -0
  4. package/CHANGELOG.md +15 -0
  5. package/LICENSE.txt +21 -0
  6. package/jest.config.js +8 -0
  7. package/jest.integ.config.js +7 -0
  8. package/lib/api/index.d.ts +13 -0
  9. package/lib/api/index.d.ts.map +1 -0
  10. package/lib/api/index.integ.test.d.ts +2 -0
  11. package/lib/api/index.integ.test.d.ts.map +1 -0
  12. package/lib/api/index.integ.test.js +57 -0
  13. package/lib/api/index.integ.test.js.map +1 -0
  14. package/lib/api/index.js +91 -0
  15. package/lib/api/index.js.map +1 -0
  16. package/lib/api/rosetta/index.d.ts +9 -0
  17. package/lib/api/rosetta/index.d.ts.map +1 -0
  18. package/lib/api/rosetta/index.js +90 -0
  19. package/lib/api/rosetta/index.js.map +1 -0
  20. package/lib/api/rosetta/types.d.ts +143 -0
  21. package/lib/api/rosetta/types.d.ts.map +1 -0
  22. package/lib/api/rosetta/types.js +3 -0
  23. package/lib/api/rosetta/types.js.map +1 -0
  24. package/lib/api/rosetta/utils.d.ts +43 -0
  25. package/lib/api/rosetta/utils.d.ts.map +1 -0
  26. package/lib/api/rosetta/utils.js +60 -0
  27. package/lib/api/rosetta/utils.js.map +1 -0
  28. package/lib/api/rosetta/utils.test.d.ts +2 -0
  29. package/lib/api/rosetta/utils.test.d.ts.map +1 -0
  30. package/lib/api/rosetta/utils.test.js +82 -0
  31. package/lib/api/rosetta/utils.test.js.map +1 -0
  32. package/lib/bridge/broadcast.d.ts +6 -0
  33. package/lib/bridge/broadcast.d.ts.map +1 -0
  34. package/lib/bridge/broadcast.js +11 -0
  35. package/lib/bridge/broadcast.js.map +1 -0
  36. package/lib/bridge/broadcast.test.d.ts +2 -0
  37. package/lib/bridge/broadcast.test.d.ts.map +1 -0
  38. package/lib/bridge/broadcast.test.js +36 -0
  39. package/lib/bridge/broadcast.test.js.map +1 -0
  40. package/lib/bridge/buildTransaction.d.ts +4 -0
  41. package/lib/bridge/buildTransaction.d.ts.map +1 -0
  42. package/lib/bridge/buildTransaction.js +37 -0
  43. package/lib/bridge/buildTransaction.js.map +1 -0
  44. package/lib/bridge/buildTransaction.test.d.ts +2 -0
  45. package/lib/bridge/buildTransaction.test.d.ts.map +1 -0
  46. package/lib/bridge/buildTransaction.test.js +57 -0
  47. package/lib/bridge/buildTransaction.test.js.map +1 -0
  48. package/lib/bridge/cli-transaction.d.ts +18 -0
  49. package/lib/bridge/cli-transaction.d.ts.map +1 -0
  50. package/lib/bridge/cli-transaction.js +37 -0
  51. package/lib/bridge/cli-transaction.js.map +1 -0
  52. package/lib/bridge/createTransaction.d.ts +4 -0
  53. package/lib/bridge/createTransaction.d.ts.map +1 -0
  54. package/lib/bridge/createTransaction.js +21 -0
  55. package/lib/bridge/createTransaction.js.map +1 -0
  56. package/lib/bridge/createTransaction.test.d.ts +2 -0
  57. package/lib/bridge/createTransaction.test.d.ts.map +1 -0
  58. package/lib/bridge/createTransaction.test.js +24 -0
  59. package/lib/bridge/createTransaction.test.js.map +1 -0
  60. package/lib/bridge/deviceTransactionConfig.d.ts +11 -0
  61. package/lib/bridge/deviceTransactionConfig.d.ts.map +1 -0
  62. package/lib/bridge/deviceTransactionConfig.js +8 -0
  63. package/lib/bridge/deviceTransactionConfig.js.map +1 -0
  64. package/lib/bridge/errors.d.ts +10 -0
  65. package/lib/bridge/errors.d.ts.map +1 -0
  66. package/lib/bridge/errors.js +17 -0
  67. package/lib/bridge/errors.js.map +1 -0
  68. package/lib/bridge/estimateMaxSpendable.d.ts +5 -0
  69. package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
  70. package/lib/bridge/estimateMaxSpendable.js +26 -0
  71. package/lib/bridge/estimateMaxSpendable.js.map +1 -0
  72. package/lib/bridge/getEstimatedFees.d.ts +8 -0
  73. package/lib/bridge/getEstimatedFees.d.ts.map +1 -0
  74. package/lib/bridge/getEstimatedFees.js +9 -0
  75. package/lib/bridge/getEstimatedFees.js.map +1 -0
  76. package/lib/bridge/getTransactionStatus.d.ts +5 -0
  77. package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
  78. package/lib/bridge/getTransactionStatus.js +62 -0
  79. package/lib/bridge/getTransactionStatus.js.map +1 -0
  80. package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
  81. package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
  82. package/lib/bridge/getTransactionStatus.test.js +138 -0
  83. package/lib/bridge/getTransactionStatus.test.js.map +1 -0
  84. package/lib/bridge/index.d.ts +14 -0
  85. package/lib/bridge/index.d.ts.map +1 -0
  86. package/lib/bridge/index.js +59 -0
  87. package/lib/bridge/index.js.map +1 -0
  88. package/lib/bridge/index.test.d.ts +2 -0
  89. package/lib/bridge/index.test.d.ts.map +1 -0
  90. package/lib/bridge/index.test.js +32 -0
  91. package/lib/bridge/index.test.js.map +1 -0
  92. package/lib/bridge/prepareTransaction.d.ts +4 -0
  93. package/lib/bridge/prepareTransaction.d.ts.map +1 -0
  94. package/lib/bridge/prepareTransaction.js +23 -0
  95. package/lib/bridge/prepareTransaction.js.map +1 -0
  96. package/lib/bridge/prepareTransaction.test.d.ts +2 -0
  97. package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
  98. package/lib/bridge/prepareTransaction.test.js +43 -0
  99. package/lib/bridge/prepareTransaction.test.js.map +1 -0
  100. package/lib/bridge/signOperation.d.ts +12 -0
  101. package/lib/bridge/signOperation.d.ts.map +1 -0
  102. package/lib/bridge/signOperation.js +72 -0
  103. package/lib/bridge/signOperation.js.map +1 -0
  104. package/lib/bridge/signOperation.test.d.ts +2 -0
  105. package/lib/bridge/signOperation.test.d.ts.map +1 -0
  106. package/lib/bridge/signOperation.test.js +129 -0
  107. package/lib/bridge/signOperation.test.js.map +1 -0
  108. package/lib/bridge/synchronisation.d.ts +7 -0
  109. package/lib/bridge/synchronisation.d.ts.map +1 -0
  110. package/lib/bridge/synchronisation.js +155 -0
  111. package/lib/bridge/synchronisation.js.map +1 -0
  112. package/lib/bridge/synchronisation.test.d.ts +2 -0
  113. package/lib/bridge/synchronisation.test.d.ts.map +1 -0
  114. package/lib/bridge/synchronisation.test.js +164 -0
  115. package/lib/bridge/synchronisation.test.js.map +1 -0
  116. package/lib/bridge/transaction.d.ts +14 -0
  117. package/lib/bridge/transaction.d.ts.map +1 -0
  118. package/lib/bridge/transaction.js +61 -0
  119. package/lib/bridge/transaction.js.map +1 -0
  120. package/lib/common-logic/index.d.ts +9 -0
  121. package/lib/common-logic/index.d.ts.map +1 -0
  122. package/lib/common-logic/index.js +96 -0
  123. package/lib/common-logic/index.js.map +1 -0
  124. package/lib/common-logic/index.test.d.ts +2 -0
  125. package/lib/common-logic/index.test.d.ts.map +1 -0
  126. package/lib/common-logic/index.test.js +181 -0
  127. package/lib/common-logic/index.test.js.map +1 -0
  128. package/lib/config.d.ts +9 -0
  129. package/lib/config.d.ts.map +1 -0
  130. package/lib/config.js +16 -0
  131. package/lib/config.js.map +1 -0
  132. package/lib/consts.d.ts +16 -0
  133. package/lib/consts.d.ts.map +1 -0
  134. package/lib/consts.js +19 -0
  135. package/lib/consts.js.map +1 -0
  136. package/lib/signer/getAddress.d.ts +6 -0
  137. package/lib/signer/getAddress.d.ts.map +1 -0
  138. package/lib/signer/getAddress.js +22 -0
  139. package/lib/signer/getAddress.js.map +1 -0
  140. package/lib/signer/getAddress.test.d.ts +2 -0
  141. package/lib/signer/getAddress.test.d.ts.map +1 -0
  142. package/lib/signer/getAddress.test.js +106 -0
  143. package/lib/signer/getAddress.test.js.map +1 -0
  144. package/lib/signer/index.d.ts +3 -0
  145. package/lib/signer/index.d.ts.map +1 -0
  146. package/lib/signer/index.js +8 -0
  147. package/lib/signer/index.js.map +1 -0
  148. package/lib/test/bot-deviceActions.d.ts +4 -0
  149. package/lib/test/bot-deviceActions.d.ts.map +1 -0
  150. package/lib/test/bot-deviceActions.js +67 -0
  151. package/lib/test/bot-deviceActions.js.map +1 -0
  152. package/lib/test/bot-specs.d.ts +7 -0
  153. package/lib/test/bot-specs.d.ts.map +1 -0
  154. package/lib/test/bot-specs.js +107 -0
  155. package/lib/test/bot-specs.js.map +1 -0
  156. package/lib/test/bridgeDatasetTest.d.ts +4 -0
  157. package/lib/test/bridgeDatasetTest.d.ts.map +1 -0
  158. package/lib/test/bridgeDatasetTest.js +174 -0
  159. package/lib/test/bridgeDatasetTest.js.map +1 -0
  160. package/lib/test/fixtures.d.ts +55 -0
  161. package/lib/test/fixtures.d.ts.map +1 -0
  162. package/lib/test/fixtures.js +194 -0
  163. package/lib/test/fixtures.js.map +1 -0
  164. package/lib/test/index.d.ts +4 -0
  165. package/lib/test/index.d.ts.map +1 -0
  166. package/lib/test/index.js +20 -0
  167. package/lib/test/index.js.map +1 -0
  168. package/lib/test/testUtils.d.ts +2 -0
  169. package/lib/test/testUtils.d.ts.map +1 -0
  170. package/lib/test/testUtils.js +8 -0
  171. package/lib/test/testUtils.js.map +1 -0
  172. package/lib/test/testUtils.test.d.ts +2 -0
  173. package/lib/test/testUtils.test.d.ts.map +1 -0
  174. package/lib/test/testUtils.test.js +11 -0
  175. package/lib/test/testUtils.test.js.map +1 -0
  176. package/lib/types/common.d.ts +55 -0
  177. package/lib/types/common.d.ts.map +1 -0
  178. package/lib/types/common.js +3 -0
  179. package/lib/types/common.js.map +1 -0
  180. package/lib/types/index.d.ts +3 -0
  181. package/lib/types/index.d.ts.map +1 -0
  182. package/lib/types/index.js +19 -0
  183. package/lib/types/index.js.map +1 -0
  184. package/lib/types/signer.d.ts +32 -0
  185. package/lib/types/signer.d.ts.map +1 -0
  186. package/lib/types/signer.js +3 -0
  187. package/lib/types/signer.js.map +1 -0
  188. package/lib-es/api/index.d.ts +13 -0
  189. package/lib-es/api/index.d.ts.map +1 -0
  190. package/lib-es/api/index.integ.test.d.ts +2 -0
  191. package/lib-es/api/index.integ.test.d.ts.map +1 -0
  192. package/lib-es/api/index.integ.test.js +55 -0
  193. package/lib-es/api/index.integ.test.js.map +1 -0
  194. package/lib-es/api/index.js +79 -0
  195. package/lib-es/api/index.js.map +1 -0
  196. package/lib-es/api/rosetta/index.d.ts +8 -0
  197. package/lib-es/api/rosetta/index.d.ts.map +1 -0
  198. package/lib-es/api/rosetta/index.js +78 -0
  199. package/lib-es/api/rosetta/index.js.map +1 -0
  200. package/lib-es/api/rosetta/types.d.ts +143 -0
  201. package/lib-es/api/rosetta/types.d.ts.map +1 -0
  202. package/lib-es/api/rosetta/types.js +2 -0
  203. package/lib-es/api/rosetta/types.js.map +1 -0
  204. package/lib-es/api/rosetta/utils.d.ts +43 -0
  205. package/lib-es/api/rosetta/utils.d.ts.map +1 -0
  206. package/lib-es/api/rosetta/utils.js +54 -0
  207. package/lib-es/api/rosetta/utils.js.map +1 -0
  208. package/lib-es/api/rosetta/utils.test.d.ts +2 -0
  209. package/lib-es/api/rosetta/utils.test.d.ts.map +1 -0
  210. package/lib-es/api/rosetta/utils.test.js +80 -0
  211. package/lib-es/api/rosetta/utils.test.js.map +1 -0
  212. package/lib-es/bridge/broadcast.d.ts +6 -0
  213. package/lib-es/bridge/broadcast.d.ts.map +1 -0
  214. package/lib-es/bridge/broadcast.js +9 -0
  215. package/lib-es/bridge/broadcast.js.map +1 -0
  216. package/lib-es/bridge/broadcast.test.d.ts +2 -0
  217. package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
  218. package/lib-es/bridge/broadcast.test.js +31 -0
  219. package/lib-es/bridge/broadcast.test.js.map +1 -0
  220. package/lib-es/bridge/buildTransaction.d.ts +4 -0
  221. package/lib-es/bridge/buildTransaction.d.ts.map +1 -0
  222. package/lib-es/bridge/buildTransaction.js +30 -0
  223. package/lib-es/bridge/buildTransaction.js.map +1 -0
  224. package/lib-es/bridge/buildTransaction.test.d.ts +2 -0
  225. package/lib-es/bridge/buildTransaction.test.d.ts.map +1 -0
  226. package/lib-es/bridge/buildTransaction.test.js +55 -0
  227. package/lib-es/bridge/buildTransaction.test.js.map +1 -0
  228. package/lib-es/bridge/cli-transaction.d.ts +18 -0
  229. package/lib-es/bridge/cli-transaction.d.ts.map +1 -0
  230. package/lib-es/bridge/cli-transaction.js +31 -0
  231. package/lib-es/bridge/cli-transaction.js.map +1 -0
  232. package/lib-es/bridge/createTransaction.d.ts +4 -0
  233. package/lib-es/bridge/createTransaction.d.ts.map +1 -0
  234. package/lib-es/bridge/createTransaction.js +14 -0
  235. package/lib-es/bridge/createTransaction.js.map +1 -0
  236. package/lib-es/bridge/createTransaction.test.d.ts +2 -0
  237. package/lib-es/bridge/createTransaction.test.d.ts.map +1 -0
  238. package/lib-es/bridge/createTransaction.test.js +19 -0
  239. package/lib-es/bridge/createTransaction.test.js.map +1 -0
  240. package/lib-es/bridge/deviceTransactionConfig.d.ts +11 -0
  241. package/lib-es/bridge/deviceTransactionConfig.d.ts.map +1 -0
  242. package/lib-es/bridge/deviceTransactionConfig.js +6 -0
  243. package/lib-es/bridge/deviceTransactionConfig.js.map +1 -0
  244. package/lib-es/bridge/errors.d.ts +10 -0
  245. package/lib-es/bridge/errors.d.ts.map +1 -0
  246. package/lib-es/bridge/errors.js +14 -0
  247. package/lib-es/bridge/errors.js.map +1 -0
  248. package/lib-es/bridge/estimateMaxSpendable.d.ts +5 -0
  249. package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
  250. package/lib-es/bridge/estimateMaxSpendable.js +21 -0
  251. package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
  252. package/lib-es/bridge/getEstimatedFees.d.ts +8 -0
  253. package/lib-es/bridge/getEstimatedFees.d.ts.map +1 -0
  254. package/lib-es/bridge/getEstimatedFees.js +7 -0
  255. package/lib-es/bridge/getEstimatedFees.js.map +1 -0
  256. package/lib-es/bridge/getTransactionStatus.d.ts +5 -0
  257. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
  258. package/lib-es/bridge/getTransactionStatus.js +60 -0
  259. package/lib-es/bridge/getTransactionStatus.js.map +1 -0
  260. package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
  261. package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
  262. package/lib-es/bridge/getTransactionStatus.test.js +133 -0
  263. package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
  264. package/lib-es/bridge/index.d.ts +14 -0
  265. package/lib-es/bridge/index.d.ts.map +1 -0
  266. package/lib-es/bridge/index.js +50 -0
  267. package/lib-es/bridge/index.js.map +1 -0
  268. package/lib-es/bridge/index.test.d.ts +2 -0
  269. package/lib-es/bridge/index.test.d.ts.map +1 -0
  270. package/lib-es/bridge/index.test.js +30 -0
  271. package/lib-es/bridge/index.test.js.map +1 -0
  272. package/lib-es/bridge/prepareTransaction.d.ts +4 -0
  273. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
  274. package/lib-es/bridge/prepareTransaction.js +16 -0
  275. package/lib-es/bridge/prepareTransaction.js.map +1 -0
  276. package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
  277. package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
  278. package/lib-es/bridge/prepareTransaction.test.js +38 -0
  279. package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
  280. package/lib-es/bridge/signOperation.d.ts +12 -0
  281. package/lib-es/bridge/signOperation.d.ts.map +1 -0
  282. package/lib-es/bridge/signOperation.js +64 -0
  283. package/lib-es/bridge/signOperation.js.map +1 -0
  284. package/lib-es/bridge/signOperation.test.d.ts +2 -0
  285. package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
  286. package/lib-es/bridge/signOperation.test.js +127 -0
  287. package/lib-es/bridge/signOperation.test.js.map +1 -0
  288. package/lib-es/bridge/synchronisation.d.ts +7 -0
  289. package/lib-es/bridge/synchronisation.d.ts.map +1 -0
  290. package/lib-es/bridge/synchronisation.js +147 -0
  291. package/lib-es/bridge/synchronisation.js.map +1 -0
  292. package/lib-es/bridge/synchronisation.test.d.ts +2 -0
  293. package/lib-es/bridge/synchronisation.test.d.ts.map +1 -0
  294. package/lib-es/bridge/synchronisation.test.js +159 -0
  295. package/lib-es/bridge/synchronisation.test.js.map +1 -0
  296. package/lib-es/bridge/transaction.d.ts +14 -0
  297. package/lib-es/bridge/transaction.d.ts.map +1 -0
  298. package/lib-es/bridge/transaction.js +53 -0
  299. package/lib-es/bridge/transaction.js.map +1 -0
  300. package/lib-es/common-logic/index.d.ts +9 -0
  301. package/lib-es/common-logic/index.d.ts.map +1 -0
  302. package/lib-es/common-logic/index.js +84 -0
  303. package/lib-es/common-logic/index.js.map +1 -0
  304. package/lib-es/common-logic/index.test.d.ts +2 -0
  305. package/lib-es/common-logic/index.test.d.ts.map +1 -0
  306. package/lib-es/common-logic/index.test.js +179 -0
  307. package/lib-es/common-logic/index.test.js.map +1 -0
  308. package/lib-es/config.d.ts +9 -0
  309. package/lib-es/config.d.ts.map +1 -0
  310. package/lib-es/config.js +11 -0
  311. package/lib-es/config.js.map +1 -0
  312. package/lib-es/consts.d.ts +16 -0
  313. package/lib-es/consts.d.ts.map +1 -0
  314. package/lib-es/consts.js +16 -0
  315. package/lib-es/consts.js.map +1 -0
  316. package/lib-es/signer/getAddress.d.ts +6 -0
  317. package/lib-es/signer/getAddress.d.ts.map +1 -0
  318. package/lib-es/signer/getAddress.js +17 -0
  319. package/lib-es/signer/getAddress.js.map +1 -0
  320. package/lib-es/signer/getAddress.test.d.ts +2 -0
  321. package/lib-es/signer/getAddress.test.d.ts.map +1 -0
  322. package/lib-es/signer/getAddress.test.js +101 -0
  323. package/lib-es/signer/getAddress.test.js.map +1 -0
  324. package/lib-es/signer/index.d.ts +3 -0
  325. package/lib-es/signer/index.d.ts.map +1 -0
  326. package/lib-es/signer/index.js +3 -0
  327. package/lib-es/signer/index.js.map +1 -0
  328. package/lib-es/test/bot-deviceActions.d.ts +4 -0
  329. package/lib-es/test/bot-deviceActions.d.ts.map +1 -0
  330. package/lib-es/test/bot-deviceActions.js +64 -0
  331. package/lib-es/test/bot-deviceActions.js.map +1 -0
  332. package/lib-es/test/bot-specs.d.ts +7 -0
  333. package/lib-es/test/bot-specs.d.ts.map +1 -0
  334. package/lib-es/test/bot-specs.js +102 -0
  335. package/lib-es/test/bot-specs.js.map +1 -0
  336. package/lib-es/test/bridgeDatasetTest.d.ts +4 -0
  337. package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -0
  338. package/lib-es/test/bridgeDatasetTest.js +171 -0
  339. package/lib-es/test/bridgeDatasetTest.js.map +1 -0
  340. package/lib-es/test/fixtures.d.ts +55 -0
  341. package/lib-es/test/fixtures.d.ts.map +1 -0
  342. package/lib-es/test/fixtures.js +182 -0
  343. package/lib-es/test/fixtures.js.map +1 -0
  344. package/lib-es/test/index.d.ts +4 -0
  345. package/lib-es/test/index.d.ts.map +1 -0
  346. package/lib-es/test/index.js +4 -0
  347. package/lib-es/test/index.js.map +1 -0
  348. package/lib-es/test/testUtils.d.ts +2 -0
  349. package/lib-es/test/testUtils.d.ts.map +1 -0
  350. package/lib-es/test/testUtils.js +4 -0
  351. package/lib-es/test/testUtils.js.map +1 -0
  352. package/lib-es/test/testUtils.test.d.ts +2 -0
  353. package/lib-es/test/testUtils.test.d.ts.map +1 -0
  354. package/lib-es/test/testUtils.test.js +9 -0
  355. package/lib-es/test/testUtils.test.js.map +1 -0
  356. package/lib-es/types/common.d.ts +55 -0
  357. package/lib-es/types/common.d.ts.map +1 -0
  358. package/lib-es/types/common.js +2 -0
  359. package/lib-es/types/common.js.map +1 -0
  360. package/lib-es/types/index.d.ts +3 -0
  361. package/lib-es/types/index.d.ts.map +1 -0
  362. package/lib-es/types/index.js +3 -0
  363. package/lib-es/types/index.js.map +1 -0
  364. package/lib-es/types/signer.d.ts +32 -0
  365. package/lib-es/types/signer.d.ts.map +1 -0
  366. package/lib-es/types/signer.js +2 -0
  367. package/lib-es/types/signer.js.map +1 -0
  368. package/package.json +143 -0
  369. package/src/api/index.integ.test.ts +62 -0
  370. package/src/api/index.ts +120 -0
  371. package/src/api/rosetta/index.ts +110 -0
  372. package/src/api/rosetta/types.ts +156 -0
  373. package/src/api/rosetta/utils.test.ts +100 -0
  374. package/src/api/rosetta/utils.ts +71 -0
  375. package/src/bridge/broadcast.test.ts +35 -0
  376. package/src/bridge/broadcast.ts +17 -0
  377. package/src/bridge/buildTransaction.test.ts +68 -0
  378. package/src/bridge/buildTransaction.ts +34 -0
  379. package/src/bridge/cli-transaction.ts +43 -0
  380. package/src/bridge/createTransaction.test.ts +21 -0
  381. package/src/bridge/createTransaction.ts +19 -0
  382. package/src/bridge/deviceTransactionConfig.ts +15 -0
  383. package/src/bridge/errors.ts +16 -0
  384. package/src/bridge/estimateMaxSpendable.ts +31 -0
  385. package/src/bridge/getEstimatedFees.ts +17 -0
  386. package/src/bridge/getTransactionStatus.test.ts +175 -0
  387. package/src/bridge/getTransactionStatus.ts +87 -0
  388. package/src/bridge/index.test.ts +39 -0
  389. package/src/bridge/index.ts +72 -0
  390. package/src/bridge/prepareTransaction.test.ts +43 -0
  391. package/src/bridge/prepareTransaction.ts +24 -0
  392. package/src/bridge/signOperation.test.ts +158 -0
  393. package/src/bridge/signOperation.ts +112 -0
  394. package/src/bridge/synchronisation.test.ts +184 -0
  395. package/src/bridge/synchronisation.ts +168 -0
  396. package/src/bridge/transaction.ts +69 -0
  397. package/src/common-logic/index.test.ts +225 -0
  398. package/src/common-logic/index.ts +97 -0
  399. package/src/config.ts +21 -0
  400. package/src/consts.ts +18 -0
  401. package/src/signer/getAddress.test.ts +131 -0
  402. package/src/signer/getAddress.ts +24 -0
  403. package/src/signer/index.ts +3 -0
  404. package/src/test/bot-deviceActions.ts +73 -0
  405. package/src/test/bot-specs.ts +130 -0
  406. package/src/test/bridgeDatasetTest.ts +180 -0
  407. package/src/test/fixtures.ts +226 -0
  408. package/src/test/index.ts +3 -0
  409. package/src/test/testUtils.test.ts +9 -0
  410. package/src/test/testUtils.ts +3 -0
  411. package/src/types/common.ts +70 -0
  412. package/src/types/index.ts +2 -0
  413. package/src/types/signer.ts +29 -0
  414. package/tsconfig.json +13 -0
@@ -0,0 +1,55 @@
1
+ import type { BigNumber } from "bignumber.js";
2
+ import { Account, AccountRaw, Operation, TransactionCommon, TransactionCommonRaw, TransactionStatusCommon, TransactionStatusCommonRaw } from "@ledgerhq/types-live";
3
+ export type Transaction = TransactionCommon & {
4
+ family: "mina";
5
+ fees: {
6
+ fee: BigNumber;
7
+ accountCreationFee: BigNumber;
8
+ };
9
+ memo: string | undefined;
10
+ nonce: number;
11
+ };
12
+ export type TransactionRaw = TransactionCommonRaw & {
13
+ family: "mina";
14
+ fees: {
15
+ fee: string;
16
+ accountCreationFee: string;
17
+ };
18
+ memo: string | undefined;
19
+ nonce: number;
20
+ };
21
+ export type MinaAccount = Account;
22
+ export type MinaAPIAccount = {
23
+ blockHeight: number;
24
+ balance: BigNumber;
25
+ spendableBalance: BigNumber;
26
+ };
27
+ export type MinaAccountRaw = AccountRaw;
28
+ export type TransactionStatus = TransactionStatusCommon;
29
+ export type TransactionStatusRaw = TransactionStatusCommonRaw;
30
+ export type StatusErrorMap = {
31
+ recipient?: Error;
32
+ amount?: Error;
33
+ fees?: Error;
34
+ transaction?: Error;
35
+ };
36
+ export type MinaUnsignedTransaction = {
37
+ txType: number;
38
+ senderAccount: number;
39
+ senderAddress: string;
40
+ receiverAddress: string;
41
+ amount: number;
42
+ fee: number;
43
+ nonce: number;
44
+ memo: string;
45
+ networkId: number;
46
+ };
47
+ export interface MinaSignedTransaction {
48
+ signature: string;
49
+ transaction: MinaUnsignedTransaction;
50
+ }
51
+ export type MinaOperation = Operation<{
52
+ memo: string | undefined;
53
+ accountCreationFee: string;
54
+ }>;
55
+ //# sourceMappingURL=common.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EACL,OAAO,EACP,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,oBAAoB,EACpB,uBAAuB,EACvB,0BAA0B,EAC3B,MAAM,sBAAsB,CAAC;AAE9B,MAAM,MAAM,WAAW,GAAG,iBAAiB,GAAG;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE;QACJ,GAAG,EAAE,SAAS,CAAC;QACf,kBAAkB,EAAE,SAAS,CAAC;KAC/B,CAAC;IACF,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,oBAAoB,GAAG;IAClD,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE;QACJ,GAAG,EAAE,MAAM,CAAC;QACZ,kBAAkB,EAAE,MAAM,CAAC;KAC5B,CAAC;IACF,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG,OAAO,CAAC;AAElC,MAAM,MAAM,cAAc,GAAG;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,SAAS,CAAC;IACnB,gBAAgB,EAAE,SAAS,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC;AAExC,MAAM,MAAM,iBAAiB,GAAG,uBAAuB,CAAC;AAExD,MAAM,MAAM,oBAAoB,GAAG,0BAA0B,CAAC;AAE9D,MAAM,MAAM,cAAc,GAAG;IAC3B,SAAS,CAAC,EAAE,KAAK,CAAC;IAClB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,IAAI,CAAC,EAAE,KAAK,CAAC;IACb,WAAW,CAAC,EAAE,KAAK,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,WAAW,qBAAqB;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,uBAAuB,CAAC;CACtC;AAED,MAAM,MAAM,aAAa,GAAG,SAAS,CAAC;IAAE,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IAAC,kBAAkB,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=common.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ export * from "./common";
2
+ export * from "./signer";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from "./common";
2
+ export * from "./signer";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC"}
@@ -0,0 +1,32 @@
1
+ interface SignTransactionArgs {
2
+ txType: number;
3
+ senderAccount: number;
4
+ senderAddress: string;
5
+ receiverAddress: string;
6
+ amount: number;
7
+ fee: number;
8
+ nonce: number;
9
+ validUntil?: number;
10
+ memo?: string;
11
+ networkId: number;
12
+ }
13
+ interface BaseLedgerResponse {
14
+ returnCode: string;
15
+ statusText?: string;
16
+ message?: string;
17
+ }
18
+ interface SignTransactionResponse extends BaseLedgerResponse {
19
+ signature?: string | null;
20
+ }
21
+ export interface GetAddressResponse extends BaseLedgerResponse {
22
+ publicKey?: string | null;
23
+ }
24
+ export type MinaSignature = {
25
+ signature?: string;
26
+ };
27
+ export interface MinaSigner {
28
+ getAddress(account?: number, verify?: boolean): Promise<GetAddressResponse>;
29
+ signTransaction(transaction: SignTransactionArgs): Promise<SignTransactionResponse>;
30
+ }
31
+ export {};
32
+ //# sourceMappingURL=signer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,UAAU,mBAAmB;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AACD,UAAU,kBAAkB;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AACD,UAAU,uBAAwB,SAAQ,kBAAkB;IAC1D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B;AAED,MAAM,WAAW,kBAAmB,SAAQ,kBAAkB;IAC5D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B;AACD,MAAM,MAAM,aAAa,GAAG;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AACnD,MAAM,WAAW,UAAU;IACzB,UAAU,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC5E,eAAe,CAAC,WAAW,EAAE,mBAAmB,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAAC;CACrF"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=signer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.js","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,143 @@
1
+ {
2
+ "name": "@ledgerhq/coin-mina",
3
+ "version": "1.1.0-nightly.0",
4
+ "description": "Mina Coin integration",
5
+ "keywords": [
6
+ "Ledger",
7
+ "LedgerWallet",
8
+ "mina",
9
+ "Hardware Wallet"
10
+ ],
11
+ "repository": {
12
+ "type": "git",
13
+ "url": "https://github.com/LedgerHQ/ledger-live.git"
14
+ },
15
+ "bugs": {
16
+ "url": "https://github.com/LedgerHQ/ledger-live/issues"
17
+ },
18
+ "homepage": "https://github.com/LedgerHQ/ledger-live/tree/develop/libs/coin-modules/coin-mina",
19
+ "publishConfig": {
20
+ "access": "public"
21
+ },
22
+ "typesVersions": {
23
+ "*": {
24
+ "lib/*": [
25
+ "lib/*"
26
+ ],
27
+ "lib-es/*": [
28
+ "lib-es/*"
29
+ ],
30
+ "api": [
31
+ "lib/api/index"
32
+ ],
33
+ "deviceTransactionConfig": [
34
+ "lib/bridge/deviceTransactionConfig"
35
+ ],
36
+ "logic": [
37
+ "lib/logic/index"
38
+ ],
39
+ "specs": [
40
+ "lib/test/bot-specs"
41
+ ],
42
+ "transaction": [
43
+ "lib/bridge/transaction"
44
+ ],
45
+ "types": [
46
+ "lib/types/index"
47
+ ],
48
+ "*": [
49
+ "lib/*",
50
+ "lib/bridge/*",
51
+ "lib/logic/*",
52
+ "lib/signer/*",
53
+ "lib/test/*",
54
+ "lib/types/*"
55
+ ]
56
+ }
57
+ },
58
+ "exports": {
59
+ "./lib/*": "./lib/*.js",
60
+ "./lib-es/*": "./lib-es/*.js",
61
+ "./api": {
62
+ "require": "./lib/api/index.js",
63
+ "default": "./lib-es/api/index.js"
64
+ },
65
+ "./deviceTransactionConfig": {
66
+ "require": "./lib/bridge/deviceTransactionConfig.js",
67
+ "default": "./lib-es/bridge/deviceTransactionConfig.js"
68
+ },
69
+ "./logic": {
70
+ "require": "./lib/common-logic/index.js",
71
+ "default": "./lib-es/common-logic/index.js"
72
+ },
73
+ "./signer": {
74
+ "require": "./lib/signer/index.js",
75
+ "default": "./lib-es/signer/index.js"
76
+ },
77
+ "./specs": {
78
+ "require": "./lib/test/bot-specs.js",
79
+ "default": "./lib-es/test/bot-specs.js"
80
+ },
81
+ "./bridge": {
82
+ "require": "./lib/bridge/index.js",
83
+ "default": "./lib-es/bridge/index.js"
84
+ },
85
+ "./transaction": {
86
+ "require": "./lib/bridge/transaction.js",
87
+ "default": "./lib-es/bridge/transaction.js"
88
+ },
89
+ "./types": {
90
+ "require": "./lib/types/index.js",
91
+ "default": "./lib-es/types/index.js"
92
+ },
93
+ "./*": {
94
+ "require": "./lib/*.js",
95
+ "default": "./lib-es/*.js"
96
+ },
97
+ ".": {
98
+ "require": "./lib/index.js",
99
+ "default": "./lib-es/index.js"
100
+ },
101
+ "./package.json": "./package.json"
102
+ },
103
+ "license": "Apache-2.0",
104
+ "dependencies": {
105
+ "bignumber.js": "^9.1.2",
106
+ "bs58check": "^2.1.2",
107
+ "expect": "^27.4.6",
108
+ "invariant": "^2.2.2",
109
+ "lodash": "^4.17.21",
110
+ "rxjs": "^7.8.1",
111
+ "@ledgerhq/coin-framework": "^2.6.0-nightly.5",
112
+ "@ledgerhq/cryptoassets": "^13.15.0-nightly.3",
113
+ "@ledgerhq/devices": "^8.4.5-nightly.0",
114
+ "@ledgerhq/errors": "^6.20.0-nightly.0",
115
+ "@ledgerhq/live-network": "^2.0.7-nightly.1",
116
+ "@ledgerhq/logs": "^6.12.0",
117
+ "@ledgerhq/types-cryptoassets": "^7.22.0-nightly.0",
118
+ "@ledgerhq/types-live": "^6.66.0-nightly.4"
119
+ },
120
+ "devDependencies": {
121
+ "@types/invariant": "^2.2.2",
122
+ "@types/bs58check": "^2.1.2",
123
+ "expect": "^27.4.6",
124
+ "@types/jest": "^29.5.10",
125
+ "@types/lodash": "^4.14.191",
126
+ "jest": "^29.7.0",
127
+ "ts-jest": "^29.1.1"
128
+ },
129
+ "scripts": {
130
+ "clean": "rimraf lib lib-es",
131
+ "build": "tsc && tsc -m esnext --moduleResolution bundler --outDir lib-es",
132
+ "coverage": "jest --coverage --testPathIgnorePatterns='/bridge.integration.test.ts|node_modules|lib-es|lib/' --passWithNoTests && mv coverage/coverage-final.json coverage/coverage-boilerplate.json",
133
+ "prewatch": "pnpm build",
134
+ "watch": "tsc --watch",
135
+ "doc": "documentation readme src/** --section=API --pe ts --re ts --re d.ts",
136
+ "lint": "eslint ./src --no-error-on-unmatched-pattern --ext .ts,.tsx --cache",
137
+ "lint:fix": "pnpm lint --fix",
138
+ "test": "jest",
139
+ "test-integ": "DOTENV_CONFIG_PATH=.env.integ.test jest --config=jest.integ.config.js",
140
+ "typecheck": "tsc --noEmit",
141
+ "unimported": "unimported"
142
+ }
143
+ }
@@ -0,0 +1,62 @@
1
+ import { getAccount, getBlockInfo, getTransactions } from ".";
2
+ import { getCoinConfig } from "../config";
3
+ import { CurrencyConfig } from "@ledgerhq/coin-framework/config";
4
+
5
+ jest.mock("../config");
6
+ describe("backend api tests", () => {
7
+ jest.mocked(getCoinConfig).mockReturnValue({
8
+ ...({} as unknown as CurrencyConfig),
9
+ infra: {
10
+ API_MINA_ROSETTA_NODE: "https://mina.coin.ledger.com/node",
11
+ },
12
+ });
13
+ const validAddress = ["B62qjWLs1W3J2fFGixeX49w1o7VvSGuMBNotnFhzs3PZ7PbtdFbhdeD"];
14
+ const invalidAddress = [
15
+ "B62qkdFWJSW8zaTBZjTVtmeU3rVxyUkNxPhKKW8T2JBtpj5XfdywLJM",
16
+ "novalidaddress",
17
+ ];
18
+
19
+ it("getAccount for valid address", async () => {
20
+ const account = await getAccount(validAddress[0]);
21
+ expect(account).toBeDefined();
22
+ expect(account.balance.toNumber()).toBeGreaterThan(0);
23
+ });
24
+
25
+ it("get block info", async () => {
26
+ const blockInfo = await getBlockInfo(1);
27
+ expect(blockInfo).toBeDefined();
28
+ expect(blockInfo.block.block_identifier.index).toBe(1);
29
+ });
30
+
31
+ it("get balance should fail for invalid address", async () => {
32
+ for (const address of invalidAddress) {
33
+ const account = await getAccount(address);
34
+ expect(account).toBeDefined();
35
+ expect(account.balance.toNumber()).toBe(0);
36
+ }
37
+ }, 10000);
38
+
39
+ it("get balance should succeed for valid address", async () => {
40
+ for (const address of validAddress) {
41
+ const account = await getAccount(address);
42
+ expect(account).toBeDefined();
43
+ expect(account.balance.toNumber()).toBeGreaterThan(0);
44
+ }
45
+ });
46
+
47
+ it("get transactions should not fail for invalid address", async () => {
48
+ for (const address of invalidAddress) {
49
+ const transactions = await getTransactions(address);
50
+ expect(transactions).toBeDefined();
51
+ expect(transactions.length).toBe(0);
52
+ }
53
+ }, 30000);
54
+
55
+ it("get transactions should succeed for valid address", async () => {
56
+ for (const address of validAddress) {
57
+ const transactions = await getTransactions(address);
58
+ expect(transactions).toBeDefined();
59
+ expect(transactions.length).toBeGreaterThan(0);
60
+ }
61
+ }, 30000);
62
+ });
@@ -0,0 +1,120 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { MinaAPIAccount, MinaSignedTransaction, Transaction } from "../types/common";
3
+ import {
4
+ fetchAccountBalance,
5
+ fetchAccountTransactions,
6
+ fetchNetworkStatus,
7
+ fetchTransactionMetadata,
8
+ rosettaGetBlockInfo,
9
+ rosettaSubmitTransaction,
10
+ } from "./rosetta";
11
+ import { MINA_TOKEN_ID } from "../consts";
12
+ import { isValidAddress } from "../common-logic";
13
+ import { RosettaBlockInfoResponse, RosettaTransaction } from "./rosetta/types";
14
+ import { log } from "@ledgerhq/logs";
15
+
16
+ export const getAccount = async (address: string): Promise<MinaAPIAccount> => {
17
+ const networkStatus = await fetchNetworkStatus();
18
+ let balance = new BigNumber(0);
19
+ let spendableBalance = new BigNumber(0);
20
+ try {
21
+ const resp = await fetchAccountBalance(address);
22
+ balance = new BigNumber(resp.balances[0].metadata.total_balance);
23
+ spendableBalance = new BigNumber(resp.balances[0].metadata.liquid_balance);
24
+ } catch (e) {
25
+ log("info", "[mina] getAccount error:", {
26
+ address,
27
+ error: e,
28
+ });
29
+ // fail is expected for when account has no balance and no transactions
30
+ /* empty */
31
+ }
32
+
33
+ return {
34
+ blockHeight: networkStatus.current_block_identifier.index,
35
+ balance,
36
+ spendableBalance,
37
+ };
38
+ };
39
+
40
+ export const getBlockInfo = async (blockHeight: number): Promise<RosettaBlockInfoResponse> => {
41
+ const data = await rosettaGetBlockInfo(blockHeight);
42
+ return data;
43
+ };
44
+
45
+ export const getTransactions = async (
46
+ address: string,
47
+ offset: number = 0,
48
+ ): Promise<RosettaTransaction[]> => {
49
+ const txns = await fetchAccountTransactions(address, offset);
50
+ return txns.sort((a, b) => b.timestamp - a.timestamp);
51
+ };
52
+
53
+ export const broadcastTransaction = async (txn: MinaSignedTransaction): Promise<string> => {
54
+ const { nonce, receiverAddress, amount, fee, memo, senderAddress } = txn.transaction;
55
+ const blob = {
56
+ signature: txn.signature,
57
+ payment: {
58
+ to: receiverAddress,
59
+ from: senderAddress,
60
+ fee: fee.toFixed(),
61
+ token: MINA_TOKEN_ID,
62
+ nonce: nonce.toFixed(),
63
+ memo: memo ?? null,
64
+ amount: amount.toFixed(),
65
+ valid_until: null,
66
+ },
67
+ stake_delegation: null,
68
+ };
69
+
70
+ const { data } = await rosettaSubmitTransaction(JSON.stringify(blob));
71
+
72
+ return data.transaction_identifier.hash;
73
+ };
74
+
75
+ export const getFees = async (
76
+ txn: Transaction,
77
+ address: string,
78
+ ): Promise<{
79
+ fee: BigNumber;
80
+ accountCreationFee: BigNumber;
81
+ }> => {
82
+ if (!txn.amount || !txn.recipient || !isValidAddress(txn.recipient)) {
83
+ return { fee: txn.fees.fee, accountCreationFee: new BigNumber(0) };
84
+ }
85
+
86
+ const { data } = await fetchTransactionMetadata(
87
+ address,
88
+ txn.recipient,
89
+ txn.fees.fee.toNumber(),
90
+ txn.amount.toNumber(),
91
+ );
92
+
93
+ const accountCreationFee = data.metadata.account_creation_fee
94
+ ? new BigNumber(data.metadata.account_creation_fee)
95
+ : new BigNumber(0);
96
+
97
+ return {
98
+ fee: new BigNumber(data.suggested_fee[0].value),
99
+ accountCreationFee,
100
+ };
101
+ };
102
+
103
+ export const getNonce = async (txn: Transaction, address: string): Promise<number> => {
104
+ if (!txn.recipient || !isValidAddress(txn.recipient)) {
105
+ return txn.nonce;
106
+ }
107
+
108
+ if (!txn.amount || !txn.fees) {
109
+ return txn.nonce;
110
+ }
111
+
112
+ const { data } = await fetchTransactionMetadata(
113
+ address,
114
+ txn.recipient,
115
+ txn.fees.fee.toNumber(),
116
+ txn.amount.toNumber(),
117
+ );
118
+
119
+ return parseInt(data.metadata.nonce);
120
+ };
@@ -0,0 +1,110 @@
1
+ import network from "@ledgerhq/live-network";
2
+ import {
3
+ FetchAccountBalanceResponse,
4
+ FetchAccountTransactionsResponse,
5
+ FetchNetworkStatusResponse,
6
+ RosettaBlockInfoResponse,
7
+ RosettaMetadataResponse,
8
+ RosettaPreprocessResponse,
9
+ RosettaSubmitResponse,
10
+ RosettaTransaction,
11
+ } from "./types";
12
+ import { getCoinConfig } from "../../config";
13
+ import { addNetworkIdentifier, buildAccountIdentifier, makeTransferPayload } from "./utils";
14
+ import { MAX_TRANSACTIONS_PER_PAGE } from "../../consts";
15
+ import { LiveNetworkResponse } from "@ledgerhq/live-network/lib/network";
16
+
17
+ const getRosettaUrl = (route: string): string => {
18
+ const currencyConfig = getCoinConfig();
19
+ return `${currencyConfig.infra.API_MINA_ROSETTA_NODE}${route || ""}`;
20
+ };
21
+
22
+ export const fetchNetworkStatus = async () => {
23
+ const { data } = await network<FetchNetworkStatusResponse>({
24
+ method: "POST",
25
+ url: getRosettaUrl("/network/status"),
26
+ data: addNetworkIdentifier({}),
27
+ });
28
+
29
+ return data;
30
+ };
31
+
32
+ export const fetchAccountBalance = async (address: string) => {
33
+ const { data } = await network<FetchAccountBalanceResponse>({
34
+ method: "POST",
35
+ url: getRosettaUrl("/account/balance"),
36
+ data: addNetworkIdentifier(buildAccountIdentifier(address)),
37
+ });
38
+
39
+ return data;
40
+ };
41
+
42
+ export const fetchAccountTransactions = async (
43
+ address: string,
44
+ offset: number = 0,
45
+ ): Promise<RosettaTransaction[]> => {
46
+ const transactions: RosettaTransaction[] = [];
47
+ let currentOffset: number | undefined = offset;
48
+ while (currentOffset !== undefined) {
49
+ const response: LiveNetworkResponse<FetchAccountTransactionsResponse> =
50
+ await network<FetchAccountTransactionsResponse>({
51
+ method: "POST",
52
+ url: getRosettaUrl("/search/transactions"),
53
+ data: {
54
+ ...addNetworkIdentifier(buildAccountIdentifier(address)),
55
+ offset: currentOffset,
56
+ limit: MAX_TRANSACTIONS_PER_PAGE,
57
+ include_timestamp: true,
58
+ },
59
+ });
60
+ const { data } = response;
61
+ transactions.push(...data.transactions);
62
+
63
+ currentOffset = data.next_offset;
64
+ }
65
+
66
+ return transactions;
67
+ };
68
+
69
+ export const rosettaGetBlockInfo = async (blockHeight: number) => {
70
+ const { data } = await network<RosettaBlockInfoResponse>({
71
+ method: "POST",
72
+ url: getRosettaUrl("/block"),
73
+ data: addNetworkIdentifier({ block_identifier: { index: blockHeight } }),
74
+ });
75
+ return data;
76
+ };
77
+
78
+ const rosettaPreprocess = async (from: string, to: string, feeNano: number, valueNano: number) => {
79
+ const payload = makeTransferPayload(from, to, feeNano, valueNano);
80
+ const { data } = await network<RosettaPreprocessResponse>({
81
+ method: "POST",
82
+ url: getRosettaUrl("/construction/preprocess"),
83
+ data: addNetworkIdentifier(payload),
84
+ });
85
+
86
+ return data;
87
+ };
88
+
89
+ export const fetchTransactionMetadata = async (
90
+ srcAddress: string,
91
+ destAddress: string,
92
+ feeNano: number,
93
+ valueNano: number,
94
+ ) => {
95
+ const options = await rosettaPreprocess(srcAddress, destAddress, feeNano, valueNano);
96
+ const payload = makeTransferPayload(srcAddress, destAddress, feeNano, valueNano);
97
+ return await network<RosettaMetadataResponse>({
98
+ method: "POST",
99
+ url: getRosettaUrl("/construction/metadata"),
100
+ data: addNetworkIdentifier({ ...payload, ...options }),
101
+ });
102
+ };
103
+
104
+ export const rosettaSubmitTransaction = async (blob: string) => {
105
+ return await network<RosettaSubmitResponse>({
106
+ method: "POST",
107
+ url: getRosettaUrl("/construction/submit"),
108
+ data: addNetworkIdentifier({ signed_transaction: blob }),
109
+ });
110
+ };