@ledgerhq/coin-canton 0.2.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 (424) hide show
  1. package/.env.integ.test.example +2 -0
  2. package/.eslintrc.js +22 -0
  3. package/.turbo/turbo-build.log +4 -0
  4. package/.unimportedrc.json +29 -0
  5. package/CHANGELOG.md +14 -0
  6. package/LICENSE.txt +21 -0
  7. package/jest.config.js +21 -0
  8. package/jest.integ.config.js +8 -0
  9. package/lib/api/index.d.ts +4 -0
  10. package/lib/api/index.d.ts.map +1 -0
  11. package/lib/api/index.js +44 -0
  12. package/lib/api/index.js.map +1 -0
  13. package/lib/api/index.test.d.ts +2 -0
  14. package/lib/api/index.test.d.ts.map +1 -0
  15. package/lib/api/index.test.js +16 -0
  16. package/lib/api/index.test.js.map +1 -0
  17. package/lib/bridge/broadcast.d.ts +4 -0
  18. package/lib/bridge/broadcast.d.ts.map +1 -0
  19. package/lib/bridge/broadcast.js +11 -0
  20. package/lib/bridge/broadcast.js.map +1 -0
  21. package/lib/bridge/broadcast.test.d.ts +2 -0
  22. package/lib/bridge/broadcast.test.d.ts.map +1 -0
  23. package/lib/bridge/broadcast.test.js +35 -0
  24. package/lib/bridge/broadcast.test.js.map +1 -0
  25. package/lib/bridge/createTransaction.d.ts +4 -0
  26. package/lib/bridge/createTransaction.d.ts.map +1 -0
  27. package/lib/bridge/createTransaction.js +19 -0
  28. package/lib/bridge/createTransaction.js.map +1 -0
  29. package/lib/bridge/createTransaction.test.d.ts +2 -0
  30. package/lib/bridge/createTransaction.test.d.ts.map +1 -0
  31. package/lib/bridge/createTransaction.test.js +12 -0
  32. package/lib/bridge/createTransaction.test.js.map +1 -0
  33. package/lib/bridge/deviceTransactionConfig.d.ts +11 -0
  34. package/lib/bridge/deviceTransactionConfig.d.ts.map +1 -0
  35. package/lib/bridge/deviceTransactionConfig.js +21 -0
  36. package/lib/bridge/deviceTransactionConfig.js.map +1 -0
  37. package/lib/bridge/deviceTransactionConfig.test.d.ts +2 -0
  38. package/lib/bridge/deviceTransactionConfig.test.d.ts.map +1 -0
  39. package/lib/bridge/deviceTransactionConfig.test.js +22 -0
  40. package/lib/bridge/deviceTransactionConfig.test.js.map +1 -0
  41. package/lib/bridge/estimateMaxSpendable.d.ts +4 -0
  42. package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
  43. package/lib/bridge/estimateMaxSpendable.js +26 -0
  44. package/lib/bridge/estimateMaxSpendable.js.map +1 -0
  45. package/lib/bridge/getTransactionStatus.d.ts +4 -0
  46. package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
  47. package/lib/bridge/getTransactionStatus.js +78 -0
  48. package/lib/bridge/getTransactionStatus.js.map +1 -0
  49. package/lib/bridge/index.d.ts +11 -0
  50. package/lib/bridge/index.d.ts.map +1 -0
  51. package/lib/bridge/index.js +51 -0
  52. package/lib/bridge/index.js.map +1 -0
  53. package/lib/bridge/index.test.d.ts +2 -0
  54. package/lib/bridge/index.test.d.ts.map +1 -0
  55. package/lib/bridge/index.test.js +31 -0
  56. package/lib/bridge/index.test.js.map +1 -0
  57. package/lib/bridge/prepareTransaction.d.ts +4 -0
  58. package/lib/bridge/prepareTransaction.d.ts.map +1 -0
  59. package/lib/bridge/prepareTransaction.js +20 -0
  60. package/lib/bridge/prepareTransaction.js.map +1 -0
  61. package/lib/bridge/prepareTransaction.test.d.ts +2 -0
  62. package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
  63. package/lib/bridge/prepareTransaction.test.js +30 -0
  64. package/lib/bridge/prepareTransaction.test.js.map +1 -0
  65. package/lib/bridge/signOperation.d.ts +5 -0
  66. package/lib/bridge/signOperation.d.ts.map +1 -0
  67. package/lib/bridge/signOperation.js +71 -0
  68. package/lib/bridge/signOperation.js.map +1 -0
  69. package/lib/bridge/sync.d.ts +3 -0
  70. package/lib/bridge/sync.d.ts.map +1 -0
  71. package/lib/bridge/sync.js +86 -0
  72. package/lib/bridge/sync.js.map +1 -0
  73. package/lib/bridge/transaction.d.ts +15 -0
  74. package/lib/bridge/transaction.d.ts.map +1 -0
  75. package/lib/bridge/transaction.js +50 -0
  76. package/lib/bridge/transaction.js.map +1 -0
  77. package/lib/bridge/updateTransaction.d.ts +4 -0
  78. package/lib/bridge/updateTransaction.d.ts.map +1 -0
  79. package/lib/bridge/updateTransaction.js +17 -0
  80. package/lib/bridge/updateTransaction.js.map +1 -0
  81. package/lib/common-logic/account/getBalance.d.ts +3 -0
  82. package/lib/common-logic/account/getBalance.d.ts.map +1 -0
  83. package/lib/common-logic/account/getBalance.js +10 -0
  84. package/lib/common-logic/account/getBalance.js.map +1 -0
  85. package/lib/common-logic/account/getNextSequence.d.ts +2 -0
  86. package/lib/common-logic/account/getNextSequence.d.ts.map +1 -0
  87. package/lib/common-logic/account/getNextSequence.js +9 -0
  88. package/lib/common-logic/account/getNextSequence.js.map +1 -0
  89. package/lib/common-logic/common.d.ts +3 -0
  90. package/lib/common-logic/common.d.ts.map +1 -0
  91. package/lib/common-logic/common.js +11 -0
  92. package/lib/common-logic/common.js.map +1 -0
  93. package/lib/common-logic/history/lastBlock.d.ts +3 -0
  94. package/lib/common-logic/history/lastBlock.d.ts.map +1 -0
  95. package/lib/common-logic/history/lastBlock.js +13 -0
  96. package/lib/common-logic/history/lastBlock.js.map +1 -0
  97. package/lib/common-logic/history/listOperations.d.ts +11 -0
  98. package/lib/common-logic/history/listOperations.d.ts.map +1 -0
  99. package/lib/common-logic/history/listOperations.js +52 -0
  100. package/lib/common-logic/history/listOperations.js.map +1 -0
  101. package/lib/common-logic/index.d.ts +11 -0
  102. package/lib/common-logic/index.d.ts.map +1 -0
  103. package/lib/common-logic/index.js +24 -0
  104. package/lib/common-logic/index.js.map +1 -0
  105. package/lib/common-logic/transaction/broadcast.d.ts +2 -0
  106. package/lib/common-logic/transaction/broadcast.d.ts.map +1 -0
  107. package/lib/common-logic/transaction/broadcast.js +9 -0
  108. package/lib/common-logic/transaction/broadcast.js.map +1 -0
  109. package/lib/common-logic/transaction/combine.d.ts +2 -0
  110. package/lib/common-logic/transaction/combine.d.ts.map +1 -0
  111. package/lib/common-logic/transaction/combine.js +9 -0
  112. package/lib/common-logic/transaction/combine.js.map +1 -0
  113. package/lib/common-logic/transaction/craftTransaction.d.ts +15 -0
  114. package/lib/common-logic/transaction/craftTransaction.d.ts.map +1 -0
  115. package/lib/common-logic/transaction/craftTransaction.js +20 -0
  116. package/lib/common-logic/transaction/craftTransaction.js.map +1 -0
  117. package/lib/common-logic/transaction/estimateFees.d.ts +2 -0
  118. package/lib/common-logic/transaction/estimateFees.d.ts.map +1 -0
  119. package/lib/common-logic/transaction/estimateFees.js +21 -0
  120. package/lib/common-logic/transaction/estimateFees.js.map +1 -0
  121. package/lib/common-logic/utils.d.ts +6 -0
  122. package/lib/common-logic/utils.d.ts.map +1 -0
  123. package/lib/common-logic/utils.js +22 -0
  124. package/lib/common-logic/utils.js.map +1 -0
  125. package/lib/config.d.ts +12 -0
  126. package/lib/config.d.ts.map +1 -0
  127. package/lib/config.js +9 -0
  128. package/lib/config.js.map +1 -0
  129. package/lib/index.d.ts +4 -0
  130. package/lib/index.d.ts.map +1 -0
  131. package/lib/index.js +21 -0
  132. package/lib/index.js.map +1 -0
  133. package/lib/network/indexer.d.ts +6 -0
  134. package/lib/network/indexer.d.ts.map +1 -0
  135. package/lib/network/indexer.js +19 -0
  136. package/lib/network/indexer.js.map +1 -0
  137. package/lib/network/mock-network.d.ts +5 -0
  138. package/lib/network/mock-network.d.ts.map +1 -0
  139. package/lib/network/mock-network.js +29 -0
  140. package/lib/network/mock-network.js.map +1 -0
  141. package/lib/network/node.d.ts +12 -0
  142. package/lib/network/node.d.ts.map +1 -0
  143. package/lib/network/node.js +92 -0
  144. package/lib/network/node.js.map +1 -0
  145. package/lib/network/types.d.ts +47 -0
  146. package/lib/network/types.d.ts.map +1 -0
  147. package/lib/network/types.js +7 -0
  148. package/lib/network/types.js.map +1 -0
  149. package/lib/signer/getAddress.d.ts +6 -0
  150. package/lib/signer/getAddress.d.ts.map +1 -0
  151. package/lib/signer/getAddress.js +14 -0
  152. package/lib/signer/getAddress.js.map +1 -0
  153. package/lib/signer/index.d.ts +6 -0
  154. package/lib/signer/index.d.ts.map +1 -0
  155. package/lib/signer/index.js +11 -0
  156. package/lib/signer/index.js.map +1 -0
  157. package/lib/test/bot-deviceActions.d.ts +4 -0
  158. package/lib/test/bot-deviceActions.d.ts.map +1 -0
  159. package/lib/test/bot-deviceActions.js +44 -0
  160. package/lib/test/bot-deviceActions.js.map +1 -0
  161. package/lib/test/bot-specs.d.ts +2 -0
  162. package/lib/test/bot-specs.d.ts.map +1 -0
  163. package/lib/test/bot-specs.js +79 -0
  164. package/lib/test/bot-specs.js.map +1 -0
  165. package/lib/test/bridgeDatasetTest.d.ts +5 -0
  166. package/lib/test/bridgeDatasetTest.d.ts.map +1 -0
  167. package/lib/test/bridgeDatasetTest.js +148 -0
  168. package/lib/test/bridgeDatasetTest.js.map +1 -0
  169. package/lib/test/cli.d.ts +26 -0
  170. package/lib/test/cli.d.ts.map +1 -0
  171. package/lib/test/cli.js +36 -0
  172. package/lib/test/cli.js.map +1 -0
  173. package/lib/test/index.d.ts +5 -0
  174. package/lib/test/index.d.ts.map +1 -0
  175. package/lib/test/index.js +26 -0
  176. package/lib/test/index.js.map +1 -0
  177. package/lib/types/bridge.d.ts +23 -0
  178. package/lib/types/bridge.d.ts.map +1 -0
  179. package/lib/types/bridge.js +3 -0
  180. package/lib/types/bridge.js.map +1 -0
  181. package/lib/types/errors.d.ts +4 -0
  182. package/lib/types/errors.d.ts.map +1 -0
  183. package/lib/types/errors.js +6 -0
  184. package/lib/types/errors.js.map +1 -0
  185. package/lib/types/index.d.ts +13 -0
  186. package/lib/types/index.d.ts.map +1 -0
  187. package/lib/types/index.js +19 -0
  188. package/lib/types/index.js.map +1 -0
  189. package/lib/types/signer.d.ts +10 -0
  190. package/lib/types/signer.d.ts.map +1 -0
  191. package/lib/types/signer.js +3 -0
  192. package/lib/types/signer.js.map +1 -0
  193. package/lib-es/api/index.d.ts +4 -0
  194. package/lib-es/api/index.d.ts.map +1 -0
  195. package/lib-es/api/index.js +38 -0
  196. package/lib-es/api/index.js.map +1 -0
  197. package/lib-es/api/index.test.d.ts +2 -0
  198. package/lib-es/api/index.test.d.ts.map +1 -0
  199. package/lib-es/api/index.test.js +14 -0
  200. package/lib-es/api/index.test.js.map +1 -0
  201. package/lib-es/bridge/broadcast.d.ts +4 -0
  202. package/lib-es/bridge/broadcast.d.ts.map +1 -0
  203. package/lib-es/bridge/broadcast.js +7 -0
  204. package/lib-es/bridge/broadcast.js.map +1 -0
  205. package/lib-es/bridge/broadcast.test.d.ts +2 -0
  206. package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
  207. package/lib-es/bridge/broadcast.test.js +33 -0
  208. package/lib-es/bridge/broadcast.test.js.map +1 -0
  209. package/lib-es/bridge/createTransaction.d.ts +4 -0
  210. package/lib-es/bridge/createTransaction.d.ts.map +1 -0
  211. package/lib-es/bridge/createTransaction.js +12 -0
  212. package/lib-es/bridge/createTransaction.js.map +1 -0
  213. package/lib-es/bridge/createTransaction.test.d.ts +2 -0
  214. package/lib-es/bridge/createTransaction.test.d.ts.map +1 -0
  215. package/lib-es/bridge/createTransaction.test.js +10 -0
  216. package/lib-es/bridge/createTransaction.test.js.map +1 -0
  217. package/lib-es/bridge/deviceTransactionConfig.d.ts +11 -0
  218. package/lib-es/bridge/deviceTransactionConfig.d.ts.map +1 -0
  219. package/lib-es/bridge/deviceTransactionConfig.js +19 -0
  220. package/lib-es/bridge/deviceTransactionConfig.js.map +1 -0
  221. package/lib-es/bridge/deviceTransactionConfig.test.d.ts +2 -0
  222. package/lib-es/bridge/deviceTransactionConfig.test.d.ts.map +1 -0
  223. package/lib-es/bridge/deviceTransactionConfig.test.js +17 -0
  224. package/lib-es/bridge/deviceTransactionConfig.test.js.map +1 -0
  225. package/lib-es/bridge/estimateMaxSpendable.d.ts +4 -0
  226. package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
  227. package/lib-es/bridge/estimateMaxSpendable.js +19 -0
  228. package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
  229. package/lib-es/bridge/getTransactionStatus.d.ts +4 -0
  230. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
  231. package/lib-es/bridge/getTransactionStatus.js +71 -0
  232. package/lib-es/bridge/getTransactionStatus.js.map +1 -0
  233. package/lib-es/bridge/index.d.ts +11 -0
  234. package/lib-es/bridge/index.d.ts.map +1 -0
  235. package/lib-es/bridge/index.js +45 -0
  236. package/lib-es/bridge/index.js.map +1 -0
  237. package/lib-es/bridge/index.test.d.ts +2 -0
  238. package/lib-es/bridge/index.test.d.ts.map +1 -0
  239. package/lib-es/bridge/index.test.js +29 -0
  240. package/lib-es/bridge/index.test.js.map +1 -0
  241. package/lib-es/bridge/prepareTransaction.d.ts +4 -0
  242. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
  243. package/lib-es/bridge/prepareTransaction.js +13 -0
  244. package/lib-es/bridge/prepareTransaction.js.map +1 -0
  245. package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
  246. package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
  247. package/lib-es/bridge/prepareTransaction.test.js +25 -0
  248. package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
  249. package/lib-es/bridge/signOperation.d.ts +5 -0
  250. package/lib-es/bridge/signOperation.d.ts.map +1 -0
  251. package/lib-es/bridge/signOperation.js +67 -0
  252. package/lib-es/bridge/signOperation.js.map +1 -0
  253. package/lib-es/bridge/sync.d.ts +3 -0
  254. package/lib-es/bridge/sync.d.ts.map +1 -0
  255. package/lib-es/bridge/sync.js +79 -0
  256. package/lib-es/bridge/sync.js.map +1 -0
  257. package/lib-es/bridge/transaction.d.ts +15 -0
  258. package/lib-es/bridge/transaction.d.ts.map +1 -0
  259. package/lib-es/bridge/transaction.js +44 -0
  260. package/lib-es/bridge/transaction.js.map +1 -0
  261. package/lib-es/bridge/updateTransaction.d.ts +4 -0
  262. package/lib-es/bridge/updateTransaction.d.ts.map +1 -0
  263. package/lib-es/bridge/updateTransaction.js +13 -0
  264. package/lib-es/bridge/updateTransaction.js.map +1 -0
  265. package/lib-es/common-logic/account/getBalance.d.ts +3 -0
  266. package/lib-es/common-logic/account/getBalance.d.ts.map +1 -0
  267. package/lib-es/common-logic/account/getBalance.js +7 -0
  268. package/lib-es/common-logic/account/getBalance.js.map +1 -0
  269. package/lib-es/common-logic/account/getNextSequence.d.ts +2 -0
  270. package/lib-es/common-logic/account/getNextSequence.d.ts.map +1 -0
  271. package/lib-es/common-logic/account/getNextSequence.js +6 -0
  272. package/lib-es/common-logic/account/getNextSequence.js.map +1 -0
  273. package/lib-es/common-logic/common.d.ts +3 -0
  274. package/lib-es/common-logic/common.d.ts.map +1 -0
  275. package/lib-es/common-logic/common.js +7 -0
  276. package/lib-es/common-logic/common.js.map +1 -0
  277. package/lib-es/common-logic/history/lastBlock.d.ts +3 -0
  278. package/lib-es/common-logic/history/lastBlock.d.ts.map +1 -0
  279. package/lib-es/common-logic/history/lastBlock.js +10 -0
  280. package/lib-es/common-logic/history/lastBlock.js.map +1 -0
  281. package/lib-es/common-logic/history/listOperations.d.ts +11 -0
  282. package/lib-es/common-logic/history/listOperations.d.ts.map +1 -0
  283. package/lib-es/common-logic/history/listOperations.js +49 -0
  284. package/lib-es/common-logic/history/listOperations.js.map +1 -0
  285. package/lib-es/common-logic/index.d.ts +11 -0
  286. package/lib-es/common-logic/index.d.ts.map +1 -0
  287. package/lib-es/common-logic/index.js +11 -0
  288. package/lib-es/common-logic/index.js.map +1 -0
  289. package/lib-es/common-logic/transaction/broadcast.d.ts +2 -0
  290. package/lib-es/common-logic/transaction/broadcast.d.ts.map +1 -0
  291. package/lib-es/common-logic/transaction/broadcast.js +6 -0
  292. package/lib-es/common-logic/transaction/broadcast.js.map +1 -0
  293. package/lib-es/common-logic/transaction/combine.d.ts +2 -0
  294. package/lib-es/common-logic/transaction/combine.d.ts.map +1 -0
  295. package/lib-es/common-logic/transaction/combine.js +6 -0
  296. package/lib-es/common-logic/transaction/combine.js.map +1 -0
  297. package/lib-es/common-logic/transaction/craftTransaction.d.ts +15 -0
  298. package/lib-es/common-logic/transaction/craftTransaction.d.ts.map +1 -0
  299. package/lib-es/common-logic/transaction/craftTransaction.js +17 -0
  300. package/lib-es/common-logic/transaction/craftTransaction.js.map +1 -0
  301. package/lib-es/common-logic/transaction/estimateFees.d.ts +2 -0
  302. package/lib-es/common-logic/transaction/estimateFees.d.ts.map +1 -0
  303. package/lib-es/common-logic/transaction/estimateFees.js +18 -0
  304. package/lib-es/common-logic/transaction/estimateFees.js.map +1 -0
  305. package/lib-es/common-logic/utils.d.ts +6 -0
  306. package/lib-es/common-logic/utils.d.ts.map +1 -0
  307. package/lib-es/common-logic/utils.js +13 -0
  308. package/lib-es/common-logic/utils.js.map +1 -0
  309. package/lib-es/config.d.ts +12 -0
  310. package/lib-es/config.d.ts.map +1 -0
  311. package/lib-es/config.js +4 -0
  312. package/lib-es/config.js.map +1 -0
  313. package/lib-es/index.d.ts +4 -0
  314. package/lib-es/index.d.ts.map +1 -0
  315. package/lib-es/index.js +3 -0
  316. package/lib-es/index.js.map +1 -0
  317. package/lib-es/network/indexer.d.ts +6 -0
  318. package/lib-es/network/indexer.d.ts.map +1 -0
  319. package/lib-es/network/indexer.js +12 -0
  320. package/lib-es/network/indexer.js.map +1 -0
  321. package/lib-es/network/mock-network.d.ts +5 -0
  322. package/lib-es/network/mock-network.d.ts.map +1 -0
  323. package/lib-es/network/mock-network.js +25 -0
  324. package/lib-es/network/mock-network.js.map +1 -0
  325. package/lib-es/network/node.d.ts +12 -0
  326. package/lib-es/network/node.d.ts.map +1 -0
  327. package/lib-es/network/node.js +80 -0
  328. package/lib-es/network/node.js.map +1 -0
  329. package/lib-es/network/types.d.ts +47 -0
  330. package/lib-es/network/types.d.ts.map +1 -0
  331. package/lib-es/network/types.js +4 -0
  332. package/lib-es/network/types.js.map +1 -0
  333. package/lib-es/signer/getAddress.d.ts +6 -0
  334. package/lib-es/signer/getAddress.d.ts.map +1 -0
  335. package/lib-es/signer/getAddress.js +12 -0
  336. package/lib-es/signer/getAddress.js.map +1 -0
  337. package/lib-es/signer/index.d.ts +6 -0
  338. package/lib-es/signer/index.d.ts.map +1 -0
  339. package/lib-es/signer/index.js +6 -0
  340. package/lib-es/signer/index.js.map +1 -0
  341. package/lib-es/test/bot-deviceActions.d.ts +4 -0
  342. package/lib-es/test/bot-deviceActions.d.ts.map +1 -0
  343. package/lib-es/test/bot-deviceActions.js +41 -0
  344. package/lib-es/test/bot-deviceActions.js.map +1 -0
  345. package/lib-es/test/bot-specs.d.ts +1 -0
  346. package/lib-es/test/bot-specs.d.ts.map +1 -0
  347. package/lib-es/test/bot-specs.js +78 -0
  348. package/lib-es/test/bot-specs.js.map +1 -0
  349. package/lib-es/test/bridgeDatasetTest.d.ts +5 -0
  350. package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -0
  351. package/lib-es/test/bridgeDatasetTest.js +142 -0
  352. package/lib-es/test/bridgeDatasetTest.js.map +1 -0
  353. package/lib-es/test/cli.d.ts +26 -0
  354. package/lib-es/test/cli.d.ts.map +1 -0
  355. package/lib-es/test/cli.js +30 -0
  356. package/lib-es/test/cli.js.map +1 -0
  357. package/lib-es/test/index.d.ts +5 -0
  358. package/lib-es/test/index.d.ts.map +1 -0
  359. package/lib-es/test/index.js +6 -0
  360. package/lib-es/test/index.js.map +1 -0
  361. package/lib-es/types/bridge.d.ts +23 -0
  362. package/lib-es/types/bridge.d.ts.map +1 -0
  363. package/lib-es/types/bridge.js +2 -0
  364. package/lib-es/types/bridge.js.map +1 -0
  365. package/lib-es/types/errors.d.ts +4 -0
  366. package/lib-es/types/errors.d.ts.map +1 -0
  367. package/lib-es/types/errors.js +3 -0
  368. package/lib-es/types/errors.js.map +1 -0
  369. package/lib-es/types/index.d.ts +13 -0
  370. package/lib-es/types/index.d.ts.map +1 -0
  371. package/lib-es/types/index.js +3 -0
  372. package/lib-es/types/index.js.map +1 -0
  373. package/lib-es/types/signer.d.ts +10 -0
  374. package/lib-es/types/signer.d.ts.map +1 -0
  375. package/lib-es/types/signer.js +2 -0
  376. package/lib-es/types/signer.js.map +1 -0
  377. package/package.json +137 -0
  378. package/src/api/index.test.ts +15 -0
  379. package/src/api/index.ts +65 -0
  380. package/src/bridge/broadcast.test.ts +36 -0
  381. package/src/bridge/broadcast.ts +11 -0
  382. package/src/bridge/createTransaction.test.ts +12 -0
  383. package/src/bridge/createTransaction.ts +14 -0
  384. package/src/bridge/deviceTransactionConfig.test.ts +22 -0
  385. package/src/bridge/deviceTransactionConfig.ts +34 -0
  386. package/src/bridge/estimateMaxSpendable.ts +25 -0
  387. package/src/bridge/getTransactionStatus.ts +88 -0
  388. package/src/bridge/index.test.ts +31 -0
  389. package/src/bridge/index.ts +62 -0
  390. package/src/bridge/prepareTransaction.test.ts +29 -0
  391. package/src/bridge/prepareTransaction.ts +25 -0
  392. package/src/bridge/signOperation.ts +93 -0
  393. package/src/bridge/sync.ts +106 -0
  394. package/src/bridge/transaction.ts +61 -0
  395. package/src/bridge/updateTransaction.ts +17 -0
  396. package/src/common-logic/account/getBalance.ts +8 -0
  397. package/src/common-logic/account/getNextSequence.ts +6 -0
  398. package/src/common-logic/common.ts +9 -0
  399. package/src/common-logic/history/lastBlock.ts +11 -0
  400. package/src/common-logic/history/listOperations.ts +64 -0
  401. package/src/common-logic/index.ts +11 -0
  402. package/src/common-logic/transaction/broadcast.ts +6 -0
  403. package/src/common-logic/transaction/combine.ts +6 -0
  404. package/src/common-logic/transaction/craftTransaction.ts +36 -0
  405. package/src/common-logic/transaction/estimateFees.ts +16 -0
  406. package/src/common-logic/utils.ts +18 -0
  407. package/src/config.ts +12 -0
  408. package/src/index.ts +4 -0
  409. package/src/network/indexer.ts +17 -0
  410. package/src/network/mock-network.ts +25 -0
  411. package/src/network/node.ts +94 -0
  412. package/src/network/types.ts +51 -0
  413. package/src/signer/getAddress.ts +20 -0
  414. package/src/signer/index.ts +7 -0
  415. package/src/test/bot-deviceActions.ts +48 -0
  416. package/src/test/bot-specs.ts +76 -0
  417. package/src/test/bridgeDatasetTest.ts +147 -0
  418. package/src/test/cli.ts +44 -0
  419. package/src/test/index.ts +6 -0
  420. package/src/types/bridge.ts +33 -0
  421. package/src/types/errors.ts +3 -0
  422. package/src/types/index.ts +13 -0
  423. package/src/types/signer.ts +11 -0
  424. package/tsconfig.json +12 -0
@@ -0,0 +1,2 @@
1
+ PUB_KEY = "XPUB"
2
+ SECRET_KEY = "SECRET"
package/.eslintrc.js ADDED
@@ -0,0 +1,22 @@
1
+ module.exports = {
2
+ env: {
3
+ browser: true,
4
+ es6: true,
5
+ },
6
+ overrides: [
7
+ {
8
+ files: ["src/**/*.test.{ts,tsx}"],
9
+ env: {
10
+ "jest/globals": true,
11
+ },
12
+ plugins: ["jest"],
13
+ },
14
+ ],
15
+ rules: {
16
+ "no-console": ["error", { allow: ["warn", "error"] }],
17
+ "@typescript-eslint/no-empty-function": "off",
18
+ "no-empty-pattern": "off",
19
+ "@typescript-eslint/no-explicit-any": "warn",
20
+ "@typescript-eslint/no-unused-vars": "warn",
21
+ },
22
+ };
@@ -0,0 +1,4 @@
1
+
2
+ > @ledgerhq/coin-canton@0.1.0 build /home/runner/work/ledger-live/ledger-live/libs/coin-modules/coin-canton
3
+ > tsc && tsc -m esnext --moduleResolution bundler --outDir lib-es
4
+
@@ -0,0 +1,29 @@
1
+ {
2
+ "entry": [
3
+ "src/api/index.ts",
4
+ "src/bridge/index.ts",
5
+ "src/bridge/deviceTransactionConfig.ts",
6
+ "src/datasets/dataset-1.ts",
7
+ "src/signer/index.ts",
8
+ "src/test/index.ts",
9
+ "src/index.ts"
10
+ ],
11
+ "ignorePatterns": [
12
+ "**/node_modules/**",
13
+ "**/*.fixture.ts",
14
+ "**/*.mock.ts",
15
+ "**/*.test.{js,jsx,ts,tsx}"
16
+ ],
17
+ "ignoreUnresolved": [
18
+ "jest-get-type",
19
+ "jest-matcher-utils",
20
+ "jest-message-util"
21
+ ],
22
+ "ignoreUnimported": [
23
+ "src/network/mock-network.ts",
24
+ "src/test/bot-specs.ts"
25
+ ],
26
+ "ignoreUnused": [
27
+ "@ledgerhq/devices"
28
+ ]
29
+ }
package/CHANGELOG.md ADDED
@@ -0,0 +1,14 @@
1
+ # @ledgerhq/coin-canton
2
+
3
+ ## 0.2.0-nightly.0
4
+
5
+ ### Minor Changes
6
+
7
+ - [#11164](https://github.com/LedgerHQ/ledger-live/pull/11164) [`2da9b4a`](https://github.com/LedgerHQ/ledger-live/commit/2da9b4a5dd9fec3fea188fc9fa107b2c3479d1be) Thanks [@hedi-edelbloute](https://github.com/hedi-edelbloute)! - Canton module init
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [[`2da9b4a`](https://github.com/LedgerHQ/ledger-live/commit/2da9b4a5dd9fec3fea188fc9fa107b2c3479d1be), [`417e4fc`](https://github.com/LedgerHQ/ledger-live/commit/417e4fc8b92ebc95542ca915e14023fdb62497bb)]:
12
+ - @ledgerhq/cryptoassets@13.23.0-nightly.2
13
+ - @ledgerhq/types-live@6.79.0-nightly.1
14
+ - @ledgerhq/coin-framework@6.0.0-nightly.3
package/LICENSE.txt ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License
2
+
3
+ Copyright (c) 2017-present Ledger https://www.ledger.com/
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
package/jest.config.js ADDED
@@ -0,0 +1,21 @@
1
+ /** @type {import('ts-jest/dist/types').JestConfigWithTsJest} */
2
+ // `workerThreads: true` is required for validating object with `bigint` values
3
+ module.exports = {
4
+ preset: "ts-jest",
5
+ testEnvironment: "node",
6
+ passWithNoTests: true,
7
+ setupFilesAfterEnv: ["@ledgerhq/disable-network-setup"],
8
+ collectCoverageFrom: [
9
+ "src/**/*.ts",
10
+ "!src/**/*.test.ts",
11
+ "!src/**/*.spec.ts",
12
+ "!src/test/**/*.ts",
13
+ ],
14
+ coverageReporters: ["json", ["lcov", { file: "lcov.info", projectRoot: "../../../" }], "text"],
15
+ testPathIgnorePatterns: ["lib/", "lib-es/", ".*\\.integ\\.test\\.[tj]s"],
16
+ workerThreads: true,
17
+ reporters: [
18
+ "default",
19
+ ["jest-sonar", { outputName: "sonar-executionTests-report.xml", reportedFilePath: "absolute" }],
20
+ ],
21
+ };
@@ -0,0 +1,8 @@
1
+ /** @type {import('ts-jest/dist/types').JestConfigWithTsJest} */
2
+ module.exports = {
3
+ preset: "ts-jest",
4
+ testEnvironment: "node",
5
+ testRegex: ".integ.test.ts$",
6
+ testPathIgnorePatterns: ["lib/", "lib-es/"],
7
+ setupFiles: ["dotenv/config"],
8
+ };
@@ -0,0 +1,4 @@
1
+ import { AlpacaApi } from "@ledgerhq/coin-framework/api/index";
2
+ import { type CantonConfig } from "../config";
3
+ export declare function createApi(config: CantonConfig): AlpacaApi;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAKV,MAAM,oCAAoC,CAAC;AAC5C,OAAmB,EAAE,KAAK,YAAY,EAAE,MAAM,WAAW,CAAC;AAa1D,wBAAgB,SAAS,CAAC,MAAM,EAAE,YAAY,GAAG,SAAS,CAkBzD"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.createApi = createApi;
7
+ const config_1 = __importDefault(require("../config"));
8
+ const common_logic_1 = require("../common-logic");
9
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
+ function createApi(config) {
11
+ config_1.default.setCoinConfig(() => ({ ...config, status: { type: "active" } }));
12
+ return {
13
+ broadcast: common_logic_1.broadcast,
14
+ combine: common_logic_1.combine,
15
+ craftTransaction: craft,
16
+ estimateFees: estimate,
17
+ getBalance: common_logic_1.getBalance,
18
+ lastBlock: common_logic_1.lastBlock,
19
+ listOperations: common_logic_1.listOperations,
20
+ getBlock(_height) {
21
+ throw new Error("getBlock is not supported");
22
+ },
23
+ getBlockInfo(_height) {
24
+ throw new Error("getBlockInfo is not supported");
25
+ },
26
+ };
27
+ }
28
+ async function craft(transactionIntent) {
29
+ const nextSequenceNumber = await (0, common_logic_1.getNextValidSequence)(transactionIntent.sender);
30
+ const tx = await (0, common_logic_1.craftTransaction)({ address: transactionIntent.sender, nextSequenceNumber }, {
31
+ recipient: transactionIntent.recipient,
32
+ amount: new bignumber_js_1.default(transactionIntent.amount.toString()),
33
+ });
34
+ return tx.serializedTransaction;
35
+ }
36
+ async function estimate(transactionIntent) {
37
+ const { serializedTransaction } = await (0, common_logic_1.craftTransaction)({ address: transactionIntent.sender }, {
38
+ recipient: transactionIntent.recipient,
39
+ amount: new bignumber_js_1.default(transactionIntent.amount.toString()),
40
+ });
41
+ const value = await (0, common_logic_1.estimateFees)(serializedTransaction);
42
+ return { value };
43
+ }
44
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":";;;;;AAoBA,8BAkBC;AA/BD,uDAA0D;AAC1D,kDASyB;AACzB,gEAAqC;AAErC,SAAgB,SAAS,CAAC,MAAoB;IAC5C,gBAAU,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;IAE5E,OAAO;QACL,SAAS,EAAT,wBAAS;QACT,OAAO,EAAP,sBAAO;QACP,gBAAgB,EAAE,KAAK;QACvB,YAAY,EAAE,QAAQ;QACtB,UAAU,EAAV,yBAAU;QACV,SAAS,EAAT,wBAAS;QACT,cAAc,EAAd,6BAAc;QACd,QAAQ,CAAC,OAAO;YACd,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAC/C,CAAC;QACD,YAAY,CAAC,OAAe;YAC1B,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;KACF,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,KAAK,CAAC,iBAAoC;IACvD,MAAM,kBAAkB,GAAG,MAAM,IAAA,mCAAoB,EAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IAChF,MAAM,EAAE,GAAG,MAAM,IAAA,+BAAgB,EAC/B,EAAE,OAAO,EAAE,iBAAiB,CAAC,MAAM,EAAE,kBAAkB,EAAE,EACzD;QACE,SAAS,EAAE,iBAAiB,CAAC,SAAS;QACtC,MAAM,EAAE,IAAI,sBAAS,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;KAC3D,CACF,CAAC;IACF,OAAO,EAAE,CAAC,qBAAqB,CAAC;AAClC,CAAC;AAED,KAAK,UAAU,QAAQ,CAAC,iBAAoC;IAC1D,MAAM,EAAE,qBAAqB,EAAE,GAAG,MAAM,IAAA,+BAAgB,EACtD,EAAE,OAAO,EAAE,iBAAiB,CAAC,MAAM,EAAE,EACrC;QACE,SAAS,EAAE,iBAAiB,CAAC,SAAS;QACtC,MAAM,EAAE,IAAI,sBAAS,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;KAC3D,CACF,CAAC;IAEF,MAAM,KAAK,GAAG,MAAM,IAAA,2BAAY,EAAC,qBAAqB,CAAC,CAAC;IAExD,OAAO,EAAE,KAAK,EAAE,CAAC;AACnB,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/api/index.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const _1 = require(".");
4
+ describe("createApi", () => {
5
+ it("should return every api methods", () => {
6
+ const api = (0, _1.createApi)({});
7
+ expect(api.broadcast).toBeDefined();
8
+ expect(api.combine).toBeDefined();
9
+ expect(api.craftTransaction).toBeDefined();
10
+ expect(api.estimateFees).toBeDefined();
11
+ expect(api.getBalance).toBeDefined();
12
+ expect(api.lastBlock).toBeDefined();
13
+ expect(api.listOperations).toBeDefined();
14
+ });
15
+ });
16
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/api/index.test.ts"],"names":[],"mappings":";;AAAA,wBAA8B;AAG9B,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,GAAG,GAAG,IAAA,YAAS,EAAC,EAAkB,CAAC,CAAC;QAC1C,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,WAAW,EAAE,CAAC;QAC3C,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;QACvC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const broadcast: AccountBridge<Transaction>["broadcast"];
4
+ //# sourceMappingURL=broadcast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAK7D,CAAC"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.broadcast = void 0;
4
+ const operation_1 = require("@ledgerhq/coin-framework/operation");
5
+ const common_logic_1 = require("../common-logic");
6
+ const broadcast = async ({ signedOperation: { signature, operation }, }) => {
7
+ const hash = await (0, common_logic_1.broadcast)(signature);
8
+ return (0, operation_1.patchOperationWithHash)(operation, hash);
9
+ };
10
+ exports.broadcast = broadcast;
11
+ //# sourceMappingURL=broadcast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;AACA,kEAA4E;AAC5E,kDAA8D;AAGvD,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAC1C,EAAE,EAAE;IACH,MAAM,IAAI,GAAG,MAAM,IAAA,wBAAc,EAAC,SAAS,CAAC,CAAC;IAC7C,OAAO,IAAA,kCAAsB,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC;AALW,QAAA,SAAS,aAKpB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=broadcast.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.test.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const broadcast_1 = require("./broadcast");
4
+ jest.mock("@ledgerhq/coin-framework/operation");
5
+ jest.mock("../common-logic");
6
+ const operation_1 = require("@ledgerhq/coin-framework/operation");
7
+ const common_logic_1 = require("../common-logic");
8
+ describe("broadcast", () => {
9
+ let patchOperationSpy;
10
+ let broadcastSpy;
11
+ beforeEach(() => {
12
+ patchOperationSpy = jest.spyOn({ patchOperationWithHash: operation_1.patchOperationWithHash }, "patchOperationWithHash");
13
+ broadcastSpy = jest.spyOn({ broadcastLogic: common_logic_1.broadcast }, "broadcastLogic");
14
+ broadcastSpy.mockResolvedValue("hash");
15
+ });
16
+ it("should broadcast", () => {
17
+ (0, broadcast_1.broadcast)({
18
+ signedOperation: {
19
+ signature: undefined,
20
+ operation: undefined,
21
+ },
22
+ });
23
+ expect(common_logic_1.broadcast).toHaveBeenCalledTimes(1);
24
+ });
25
+ it("should patch operation with hash", () => {
26
+ (0, broadcast_1.broadcast)({
27
+ signedOperation: {
28
+ signature: undefined,
29
+ operation: undefined,
30
+ },
31
+ });
32
+ expect(patchOperationSpy).toHaveBeenCalledWith(undefined, "hash");
33
+ });
34
+ });
35
+ //# sourceMappingURL=broadcast.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":";;AACA,2CAAwC;AACxC,IAAI,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;AAChD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;AAC7B,kEAA4E;AAC5E,kDAA8D;AAE9D,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,IAAI,iBAAmC,CAAC;IACxC,IAAI,YAA8B,CAAC;IACnC,UAAU,CAAC,GAAG,EAAE;QACd,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,sBAAsB,EAAtB,kCAAsB,EAAE,EAAE,wBAAwB,CAAC,CAAC;QACrF,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,cAAc,EAAd,wBAAc,EAAE,EAAE,gBAAgB,CAAC,CAAC;QAChE,YAAY,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC1B,IAAA,qBAAS,EAAC;YACR,eAAe,EAAE;gBACf,SAAS,EAAE,SAAS;gBACpB,SAAS,EAAE,SAAS;aACrB;SACkC,CAAC,CAAC;QACvC,MAAM,CAAC,wBAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,IAAA,qBAAS,EAAC;YACR,eAAe,EAAE;gBACf,SAAS,EAAE,SAAS;gBACpB,SAAS,EAAE,SAAS;aACrB;SACkC,CAAC,CAAC;QACvC,MAAM,CAAC,iBAAiB,CAAC,CAAC,oBAAoB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { Transaction } from "../types";
2
+ import { AccountBridge } from "@ledgerhq/types-live";
3
+ export declare const createTransaction: AccountBridge<Transaction>["createTransaction"];
4
+ //# sourceMappingURL=createTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAQ5E,CAAC"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.createTransaction = void 0;
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ // We create an empty transaction that will be filled later
9
+ const createTransaction = () => ({
10
+ family: "canton",
11
+ amount: new bignumber_js_1.default(0),
12
+ recipient: "",
13
+ fee: null,
14
+ memo: undefined,
15
+ networkInfo: null,
16
+ feeCustomUnit: null,
17
+ });
18
+ exports.createTransaction = createTransaction;
19
+ //# sourceMappingURL=createTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAIrC,2DAA2D;AACpD,MAAM,iBAAiB,GAAoD,GAAG,EAAE,CAAC,CAAC;IACvF,MAAM,EAAE,QAAQ;IAChB,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;IACxB,SAAS,EAAE,EAAE;IACb,GAAG,EAAE,IAAI;IACT,IAAI,EAAE,SAAS;IACf,WAAW,EAAE,IAAI;IACjB,aAAa,EAAE,IAAI;CACpB,CAAC,CAAC;AARU,QAAA,iBAAiB,qBAQ3B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=createTransaction.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const createTransaction_1 = require("./createTransaction");
4
+ describe("createTransaction", () => {
5
+ it("should create a 0 amount transaction", () => {
6
+ expect((0, createTransaction_1.createTransaction)({}).amount.toNumber()).toEqual(0);
7
+ });
8
+ it("should create a transaction with boilerplate family", () => {
9
+ expect((0, createTransaction_1.createTransaction)({}).family).toEqual("boilerplate");
10
+ });
11
+ });
12
+ //# sourceMappingURL=createTransaction.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.test.ts"],"names":[],"mappings":";;AACA,2DAAwD;AAExD,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IACtF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { AccountLike, Account } from "@ledgerhq/types-live";
2
+ import type { Transaction, TransactionStatus } from "../types";
3
+ import type { CommonDeviceTransactionField } from "@ledgerhq/coin-framework/transaction/common";
4
+ declare function getDeviceTransactionConfig({ transaction: {}, status: { amount, estimatedFees }, }: {
5
+ account: AccountLike;
6
+ parentAccount: Account | null | undefined;
7
+ transaction: Transaction;
8
+ status: TransactionStatus;
9
+ }): Array<CommonDeviceTransactionField>;
10
+ export default getDeviceTransactionConfig;
11
+ //# sourceMappingURL=deviceTransactionConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deviceTransactionConfig.d.ts","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACjE,OAAO,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC/D,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,6CAA6C,CAAC;AAGhG,iBAAS,0BAA0B,CAAC,EAClC,WAAW,EAAE,EAAE,EACf,MAAM,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,GAClC,EAAE;IACD,OAAO,EAAE,WAAW,CAAC;IACrB,aAAa,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC;IAC1C,WAAW,EAAE,WAAW,CAAC;IACzB,MAAM,EAAE,iBAAiB,CAAC;CAC3B,GAAG,KAAK,CAAC,4BAA4B,CAAC,CAkBtC;AAED,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // This method adds additional fields that need to be reviewed when signing a transaction on the device.
4
+ function getDeviceTransactionConfig({ transaction: {}, status: { amount, estimatedFees }, }) {
5
+ const fields = [];
6
+ if (!amount.isZero()) {
7
+ fields.push({
8
+ type: "amount",
9
+ label: "Amount",
10
+ });
11
+ }
12
+ if (!estimatedFees.isZero()) {
13
+ fields.push({
14
+ type: "fees",
15
+ label: "Fees",
16
+ });
17
+ }
18
+ return fields;
19
+ }
20
+ exports.default = getDeviceTransactionConfig;
21
+ //# sourceMappingURL=deviceTransactionConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deviceTransactionConfig.js","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.ts"],"names":[],"mappings":";;AAIA,wGAAwG;AACxG,SAAS,0BAA0B,CAAC,EAClC,WAAW,EAAE,EAAE,EACf,MAAM,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,GAMlC;IACC,MAAM,MAAM,GAAwC,EAAE,CAAC;IAEvD,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;QACrB,MAAM,CAAC,IAAI,CAAC;YACV,IAAI,EAAE,QAAQ;YACd,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC;QAC5B,MAAM,CAAC,IAAI,CAAC;YACV,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,MAAM;SACd,CAAC,CAAC;IACL,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,kBAAe,0BAA0B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=deviceTransactionConfig.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deviceTransactionConfig.test.d.ts","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const deviceTransactionConfig_1 = __importDefault(require("./deviceTransactionConfig"));
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ describe("getDeviceTransactionConfig", () => {
9
+ it("should return amount field when it's more than 0", () => {
10
+ expect((0, deviceTransactionConfig_1.default)({
11
+ transaction: {},
12
+ status: { amount: new bignumber_js_1.default(1), estimatedFees: new bignumber_js_1.default(0) },
13
+ })[0]).toEqual({ type: "amount", label: "Amount" });
14
+ });
15
+ it("should return fee field when it's more than 0", () => {
16
+ expect((0, deviceTransactionConfig_1.default)({
17
+ transaction: {},
18
+ status: { amount: new bignumber_js_1.default(0), estimatedFees: new bignumber_js_1.default(1) },
19
+ })[0]).toEqual({ type: "fees", label: "Fees" });
20
+ });
21
+ });
22
+ //# sourceMappingURL=deviceTransactionConfig.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deviceTransactionConfig.test.js","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.test.ts"],"names":[],"mappings":";;;;;AAAA,wFAAmE;AACnE,gEAAqC;AAErC,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,CACJ,IAAA,iCAA0B,EAAC;YACzB,WAAW,EAAE,EAAE;YACf,MAAM,EAAE,EAAE,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE;SAC/D,CAAC,CAAC,CAAC,CAAC,CACb,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,CACJ,IAAA,iCAA0B,EAAC;YACzB,WAAW,EAAE,EAAE;YACf,MAAM,EAAE,EAAE,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE;SAC/D,CAAC,CAAC,CAAC,CAAC,CACb,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const estimateMaxSpendable: AccountBridge<Transaction>["estimateMaxSpendable"];
4
+ //# sourceMappingURL=estimateMaxSpendable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAMrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAenF,CAAC"}
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.estimateMaxSpendable = void 0;
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ const index_1 = require("@ledgerhq/coin-framework/account/index");
9
+ const abandonseed_1 = require("@ledgerhq/cryptoassets/abandonseed");
10
+ const getTransactionStatus_1 = require("./getTransactionStatus");
11
+ const prepareTransaction_1 = require("./prepareTransaction");
12
+ const createTransaction_1 = require("./createTransaction");
13
+ const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
14
+ const mainAccount = (0, index_1.getMainAccount)(account, parentAccount);
15
+ const newTransaction = await (0, prepareTransaction_1.prepareTransaction)(mainAccount, {
16
+ ...(0, createTransaction_1.createTransaction)(account),
17
+ ...transaction,
18
+ // fee estimation might require a recipient to work, in that case, we use a dummy one
19
+ recipient: transaction?.recipient || (0, abandonseed_1.getAbandonSeedAddress)("boilerplate"),
20
+ amount: new bignumber_js_1.default(0),
21
+ });
22
+ const status = await (0, getTransactionStatus_1.getTransactionStatus)(mainAccount, newTransaction);
23
+ return bignumber_js_1.default.max(0, account.spendableBalance.minus(status.estimatedFees));
24
+ };
25
+ exports.estimateMaxSpendable = estimateMaxSpendable;
26
+ //# sourceMappingURL=estimateMaxSpendable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAErC,kEAAwE;AACxE,oEAA2E;AAC3E,iEAA8D;AAC9D,6DAA0D;AAC1D,2DAAwD;AAGjD,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GACZ,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,IAAA,sBAAc,EAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAC3D,MAAM,cAAc,GAAG,MAAM,IAAA,uCAAkB,EAAC,WAAW,EAAE;QAC3D,GAAG,IAAA,qCAAiB,EAAC,OAAO,CAAC;QAC7B,GAAG,WAAW;QACd,qFAAqF;QACrF,SAAS,EAAE,WAAW,EAAE,SAAS,IAAI,IAAA,mCAAqB,EAAC,aAAa,CAAC;QACzE,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;KACzB,CAAC,CAAC;IACH,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,WAAW,EAAE,cAAc,CAAC,CAAC;IACvE,OAAO,sBAAS,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;AAChF,CAAC,CAAC;AAfW,QAAA,oBAAoB,wBAe/B"}
@@ -0,0 +1,4 @@
1
+ import { Account, AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction, TransactionStatus } from "../types";
3
+ export declare const getTransactionStatus: AccountBridge<Transaction, Account, TransactionStatus>["getTransactionStatus"];
4
+ //# sourceMappingURL=getTransactionStatus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE9D,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAI1D,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAC9C,WAAW,EACX,OAAO,EACP,iBAAiB,CAClB,CAAC,sBAAsB,CAiEvB,CAAC"}
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getTransactionStatus = void 0;
7
+ const errors_1 = require("@ledgerhq/errors");
8
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
+ const index_1 = require("@ledgerhq/coin-framework/currencies/index");
10
+ const utils_1 = require("../common-logic/utils");
11
+ const config_1 = __importDefault(require("../config"));
12
+ const getTransactionStatus = async (account, transaction) => {
13
+ const errors = {};
14
+ const warnings = {};
15
+ // reserveAmount is the minimum amount of currency that an account must hold in order to stay activated
16
+ const reserveAmount = new bignumber_js_1.default(config_1.default.getCoinConfig().minReserve);
17
+ const estimatedFees = new bignumber_js_1.default(transaction.fee || 0);
18
+ const totalSpent = new bignumber_js_1.default(transaction.amount).plus(estimatedFees);
19
+ const amount = new bignumber_js_1.default(transaction.amount);
20
+ if (amount.gt(0) && estimatedFees.times(10).gt(amount)) {
21
+ // if the fee is more than 10 times the amount, we warn the user that fee is high compared to what he is sending
22
+ warnings.feeTooHigh = new errors_1.FeeTooHigh();
23
+ }
24
+ if (!transaction.fee) {
25
+ // if the fee is not loaded, we can't do much
26
+ errors.fee = new errors_1.FeeNotLoaded();
27
+ }
28
+ else if (transaction.fee.eq(0)) {
29
+ // On some chains, 0 fee could still work so this is optional
30
+ errors.fee = new errors_1.FeeRequired();
31
+ }
32
+ else if (totalSpent.gt(account.balance.minus(reserveAmount))) {
33
+ // if the total spent is greater than the balance minus the reserve amount, tx is invalid
34
+ errors.amount = new errors_1.NotEnoughSpendableBalance("", {
35
+ minimumAmount: (0, index_1.formatCurrencyUnit)(account.currency.units[0], reserveAmount, {
36
+ disableRounding: true,
37
+ useGrouping: false,
38
+ showCode: true,
39
+ }),
40
+ });
41
+ }
42
+ else if (transaction.recipient && transaction.amount.lt(reserveAmount)) {
43
+ // if we send an amount lower than reserve amount AND target account is new, we need to warn the user that the target account will not be activated
44
+ errors.amount = new errors_1.NotEnoughBalanceBecauseDestinationNotCreated("", {
45
+ minimalAmount: (0, index_1.formatCurrencyUnit)(account.currency.units[0], reserveAmount, {
46
+ disableRounding: true,
47
+ useGrouping: false,
48
+ showCode: true,
49
+ }),
50
+ });
51
+ }
52
+ if (!transaction.recipient) {
53
+ errors.recipient = new errors_1.RecipientRequired("");
54
+ }
55
+ else if (account.freshAddress === transaction.recipient) {
56
+ // we want to prevent user from sending to themselves (even if it's technically feasible)
57
+ errors.recipient = new errors_1.InvalidAddressBecauseDestinationIsAlsoSource();
58
+ }
59
+ else if (!(0, utils_1.isRecipientValid)(transaction.recipient)) {
60
+ // We want to prevent user from sending to an invalid address
61
+ errors.recipient = new errors_1.InvalidAddress("", {
62
+ currencyName: account.currency.name,
63
+ });
64
+ }
65
+ if (!errors.amount && amount.eq(0)) {
66
+ // if the amount is 0, we prevent the user from sending the tx (even if it's technically feasible)
67
+ errors.amount = new errors_1.AmountRequired();
68
+ }
69
+ return {
70
+ errors,
71
+ warnings,
72
+ estimatedFees,
73
+ amount,
74
+ totalSpent,
75
+ };
76
+ };
77
+ exports.getTransactionStatus = getTransactionStatus;
78
+ //# 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,11 @@
1
+ import { CoinConfig } from "@ledgerhq/coin-framework/config";
2
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
3
+ import type { AccountBridge, CurrencyBridge } from "@ledgerhq/types-live";
4
+ import { type CantonCoinConfig } from "../config";
5
+ import { BoilerplateSigner } from "../types";
6
+ import type { Transaction } from "../types";
7
+ export declare function createBridges(signerContext: SignerContext<BoilerplateSigner>, coinConfig: CoinConfig<CantonCoinConfig>): {
8
+ currencyBridge: CurrencyBridge;
9
+ accountBridge: AccountBridge<Transaction>;
10
+ };
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC1E,OAAyB,EAAE,KAAK,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAEpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAU5C,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,iBAAiB,CAAC,EAC/C,UAAU,EAAE,UAAU,CAAC,gBAAgB,CAAC;;;EAoCzC"}