@ledgerhq/coin-mina 1.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 (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 +8 -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,21 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import { getMainAccount } from "@ledgerhq/coin-framework/account/index";
3
+ import { getMaxAmount } from "../common-logic";
4
+ import { createTransaction } from "./createTransaction";
5
+ import getEstimatedFees from "./getEstimatedFees";
6
+ const estimateMaxSpendable = async ({ account, parentAccount, transaction }) => {
7
+ const a = getMainAccount(account, parentAccount);
8
+ const t = {
9
+ ...createTransaction(account),
10
+ ...transaction,
11
+ amount: a.spendableBalance,
12
+ };
13
+ const { fee } = await getEstimatedFees(t, a.freshAddress);
14
+ const maxSpendable = getMaxAmount(a, t, fee);
15
+ if (maxSpendable.lt(0)) {
16
+ return new BigNumber(0);
17
+ }
18
+ return maxSpendable;
19
+ };
20
+ export default estimateMaxSpendable;
21
+ //# sourceMappingURL=estimateMaxSpendable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAElD,MAAM,oBAAoB,GAGE,KAAK,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,EAAsB,EAAE;IAChG,MAAM,CAAC,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAgB,CAAC;IAChE,MAAM,CAAC,GAAG;QACR,GAAG,iBAAiB,CAAC,OAAO,CAAC;QAC7B,GAAG,WAAW;QACd,MAAM,EAAE,CAAC,CAAC,gBAAgB;KAC3B,CAAC;IAEF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,gBAAgB,CAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAE1D,MAAM,YAAY,GAAG,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;IAE7C,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACvB,OAAO,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import { Transaction } from "../types/common";
3
+ declare const getEstimatedFees: (transaction: Transaction, address: string) => Promise<{
4
+ fee: BigNumber;
5
+ accountCreationFee: BigNumber;
6
+ }>;
7
+ export default getEstimatedFees;
8
+ //# sourceMappingURL=getEstimatedFees.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getEstimatedFees.d.ts","sourceRoot":"","sources":["../../src/bridge/getEstimatedFees.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,QAAA,MAAM,gBAAgB,gBACP,WAAW,WACf,MAAM;SAEV,SAAS;wBACM,SAAS;EAK9B,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { getFees } from "../api";
2
+ const getEstimatedFees = async (transaction, address) => {
3
+ const { fee, accountCreationFee } = await getFees(transaction, address);
4
+ return { fee, accountCreationFee };
5
+ };
6
+ export default getEstimatedFees;
7
+ //# sourceMappingURL=getEstimatedFees.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getEstimatedFees.js","sourceRoot":"","sources":["../../src/bridge/getEstimatedFees.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAGjC,MAAM,gBAAgB,GAAG,KAAK,EAC5B,WAAwB,EACxB,OAAe,EAId,EAAE;IACH,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,MAAM,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IAExE,OAAO,EAAE,GAAG,EAAE,kBAAkB,EAAE,CAAC;AACrC,CAAC,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Transaction, MinaAccount, TransactionStatus } from "../types/common";
2
+ import { AccountBridge } from "@ledgerhq/types-live";
3
+ declare const getTransactionStatus: AccountBridge<Transaction, MinaAccount, TransactionStatus>["getTransactionStatus"];
4
+ export default getTransactionStatus;
5
+ //# sourceMappingURL=getTransactionStatus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,iBAAiB,EAAkB,MAAM,iBAAiB,CAAC;AAEnG,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAIrD,QAAA,MAAM,oBAAoB,EAAE,aAAa,CACvC,WAAW,EACX,WAAW,EACX,iBAAiB,CAClB,CAAC,sBAAsB,CAiEvB,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import { NotEnoughBalance, RecipientRequired, InvalidAddress, FeeNotLoaded, AmountRequired, InvalidAddressBecauseDestinationIsAlsoSource, } from "@ledgerhq/errors";
3
+ import { isValidAddress, isValidMemo, getMaxAmount, getTotalSpent } from "../common-logic";
4
+ import { AccountCreationFeeWarning, InvalidMemoMina, AmountTooSmall } from "./errors";
5
+ import { formatCurrencyUnit } from "@ledgerhq/coin-framework/currencies";
6
+ const getTransactionStatus = async (a, t) => {
7
+ const errors = {};
8
+ const warnings = {};
9
+ const useAllAmount = !!t.useAllAmount;
10
+ if (t.fees.fee.lte(0)) {
11
+ errors.fees = new FeeNotLoaded();
12
+ }
13
+ if (!t.recipient) {
14
+ errors.recipient = new RecipientRequired();
15
+ }
16
+ if (t.recipient && !isValidAddress(t.recipient)) {
17
+ errors.recipient = new InvalidAddress("", {
18
+ currencyName: a.currency.name,
19
+ });
20
+ }
21
+ if (t.memo && !isValidMemo(t.memo)) {
22
+ errors.transaction = new InvalidMemoMina();
23
+ }
24
+ if (t.recipient === a.freshAddress) {
25
+ errors.recipient = new InvalidAddressBecauseDestinationIsAlsoSource();
26
+ }
27
+ if (t.fees?.accountCreationFee.gt(0)) {
28
+ const fee = formatCurrencyUnit(a.currency.units[0], t.fees.accountCreationFee, {
29
+ showCode: true,
30
+ disableRounding: true,
31
+ });
32
+ warnings.recipient = new AccountCreationFeeWarning(undefined, {
33
+ fee,
34
+ });
35
+ if (t.amount.lt(t.fees.accountCreationFee) && t.amount.gt(0)) {
36
+ errors.amount = new AmountTooSmall(undefined, {
37
+ amount: fee,
38
+ });
39
+ }
40
+ }
41
+ const estimatedFees = t.fees.fee || new BigNumber(0);
42
+ const maxAmountWithFees = getMaxAmount(a, t, estimatedFees);
43
+ const totalSpent = getTotalSpent(a, t, estimatedFees);
44
+ const amount = useAllAmount ? maxAmountWithFees : new BigNumber(t.amount);
45
+ if (amount.lte(0) && !t.useAllAmount) {
46
+ errors.amount = new AmountRequired();
47
+ }
48
+ if (amount.gt(maxAmountWithFees)) {
49
+ errors.amount = new NotEnoughBalance();
50
+ }
51
+ return Promise.resolve({
52
+ errors,
53
+ warnings,
54
+ estimatedFees,
55
+ amount,
56
+ totalSpent,
57
+ });
58
+ };
59
+ export default getTransactionStatus;
60
+ //# sourceMappingURL=getTransactionStatus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=getTransactionStatus.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,133 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import { NotEnoughBalance, RecipientRequired, InvalidAddress, FeeNotLoaded, AmountRequired, InvalidAddressBecauseDestinationIsAlsoSource, } from "@ledgerhq/errors";
3
+ import { AccountCreationFeeWarning, InvalidMemoMina, AmountTooSmall } from "./errors";
4
+ import getTransactionStatus from "./getTransactionStatus";
5
+ import { createMockAccount, createMockTransaction } from "../test/fixtures";
6
+ import { formatCurrencyUnit } from "@ledgerhq/coin-framework/currencies";
7
+ import getEstimatedFees from "./getEstimatedFees";
8
+ // Mock dependencies
9
+ jest.mock("@ledgerhq/coin-framework/currencies", () => ({
10
+ formatCurrencyUnit: jest.fn().mockReturnValue("0.1 MINA"),
11
+ }));
12
+ jest.mock("./getEstimatedFees");
13
+ describe("getTransactionStatus", () => {
14
+ // Standard test fixtures
15
+ const mockAccount = createMockAccount();
16
+ const mockTransaction = createMockTransaction({ amount: new BigNumber(800) });
17
+ beforeEach(() => {
18
+ jest.clearAllMocks();
19
+ });
20
+ it("should return a valid transaction status with no errors for valid inputs", async () => {
21
+ const result = await getTransactionStatus(mockAccount, mockTransaction);
22
+ expect(result.errors).toEqual({});
23
+ expect(result.warnings).toEqual({});
24
+ expect(result.estimatedFees).toEqual(new BigNumber(10));
25
+ expect(result.amount).toEqual(new BigNumber(800));
26
+ expect(result.totalSpent).toEqual(new BigNumber(810)); // amount + fee
27
+ });
28
+ it("should handle missing fees with FeeNotLoaded error", async () => {
29
+ getEstimatedFees.mockResolvedValue({
30
+ fee: new BigNumber(10),
31
+ accountCreationFee: new BigNumber(0),
32
+ });
33
+ // Using Type casting to handle the null fees for testing purposes
34
+ const txWithoutFees = {
35
+ ...mockTransaction,
36
+ fees: {
37
+ fee: new BigNumber(0),
38
+ accountCreationFee: new BigNumber(0),
39
+ },
40
+ };
41
+ const result = await getTransactionStatus(mockAccount, txWithoutFees);
42
+ expect(result.errors.fees).toBeInstanceOf(FeeNotLoaded);
43
+ });
44
+ it("should handle missing recipient with RecipientRequired error", async () => {
45
+ const txWithoutRecipient = {
46
+ ...mockTransaction,
47
+ recipient: "",
48
+ };
49
+ const result = await getTransactionStatus(mockAccount, txWithoutRecipient);
50
+ expect(result.errors.recipient).toBeInstanceOf(RecipientRequired);
51
+ });
52
+ it("should handle invalid recipient address with InvalidAddress error", async () => {
53
+ const txWithInvalidRecipient = {
54
+ ...mockTransaction,
55
+ recipient: "invalid-address",
56
+ };
57
+ const result = await getTransactionStatus(mockAccount, txWithInvalidRecipient);
58
+ expect(result.errors.recipient).toBeInstanceOf(InvalidAddress);
59
+ });
60
+ it("should handle self-transfer with InvalidAddressBecauseDestinationIsAlsoSource error", async () => {
61
+ const txWithSelfTransfer = {
62
+ ...mockTransaction,
63
+ recipient: mockAccount.freshAddress,
64
+ };
65
+ const result = await getTransactionStatus(mockAccount, txWithSelfTransfer);
66
+ expect(result.errors.recipient).toBeInstanceOf(InvalidAddressBecauseDestinationIsAlsoSource);
67
+ });
68
+ it("should handle invalid memo with InvalidMemoMina error", async () => {
69
+ const veryLongMemo = "a".repeat(33); // Create memo longer than MAX_MEMO_LENGTH (32)
70
+ const txWithInvalidMemo = {
71
+ ...mockTransaction,
72
+ memo: veryLongMemo,
73
+ };
74
+ const result = await getTransactionStatus(mockAccount, txWithInvalidMemo);
75
+ expect(result.errors.transaction).toBeInstanceOf(InvalidMemoMina);
76
+ });
77
+ it("should add AccountCreationFeeWarning when account creation fee is present", async () => {
78
+ const txWithAccountCreationFee = {
79
+ ...mockTransaction,
80
+ fees: {
81
+ fee: new BigNumber(10),
82
+ accountCreationFee: new BigNumber(100),
83
+ },
84
+ };
85
+ const result = await getTransactionStatus(mockAccount, txWithAccountCreationFee);
86
+ expect(result.warnings.recipient).toBeInstanceOf(AccountCreationFeeWarning);
87
+ expect(formatCurrencyUnit).toHaveBeenCalled();
88
+ });
89
+ it("should add AmountTooSmall error when amount is less than account creation fee", async () => {
90
+ const txWithSmallAmount = {
91
+ ...mockTransaction,
92
+ amount: new BigNumber(50),
93
+ fees: {
94
+ fee: new BigNumber(10),
95
+ accountCreationFee: new BigNumber(100),
96
+ },
97
+ };
98
+ const result = await getTransactionStatus(mockAccount, txWithSmallAmount);
99
+ expect(result.errors.amount).toBeInstanceOf(AmountTooSmall);
100
+ });
101
+ it("should handle zero amount with AmountRequired error when useAllAmount is false", async () => {
102
+ const txWithZeroAmount = {
103
+ ...mockTransaction,
104
+ amount: new BigNumber(0),
105
+ useAllAmount: false,
106
+ };
107
+ const result = await getTransactionStatus(mockAccount, txWithZeroAmount);
108
+ expect(result.errors.amount).toBeInstanceOf(AmountRequired);
109
+ });
110
+ it("should handle amount greater than max with NotEnoughBalance error", async () => {
111
+ // Account has spendable balance of 900
112
+ const txWithTooLargeAmount = {
113
+ ...mockTransaction,
114
+ amount: new BigNumber(1000),
115
+ useAllAmount: false,
116
+ };
117
+ const result = await getTransactionStatus(mockAccount, txWithTooLargeAmount);
118
+ expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
119
+ });
120
+ it("should calculate correct amount and totalSpent when useAllAmount is true", async () => {
121
+ const txWithUseAllAmount = {
122
+ ...mockTransaction,
123
+ amount: new BigNumber(0), // Amount should be ignored when useAllAmount is true
124
+ useAllAmount: true,
125
+ };
126
+ const result = await getTransactionStatus(mockAccount, txWithUseAllAmount);
127
+ // Should return spendableBalance - fee as the amount
128
+ expect(result.amount).toEqual(new BigNumber(890)); // spendableBalance(900) - fee(10)
129
+ expect(result.totalSpent).toEqual(new BigNumber(900)); // spendableBalance
130
+ expect(result.errors).toEqual({});
131
+ });
132
+ });
133
+ //# sourceMappingURL=getTransactionStatus.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.test.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import type { AccountBridge, CurrencyBridge } from "@ledgerhq/types-live";
2
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
3
+ import type { Transaction } from "../types/common";
4
+ import { MinaSigner } from "../types/signer";
5
+ import { MinaCoinConfig } from "../config";
6
+ import makeCliTools from "./cli-transaction";
7
+ export { makeCliTools };
8
+ export declare function buildCurrencyBridge(signerContext: SignerContext<MinaSigner>): CurrencyBridge;
9
+ export declare function buildAccountBridge(signerContext: SignerContext<MinaSigner>): AccountBridge<Transaction>;
10
+ export declare function createBridges(signerContext: SignerContext<MinaSigner>, coinConfig: MinaCoinConfig): {
11
+ currencyBridge: CurrencyBridge;
12
+ accountBridge: AccountBridge<Transaction>;
13
+ };
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAO1E,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAGnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAiB,MAAM,WAAW,CAAC;AAO1D,OAAO,YAAY,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,YAAY,EAAE,CAAC;AAExB,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,GAAG,cAAc,CAa5F;AAED,wBAAgB,kBAAkB,CAChC,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,GACvC,aAAa,CAAC,WAAW,CAAC,CAkB5B;AAED,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,EACxC,UAAU,EAAE,cAAc;;;EAQ3B"}
@@ -0,0 +1,50 @@
1
+ import { makeAccountBridgeReceive, getSerializedAddressParameters, updateTransaction, makeScanAccounts, } from "@ledgerhq/coin-framework/bridge/jsHelpers";
2
+ import getAddressWrapper from "@ledgerhq/coin-framework/bridge/getAddressWrapper";
3
+ import resolver from "../signer/getAddress";
4
+ import { sync, getAccountShape } from "./synchronisation";
5
+ import { setCoinConfig } from "../config";
6
+ import broadcast from "./broadcast";
7
+ import { createTransaction } from "./createTransaction";
8
+ import estimateMaxSpendable from "./estimateMaxSpendable";
9
+ import getTransactionStatus from "./getTransactionStatus";
10
+ import { prepareTransaction } from "./prepareTransaction";
11
+ import buildSignOperation from "./signOperation";
12
+ import makeCliTools from "./cli-transaction";
13
+ export { makeCliTools };
14
+ export function buildCurrencyBridge(signerContext) {
15
+ const getAddress = resolver(signerContext);
16
+ const scanAccounts = makeScanAccounts({
17
+ getAccountShape,
18
+ getAddressFn: getAddress,
19
+ });
20
+ return {
21
+ preload: async () => Promise.resolve({}),
22
+ hydrate: () => { },
23
+ scanAccounts,
24
+ };
25
+ }
26
+ export function buildAccountBridge(signerContext) {
27
+ const getAddress = resolver(signerContext);
28
+ const receive = makeAccountBridgeReceive(getAddressWrapper(getAddress));
29
+ const signOperation = buildSignOperation(signerContext);
30
+ return {
31
+ estimateMaxSpendable,
32
+ createTransaction,
33
+ updateTransaction,
34
+ getTransactionStatus,
35
+ prepareTransaction,
36
+ sync,
37
+ receive,
38
+ signOperation,
39
+ broadcast,
40
+ getSerializedAddressParameters,
41
+ };
42
+ }
43
+ export function createBridges(signerContext, coinConfig) {
44
+ setCoinConfig(coinConfig);
45
+ return {
46
+ currencyBridge: buildCurrencyBridge(signerContext),
47
+ accountBridge: buildAccountBridge(signerContext),
48
+ };
49
+ }
50
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,wBAAwB,EACxB,8BAA8B,EAC9B,iBAAiB,EACjB,gBAAgB,GACjB,MAAM,2CAA2C,CAAC;AAEnD,OAAO,iBAAiB,MAAM,mDAAmD,CAAC;AAElF,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAE1D,OAAO,EAAkB,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1D,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAC1D,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,kBAAkB,MAAM,iBAAiB,CAAC;AACjD,OAAO,YAAY,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,YAAY,EAAE,CAAC;AAExB,MAAM,UAAU,mBAAmB,CAAC,aAAwC;IAC1E,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,YAAY,GAAG,gBAAgB,CAAC;QACpC,eAAe;QACf,YAAY,EAAE,UAAU;KACzB,CAAC,CAAC;IAEH,OAAO;QACL,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACxC,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,YAAY;KACb,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAChC,aAAwC;IAExC,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,OAAO,GAAG,wBAAwB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB;QACpB,iBAAiB;QACjB,iBAAiB;QACjB,oBAAoB;QACpB,kBAAkB;QAClB,IAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS;QACT,8BAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,aAAwC,EACxC,UAA0B;IAE1B,aAAa,CAAC,UAAU,CAAC,CAAC;IAE1B,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/bridge/index.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,30 @@
1
+ import { createBridges } from ".";
2
+ describe("createBridges", () => {
3
+ let bridges;
4
+ beforeEach(() => {
5
+ bridges = createBridges(undefined, {});
6
+ });
7
+ it("should return both bridges interface", () => {
8
+ expect(bridges.accountBridge).toBeDefined();
9
+ expect(bridges.currencyBridge).toBeDefined();
10
+ });
11
+ it("should have a currency bridge with required methods", () => {
12
+ expect(bridges.currencyBridge).toBeDefined();
13
+ expect(bridges.currencyBridge.preload).toBeDefined();
14
+ expect(bridges.currencyBridge.hydrate).toBeDefined();
15
+ expect(bridges.currencyBridge.scanAccounts).toBeDefined();
16
+ });
17
+ it("should have an account bridge with required methods", () => {
18
+ expect(bridges.accountBridge).toBeDefined();
19
+ expect(bridges.accountBridge.broadcast).toBeDefined();
20
+ expect(bridges.accountBridge.createTransaction).toBeDefined();
21
+ expect(bridges.accountBridge.estimateMaxSpendable).toBeDefined();
22
+ expect(bridges.accountBridge.getTransactionStatus).toBeDefined();
23
+ expect(bridges.accountBridge.prepareTransaction).toBeDefined();
24
+ expect(bridges.accountBridge.receive).toBeDefined();
25
+ expect(bridges.accountBridge.signOperation).toBeDefined();
26
+ expect(bridges.accountBridge.sync).toBeDefined();
27
+ expect(bridges.accountBridge.updateTransaction).toBeDefined();
28
+ });
29
+ });
30
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/bridge/index.test.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAC;AAIlC,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,OAAyC,CAAC;IAC9C,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,aAAa,CACrB,SAAiD,EACjD,EAA+B,CAChC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;QAC7C,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QACtD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;QAC9D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,WAAW,EAAE,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,WAAW,EAAE,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC1D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;IAChE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { MinaAccount, Transaction } from "../types/common";
3
+ export declare const prepareTransaction: AccountBridge<Transaction, MinaAccount>["prepareTransaction"];
4
+ //# sourceMappingURL=prepareTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG9D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG3D,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAC5C,WAAW,EACX,WAAW,CACZ,CAAC,oBAAoB,CAarB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { updateTransaction } from "@ledgerhq/coin-framework/bridge/jsHelpers";
2
+ import estimateMaxSpendable from "./estimateMaxSpendable";
3
+ import getEstimatedFees from "./getEstimatedFees";
4
+ import { getNonce } from "../api";
5
+ export const prepareTransaction = async (a, t) => {
6
+ const { fee, accountCreationFee } = await getEstimatedFees(t, a.freshAddress);
7
+ const amount = t.useAllAmount
8
+ ? await estimateMaxSpendable({
9
+ account: a,
10
+ transaction: t,
11
+ })
12
+ : t.amount;
13
+ const nonce = await getNonce(t, a.freshAddress);
14
+ return updateTransaction(t, { fees: { fee, accountCreationFee }, amount, nonce });
15
+ };
16
+ //# sourceMappingURL=prepareTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAE9E,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAC1D,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAElD,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,CAAC,MAAM,kBAAkB,GAGL,KAAK,EAAE,CAAU,EAAE,CAAc,EAAE,EAAE;IAC7D,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,MAAM,gBAAgB,CAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAE9E,MAAM,MAAM,GAAG,CAAC,CAAC,YAAY;QAC3B,CAAC,CAAC,MAAM,oBAAoB,CAAC;YACzB,OAAO,EAAE,CAAC;YACV,WAAW,EAAE,CAAC;SACf,CAAC;QACJ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAEb,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAEhD,OAAO,iBAAiB,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;AACpF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=prepareTransaction.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepareTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,38 @@
1
+ import BigNumber from "bignumber.js";
2
+ import estimateFees from "./getEstimatedFees";
3
+ import { getNonce } from "../api";
4
+ import { prepareTransaction } from "./prepareTransaction";
5
+ jest.mock("../api");
6
+ jest.mock("./getEstimatedFees");
7
+ describe("prepareTransaction", () => {
8
+ let estimateFeesSpy;
9
+ let getNonceSpy;
10
+ beforeEach(() => {
11
+ getNonceSpy = jest.spyOn({ getNonce }, "getNonce");
12
+ estimateFeesSpy = jest.spyOn({ estimateFees }, "estimateFees");
13
+ estimateFeesSpy.mockResolvedValue({
14
+ fee: new BigNumber(1),
15
+ accountCreationFee: new BigNumber(1),
16
+ });
17
+ getNonceSpy.mockResolvedValue(1);
18
+ });
19
+ it("should update fee fields if it's different", async () => {
20
+ const oldTx = {
21
+ fees: { fee: new BigNumber(0), accountCreationFee: new BigNumber(0) },
22
+ };
23
+ const newTx = await prepareTransaction({}, oldTx);
24
+ expect(newTx.fees.fee).toEqual(new BigNumber(1));
25
+ expect(newTx.fees.accountCreationFee).toEqual(new BigNumber(1));
26
+ expect(getNonceSpy).toHaveBeenCalledTimes(1);
27
+ expect(getNonceSpy).toHaveBeenCalledWith(oldTx, undefined);
28
+ });
29
+ it("should update nonce if it's different", async () => {
30
+ const oldTx = {
31
+ nonce: 0,
32
+ fees: { fee: new BigNumber(0), accountCreationFee: new BigNumber(0) },
33
+ };
34
+ const newTx = await prepareTransaction({}, oldTx);
35
+ expect(newTx.nonce).toEqual(1);
36
+ });
37
+ });
38
+ //# sourceMappingURL=prepareTransaction.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepareTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.test.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,YAAY,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAI1D,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AACpB,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;AAEhC,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAI,eAAiC,CAAC;IACtC,IAAI,WAA6B,CAAC;IAClC,UAAU,CAAC,GAAG,EAAE;QACd,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,EAAE,UAAU,CAAC,CAAC;QACnD,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,YAAY,EAAE,EAAE,cAAc,CAAC,CAAC;QAC/D,eAAe,CAAC,iBAAiB,CAAC;YAChC,GAAG,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;YACrB,kBAAkB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;SACrC,CAAC,CAAC;QACH,WAAW,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,KAAK,GAAG;YACZ,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE;SACtE,CAAC;QACF,MAAM,KAAK,GAAG,MAAM,kBAAkB,CAAC,EAAa,EAAE,KAAoB,CAAC,CAAC;QAC5E,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,KAAK,GAAG;YACZ,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE;SACtE,CAAC;QACF,MAAM,KAAK,GAAG,MAAM,kBAAkB,CAAC,EAAa,EAAE,KAAoB,CAAC,CAAC;QAC5E,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import type { MinaOperation, Transaction } from "../types/common";
3
+ import type { Account, AccountBridge } from "@ledgerhq/types-live";
4
+ import { MinaSigner } from "../types/signer";
5
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
6
+ export declare const buildOptimisticOperation: (account: Account, transaction: Transaction, fee: BigNumber) => MinaOperation;
7
+ /**
8
+ * Sign Transaction with Ledger hardware
9
+ */
10
+ export declare const buildSignOperation: (signerContext: SignerContext<MinaSigner>) => AccountBridge<Transaction>["signOperation"];
11
+ export default buildSignOperation;
12
+ //# sourceMappingURL=signOperation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,KAAK,EAAE,aAAa,EAAyB,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACzF,OAAO,KAAK,EACV,OAAO,EAIP,aAAa,EACd,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAiB,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAKhE,eAAO,MAAM,wBAAwB,YAC1B,OAAO,eACH,WAAW,OACnB,SAAS,KACb,aA4BF,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,kBAAkB,kBACb,cAAc,UAAU,CAAC,KAAG,cAAc,WAAW,CAAC,CAAC,eAAe,CAqDlF,CAAC;AAEP,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,64 @@
1
+ import { BigNumber } from "bignumber.js";
2
+ import { Observable } from "rxjs";
3
+ import { FeeNotLoaded } from "@ledgerhq/errors";
4
+ import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
5
+ import { buildTransaction } from "./buildTransaction";
6
+ import { reEncodeRawSignature } from "../common-logic";
7
+ import invariant from "invariant";
8
+ export const buildOptimisticOperation = (account, transaction, fee) => {
9
+ let value = new BigNumber(transaction.amount).plus(fee);
10
+ if (transaction.fees?.accountCreationFee.gt(0)) {
11
+ value = value.minus(transaction.fees.accountCreationFee);
12
+ }
13
+ const type = "OUT";
14
+ const operation = {
15
+ id: encodeOperationId(account.id, "", type),
16
+ hash: "",
17
+ type,
18
+ value,
19
+ fee,
20
+ blockHash: null,
21
+ blockHeight: null,
22
+ senders: [account.freshAddress],
23
+ recipients: [transaction.recipient].filter(Boolean),
24
+ accountId: account.id,
25
+ date: new Date(),
26
+ extra: {
27
+ memo: transaction.memo,
28
+ accountCreationFee: transaction.fees.accountCreationFee.toString(),
29
+ },
30
+ };
31
+ return operation;
32
+ };
33
+ /**
34
+ * Sign Transaction with Ledger hardware
35
+ */
36
+ export const buildSignOperation = (signerContext) => ({ account, transaction, deviceId, }) => new Observable(o => {
37
+ async function main() {
38
+ o.next({ type: "device-signature-requested" });
39
+ if (!transaction.fees) {
40
+ throw new FeeNotLoaded();
41
+ }
42
+ const unsigned = await buildTransaction(account, transaction);
43
+ const { signature } = (await signerContext(deviceId, signer => signer.signTransaction(unsigned)));
44
+ invariant(signature, "signature should be defined if user accepted");
45
+ const encodedSignature = reEncodeRawSignature(signature);
46
+ const signedTransaction = {
47
+ transaction: unsigned,
48
+ signature: encodedSignature,
49
+ };
50
+ o.next({ type: "device-signature-granted" });
51
+ const operation = buildOptimisticOperation(account, transaction, transaction.fees.fee ?? new BigNumber(0));
52
+ const signedSerializedTx = JSON.stringify(signedTransaction);
53
+ o.next({
54
+ type: "signed",
55
+ signedOperation: {
56
+ operation,
57
+ signature: signedSerializedTx,
58
+ },
59
+ });
60
+ }
61
+ main().then(() => o.complete(), e => o.error(e));
62
+ });
63
+ export default buildSignOperation;
64
+ //# sourceMappingURL=signOperation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=signOperation.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signOperation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.test.ts"],"names":[],"mappings":""}