@ledgerhq/coin-vechain 2.9.1-nightly.1 → 2.9.2-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 (475) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/.unimportedrc.json +16 -4
  3. package/CHANGELOG.md +23 -9
  4. package/lib/bridge/broadcast.d.ts.map +1 -1
  5. package/lib/bridge/broadcast.js +2 -3
  6. package/lib/bridge/broadcast.js.map +1 -1
  7. package/lib/bridge/broadcast.test.d.ts +2 -0
  8. package/lib/bridge/broadcast.test.d.ts.map +1 -0
  9. package/lib/bridge/broadcast.test.js +188 -0
  10. package/lib/bridge/broadcast.test.js.map +1 -0
  11. package/lib/bridge/buildOptimisticOperatioin.test.d.ts +2 -0
  12. package/lib/bridge/buildOptimisticOperatioin.test.d.ts.map +1 -0
  13. package/lib/bridge/buildOptimisticOperatioin.test.js +286 -0
  14. package/lib/bridge/buildOptimisticOperatioin.test.js.map +1 -0
  15. package/lib/bridge/createTransaction.d.ts.map +1 -1
  16. package/lib/bridge/createTransaction.js +2 -1
  17. package/lib/bridge/createTransaction.js.map +1 -1
  18. package/lib/bridge/createTransaction.test.d.ts +2 -0
  19. package/lib/bridge/createTransaction.test.d.ts.map +1 -0
  20. package/lib/bridge/createTransaction.test.js +167 -0
  21. package/lib/bridge/createTransaction.test.js.map +1 -0
  22. package/lib/bridge/estimateMaxSpendable.test.d.ts +2 -0
  23. package/lib/bridge/estimateMaxSpendable.test.d.ts.map +1 -0
  24. package/lib/bridge/estimateMaxSpendable.test.js +269 -0
  25. package/lib/bridge/estimateMaxSpendable.test.js.map +1 -0
  26. package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
  27. package/lib/bridge/getTransactionStatus.js +3 -1
  28. package/lib/bridge/getTransactionStatus.js.map +1 -1
  29. package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
  30. package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
  31. package/lib/bridge/getTransactionStatus.test.js +282 -0
  32. package/lib/bridge/getTransactionStatus.test.js.map +1 -0
  33. package/lib/bridge/helpers.test.d.ts +2 -0
  34. package/lib/bridge/helpers.test.d.ts.map +1 -0
  35. package/lib/bridge/helpers.test.js +298 -0
  36. package/lib/bridge/helpers.test.js.map +1 -0
  37. package/lib/bridge/prepareTransaction.d.ts.map +1 -1
  38. package/lib/bridge/prepareTransaction.js +10 -3
  39. package/lib/bridge/prepareTransaction.js.map +1 -1
  40. package/lib/bridge/prepareTransaction.test.d.ts +2 -0
  41. package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
  42. package/lib/bridge/prepareTransaction.test.js +277 -0
  43. package/lib/bridge/prepareTransaction.test.js.map +1 -0
  44. package/lib/bridge/signOperation.d.ts.map +1 -1
  45. package/lib/bridge/signOperation.js +3 -3
  46. package/lib/bridge/signOperation.js.map +1 -1
  47. package/lib/bridge/signOperation.test.d.ts +2 -0
  48. package/lib/bridge/signOperation.test.d.ts.map +1 -0
  49. package/lib/bridge/signOperation.test.js +295 -0
  50. package/lib/bridge/signOperation.test.js.map +1 -0
  51. package/lib/bridge/synchronisation.d.ts.map +1 -1
  52. package/lib/bridge/synchronisation.js +2 -2
  53. package/lib/bridge/synchronisation.js.map +1 -1
  54. package/lib/bridge/transaction.test.d.ts +2 -0
  55. package/lib/bridge/transaction.test.d.ts.map +1 -0
  56. package/lib/bridge/transaction.test.js +353 -0
  57. package/lib/bridge/transaction.test.js.map +1 -0
  58. package/lib/common-logic/calculateClauses.d.ts +5 -0
  59. package/lib/common-logic/calculateClauses.d.ts.map +1 -0
  60. package/lib/common-logic/{logic.js → calculateClauses.js} +7 -10
  61. package/lib/common-logic/calculateClauses.js.map +1 -0
  62. package/lib/common-logic/calculateClauses.test.d.ts +2 -0
  63. package/lib/common-logic/calculateClauses.test.d.ts.map +1 -0
  64. package/lib/common-logic/calculateClauses.test.js +156 -0
  65. package/lib/common-logic/calculateClauses.test.js.map +1 -0
  66. package/lib/common-logic/calculateGasFees.d.ts +9 -0
  67. package/lib/common-logic/calculateGasFees.d.ts.map +1 -0
  68. package/lib/common-logic/calculateGasFees.js +39 -0
  69. package/lib/common-logic/calculateGasFees.js.map +1 -0
  70. package/lib/common-logic/calculateGasFees.test.d.ts +2 -0
  71. package/lib/common-logic/calculateGasFees.test.d.ts.map +1 -0
  72. package/lib/common-logic/calculateGasFees.test.js +279 -0
  73. package/lib/common-logic/calculateGasFees.test.js.map +1 -0
  74. package/lib/common-logic/calculateTransactionInfo.d.ts +10 -0
  75. package/lib/common-logic/calculateTransactionInfo.d.ts.map +1 -0
  76. package/lib/common-logic/calculateTransactionInfo.js +81 -0
  77. package/lib/common-logic/calculateTransactionInfo.js.map +1 -0
  78. package/lib/common-logic/calculateTransactionInfo.test.d.ts +2 -0
  79. package/lib/common-logic/calculateTransactionInfo.test.d.ts.map +1 -0
  80. package/lib/common-logic/calculateTransactionInfo.test.js +314 -0
  81. package/lib/common-logic/calculateTransactionInfo.test.js.map +1 -0
  82. package/lib/common-logic/estimateGas.d.ts +10 -0
  83. package/lib/common-logic/estimateGas.d.ts.map +1 -0
  84. package/lib/common-logic/estimateGas.js +17 -0
  85. package/lib/common-logic/estimateGas.js.map +1 -0
  86. package/lib/common-logic/estimateGas.test.d.ts +2 -0
  87. package/lib/common-logic/estimateGas.test.d.ts.map +1 -0
  88. package/lib/common-logic/estimateGas.test.js +129 -0
  89. package/lib/common-logic/estimateGas.test.js.map +1 -0
  90. package/lib/common-logic/fixPrefixCase.d.ts +2 -0
  91. package/lib/common-logic/fixPrefixCase.d.ts.map +1 -0
  92. package/lib/common-logic/fixPrefixCase.js +9 -0
  93. package/lib/common-logic/fixPrefixCase.js.map +1 -0
  94. package/lib/common-logic/fixPrefixCase.test.d.ts +2 -0
  95. package/lib/common-logic/fixPrefixCase.test.d.ts.map +1 -0
  96. package/lib/common-logic/fixPrefixCase.test.js +46 -0
  97. package/lib/common-logic/fixPrefixCase.test.js.map +1 -0
  98. package/lib/common-logic/generateNonce.d.ts +6 -0
  99. package/lib/common-logic/generateNonce.d.ts.map +1 -0
  100. package/lib/common-logic/generateNonce.js +13 -0
  101. package/lib/common-logic/generateNonce.js.map +1 -0
  102. package/lib/common-logic/generateNonce.test.d.ts +2 -0
  103. package/lib/common-logic/generateNonce.test.d.ts.map +1 -0
  104. package/lib/common-logic/generateNonce.test.js +59 -0
  105. package/lib/common-logic/generateNonce.test.js.map +1 -0
  106. package/lib/common-logic/getThorClient.d.ts +7 -0
  107. package/lib/common-logic/getThorClient.d.ts.map +1 -0
  108. package/lib/common-logic/getThorClient.js +14 -0
  109. package/lib/common-logic/getThorClient.js.map +1 -0
  110. package/lib/common-logic/getThorClient.test.d.ts +2 -0
  111. package/lib/common-logic/getThorClient.test.d.ts.map +1 -0
  112. package/lib/common-logic/getThorClient.test.js +53 -0
  113. package/lib/common-logic/getThorClient.test.js.map +1 -0
  114. package/lib/common-logic/index.d.ts +8 -6
  115. package/lib/common-logic/index.d.ts.map +1 -1
  116. package/lib/common-logic/index.js +8 -6
  117. package/lib/common-logic/index.js.map +1 -1
  118. package/lib/common-logic/{mapping-utils.d.ts → mapTransfersToOperations.d.ts} +2 -2
  119. package/lib/common-logic/mapTransfersToOperations.d.ts.map +1 -0
  120. package/lib/common-logic/{mapping-utils.js → mapTransfersToOperations.js} +26 -19
  121. package/lib/common-logic/mapTransfersToOperations.js.map +1 -0
  122. package/lib/common-logic/mapTransfersToOperations.test.d.ts +2 -0
  123. package/lib/common-logic/mapTransfersToOperations.test.d.ts.map +1 -0
  124. package/lib/common-logic/mapTransfersToOperations.test.js +274 -0
  125. package/lib/common-logic/mapTransfersToOperations.test.js.map +1 -0
  126. package/lib/common-logic/{pad-address.d.ts → padAddress.d.ts} +1 -1
  127. package/lib/common-logic/padAddress.d.ts.map +1 -0
  128. package/lib/common-logic/{pad-address.js → padAddress.js} +1 -1
  129. package/lib/common-logic/padAddress.js.map +1 -0
  130. package/lib/common-logic/padAddress.test.d.ts +2 -0
  131. package/lib/common-logic/padAddress.test.d.ts.map +1 -0
  132. package/lib/common-logic/padAddress.test.js +59 -0
  133. package/lib/common-logic/padAddress.test.js.map +1 -0
  134. package/lib/common-logic/parseAddress.d.ts +7 -0
  135. package/lib/common-logic/parseAddress.d.ts.map +1 -0
  136. package/lib/common-logic/parseAddress.js +15 -0
  137. package/lib/common-logic/parseAddress.js.map +1 -0
  138. package/lib/common-logic/parseAddress.test.d.ts +2 -0
  139. package/lib/common-logic/parseAddress.test.d.ts.map +1 -0
  140. package/lib/common-logic/parseAddress.test.js +97 -0
  141. package/lib/common-logic/parseAddress.test.js.map +1 -0
  142. package/lib/constants/env.d.ts +2 -0
  143. package/lib/constants/env.d.ts.map +1 -0
  144. package/lib/constants/env.js +6 -0
  145. package/lib/constants/env.js.map +1 -0
  146. package/lib/constants/index.d.ts +2 -0
  147. package/lib/constants/index.d.ts.map +1 -0
  148. package/lib/constants/index.js +18 -0
  149. package/lib/constants/index.js.map +1 -0
  150. package/lib/network/sdk.d.ts +3 -10
  151. package/lib/network/sdk.d.ts.map +1 -1
  152. package/lib/network/sdk.js +15 -30
  153. package/lib/network/sdk.js.map +1 -1
  154. package/lib/signer/getAddress.test.d.ts +2 -0
  155. package/lib/signer/getAddress.test.d.ts.map +1 -0
  156. package/lib/signer/getAddress.test.js +357 -0
  157. package/lib/signer/getAddress.test.js.map +1 -0
  158. package/lib/signer/signMessage.d.ts.map +1 -1
  159. package/lib/signer/signMessage.js +3 -3
  160. package/lib/signer/signMessage.js.map +1 -1
  161. package/lib/signer/signMessage.test.d.ts +2 -0
  162. package/lib/signer/signMessage.test.d.ts.map +1 -0
  163. package/lib/signer/signMessage.test.js +242 -0
  164. package/lib/signer/signMessage.test.js.map +1 -0
  165. package/lib/test/bridgeDatasetTest.d.ts.map +1 -1
  166. package/lib/test/bridgeDatasetTest.js +79 -53
  167. package/lib/test/bridgeDatasetTest.js.map +1 -1
  168. package/lib/test/cli.d.ts.map +1 -1
  169. package/lib/test/cli.js +5 -4
  170. package/lib/test/cli.js.map +1 -1
  171. package/lib/types/bridge.d.ts +11 -3
  172. package/lib/types/bridge.d.ts.map +1 -1
  173. package/lib/types/bridge.js +3 -0
  174. package/lib/types/bridge.js.map +1 -1
  175. package/lib/types/constants.d.ts +0 -3
  176. package/lib/types/constants.d.ts.map +1 -1
  177. package/lib/types/constants.js +1 -4
  178. package/lib/types/constants.js.map +1 -1
  179. package/lib/types/signer.d.ts +0 -2
  180. package/lib/types/signer.d.ts.map +1 -1
  181. package/lib-es/bridge/broadcast.d.ts.map +1 -1
  182. package/lib-es/bridge/broadcast.js +2 -3
  183. package/lib-es/bridge/broadcast.js.map +1 -1
  184. package/lib-es/bridge/broadcast.test.d.ts +2 -0
  185. package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
  186. package/lib-es/bridge/broadcast.test.js +183 -0
  187. package/lib-es/bridge/broadcast.test.js.map +1 -0
  188. package/lib-es/bridge/buildOptimisticOperatioin.test.d.ts +2 -0
  189. package/lib-es/bridge/buildOptimisticOperatioin.test.d.ts.map +1 -0
  190. package/lib-es/bridge/buildOptimisticOperatioin.test.js +281 -0
  191. package/lib-es/bridge/buildOptimisticOperatioin.test.js.map +1 -0
  192. package/lib-es/bridge/createTransaction.d.ts.map +1 -1
  193. package/lib-es/bridge/createTransaction.js +3 -2
  194. package/lib-es/bridge/createTransaction.js.map +1 -1
  195. package/lib-es/bridge/createTransaction.test.d.ts +2 -0
  196. package/lib-es/bridge/createTransaction.test.d.ts.map +1 -0
  197. package/lib-es/bridge/createTransaction.test.js +162 -0
  198. package/lib-es/bridge/createTransaction.test.js.map +1 -0
  199. package/lib-es/bridge/estimateMaxSpendable.test.d.ts +2 -0
  200. package/lib-es/bridge/estimateMaxSpendable.test.d.ts.map +1 -0
  201. package/lib-es/bridge/estimateMaxSpendable.test.js +264 -0
  202. package/lib-es/bridge/estimateMaxSpendable.test.js.map +1 -0
  203. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
  204. package/lib-es/bridge/getTransactionStatus.js +4 -2
  205. package/lib-es/bridge/getTransactionStatus.js.map +1 -1
  206. package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
  207. package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
  208. package/lib-es/bridge/getTransactionStatus.test.js +277 -0
  209. package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
  210. package/lib-es/bridge/helpers.test.d.ts +2 -0
  211. package/lib-es/bridge/helpers.test.d.ts.map +1 -0
  212. package/lib-es/bridge/helpers.test.js +293 -0
  213. package/lib-es/bridge/helpers.test.js.map +1 -0
  214. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
  215. package/lib-es/bridge/prepareTransaction.js +11 -4
  216. package/lib-es/bridge/prepareTransaction.js.map +1 -1
  217. package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
  218. package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
  219. package/lib-es/bridge/prepareTransaction.test.js +272 -0
  220. package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
  221. package/lib-es/bridge/signOperation.d.ts.map +1 -1
  222. package/lib-es/bridge/signOperation.js +3 -3
  223. package/lib-es/bridge/signOperation.js.map +1 -1
  224. package/lib-es/bridge/signOperation.test.d.ts +2 -0
  225. package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
  226. package/lib-es/bridge/signOperation.test.js +290 -0
  227. package/lib-es/bridge/signOperation.test.js.map +1 -0
  228. package/lib-es/bridge/synchronisation.d.ts.map +1 -1
  229. package/lib-es/bridge/synchronisation.js +1 -1
  230. package/lib-es/bridge/synchronisation.js.map +1 -1
  231. package/lib-es/bridge/transaction.test.d.ts +2 -0
  232. package/lib-es/bridge/transaction.test.d.ts.map +1 -0
  233. package/lib-es/bridge/transaction.test.js +347 -0
  234. package/lib-es/bridge/transaction.test.js.map +1 -0
  235. package/lib-es/common-logic/calculateClauses.d.ts +5 -0
  236. package/lib-es/common-logic/calculateClauses.d.ts.map +1 -0
  237. package/lib-es/common-logic/{logic.js → calculateClauses.js} +6 -6
  238. package/lib-es/common-logic/calculateClauses.js.map +1 -0
  239. package/lib-es/common-logic/calculateClauses.test.d.ts +2 -0
  240. package/lib-es/common-logic/calculateClauses.test.d.ts.map +1 -0
  241. package/lib-es/common-logic/calculateClauses.test.js +151 -0
  242. package/lib-es/common-logic/calculateClauses.test.js.map +1 -0
  243. package/lib-es/common-logic/calculateGasFees.d.ts +9 -0
  244. package/lib-es/common-logic/calculateGasFees.d.ts.map +1 -0
  245. package/lib-es/common-logic/calculateGasFees.js +32 -0
  246. package/lib-es/common-logic/calculateGasFees.js.map +1 -0
  247. package/lib-es/common-logic/calculateGasFees.test.d.ts +2 -0
  248. package/lib-es/common-logic/calculateGasFees.test.d.ts.map +1 -0
  249. package/lib-es/common-logic/calculateGasFees.test.js +274 -0
  250. package/lib-es/common-logic/calculateGasFees.test.js.map +1 -0
  251. package/lib-es/common-logic/calculateTransactionInfo.d.ts +10 -0
  252. package/lib-es/common-logic/calculateTransactionInfo.d.ts.map +1 -0
  253. package/lib-es/common-logic/calculateTransactionInfo.js +74 -0
  254. package/lib-es/common-logic/calculateTransactionInfo.js.map +1 -0
  255. package/lib-es/common-logic/calculateTransactionInfo.test.d.ts +2 -0
  256. package/lib-es/common-logic/calculateTransactionInfo.test.d.ts.map +1 -0
  257. package/lib-es/common-logic/calculateTransactionInfo.test.js +309 -0
  258. package/lib-es/common-logic/calculateTransactionInfo.test.js.map +1 -0
  259. package/lib-es/common-logic/estimateGas.d.ts +10 -0
  260. package/lib-es/common-logic/estimateGas.d.ts.map +1 -0
  261. package/lib-es/common-logic/estimateGas.js +13 -0
  262. package/lib-es/common-logic/estimateGas.js.map +1 -0
  263. package/lib-es/common-logic/estimateGas.test.d.ts +2 -0
  264. package/lib-es/common-logic/estimateGas.test.d.ts.map +1 -0
  265. package/lib-es/common-logic/estimateGas.test.js +127 -0
  266. package/lib-es/common-logic/estimateGas.test.js.map +1 -0
  267. package/lib-es/common-logic/fixPrefixCase.d.ts +2 -0
  268. package/lib-es/common-logic/fixPrefixCase.d.ts.map +1 -0
  269. package/lib-es/common-logic/fixPrefixCase.js +5 -0
  270. package/lib-es/common-logic/fixPrefixCase.js.map +1 -0
  271. package/lib-es/common-logic/fixPrefixCase.test.d.ts +2 -0
  272. package/lib-es/common-logic/fixPrefixCase.test.d.ts.map +1 -0
  273. package/lib-es/common-logic/fixPrefixCase.test.js +44 -0
  274. package/lib-es/common-logic/fixPrefixCase.test.js.map +1 -0
  275. package/lib-es/common-logic/generateNonce.d.ts +6 -0
  276. package/lib-es/common-logic/generateNonce.d.ts.map +1 -0
  277. package/lib-es/common-logic/generateNonce.js +9 -0
  278. package/lib-es/common-logic/generateNonce.js.map +1 -0
  279. package/lib-es/common-logic/generateNonce.test.d.ts +2 -0
  280. package/lib-es/common-logic/generateNonce.test.d.ts.map +1 -0
  281. package/lib-es/common-logic/generateNonce.test.js +57 -0
  282. package/lib-es/common-logic/generateNonce.test.js.map +1 -0
  283. package/lib-es/common-logic/getThorClient.d.ts +7 -0
  284. package/lib-es/common-logic/getThorClient.d.ts.map +1 -0
  285. package/lib-es/common-logic/getThorClient.js +10 -0
  286. package/lib-es/common-logic/getThorClient.js.map +1 -0
  287. package/lib-es/common-logic/getThorClient.test.d.ts +2 -0
  288. package/lib-es/common-logic/getThorClient.test.d.ts.map +1 -0
  289. package/lib-es/common-logic/getThorClient.test.js +51 -0
  290. package/lib-es/common-logic/getThorClient.test.js.map +1 -0
  291. package/lib-es/common-logic/index.d.ts +8 -6
  292. package/lib-es/common-logic/index.d.ts.map +1 -1
  293. package/lib-es/common-logic/index.js +8 -6
  294. package/lib-es/common-logic/index.js.map +1 -1
  295. package/lib-es/common-logic/{mapping-utils.d.ts → mapTransfersToOperations.d.ts} +2 -2
  296. package/lib-es/common-logic/mapTransfersToOperations.d.ts.map +1 -0
  297. package/lib-es/common-logic/mapTransfersToOperations.js +51 -0
  298. package/lib-es/common-logic/mapTransfersToOperations.js.map +1 -0
  299. package/lib-es/common-logic/mapTransfersToOperations.test.d.ts +2 -0
  300. package/lib-es/common-logic/mapTransfersToOperations.test.d.ts.map +1 -0
  301. package/lib-es/common-logic/mapTransfersToOperations.test.js +269 -0
  302. package/lib-es/common-logic/mapTransfersToOperations.test.js.map +1 -0
  303. package/lib-es/common-logic/{pad-address.d.ts → padAddress.d.ts} +1 -1
  304. package/lib-es/common-logic/padAddress.d.ts.map +1 -0
  305. package/lib-es/common-logic/{pad-address.js → padAddress.js} +1 -1
  306. package/lib-es/common-logic/padAddress.js.map +1 -0
  307. package/lib-es/common-logic/padAddress.test.d.ts +2 -0
  308. package/lib-es/common-logic/padAddress.test.d.ts.map +1 -0
  309. package/lib-es/common-logic/padAddress.test.js +57 -0
  310. package/lib-es/common-logic/padAddress.test.js.map +1 -0
  311. package/lib-es/common-logic/parseAddress.d.ts +7 -0
  312. package/lib-es/common-logic/parseAddress.d.ts.map +1 -0
  313. package/lib-es/common-logic/parseAddress.js +11 -0
  314. package/lib-es/common-logic/parseAddress.js.map +1 -0
  315. package/lib-es/common-logic/parseAddress.test.d.ts +2 -0
  316. package/lib-es/common-logic/parseAddress.test.d.ts.map +1 -0
  317. package/lib-es/common-logic/parseAddress.test.js +95 -0
  318. package/lib-es/common-logic/parseAddress.test.js.map +1 -0
  319. package/lib-es/constants/env.d.ts +2 -0
  320. package/lib-es/constants/env.d.ts.map +1 -0
  321. package/lib-es/constants/env.js +3 -0
  322. package/lib-es/constants/env.js.map +1 -0
  323. package/lib-es/constants/index.d.ts +2 -0
  324. package/lib-es/constants/index.d.ts.map +1 -0
  325. package/lib-es/constants/index.js +2 -0
  326. package/lib-es/constants/index.js.map +1 -0
  327. package/lib-es/network/sdk.d.ts +3 -10
  328. package/lib-es/network/sdk.d.ts.map +1 -1
  329. package/lib-es/network/sdk.js +5 -19
  330. package/lib-es/network/sdk.js.map +1 -1
  331. package/lib-es/signer/getAddress.test.d.ts +2 -0
  332. package/lib-es/signer/getAddress.test.d.ts.map +1 -0
  333. package/lib-es/signer/getAddress.test.js +352 -0
  334. package/lib-es/signer/getAddress.test.js.map +1 -0
  335. package/lib-es/signer/signMessage.d.ts.map +1 -1
  336. package/lib-es/signer/signMessage.js +3 -3
  337. package/lib-es/signer/signMessage.js.map +1 -1
  338. package/lib-es/signer/signMessage.test.d.ts +2 -0
  339. package/lib-es/signer/signMessage.test.d.ts.map +1 -0
  340. package/lib-es/signer/signMessage.test.js +240 -0
  341. package/lib-es/signer/signMessage.test.js.map +1 -0
  342. package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -1
  343. package/lib-es/test/bridgeDatasetTest.js +80 -54
  344. package/lib-es/test/bridgeDatasetTest.js.map +1 -1
  345. package/lib-es/test/cli.d.ts.map +1 -1
  346. package/lib-es/test/cli.js +4 -3
  347. package/lib-es/test/cli.js.map +1 -1
  348. package/lib-es/types/bridge.d.ts +11 -3
  349. package/lib-es/types/bridge.d.ts.map +1 -1
  350. package/lib-es/types/bridge.js +6 -1
  351. package/lib-es/types/bridge.js.map +1 -1
  352. package/lib-es/types/constants.d.ts +0 -3
  353. package/lib-es/types/constants.d.ts.map +1 -1
  354. package/lib-es/types/constants.js +0 -3
  355. package/lib-es/types/constants.js.map +1 -1
  356. package/lib-es/types/signer.d.ts +0 -2
  357. package/lib-es/types/signer.d.ts.map +1 -1
  358. package/package.json +10 -9
  359. package/src/bridge/broadcast.test.ts +236 -0
  360. package/src/bridge/broadcast.ts +4 -5
  361. package/src/bridge/buildOptimisticOperatioin.test.ts +364 -0
  362. package/src/bridge/createTransaction.test.ts +201 -0
  363. package/src/bridge/createTransaction.ts +3 -2
  364. package/src/bridge/estimateMaxSpendable.test.ts +319 -0
  365. package/src/bridge/getTransactionStatus.test.ts +353 -0
  366. package/src/bridge/getTransactionStatus.ts +4 -2
  367. package/src/bridge/helpers.test.ts +356 -0
  368. package/src/bridge/prepareTransaction.test.ts +345 -0
  369. package/src/bridge/prepareTransaction.ts +20 -10
  370. package/src/bridge/signOperation.test.ts +354 -0
  371. package/src/bridge/signOperation.ts +6 -3
  372. package/src/bridge/synchronisation.ts +1 -1
  373. package/src/bridge/transaction.test.ts +440 -0
  374. package/src/common-logic/calculateClauses.test.ts +186 -0
  375. package/src/common-logic/calculateClauses.ts +44 -0
  376. package/src/common-logic/calculateGasFees.test.ts +363 -0
  377. package/src/common-logic/calculateGasFees.ts +45 -0
  378. package/src/common-logic/calculateTransactionInfo.test.ts +396 -0
  379. package/src/common-logic/calculateTransactionInfo.ts +96 -0
  380. package/src/common-logic/estimateGas.test.ts +162 -0
  381. package/src/common-logic/estimateGas.ts +18 -0
  382. package/src/common-logic/fixPrefixCase.test.ts +51 -0
  383. package/src/common-logic/fixPrefixCase.ts +5 -0
  384. package/src/common-logic/generateNonce.test.ts +72 -0
  385. package/src/common-logic/generateNonce.ts +9 -0
  386. package/src/common-logic/getThorClient.test.ts +66 -0
  387. package/src/common-logic/getThorClient.ts +10 -0
  388. package/src/common-logic/index.ts +8 -6
  389. package/src/common-logic/mapTransfersToOperations.test.ts +342 -0
  390. package/src/common-logic/mapTransfersToOperations.ts +77 -0
  391. package/src/common-logic/padAddress.test.ts +65 -0
  392. package/src/common-logic/parseAddress.test.ts +130 -0
  393. package/src/common-logic/parseAddress.ts +11 -0
  394. package/src/constants/env.ts +3 -0
  395. package/src/constants/index.ts +1 -0
  396. package/src/network/sdk.ts +22 -30
  397. package/src/signer/getAddress.test.ts +454 -0
  398. package/src/signer/signMessage.test.ts +329 -0
  399. package/src/signer/signMessage.ts +4 -5
  400. package/src/test/bridgeDatasetTest.ts +86 -58
  401. package/src/test/cli.ts +4 -3
  402. package/src/types/bridge.ts +16 -3
  403. package/src/types/constants.ts +0 -3
  404. package/lib/common-logic/address-utils.d.ts +0 -2
  405. package/lib/common-logic/address-utils.d.ts.map +0 -1
  406. package/lib/common-logic/address-utils.js +0 -19
  407. package/lib/common-logic/address-utils.js.map +0 -1
  408. package/lib/common-logic/hex-utils.d.ts +0 -8
  409. package/lib/common-logic/hex-utils.d.ts.map +0 -1
  410. package/lib/common-logic/hex-utils.js +0 -52
  411. package/lib/common-logic/hex-utils.js.map +0 -1
  412. package/lib/common-logic/logic.d.ts +0 -5
  413. package/lib/common-logic/logic.d.ts.map +0 -1
  414. package/lib/common-logic/logic.js.map +0 -1
  415. package/lib/common-logic/mapping-utils.d.ts.map +0 -1
  416. package/lib/common-logic/mapping-utils.js.map +0 -1
  417. package/lib/common-logic/pad-address.d.ts.map +0 -1
  418. package/lib/common-logic/pad-address.js.map +0 -1
  419. package/lib/common-logic/transaction-utils.d.ts +0 -30
  420. package/lib/common-logic/transaction-utils.d.ts.map +0 -1
  421. package/lib/common-logic/transaction-utils.js +0 -161
  422. package/lib/common-logic/transaction-utils.js.map +0 -1
  423. package/lib/contracts/abis/VIP180.d.ts +0 -17
  424. package/lib/contracts/abis/VIP180.d.ts.map +0 -1
  425. package/lib/contracts/abis/VIP180.js +0 -265
  426. package/lib/contracts/abis/VIP180.js.map +0 -1
  427. package/lib/contracts/abis/params.d.ts +0 -8
  428. package/lib/contracts/abis/params.d.ts.map +0 -1
  429. package/lib/contracts/abis/params.js +0 -69
  430. package/lib/contracts/abis/params.js.map +0 -1
  431. package/lib/contracts/constants.d.ts +0 -6
  432. package/lib/contracts/constants.d.ts.map +0 -1
  433. package/lib/contracts/constants.js +0 -10
  434. package/lib/contracts/constants.js.map +0 -1
  435. package/lib-es/common-logic/address-utils.d.ts +0 -2
  436. package/lib-es/common-logic/address-utils.d.ts.map +0 -1
  437. package/lib-es/common-logic/address-utils.js +0 -12
  438. package/lib-es/common-logic/address-utils.js.map +0 -1
  439. package/lib-es/common-logic/hex-utils.d.ts +0 -8
  440. package/lib-es/common-logic/hex-utils.d.ts.map +0 -1
  441. package/lib-es/common-logic/hex-utils.js +0 -50
  442. package/lib-es/common-logic/hex-utils.js.map +0 -1
  443. package/lib-es/common-logic/logic.d.ts +0 -5
  444. package/lib-es/common-logic/logic.d.ts.map +0 -1
  445. package/lib-es/common-logic/logic.js.map +0 -1
  446. package/lib-es/common-logic/mapping-utils.d.ts.map +0 -1
  447. package/lib-es/common-logic/mapping-utils.js +0 -44
  448. package/lib-es/common-logic/mapping-utils.js.map +0 -1
  449. package/lib-es/common-logic/pad-address.d.ts.map +0 -1
  450. package/lib-es/common-logic/pad-address.js.map +0 -1
  451. package/lib-es/common-logic/transaction-utils.d.ts +0 -30
  452. package/lib-es/common-logic/transaction-utils.d.ts.map +0 -1
  453. package/lib-es/common-logic/transaction-utils.js +0 -150
  454. package/lib-es/common-logic/transaction-utils.js.map +0 -1
  455. package/lib-es/contracts/abis/VIP180.d.ts +0 -17
  456. package/lib-es/contracts/abis/VIP180.d.ts.map +0 -1
  457. package/lib-es/contracts/abis/VIP180.js +0 -263
  458. package/lib-es/contracts/abis/VIP180.js.map +0 -1
  459. package/lib-es/contracts/abis/params.d.ts +0 -8
  460. package/lib-es/contracts/abis/params.d.ts.map +0 -1
  461. package/lib-es/contracts/abis/params.js +0 -67
  462. package/lib-es/contracts/abis/params.js.map +0 -1
  463. package/lib-es/contracts/constants.d.ts +0 -6
  464. package/lib-es/contracts/constants.d.ts.map +0 -1
  465. package/lib-es/contracts/constants.js +0 -7
  466. package/lib-es/contracts/constants.js.map +0 -1
  467. package/src/common-logic/address-utils.ts +0 -11
  468. package/src/common-logic/hex-utils.ts +0 -53
  469. package/src/common-logic/logic.ts +0 -44
  470. package/src/common-logic/mapping-utils.ts +0 -67
  471. package/src/common-logic/transaction-utils.ts +0 -190
  472. package/src/contracts/abis/VIP180.ts +0 -265
  473. package/src/contracts/abis/params.ts +0 -70
  474. package/src/contracts/constants.ts +0 -11
  475. /package/src/common-logic/{pad-address.ts → padAddress.ts} +0 -0
@@ -1,4 +1,4 @@
1
1
 
2
- > @ledgerhq/coin-vechain@2.9.1-nightly.0 build /home/runner/work/ledger-live/ledger-live/libs/coin-modules/coin-vechain
2
+ > @ledgerhq/coin-vechain@2.9.1 build /home/runner/work/ledger-live/ledger-live/libs/coin-modules/coin-vechain
3
3
  > tsc && tsc -m esnext --moduleResolution bundler --outDir lib-es
4
4
 
@@ -33,8 +33,19 @@
33
33
  "src/common-logic/logic.ts",
34
34
  "src/common-logic/mapping-utils.ts",
35
35
  "src/common-logic/pad-address.ts",
36
- "src/common-logic/transaction-utils.ts",
36
+ "src/common-logic/calculateClauses.ts",
37
+ "src/common-logic/calculateGasFees.ts",
38
+ "src/common-logic/calculateTransactionInfo.ts",
39
+ "src/common-logic/estimateGas.ts",
40
+ "src/common-logic/fixPrefixCase.ts",
41
+ "src/common-logic/generateNonce.ts",
42
+ "src/common-logic/getThorClient.ts",
43
+ "src/common-logic/mapTransfersToOperations.ts",
44
+ "src/common-logic/padAddress.ts",
45
+ "src/common-logic/parseAddress.ts",
37
46
  "src/config.ts",
47
+ "src/constants/env.ts",
48
+ "src/constants/index.ts",
38
49
  "src/contracts/abis/VIP180.ts",
39
50
  "src/contracts/abis/params.ts",
40
51
  "src/contracts/constants.ts",
@@ -64,12 +75,13 @@
64
75
  "@ledgerhq/cryptoassets",
65
76
  "@ledgerhq/devices",
66
77
  "@ledgerhq/live-env",
78
+ "@vechain/sdk-core",
67
79
  "@ledgerhq/live-network",
80
+ "@vechain/sdk-network",
68
81
  "bignumber.js",
69
82
  "eip55",
70
83
  "invariant",
71
84
  "lodash",
72
- "rxjs",
73
- "thor-devkit"
85
+ "rxjs"
74
86
  ]
75
- }
87
+ }
package/CHANGELOG.md CHANGED
@@ -1,21 +1,35 @@
1
1
  # @ledgerhq/coin-evm
2
2
 
3
- ## 2.9.1-nightly.1
3
+ ## 2.9.2-nightly.0
4
4
 
5
5
  ### Patch Changes
6
6
 
7
- - Updated dependencies [[`2b896f9`](https://github.com/LedgerHQ/ledger-live/commit/2b896f94d6fc53ef965ed567489ad96d913466d4), [`338d979`](https://github.com/LedgerHQ/ledger-live/commit/338d979bae349b185c52b1d8c9f6718a3d142526), [`b27c96c`](https://github.com/LedgerHQ/ledger-live/commit/b27c96ccbcefb1982a40688a8385209eac99165a)]:
8
- - @ledgerhq/coin-framework@6.4.0-nightly.1
9
- - @ledgerhq/cryptoassets@13.28.0-nightly.0
10
- - @ledgerhq/live-env@2.16.0-nightly.0
11
- - @ledgerhq/live-network@2.0.17-nightly.0
7
+ - Updated dependencies [[`38a172c`](https://github.com/LedgerHQ/ledger-live/commit/38a172c23035040d077433c7f4fce60f72962ae0), [`3b5576e`](https://github.com/LedgerHQ/ledger-live/commit/3b5576e0b67fedad0f5dbbd6b9546281af4e6111), [`fe97131`](https://github.com/LedgerHQ/ledger-live/commit/fe971313776194e5942dfa9a95d6082950c3111e)]:
8
+ - @ledgerhq/devices@8.5.2-nightly.0
9
+ - @ledgerhq/live-env@2.17.0-nightly.0
10
+ - @ledgerhq/coin-framework@6.4.1-nightly.0
11
+ - @ledgerhq/cryptoassets@13.28.1-nightly.0
12
+ - @ledgerhq/live-network@2.0.18-nightly.0
12
13
 
13
- ## 2.9.1-nightly.0
14
+ ## 2.9.1
14
15
 
15
16
  ### Patch Changes
16
17
 
17
- - Updated dependencies [[`c190e2b`](https://github.com/LedgerHQ/ledger-live/commit/c190e2b104a9dd0dd693c2d72433b98115f4089f)]:
18
- - @ledgerhq/coin-framework@6.4.0-nightly.0
18
+ - Updated dependencies [[`2b896f9`](https://github.com/LedgerHQ/ledger-live/commit/2b896f94d6fc53ef965ed567489ad96d913466d4), [`338d979`](https://github.com/LedgerHQ/ledger-live/commit/338d979bae349b185c52b1d8c9f6718a3d142526), [`2482195`](https://github.com/LedgerHQ/ledger-live/commit/24821957c838a304be60ff6e16798ef3cac987cd), [`e52268a`](https://github.com/LedgerHQ/ledger-live/commit/e52268a3bc7d97a7ed09ed082786a647e048a6e8), [`89fc31e`](https://github.com/LedgerHQ/ledger-live/commit/89fc31e8ecfc5e2fd679a2694b3514f8fb19d7b7), [`ff22728`](https://github.com/LedgerHQ/ledger-live/commit/ff22728a61ab2cde6835991bf8ed115d4a39a1d0), [`c190e2b`](https://github.com/LedgerHQ/ledger-live/commit/c190e2b104a9dd0dd693c2d72433b98115f4089f), [`a87922d`](https://github.com/LedgerHQ/ledger-live/commit/a87922dc99e4f2e4b40a46fd52ad08a71012fe94), [`3489203`](https://github.com/LedgerHQ/ledger-live/commit/34892030dcfbd1a19a0eb0a8fcae9f8f01d3d2a9), [`b27c96c`](https://github.com/LedgerHQ/ledger-live/commit/b27c96ccbcefb1982a40688a8385209eac99165a)]:
19
+ - @ledgerhq/coin-framework@6.4.0
20
+ - @ledgerhq/cryptoassets@13.28.0
21
+ - @ledgerhq/live-env@2.16.0
22
+ - @ledgerhq/live-network@2.0.17
23
+
24
+ ## 2.9.1-next.0
25
+
26
+ ### Patch Changes
27
+
28
+ - Updated dependencies [[`2b896f9`](https://github.com/LedgerHQ/ledger-live/commit/2b896f94d6fc53ef965ed567489ad96d913466d4), [`338d979`](https://github.com/LedgerHQ/ledger-live/commit/338d979bae349b185c52b1d8c9f6718a3d142526), [`2482195`](https://github.com/LedgerHQ/ledger-live/commit/24821957c838a304be60ff6e16798ef3cac987cd), [`e52268a`](https://github.com/LedgerHQ/ledger-live/commit/e52268a3bc7d97a7ed09ed082786a647e048a6e8), [`89fc31e`](https://github.com/LedgerHQ/ledger-live/commit/89fc31e8ecfc5e2fd679a2694b3514f8fb19d7b7), [`ff22728`](https://github.com/LedgerHQ/ledger-live/commit/ff22728a61ab2cde6835991bf8ed115d4a39a1d0), [`c190e2b`](https://github.com/LedgerHQ/ledger-live/commit/c190e2b104a9dd0dd693c2d72433b98115f4089f), [`a87922d`](https://github.com/LedgerHQ/ledger-live/commit/a87922dc99e4f2e4b40a46fd52ad08a71012fe94), [`3489203`](https://github.com/LedgerHQ/ledger-live/commit/34892030dcfbd1a19a0eb0a8fcae9f8f01d3d2a9), [`b27c96c`](https://github.com/LedgerHQ/ledger-live/commit/b27c96ccbcefb1982a40688a8385209eac99165a)]:
29
+ - @ledgerhq/coin-framework@6.4.0-next.0
30
+ - @ledgerhq/cryptoassets@13.28.0-next.0
31
+ - @ledgerhq/live-env@2.16.0-next.0
32
+ - @ledgerhq/live-network@2.0.17-next.0
19
33
 
20
34
  ## 2.9.0
21
35
 
@@ -1 +1 @@
1
- {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvC;;GAEG;AACH,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAU7D,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAyB,MAAM,UAAU,CAAC;AAG9D;;GAEG;AACH,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAU7D,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -1,15 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.broadcast = void 0;
4
- const thor_devkit_1 = require("thor-devkit");
5
4
  const operation_1 = require("@ledgerhq/coin-framework/operation");
5
+ const types_1 = require("../types");
6
6
  const network_1 = require("../network");
7
7
  /**
8
8
  * Broadcast the signed transaction
9
9
  */
10
10
  const broadcast = async ({ signedOperation: { signature, operation, rawData }, }) => {
11
- const transaction = new thor_devkit_1.Transaction(rawData.body);
12
- transaction.signature = Buffer.from(signature, "hex");
11
+ const transaction = types_1.VechainSDKTransaction.of(rawData.body, Buffer.from(signature, "hex"));
13
12
  const hash = await (0, network_1.submit)(transaction);
14
13
  return (0, operation_1.patchOperationWithHash)(operation, hash);
15
14
  };
@@ -1 +1 @@
1
- {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;AAAA,6CAAoE;AAEpE,kEAA4E;AAG5E,wCAAoC;AAEpC;;GAEG;AACI,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,GACnD,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,IAAI,yBAAsB,CAC3C,OAA6C,CAAC,IAAI,CACpD,CAAC;IACF,WAAW,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IACtD,MAAM,IAAI,GAAG,MAAM,IAAA,gBAAM,EAAC,WAAW,CAAC,CAAC;IAEvC,OAAO,IAAA,kCAAsB,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC;AAVW,QAAA,SAAS,aAUpB;AAEF,kBAAe,iBAAS,CAAC"}
1
+ {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;AACA,kEAA4E;AAE5E,oCAA8D;AAC9D,wCAAoC;AAEpC;;GAEG;AACI,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,GACnD,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,6BAAqB,CAAC,EAAE,CACzC,OAA4C,CAAC,IAAI,EAClD,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAC9B,CAAC;IACF,MAAM,IAAI,GAAG,MAAM,IAAA,gBAAM,EAAC,WAAW,CAAC,CAAC;IAEvC,OAAO,IAAA,kCAAsB,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC;AAVW,QAAA,SAAS,aAUpB;AAEF,kBAAe,iBAAS,CAAC"}
@@ -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,188 @@
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 bignumber_js_1 = __importDefault(require("bignumber.js"));
7
+ const broadcast_1 = require("./broadcast");
8
+ const operation_1 = require("@ledgerhq/coin-framework/operation");
9
+ const network_1 = require("../network");
10
+ const types_1 = require("../types");
11
+ // Mock dependencies
12
+ jest.mock("@ledgerhq/coin-framework/operation");
13
+ jest.mock("../network");
14
+ jest.mock("../types", () => ({
15
+ ...jest.requireActual("../types"),
16
+ VechainSDKTransaction: {
17
+ of: jest.fn(),
18
+ },
19
+ }));
20
+ const mockedPatchOperationWithHash = jest.mocked(operation_1.patchOperationWithHash);
21
+ const mockedSubmit = jest.mocked(network_1.submit);
22
+ const mockedVechainSDKTransaction = jest.mocked(types_1.VechainSDKTransaction);
23
+ describe("broadcast", () => {
24
+ const mockAccount = {
25
+ type: "Account",
26
+ id: "vechain:1:0x123:",
27
+ seedIdentifier: "seed123",
28
+ derivationMode: "",
29
+ index: 0,
30
+ freshAddress: "0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4",
31
+ freshAddressPath: "44'/818'/0'/0/0",
32
+ used: true,
33
+ balance: new bignumber_js_1.default("5000000000000000000"),
34
+ spendableBalance: new bignumber_js_1.default("5000000000000000000"),
35
+ creationDate: new Date("2022-01-01"),
36
+ blockHeight: 12345,
37
+ currency: {},
38
+ operationsCount: 10,
39
+ operations: [],
40
+ pendingOperations: [],
41
+ lastSyncDate: new Date("2022-01-01"),
42
+ balanceHistoryCache: { HOUR: {}, DAY: {}, WEEK: {} },
43
+ swapHistory: [],
44
+ subAccounts: [],
45
+ };
46
+ const mockOperation = {
47
+ id: "vechain:1:0x123:0xtxhash:OUT",
48
+ hash: "",
49
+ type: "OUT",
50
+ value: new bignumber_js_1.default("1000000000000000000"),
51
+ fee: new bignumber_js_1.default("21000000000000000"),
52
+ blockHash: null,
53
+ blockHeight: null,
54
+ senders: ["0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4"],
55
+ recipients: ["0x456789012345678901234567890123456789abcd"],
56
+ accountId: "vechain:1:0x123:",
57
+ date: new Date("2022-01-01"),
58
+ extra: {},
59
+ };
60
+ const mockTransactionBody = {
61
+ chainTag: 74,
62
+ blockRef: "0x00000000000b2bce",
63
+ expiration: 18,
64
+ clauses: [
65
+ {
66
+ to: "0x456789012345678901234567890123456789abcd",
67
+ value: "1000000000000000000",
68
+ data: "0x",
69
+ },
70
+ ],
71
+ maxFeePerGas: 10000000000000,
72
+ maxPriorityFeePerGas: 1000000000000,
73
+ gas: 21000,
74
+ dependsOn: null,
75
+ nonce: "0x12345678",
76
+ };
77
+ const mockSignedOperation = {
78
+ operation: mockOperation,
79
+ signature: "1234567890abcdef",
80
+ rawData: {
81
+ family: "vechain",
82
+ body: mockTransactionBody,
83
+ },
84
+ };
85
+ const mockTransaction = {
86
+ body: mockTransactionBody,
87
+ };
88
+ beforeEach(() => {
89
+ jest.clearAllMocks();
90
+ });
91
+ it("should broadcast a signed transaction successfully", async () => {
92
+ const mockTxHash = "0xabcdef1234567890";
93
+ const mockPatchedOperation = { ...mockOperation, hash: mockTxHash };
94
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
95
+ mockedSubmit.mockResolvedValue(mockTxHash);
96
+ mockedPatchOperationWithHash.mockReturnValue(mockPatchedOperation);
97
+ const result = await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: mockSignedOperation });
98
+ expect(mockedVechainSDKTransaction.of).toHaveBeenCalledWith(mockTransactionBody, Buffer.from("1234567890abcdef", "hex"));
99
+ expect(mockedSubmit).toHaveBeenCalledWith(mockTransaction);
100
+ expect(mockedPatchOperationWithHash).toHaveBeenCalledWith(mockOperation, mockTxHash);
101
+ expect(result).toEqual(mockPatchedOperation);
102
+ });
103
+ it("should handle transaction creation from raw data", async () => {
104
+ const mockTxHash = "0x123456789abcdef0";
105
+ const mockPatchedOperation = { ...mockOperation, hash: mockTxHash };
106
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
107
+ mockedSubmit.mockResolvedValue(mockTxHash);
108
+ mockedPatchOperationWithHash.mockReturnValue(mockPatchedOperation);
109
+ await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: mockSignedOperation });
110
+ expect(mockedVechainSDKTransaction.of).toHaveBeenCalledWith(mockTransactionBody, expect.any(Buffer));
111
+ });
112
+ it("should convert hex signature to Buffer correctly", async () => {
113
+ const hexSignature = "abcdef1234567890";
114
+ const signedOpWithHexSig = {
115
+ ...mockSignedOperation,
116
+ signature: hexSignature,
117
+ };
118
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
119
+ mockedSubmit.mockResolvedValue("0xhash");
120
+ mockedPatchOperationWithHash.mockReturnValue(mockOperation);
121
+ await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: signedOpWithHexSig });
122
+ expect(mockedVechainSDKTransaction.of).toHaveBeenCalledWith(mockTransactionBody, Buffer.from(hexSignature, "hex"));
123
+ });
124
+ it("should propagate errors from submit", async () => {
125
+ const errorMessage = "Network error during submission";
126
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
127
+ mockedSubmit.mockRejectedValue(new Error(errorMessage));
128
+ await expect((0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: mockSignedOperation })).rejects.toThrow(errorMessage);
129
+ });
130
+ it("should propagate errors from VechainSDKTransaction.of", async () => {
131
+ const errorMessage = "Invalid transaction body";
132
+ mockedVechainSDKTransaction.of.mockImplementation(() => {
133
+ throw new Error(errorMessage);
134
+ });
135
+ await expect((0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: mockSignedOperation })).rejects.toThrow(errorMessage);
136
+ });
137
+ it("should handle different signature formats", async () => {
138
+ const signatures = ["12ab", "1234567890abcdef", "ff".repeat(32)];
139
+ for (const signature of signatures) {
140
+ const signedOp = { ...mockSignedOperation, signature };
141
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
142
+ mockedSubmit.mockResolvedValue("0xhash");
143
+ mockedPatchOperationWithHash.mockReturnValue(mockOperation);
144
+ await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: signedOp });
145
+ expect(mockedVechainSDKTransaction.of).toHaveBeenCalledWith(mockTransactionBody, Buffer.from(signature, "hex"));
146
+ }
147
+ });
148
+ it("should handle complex transaction bodies", async () => {
149
+ const complexBody = {
150
+ ...mockTransactionBody,
151
+ clauses: [
152
+ {
153
+ to: "0x456789012345678901234567890123456789abcd",
154
+ value: "1000000000000000000",
155
+ data: "0xa9059cbb000000000000000000000000742d35cc6634c0532925a3b8d0b251d8c1743ec40000000000000000000000000000000000000000000000000de0b6b3a7640000",
156
+ },
157
+ {
158
+ to: "0x0000000000000000000000000000456e65726779",
159
+ value: "0",
160
+ data: "0x",
161
+ },
162
+ ],
163
+ dependsOn: "0xprevious123",
164
+ };
165
+ const complexSignedOp = {
166
+ ...mockSignedOperation,
167
+ rawData: { ...mockSignedOperation.rawData, body: complexBody },
168
+ };
169
+ mockedVechainSDKTransaction.of.mockReturnValue({ body: complexBody });
170
+ mockedSubmit.mockResolvedValue("0xhash");
171
+ mockedPatchOperationWithHash.mockReturnValue(mockOperation);
172
+ await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: complexSignedOp });
173
+ expect(mockedVechainSDKTransaction.of).toHaveBeenCalledWith(complexBody, expect.any(Buffer));
174
+ });
175
+ it("should return the exact result from patchOperationWithHash", async () => {
176
+ const specificPatchedOp = {
177
+ ...mockOperation,
178
+ hash: "0xspecifichash",
179
+ blockHeight: 12345,
180
+ };
181
+ mockedVechainSDKTransaction.of.mockReturnValue(mockTransaction);
182
+ mockedSubmit.mockResolvedValue("0xspecifichash");
183
+ mockedPatchOperationWithHash.mockReturnValue(specificPatchedOp);
184
+ const result = await (0, broadcast_1.broadcast)({ account: mockAccount, signedOperation: mockSignedOperation });
185
+ expect(result).toBe(specificPatchedOp);
186
+ });
187
+ });
188
+ //# sourceMappingURL=broadcast.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=buildOptimisticOperatioin.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildOptimisticOperatioin.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperatioin.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,286 @@
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 bignumber_js_1 = __importDefault(require("bignumber.js"));
7
+ const buildOptimisticOperatioin_1 = require("./buildOptimisticOperatioin");
8
+ const operation_1 = require("@ledgerhq/coin-framework/operation");
9
+ // Mock dependencies
10
+ jest.mock("@ledgerhq/coin-framework/operation");
11
+ const mockedEncodeOperationId = jest.mocked(operation_1.encodeOperationId);
12
+ describe("buildOptimisticOperation", () => {
13
+ const mockAccount = {
14
+ type: "Account",
15
+ id: "vechain:1:0x123:",
16
+ seedIdentifier: "seed123",
17
+ derivationMode: "",
18
+ index: 0,
19
+ freshAddress: "0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4",
20
+ freshAddressPath: "44'/818'/0'/0/0",
21
+ used: true,
22
+ balance: new bignumber_js_1.default("5000000000000000000"),
23
+ spendableBalance: new bignumber_js_1.default("5000000000000000000"),
24
+ creationDate: new Date("2022-01-01"),
25
+ blockHeight: 12345,
26
+ currency: {},
27
+ operationsCount: 10,
28
+ operations: [],
29
+ pendingOperations: [],
30
+ lastSyncDate: new Date("2022-01-01"),
31
+ balanceHistoryCache: { HOUR: {}, DAY: {}, WEEK: {} },
32
+ swapHistory: [],
33
+ subAccounts: [],
34
+ };
35
+ const mockVetTransaction = {
36
+ family: "vechain",
37
+ recipient: "0x456789012345678901234567890123456789abcd",
38
+ amount: new bignumber_js_1.default("1000000000000000000"),
39
+ estimatedFees: "210000000000000000",
40
+ body: {
41
+ chainTag: 74,
42
+ blockRef: "0x00000000000b2bce",
43
+ expiration: 18,
44
+ clauses: [],
45
+ maxFeePerGas: 10000000000000,
46
+ maxPriorityFeePerGas: 1000000000000,
47
+ gas: 21000,
48
+ dependsOn: null,
49
+ nonce: "0x12345678",
50
+ },
51
+ };
52
+ const mockTokenTransaction = {
53
+ ...mockVetTransaction,
54
+ subAccountId: "vechain:1:0x123:+vtho",
55
+ };
56
+ beforeEach(() => {
57
+ jest.clearAllMocks();
58
+ mockedEncodeOperationId.mockImplementation((accountId, hash, type) => `${accountId}${hash}${type}`);
59
+ });
60
+ describe("VET transactions", () => {
61
+ it("should build optimistic operation for VET transaction", async () => {
62
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
63
+ expect(result).toEqual({
64
+ id: "vechain:1:0x123:OUT",
65
+ hash: "",
66
+ type: "OUT",
67
+ value: new bignumber_js_1.default("1000000000000000000"),
68
+ fee: new bignumber_js_1.default("210000000000000000"),
69
+ blockHash: null,
70
+ blockHeight: null,
71
+ senders: ["0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4"],
72
+ recipients: ["0x456789012345678901234567890123456789abcd"],
73
+ accountId: "vechain:1:0x123:",
74
+ date: expect.any(Date),
75
+ extra: {},
76
+ subOperations: [],
77
+ });
78
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:1:0x123:", "", "OUT");
79
+ });
80
+ it("should set correct value and fee for VET transaction", async () => {
81
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
82
+ expect(result.value).toEqual(new bignumber_js_1.default("1000000000000000000"));
83
+ expect(result.fee).toEqual(new bignumber_js_1.default("210000000000000000"));
84
+ });
85
+ it("should have empty subOperations for VET transaction", async () => {
86
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
87
+ expect(result.subOperations).toEqual([]);
88
+ });
89
+ });
90
+ describe("Token transactions", () => {
91
+ it("should build optimistic operation for token transaction", async () => {
92
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
93
+ expect(result).toEqual({
94
+ id: "vechain:1:0x123:OUT",
95
+ hash: "",
96
+ type: "NONE",
97
+ value: new bignumber_js_1.default("0"),
98
+ fee: new bignumber_js_1.default("0"),
99
+ blockHash: null,
100
+ blockHeight: null,
101
+ senders: ["0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4"],
102
+ recipients: ["0x456789012345678901234567890123456789abcd"],
103
+ accountId: "vechain:1:0x123:",
104
+ date: expect.any(Date),
105
+ extra: {},
106
+ subOperations: [
107
+ {
108
+ id: "vechain:1:0x123:+vthoOUT",
109
+ hash: "",
110
+ type: "OUT",
111
+ value: new bignumber_js_1.default("1000000000000000000"),
112
+ fee: new bignumber_js_1.default("210000000000000000"),
113
+ blockHash: null,
114
+ blockHeight: null,
115
+ senders: ["0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4"],
116
+ recipients: ["0x456789012345678901234567890123456789abcd"],
117
+ accountId: "vechain:1:0x123:+vtho",
118
+ date: expect.any(Date),
119
+ extra: {},
120
+ },
121
+ ],
122
+ });
123
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:1:0x123:", "", "OUT");
124
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:1:0x123:+vtho", "", "OUT");
125
+ });
126
+ it("should set type to NONE for token transaction main operation", async () => {
127
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
128
+ expect(result.type).toBe("NONE");
129
+ });
130
+ it("should have zero value and fee for token transaction main operation", async () => {
131
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
132
+ expect(result.value).toEqual(new bignumber_js_1.default("0"));
133
+ expect(result.fee).toEqual(new bignumber_js_1.default("0"));
134
+ });
135
+ it("should create correct subOperation for token transaction", async () => {
136
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
137
+ expect(result.subOperations).toHaveLength(1);
138
+ const subOp = result.subOperations[0];
139
+ expect(subOp.type).toBe("OUT");
140
+ expect(subOp.value).toEqual(new bignumber_js_1.default("1000000000000000000"));
141
+ expect(subOp.fee).toEqual(new bignumber_js_1.default("210000000000000000"));
142
+ expect(subOp.accountId).toBe("vechain:1:0x123:+vtho");
143
+ });
144
+ });
145
+ describe("Common operation properties", () => {
146
+ it("should set empty hash for both transaction types", async () => {
147
+ const vetResult = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
148
+ const tokenResult = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
149
+ expect(vetResult.hash).toBe("");
150
+ expect(tokenResult.hash).toBe("");
151
+ if (tokenResult.subOperations && tokenResult.subOperations[0]) {
152
+ expect(tokenResult.subOperations[0].hash).toBe("");
153
+ }
154
+ });
155
+ it("should set null blockHash and blockHeight", async () => {
156
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
157
+ expect(result.blockHash).toBe(null);
158
+ expect(result.blockHeight).toBe(null);
159
+ });
160
+ it("should set senders from account freshAddress", async () => {
161
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
162
+ expect(result.senders).toEqual(["0x742d35Cc6634C0532925a3b8D0B251d8c1743eC4"]);
163
+ });
164
+ it("should set recipients from transaction recipient", async () => {
165
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
166
+ expect(result.recipients).toEqual(["0x456789012345678901234567890123456789abcd"]);
167
+ });
168
+ it("should filter out empty recipients", async () => {
169
+ const transactionWithoutRecipient = {
170
+ ...mockVetTransaction,
171
+ recipient: "",
172
+ };
173
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, transactionWithoutRecipient);
174
+ expect(result.recipients).toEqual([]);
175
+ });
176
+ it("should set accountId from account", async () => {
177
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
178
+ expect(result.accountId).toBe("vechain:1:0x123:");
179
+ });
180
+ it("should set current date", async () => {
181
+ const before = new Date();
182
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
183
+ const after = new Date();
184
+ expect(result.date.getTime()).toBeGreaterThanOrEqual(before.getTime());
185
+ expect(result.date.getTime()).toBeLessThanOrEqual(after.getTime());
186
+ });
187
+ it("should set empty extra object", async () => {
188
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
189
+ expect(result.extra).toEqual({});
190
+ });
191
+ });
192
+ describe("encodeOperationId calls", () => {
193
+ it("should call encodeOperationId with correct parameters for VET transaction", async () => {
194
+ await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockVetTransaction);
195
+ expect(mockedEncodeOperationId).toHaveBeenCalledTimes(1);
196
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:1:0x123:", "", "OUT");
197
+ });
198
+ it("should call encodeOperationId twice for token transaction", async () => {
199
+ await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, mockTokenTransaction);
200
+ expect(mockedEncodeOperationId).toHaveBeenCalledTimes(2);
201
+ expect(mockedEncodeOperationId).toHaveBeenNthCalledWith(1, "vechain:1:0x123:", "", "OUT");
202
+ expect(mockedEncodeOperationId).toHaveBeenNthCalledWith(2, "vechain:1:0x123:+vtho", "", "OUT");
203
+ });
204
+ });
205
+ describe("different transaction amounts and fees", () => {
206
+ it("should handle different transaction amounts", async () => {
207
+ const customAmountTransaction = {
208
+ ...mockVetTransaction,
209
+ amount: new bignumber_js_1.default("2500000000000000000"), // 2.5 VET
210
+ };
211
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, customAmountTransaction);
212
+ expect(result.value).toEqual(new bignumber_js_1.default("2500000000000000000"));
213
+ });
214
+ it("should handle different estimated fees", async () => {
215
+ const customFeeTransaction = {
216
+ ...mockVetTransaction,
217
+ estimatedFees: "420000000000000000", // 0.42 VET
218
+ };
219
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, customFeeTransaction);
220
+ expect(result.fee).toEqual(new bignumber_js_1.default("420000000000000000"));
221
+ });
222
+ it("should handle zero amounts", async () => {
223
+ const zeroAmountTransaction = {
224
+ ...mockVetTransaction,
225
+ amount: new bignumber_js_1.default("0"),
226
+ };
227
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, zeroAmountTransaction);
228
+ expect(result.value).toEqual(new bignumber_js_1.default("0"));
229
+ });
230
+ it("should handle very large amounts", async () => {
231
+ const largeAmountTransaction = {
232
+ ...mockVetTransaction,
233
+ amount: new bignumber_js_1.default("1000000000000000000000000"), // 1M VET
234
+ };
235
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, largeAmountTransaction);
236
+ expect(result.value).toEqual(new bignumber_js_1.default("1000000000000000000000000"));
237
+ });
238
+ });
239
+ describe("different account and subAccount IDs", () => {
240
+ it("should handle different account IDs", async () => {
241
+ const customAccount = {
242
+ ...mockAccount,
243
+ id: "vechain:2:0xabc:",
244
+ };
245
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(customAccount, mockVetTransaction);
246
+ expect(result.accountId).toBe("vechain:2:0xabc:");
247
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:2:0xabc:", "", "OUT");
248
+ });
249
+ it("should handle different subAccount IDs", async () => {
250
+ const customSubAccountTransaction = {
251
+ ...mockTokenTransaction,
252
+ subAccountId: "vechain:1:0x123:+customtoken",
253
+ };
254
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, customSubAccountTransaction);
255
+ expect(result.subOperations[0].accountId).toBe("vechain:1:0x123:+customtoken");
256
+ expect(mockedEncodeOperationId).toHaveBeenCalledWith("vechain:1:0x123:+customtoken", "", "OUT");
257
+ });
258
+ });
259
+ describe("edge cases", () => {
260
+ it("should handle transaction with null recipient", async () => {
261
+ const nullRecipientTransaction = {
262
+ ...mockVetTransaction,
263
+ recipient: null,
264
+ };
265
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, nullRecipientTransaction);
266
+ expect(result.recipients).toEqual([]);
267
+ });
268
+ it("should handle transaction with undefined recipient", async () => {
269
+ const undefinedRecipientTransaction = {
270
+ ...mockVetTransaction,
271
+ recipient: undefined,
272
+ };
273
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(mockAccount, undefinedRecipientTransaction);
274
+ expect(result.recipients).toEqual([]);
275
+ });
276
+ it("should handle different fresh addresses", async () => {
277
+ const customAccount = {
278
+ ...mockAccount,
279
+ freshAddress: "0x999888777666555444333222111000aaabbbcccd",
280
+ };
281
+ const result = await (0, buildOptimisticOperatioin_1.buildOptimisticOperation)(customAccount, mockVetTransaction);
282
+ expect(result.senders).toEqual(["0x999888777666555444333222111000aaabbbcccd"]);
283
+ });
284
+ });
285
+ });
286
+ //# sourceMappingURL=buildOptimisticOperatioin.test.js.map