@ledgerhq/coin-multiversx 0.2.0-next.2

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 (378) hide show
  1. package/.eslintrc.js +23 -0
  2. package/.turbo/turbo-build.log +4 -0
  3. package/.unimportedrc.json +31 -0
  4. package/CHANGELOG.md +400 -0
  5. package/LICENSE.txt +21 -0
  6. package/jest.config.js +8 -0
  7. package/lib/api/apiCalls.d.ts +22 -0
  8. package/lib/api/apiCalls.d.ts.map +1 -0
  9. package/lib/api/apiCalls.js +153 -0
  10. package/lib/api/apiCalls.js.map +1 -0
  11. package/lib/api/dtos/multiversx-account.d.ts +9 -0
  12. package/lib/api/dtos/multiversx-account.d.ts.map +1 -0
  13. package/lib/api/dtos/multiversx-account.js +17 -0
  14. package/lib/api/dtos/multiversx-account.js.map +1 -0
  15. package/lib/api/index.d.ts +2 -0
  16. package/lib/api/index.d.ts.map +1 -0
  17. package/lib/api/index.js +16 -0
  18. package/lib/api/index.js.map +1 -0
  19. package/lib/api/sdk.d.ts +29 -0
  20. package/lib/api/sdk.d.ts.map +1 -0
  21. package/lib/api/sdk.js +281 -0
  22. package/lib/api/sdk.js.map +1 -0
  23. package/lib/bridge/js.d.ts +11 -0
  24. package/lib/bridge/js.d.ts.map +1 -0
  25. package/lib/bridge/js.js +62 -0
  26. package/lib/bridge/js.js.map +1 -0
  27. package/lib/bridge.integration.test.d.ts +4 -0
  28. package/lib/bridge.integration.test.d.ts.map +1 -0
  29. package/lib/bridge.integration.test.js +142 -0
  30. package/lib/bridge.integration.test.js.map +1 -0
  31. package/lib/broadcast.d.ts +9 -0
  32. package/lib/broadcast.d.ts.map +1 -0
  33. package/lib/broadcast.js +16 -0
  34. package/lib/broadcast.js.map +1 -0
  35. package/lib/buildOptimisticOperation.d.ts +4 -0
  36. package/lib/buildOptimisticOperation.d.ts.map +1 -0
  37. package/lib/buildOptimisticOperation.js +100 -0
  38. package/lib/buildOptimisticOperation.js.map +1 -0
  39. package/lib/buildOptimisticOperation.test.d.ts +2 -0
  40. package/lib/buildOptimisticOperation.test.d.ts.map +1 -0
  41. package/lib/buildOptimisticOperation.test.js +78 -0
  42. package/lib/buildOptimisticOperation.test.js.map +1 -0
  43. package/lib/buildSubAccounts.d.ts +11 -0
  44. package/lib/buildSubAccounts.d.ts.map +1 -0
  45. package/lib/buildSubAccounts.js +117 -0
  46. package/lib/buildSubAccounts.js.map +1 -0
  47. package/lib/buildTransaction.d.ts +19 -0
  48. package/lib/buildTransaction.d.ts.map +1 -0
  49. package/lib/buildTransaction.js +49 -0
  50. package/lib/buildTransaction.js.map +1 -0
  51. package/lib/buildTransaction.unit.test.d.ts +2 -0
  52. package/lib/buildTransaction.unit.test.d.ts.map +1 -0
  53. package/lib/buildTransaction.unit.test.js +47 -0
  54. package/lib/buildTransaction.unit.test.js.map +1 -0
  55. package/lib/cli-transaction.d.ts +16 -0
  56. package/lib/cli-transaction.d.ts.map +1 -0
  57. package/lib/cli-transaction.js +35 -0
  58. package/lib/cli-transaction.js.map +1 -0
  59. package/lib/config.d.ts +14 -0
  60. package/lib/config.d.ts.map +1 -0
  61. package/lib/config.js +16 -0
  62. package/lib/config.js.map +1 -0
  63. package/lib/constants.d.ts +21 -0
  64. package/lib/constants.d.ts.map +1 -0
  65. package/lib/constants.js +27 -0
  66. package/lib/constants.js.map +1 -0
  67. package/lib/createTransaction.d.ts +9 -0
  68. package/lib/createTransaction.d.ts.map +1 -0
  69. package/lib/createTransaction.js +26 -0
  70. package/lib/createTransaction.js.map +1 -0
  71. package/lib/datasets/multiversx1.d.ts +3 -0
  72. package/lib/datasets/multiversx1.d.ts.map +1 -0
  73. package/lib/datasets/multiversx1.js +21 -0
  74. package/lib/datasets/multiversx1.js.map +1 -0
  75. package/lib/deviceTransactionConfig.d.ts +10 -0
  76. package/lib/deviceTransactionConfig.d.ts.map +1 -0
  77. package/lib/deviceTransactionConfig.js +60 -0
  78. package/lib/deviceTransactionConfig.js.map +1 -0
  79. package/lib/encode.d.ts +11 -0
  80. package/lib/encode.d.ts.map +1 -0
  81. package/lib/encode.js +39 -0
  82. package/lib/encode.js.map +1 -0
  83. package/lib/errors.d.ts +16 -0
  84. package/lib/errors.d.ts.map +1 -0
  85. package/lib/errors.js +10 -0
  86. package/lib/errors.js.map +1 -0
  87. package/lib/estimateMaxSpendable.d.ts +10 -0
  88. package/lib/estimateMaxSpendable.d.ts.map +1 -0
  89. package/lib/estimateMaxSpendable.js +35 -0
  90. package/lib/estimateMaxSpendable.js.map +1 -0
  91. package/lib/formatters.d.ts +11 -0
  92. package/lib/formatters.d.ts.map +1 -0
  93. package/lib/formatters.js +65 -0
  94. package/lib/formatters.js.map +1 -0
  95. package/lib/getTransactionStatus.d.ts +5 -0
  96. package/lib/getTransactionStatus.d.ts.map +1 -0
  97. package/lib/getTransactionStatus.js +107 -0
  98. package/lib/getTransactionStatus.js.map +1 -0
  99. package/lib/helpers/denominate.d.ts +9 -0
  100. package/lib/helpers/denominate.d.ts.map +1 -0
  101. package/lib/helpers/denominate.js +75 -0
  102. package/lib/helpers/denominate.js.map +1 -0
  103. package/lib/helpers/handleTransactionStatus.d.ts +7 -0
  104. package/lib/helpers/handleTransactionStatus.d.ts.map +1 -0
  105. package/lib/helpers/handleTransactionStatus.js +18 -0
  106. package/lib/helpers/handleTransactionStatus.js.map +1 -0
  107. package/lib/helpers/hasMinimumDelegableBalance.d.ts +3 -0
  108. package/lib/helpers/hasMinimumDelegableBalance.d.ts.map +1 -0
  109. package/lib/helpers/hasMinimumDelegableBalance.js +7 -0
  110. package/lib/helpers/hasMinimumDelegableBalance.js.map +1 -0
  111. package/lib/helpers/randomizeProviders.d.ts +7 -0
  112. package/lib/helpers/randomizeProviders.d.ts.map +1 -0
  113. package/lib/helpers/randomizeProviders.js +12 -0
  114. package/lib/helpers/randomizeProviders.js.map +1 -0
  115. package/lib/hw-getAddress.d.ts +6 -0
  116. package/lib/hw-getAddress.d.ts.map +1 -0
  117. package/lib/hw-getAddress.js +14 -0
  118. package/lib/hw-getAddress.js.map +1 -0
  119. package/lib/logic.d.ts +15 -0
  120. package/lib/logic.d.ts.map +1 -0
  121. package/lib/logic.js +77 -0
  122. package/lib/logic.js.map +1 -0
  123. package/lib/preload.d.ts +11 -0
  124. package/lib/preload.d.ts.map +1 -0
  125. package/lib/preload.js +94 -0
  126. package/lib/preload.js.map +1 -0
  127. package/lib/prepareTransaction.d.ts +10 -0
  128. package/lib/prepareTransaction.d.ts.map +1 -0
  129. package/lib/prepareTransaction.js +72 -0
  130. package/lib/prepareTransaction.js.map +1 -0
  131. package/lib/reconciliation.d.ts +3 -0
  132. package/lib/reconciliation.d.ts.map +1 -0
  133. package/lib/reconciliation.js +56 -0
  134. package/lib/reconciliation.js.map +1 -0
  135. package/lib/serialization.d.ts +9 -0
  136. package/lib/serialization.d.ts.map +1 -0
  137. package/lib/serialization.js +65 -0
  138. package/lib/serialization.js.map +1 -0
  139. package/lib/signOperation.d.ts +10 -0
  140. package/lib/signOperation.d.ts.map +1 -0
  141. package/lib/signOperation.js +65 -0
  142. package/lib/signOperation.js.map +1 -0
  143. package/lib/signer.d.ts +16 -0
  144. package/lib/signer.d.ts.map +1 -0
  145. package/lib/signer.js +3 -0
  146. package/lib/signer.js.map +1 -0
  147. package/lib/specs.d.ts +7 -0
  148. package/lib/specs.d.ts.map +1 -0
  149. package/lib/specs.js +286 -0
  150. package/lib/specs.js.map +1 -0
  151. package/lib/speculos-deviceActions.d.ts +16 -0
  152. package/lib/speculos-deviceActions.d.ts.map +1 -0
  153. package/lib/speculos-deviceActions.js +250 -0
  154. package/lib/speculos-deviceActions.js.map +1 -0
  155. package/lib/synchronisation.d.ts +5 -0
  156. package/lib/synchronisation.d.ts.map +1 -0
  157. package/lib/synchronisation.js +69 -0
  158. package/lib/synchronisation.js.map +1 -0
  159. package/lib/transaction.d.ts +15 -0
  160. package/lib/transaction.d.ts.map +1 -0
  161. package/lib/transaction.js +62 -0
  162. package/lib/transaction.js.map +1 -0
  163. package/lib/types.d.ts +188 -0
  164. package/lib/types.d.ts.map +1 -0
  165. package/lib/types.js +17 -0
  166. package/lib/types.js.map +1 -0
  167. package/lib/utils/binary.utils.d.ts +5 -0
  168. package/lib/utils/binary.utils.d.ts.map +1 -0
  169. package/lib/utils/binary.utils.js +16 -0
  170. package/lib/utils/binary.utils.js.map +1 -0
  171. package/lib-es/api/apiCalls.d.ts +22 -0
  172. package/lib-es/api/apiCalls.d.ts.map +1 -0
  173. package/lib-es/api/apiCalls.js +147 -0
  174. package/lib-es/api/apiCalls.js.map +1 -0
  175. package/lib-es/api/dtos/multiversx-account.d.ts +9 -0
  176. package/lib-es/api/dtos/multiversx-account.d.ts.map +1 -0
  177. package/lib-es/api/dtos/multiversx-account.js +13 -0
  178. package/lib-es/api/dtos/multiversx-account.js.map +1 -0
  179. package/lib-es/api/index.d.ts +2 -0
  180. package/lib-es/api/index.d.ts.map +1 -0
  181. package/lib-es/api/index.js +2 -0
  182. package/lib-es/api/index.js.map +1 -0
  183. package/lib-es/api/sdk.d.ts +29 -0
  184. package/lib-es/api/sdk.d.ts.map +1 -0
  185. package/lib-es/api/sdk.js +264 -0
  186. package/lib-es/api/sdk.js.map +1 -0
  187. package/lib-es/bridge/js.d.ts +11 -0
  188. package/lib-es/bridge/js.d.ts.map +1 -0
  189. package/lib-es/bridge/js.js +53 -0
  190. package/lib-es/bridge/js.js.map +1 -0
  191. package/lib-es/bridge.integration.test.d.ts +4 -0
  192. package/lib-es/bridge.integration.test.d.ts.map +1 -0
  193. package/lib-es/bridge.integration.test.js +139 -0
  194. package/lib-es/bridge.integration.test.js.map +1 -0
  195. package/lib-es/broadcast.d.ts +9 -0
  196. package/lib-es/broadcast.d.ts.map +1 -0
  197. package/lib-es/broadcast.js +12 -0
  198. package/lib-es/broadcast.js.map +1 -0
  199. package/lib-es/buildOptimisticOperation.d.ts +4 -0
  200. package/lib-es/buildOptimisticOperation.d.ts.map +1 -0
  201. package/lib-es/buildOptimisticOperation.js +93 -0
  202. package/lib-es/buildOptimisticOperation.js.map +1 -0
  203. package/lib-es/buildOptimisticOperation.test.d.ts +2 -0
  204. package/lib-es/buildOptimisticOperation.test.d.ts.map +1 -0
  205. package/lib-es/buildOptimisticOperation.test.js +73 -0
  206. package/lib-es/buildOptimisticOperation.test.js.map +1 -0
  207. package/lib-es/buildSubAccounts.d.ts +11 -0
  208. package/lib-es/buildSubAccounts.d.ts.map +1 -0
  209. package/lib-es/buildSubAccounts.js +112 -0
  210. package/lib-es/buildSubAccounts.js.map +1 -0
  211. package/lib-es/buildTransaction.d.ts +19 -0
  212. package/lib-es/buildTransaction.d.ts.map +1 -0
  213. package/lib-es/buildTransaction.js +44 -0
  214. package/lib-es/buildTransaction.js.map +1 -0
  215. package/lib-es/buildTransaction.unit.test.d.ts +2 -0
  216. package/lib-es/buildTransaction.unit.test.d.ts.map +1 -0
  217. package/lib-es/buildTransaction.unit.test.js +42 -0
  218. package/lib-es/buildTransaction.unit.test.js.map +1 -0
  219. package/lib-es/cli-transaction.d.ts +16 -0
  220. package/lib-es/cli-transaction.d.ts.map +1 -0
  221. package/lib-es/cli-transaction.js +29 -0
  222. package/lib-es/cli-transaction.js.map +1 -0
  223. package/lib-es/config.d.ts +14 -0
  224. package/lib-es/config.d.ts.map +1 -0
  225. package/lib-es/config.js +11 -0
  226. package/lib-es/config.js.map +1 -0
  227. package/lib-es/constants.d.ts +21 -0
  228. package/lib-es/constants.d.ts.map +1 -0
  229. package/lib-es/constants.js +21 -0
  230. package/lib-es/constants.js.map +1 -0
  231. package/lib-es/createTransaction.d.ts +9 -0
  232. package/lib-es/createTransaction.d.ts.map +1 -0
  233. package/lib-es/createTransaction.js +19 -0
  234. package/lib-es/createTransaction.js.map +1 -0
  235. package/lib-es/datasets/multiversx1.d.ts +3 -0
  236. package/lib-es/datasets/multiversx1.d.ts.map +1 -0
  237. package/lib-es/datasets/multiversx1.js +18 -0
  238. package/lib-es/datasets/multiversx1.js.map +1 -0
  239. package/lib-es/deviceTransactionConfig.d.ts +10 -0
  240. package/lib-es/deviceTransactionConfig.d.ts.map +1 -0
  241. package/lib-es/deviceTransactionConfig.js +55 -0
  242. package/lib-es/deviceTransactionConfig.js.map +1 -0
  243. package/lib-es/encode.d.ts +11 -0
  244. package/lib-es/encode.d.ts.map +1 -0
  245. package/lib-es/encode.js +35 -0
  246. package/lib-es/encode.js.map +1 -0
  247. package/lib-es/errors.d.ts +16 -0
  248. package/lib-es/errors.d.ts.map +1 -0
  249. package/lib-es/errors.js +7 -0
  250. package/lib-es/errors.js.map +1 -0
  251. package/lib-es/estimateMaxSpendable.d.ts +10 -0
  252. package/lib-es/estimateMaxSpendable.d.ts.map +1 -0
  253. package/lib-es/estimateMaxSpendable.js +31 -0
  254. package/lib-es/estimateMaxSpendable.js.map +1 -0
  255. package/lib-es/formatters.d.ts +11 -0
  256. package/lib-es/formatters.d.ts.map +1 -0
  257. package/lib-es/formatters.js +60 -0
  258. package/lib-es/formatters.js.map +1 -0
  259. package/lib-es/getTransactionStatus.d.ts +5 -0
  260. package/lib-es/getTransactionStatus.d.ts.map +1 -0
  261. package/lib-es/getTransactionStatus.js +100 -0
  262. package/lib-es/getTransactionStatus.js.map +1 -0
  263. package/lib-es/helpers/denominate.d.ts +9 -0
  264. package/lib-es/helpers/denominate.d.ts.map +1 -0
  265. package/lib-es/helpers/denominate.js +71 -0
  266. package/lib-es/helpers/denominate.js.map +1 -0
  267. package/lib-es/helpers/handleTransactionStatus.d.ts +7 -0
  268. package/lib-es/helpers/handleTransactionStatus.d.ts.map +1 -0
  269. package/lib-es/helpers/handleTransactionStatus.js +14 -0
  270. package/lib-es/helpers/handleTransactionStatus.js.map +1 -0
  271. package/lib-es/helpers/hasMinimumDelegableBalance.d.ts +3 -0
  272. package/lib-es/helpers/hasMinimumDelegableBalance.d.ts.map +1 -0
  273. package/lib-es/helpers/hasMinimumDelegableBalance.js +3 -0
  274. package/lib-es/helpers/hasMinimumDelegableBalance.js.map +1 -0
  275. package/lib-es/helpers/randomizeProviders.d.ts +7 -0
  276. package/lib-es/helpers/randomizeProviders.d.ts.map +1 -0
  277. package/lib-es/helpers/randomizeProviders.js +8 -0
  278. package/lib-es/helpers/randomizeProviders.js.map +1 -0
  279. package/lib-es/hw-getAddress.d.ts +6 -0
  280. package/lib-es/hw-getAddress.d.ts.map +1 -0
  281. package/lib-es/hw-getAddress.js +12 -0
  282. package/lib-es/hw-getAddress.js.map +1 -0
  283. package/lib-es/logic.d.ts +15 -0
  284. package/lib-es/logic.d.ts.map +1 -0
  285. package/lib-es/logic.js +65 -0
  286. package/lib-es/logic.js.map +1 -0
  287. package/lib-es/preload.d.ts +11 -0
  288. package/lib-es/preload.d.ts.map +1 -0
  289. package/lib-es/preload.js +85 -0
  290. package/lib-es/preload.js.map +1 -0
  291. package/lib-es/prepareTransaction.d.ts +10 -0
  292. package/lib-es/prepareTransaction.d.ts.map +1 -0
  293. package/lib-es/prepareTransaction.js +68 -0
  294. package/lib-es/prepareTransaction.js.map +1 -0
  295. package/lib-es/reconciliation.d.ts +3 -0
  296. package/lib-es/reconciliation.d.ts.map +1 -0
  297. package/lib-es/reconciliation.js +52 -0
  298. package/lib-es/reconciliation.js.map +1 -0
  299. package/lib-es/serialization.d.ts +9 -0
  300. package/lib-es/serialization.d.ts.map +1 -0
  301. package/lib-es/serialization.js +53 -0
  302. package/lib-es/serialization.js.map +1 -0
  303. package/lib-es/signOperation.d.ts +10 -0
  304. package/lib-es/signOperation.d.ts.map +1 -0
  305. package/lib-es/signOperation.js +61 -0
  306. package/lib-es/signOperation.js.map +1 -0
  307. package/lib-es/signer.d.ts +16 -0
  308. package/lib-es/signer.d.ts.map +1 -0
  309. package/lib-es/signer.js +2 -0
  310. package/lib-es/signer.js.map +1 -0
  311. package/lib-es/specs.d.ts +7 -0
  312. package/lib-es/specs.d.ts.map +1 -0
  313. package/lib-es/specs.js +281 -0
  314. package/lib-es/specs.js.map +1 -0
  315. package/lib-es/speculos-deviceActions.d.ts +16 -0
  316. package/lib-es/speculos-deviceActions.d.ts.map +1 -0
  317. package/lib-es/speculos-deviceActions.js +244 -0
  318. package/lib-es/speculos-deviceActions.js.map +1 -0
  319. package/lib-es/synchronisation.d.ts +5 -0
  320. package/lib-es/synchronisation.d.ts.map +1 -0
  321. package/lib-es/synchronisation.js +62 -0
  322. package/lib-es/synchronisation.js.map +1 -0
  323. package/lib-es/transaction.d.ts +15 -0
  324. package/lib-es/transaction.d.ts.map +1 -0
  325. package/lib-es/transaction.js +56 -0
  326. package/lib-es/transaction.js.map +1 -0
  327. package/lib-es/types.d.ts +188 -0
  328. package/lib-es/types.d.ts.map +1 -0
  329. package/lib-es/types.js +12 -0
  330. package/lib-es/types.js.map +1 -0
  331. package/lib-es/utils/binary.utils.d.ts +5 -0
  332. package/lib-es/utils/binary.utils.d.ts.map +1 -0
  333. package/lib-es/utils/binary.utils.js +12 -0
  334. package/lib-es/utils/binary.utils.js.map +1 -0
  335. package/package.json +86 -0
  336. package/src/__snapshots__/bridge.integration.test.ts.snap +181 -0
  337. package/src/api/apiCalls.ts +243 -0
  338. package/src/api/dtos/multiversx-account.ts +20 -0
  339. package/src/api/index.ts +13 -0
  340. package/src/api/sdk.ts +368 -0
  341. package/src/bridge/js.ts +77 -0
  342. package/src/bridge.integration.test.ts +147 -0
  343. package/src/broadcast.ts +16 -0
  344. package/src/buildOptimisticOperation.test.ts +88 -0
  345. package/src/buildOptimisticOperation.ts +120 -0
  346. package/src/buildSubAccounts.ts +153 -0
  347. package/src/buildTransaction.ts +67 -0
  348. package/src/buildTransaction.unit.test.ts +49 -0
  349. package/src/cli-transaction.ts +41 -0
  350. package/src/config.ts +26 -0
  351. package/src/constants.ts +24 -0
  352. package/src/createTransaction.ts +21 -0
  353. package/src/datasets/multiversx1.ts +19 -0
  354. package/src/deviceTransactionConfig.ts +74 -0
  355. package/src/encode.ts +46 -0
  356. package/src/errors.ts +19 -0
  357. package/src/estimateMaxSpendable.ts +43 -0
  358. package/src/formatters.ts +76 -0
  359. package/src/getTransactionStatus.ts +151 -0
  360. package/src/helpers/denominate.ts +95 -0
  361. package/src/helpers/handleTransactionStatus.ts +26 -0
  362. package/src/helpers/hasMinimumDelegableBalance.ts +6 -0
  363. package/src/helpers/randomizeProviders.ts +20 -0
  364. package/src/hw-getAddress.ts +19 -0
  365. package/src/logic.ts +83 -0
  366. package/src/preload.ts +95 -0
  367. package/src/prepareTransaction.ts +78 -0
  368. package/src/reconciliation.ts +64 -0
  369. package/src/serialization.ts +72 -0
  370. package/src/signOperation.ts +99 -0
  371. package/src/signer.ts +21 -0
  372. package/src/specs.ts +387 -0
  373. package/src/speculos-deviceActions.ts +269 -0
  374. package/src/synchronisation.ts +74 -0
  375. package/src/transaction.ts +76 -0
  376. package/src/types.ts +235 -0
  377. package/src/utils/binary.utils.ts +13 -0
  378. package/tsconfig.json +13 -0
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.prepareTransaction = void 0;
4
+ const bignumber_js_1 = require("bignumber.js");
5
+ const api_1 = require("./api");
6
+ const constants_1 = require("./constants");
7
+ const encode_1 = require("./encode");
8
+ const logic_1 = require("./logic");
9
+ /**
10
+ * Prepare t before checking status
11
+ *
12
+ * @param {MultiversXAccount} account
13
+ * @param {Transaction} transaction
14
+ */
15
+ const prepareTransaction = async (account, transaction) => {
16
+ // What's the point of this extra variable ?
17
+ const preparedTx = transaction;
18
+ const tokenAccount = (transaction.subAccountId &&
19
+ account.subAccounts &&
20
+ account.subAccounts.find(ta => ta.id === transaction.subAccountId)) ||
21
+ null;
22
+ if (tokenAccount) {
23
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.ESDTTransfer(transaction, tokenAccount);
24
+ preparedTx.gasLimit = constants_1.GAS.ESDT_TRANSFER;
25
+ }
26
+ else {
27
+ switch (transaction.mode) {
28
+ case "delegate":
29
+ preparedTx.gasLimit = constants_1.GAS.DELEGATE;
30
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.delegate();
31
+ break;
32
+ case "claimRewards":
33
+ preparedTx.gasLimit = constants_1.GAS.CLAIM;
34
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.claimRewards();
35
+ break;
36
+ case "withdraw":
37
+ preparedTx.gasLimit = constants_1.GAS.DELEGATE;
38
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.withdraw();
39
+ break;
40
+ case "reDelegateRewards":
41
+ preparedTx.gasLimit = constants_1.GAS.DELEGATE;
42
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.reDelegateRewards();
43
+ break;
44
+ case "unDelegate":
45
+ preparedTx.gasLimit = constants_1.GAS.DELEGATE;
46
+ preparedTx.data = encode_1.MultiversXEncodeTransaction.unDelegate(transaction);
47
+ break;
48
+ case "send":
49
+ break;
50
+ default:
51
+ throw new Error("Unsupported transaction mode: " + transaction.mode);
52
+ }
53
+ }
54
+ if (transaction.useAllAmount) {
55
+ // Set the max amount
56
+ preparedTx.amount = tokenAccount ? tokenAccount.balance : account.spendableBalance;
57
+ // Compute estimated fees for that amount
58
+ preparedTx.fees = await (0, api_1.getFees)(preparedTx);
59
+ // Adjust max amount according to computed fees
60
+ if (!tokenAccount && (0, logic_1.isAmountSpentFromBalance)(transaction.mode)) {
61
+ preparedTx.amount = preparedTx.amount.gt(preparedTx.fees)
62
+ ? preparedTx.amount.minus(preparedTx.fees)
63
+ : new bignumber_js_1.BigNumber(0);
64
+ }
65
+ }
66
+ else {
67
+ preparedTx.fees = await (0, api_1.getFees)(preparedTx);
68
+ }
69
+ return preparedTx;
70
+ };
71
+ exports.prepareTransaction = prepareTransaction;
72
+ //# sourceMappingURL=prepareTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../src/prepareTransaction.ts"],"names":[],"mappings":";;;AAAA,+CAAyC;AAEzC,+BAAgC;AAChC,2CAAkC;AAClC,qCAAuD;AACvD,mCAAmD;AAGnD;;;;;GAKG;AACI,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACX,EAAE;IACF,4CAA4C;IAC5C,MAAM,UAAU,GAAG,WAAW,CAAC;IAE/B,MAAM,YAAY,GAChB,CAAC,WAAW,CAAC,YAAY;QACvB,OAAO,CAAC,WAAW;QACnB,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC;QACrE,IAAI,CAAC;IAEP,IAAI,YAAY,EAAE,CAAC;QACjB,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,YAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QACtF,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,aAAa,CAAC;IAC1C,CAAC;SAAM,CAAC;QACN,QAAQ,WAAW,CAAC,IAAI,EAAE,CAAC;YACzB,KAAK,UAAU;gBACb,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,QAAQ,CAAC;gBACnC,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,QAAQ,EAAE,CAAC;gBACzD,MAAM;YACR,KAAK,cAAc;gBACjB,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,KAAK,CAAC;gBAChC,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,YAAY,EAAE,CAAC;gBAC7D,MAAM;YACR,KAAK,UAAU;gBACb,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,QAAQ,CAAC;gBACnC,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,QAAQ,EAAE,CAAC;gBACzD,MAAM;YACR,KAAK,mBAAmB;gBACtB,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,QAAQ,CAAC;gBACnC,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,iBAAiB,EAAE,CAAC;gBAClE,MAAM;YACR,KAAK,YAAY;gBACf,UAAU,CAAC,QAAQ,GAAG,eAAG,CAAC,QAAQ,CAAC;gBACnC,UAAU,CAAC,IAAI,GAAG,oCAA2B,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;gBACtE,MAAM;YACR,KAAK,MAAM;gBACT,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,gCAAgC,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IAED,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;QAC7B,qBAAqB;QACrB,UAAU,CAAC,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC;QAEnF,yCAAyC;QACzC,UAAU,CAAC,IAAI,GAAG,MAAM,IAAA,aAAO,EAAC,UAAU,CAAC,CAAC;QAE5C,+CAA+C;QAC/C,IAAI,CAAC,YAAY,IAAI,IAAA,gCAAwB,EAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;YAChE,UAAU,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;gBACvD,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC;gBAC1C,CAAC,CAAC,IAAI,wBAAS,CAAC,CAAC,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;SAAM,CAAC;QACN,UAAU,CAAC,IAAI,GAAG,MAAM,IAAA,aAAO,EAAC,UAAU,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC,CAAC;AA/DW,QAAA,kBAAkB,sBA+D7B"}
@@ -0,0 +1,3 @@
1
+ import { Account, TokenAccount } from "@ledgerhq/types-live";
2
+ export declare function reconciliateSubAccounts(tokenAccounts: TokenAccount[], initialAccount: Account | undefined): TokenAccount[];
3
+ //# sourceMappingURL=reconciliation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reconciliation.d.ts","sourceRoot":"","sources":["../src/reconciliation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAc,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEzE,wBAAgB,uBAAuB,CACrC,aAAa,EAAE,YAAY,EAAE,EAC7B,cAAc,EAAE,OAAO,GAAG,SAAS,GAClC,YAAY,EAAE,CAyDhB"}
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.reconciliateSubAccounts = void 0;
4
+ const logs_1 = require("@ledgerhq/logs");
5
+ function reconciliateSubAccounts(tokenAccounts, initialAccount) {
6
+ let subAccounts;
7
+ if (initialAccount) {
8
+ const initialSubAccounts = initialAccount.subAccounts;
9
+ let anySubAccountHaveChanged = false;
10
+ const stats = [];
11
+ if (initialSubAccounts && tokenAccounts.length !== initialSubAccounts.length) {
12
+ stats.push("length differ");
13
+ anySubAccountHaveChanged = true;
14
+ }
15
+ subAccounts = tokenAccounts.map((ta) => {
16
+ const existingTokenAccount = initialSubAccounts?.find(a => a.id === ta.id);
17
+ if (existingTokenAccount) {
18
+ let sameProperties = true;
19
+ if (existingTokenAccount !== ta) {
20
+ for (const property in existingTokenAccount) {
21
+ if (existingTokenAccount[property] !== ta[property]) {
22
+ sameProperties = false;
23
+ stats.push(`field ${property} changed for ${ta.id}`);
24
+ break;
25
+ }
26
+ }
27
+ }
28
+ if (sameProperties) {
29
+ return existingTokenAccount;
30
+ }
31
+ else {
32
+ anySubAccountHaveChanged = true;
33
+ }
34
+ }
35
+ else {
36
+ anySubAccountHaveChanged = true;
37
+ stats.push(`new token account ${ta.id}`);
38
+ }
39
+ return ta;
40
+ });
41
+ if (!anySubAccountHaveChanged && initialSubAccounts) {
42
+ // eslint-disable-next-line prettier/prettier
43
+ (0, logs_1.log)("multiversx", `incremental sync: ${String(initialSubAccounts.length)} sub accounts have not changed`);
44
+ subAccounts = initialSubAccounts;
45
+ }
46
+ else {
47
+ (0, logs_1.log)("multiversx", "incremental sync: sub accounts changed: " + stats.join(", "));
48
+ }
49
+ }
50
+ else {
51
+ subAccounts = tokenAccounts.map((a) => a);
52
+ }
53
+ return subAccounts;
54
+ }
55
+ exports.reconciliateSubAccounts = reconciliateSubAccounts;
56
+ //# sourceMappingURL=reconciliation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reconciliation.js","sourceRoot":"","sources":["../src/reconciliation.ts"],"names":[],"mappings":";;;AAAA,yCAAqC;AAGrC,SAAgB,uBAAuB,CACrC,aAA6B,EAC7B,cAAmC;IAEnC,IAAI,WAAW,CAAC;IAEhB,IAAI,cAAc,EAAE,CAAC;QACnB,MAAM,kBAAkB,GAA6B,cAAc,CAAC,WAAW,CAAC;QAChF,IAAI,wBAAwB,GAAG,KAAK,CAAC;QACrC,MAAM,KAAK,GAAa,EAAE,CAAC;QAE3B,IAAI,kBAAkB,IAAI,aAAa,CAAC,MAAM,KAAK,kBAAkB,CAAC,MAAM,EAAE,CAAC;YAC7E,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5B,wBAAwB,GAAG,IAAI,CAAC;QAClC,CAAC;QAED,WAAW,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,EAAgB,EAAE,EAAE;YACnD,MAAM,oBAAoB,GAAG,kBAAkB,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;YAE3E,IAAI,oBAAoB,EAAE,CAAC;gBACzB,IAAI,cAAc,GAAG,IAAI,CAAC;gBAE1B,IAAI,oBAAoB,KAAK,EAAE,EAAE,CAAC;oBAChC,KAAK,MAAM,QAAQ,IAAI,oBAAoB,EAAE,CAAC;wBAC5C,IAAK,oBAA4B,CAAC,QAAQ,CAAC,KAAM,EAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;4BACtE,cAAc,GAAG,KAAK,CAAC;4BACvB,KAAK,CAAC,IAAI,CAAC,SAAS,QAAQ,gBAAgB,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;4BACrD,MAAM;wBACR,CAAC;oBACH,CAAC;gBACH,CAAC;gBAED,IAAI,cAAc,EAAE,CAAC;oBACnB,OAAO,oBAAoB,CAAC;gBAC9B,CAAC;qBAAM,CAAC;oBACN,wBAAwB,GAAG,IAAI,CAAC;gBAClC,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,wBAAwB,GAAG,IAAI,CAAC;gBAChC,KAAK,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;YAC3C,CAAC;YAED,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,wBAAwB,IAAI,kBAAkB,EAAE,CAAC;YACpD,6CAA6C;YAC7C,IAAA,UAAG,EACD,YAAY,EACZ,qBAAqB,MAAM,CAAC,kBAAkB,CAAC,MAAM,CAAC,gCAAgC,CACvF,CAAC;YACF,WAAW,GAAG,kBAAkB,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAA,UAAG,EAAC,YAAY,EAAE,0CAA0C,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACnF,CAAC;IACH,CAAC;SAAM,CAAC;QACN,WAAW,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,CAAe,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,OAAO,WAAW,CAAC;AACrB,CAAC;AA5DD,0DA4DC"}
@@ -0,0 +1,9 @@
1
+ import { type MultiversXResourcesRaw, type MultiversXResources, type MultiversXOperationExtraRaw, type MultiversXOperationExtra } from "./types";
2
+ import type { Account, AccountRaw, OperationExtra, OperationExtraRaw } from "@ledgerhq/types-live";
3
+ export declare function toMultiversXResourcesRaw(r: MultiversXResources): MultiversXResourcesRaw;
4
+ export declare function fromMultiversXResourcesRaw(r: MultiversXResourcesRaw): MultiversXResources;
5
+ export declare function assignToAccountRaw(account: Account, accountRaw: AccountRaw): void;
6
+ export declare function assignFromAccountRaw(accountRaw: AccountRaw, account: Account): void;
7
+ export declare function fromOperationExtraRaw(extraRaw: OperationExtraRaw): MultiversXOperationExtra;
8
+ export declare function toOperationExtraRaw(extra: OperationExtra): MultiversXOperationExtraRaw;
9
+ //# sourceMappingURL=serialization.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serialization.d.ts","sourceRoot":"","sources":["../src/serialization.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,sBAAsB,EAC3B,KAAK,mBAAmB,EAGxB,KAAK,2BAA2B,EAChC,KAAK,wBAAwB,EAG9B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAEnG,wBAAgB,wBAAwB,CAAC,CAAC,EAAE,mBAAmB,GAAG,sBAAsB,CAOvF;AAED,wBAAgB,0BAA0B,CAAC,CAAC,EAAE,sBAAsB,GAAG,mBAAmB,CAOzF;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,QAO1E;AAED,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,QAK5E;AAED,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,iBAAiB,4BAWhE;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,cAAc,+BAWxD"}
@@ -0,0 +1,65 @@
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.toOperationExtraRaw = exports.fromOperationExtraRaw = exports.assignFromAccountRaw = exports.assignToAccountRaw = exports.fromMultiversXResourcesRaw = exports.toMultiversXResourcesRaw = void 0;
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ const types_1 = require("./types");
9
+ function toMultiversXResourcesRaw(r) {
10
+ const { nonce, delegations, isGuarded } = r;
11
+ return {
12
+ nonce,
13
+ delegations,
14
+ isGuarded,
15
+ };
16
+ }
17
+ exports.toMultiversXResourcesRaw = toMultiversXResourcesRaw;
18
+ function fromMultiversXResourcesRaw(r) {
19
+ const { nonce, delegations, isGuarded } = r;
20
+ return {
21
+ nonce,
22
+ delegations,
23
+ isGuarded,
24
+ };
25
+ }
26
+ exports.fromMultiversXResourcesRaw = fromMultiversXResourcesRaw;
27
+ function assignToAccountRaw(account, accountRaw) {
28
+ const multiversxAccount = account;
29
+ if (multiversxAccount.multiversxResources) {
30
+ accountRaw.multiversxResources = toMultiversXResourcesRaw(multiversxAccount.multiversxResources);
31
+ }
32
+ }
33
+ exports.assignToAccountRaw = assignToAccountRaw;
34
+ function assignFromAccountRaw(accountRaw, account) {
35
+ const multiversxResourcesRaw = accountRaw.multiversxResources;
36
+ if (multiversxResourcesRaw)
37
+ account.multiversxResources =
38
+ fromMultiversXResourcesRaw(multiversxResourcesRaw);
39
+ }
40
+ exports.assignFromAccountRaw = assignFromAccountRaw;
41
+ function fromOperationExtraRaw(extraRaw) {
42
+ const extra = {};
43
+ if (!(0, types_1.isMultiversXOperationExtraRaw)(extraRaw)) {
44
+ // All fields might be undefined
45
+ return extra;
46
+ }
47
+ if (extraRaw.amount) {
48
+ extra.amount = new bignumber_js_1.default(extraRaw.amount);
49
+ }
50
+ return extra;
51
+ }
52
+ exports.fromOperationExtraRaw = fromOperationExtraRaw;
53
+ function toOperationExtraRaw(extra) {
54
+ const extraRaw = {};
55
+ if (!(0, types_1.isMultiversXOperationExtra)(extra)) {
56
+ // All fields might be undefined
57
+ return extraRaw;
58
+ }
59
+ if (extra.amount) {
60
+ extraRaw.amount = extra.amount.toString();
61
+ }
62
+ return extraRaw;
63
+ }
64
+ exports.toOperationExtraRaw = toOperationExtraRaw;
65
+ //# sourceMappingURL=serialization.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serialization.js","sourceRoot":"","sources":["../src/serialization.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AACrC,mCASiB;AAGjB,SAAgB,wBAAwB,CAAC,CAAsB;IAC7D,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;IAC5C,OAAO;QACL,KAAK;QACL,WAAW;QACX,SAAS;KACV,CAAC;AACJ,CAAC;AAPD,4DAOC;AAED,SAAgB,0BAA0B,CAAC,CAAyB;IAClE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;IAC5C,OAAO;QACL,KAAK;QACL,WAAW;QACX,SAAS;KACV,CAAC;AACJ,CAAC;AAPD,gEAOC;AAED,SAAgB,kBAAkB,CAAC,OAAgB,EAAE,UAAsB;IACzE,MAAM,iBAAiB,GAAG,OAA4B,CAAC;IACvD,IAAI,iBAAiB,CAAC,mBAAmB,EAAE,CAAC;QACzC,UAAmC,CAAC,mBAAmB,GAAG,wBAAwB,CACjF,iBAAiB,CAAC,mBAAmB,CACtC,CAAC;IACJ,CAAC;AACH,CAAC;AAPD,gDAOC;AAED,SAAgB,oBAAoB,CAAC,UAAsB,EAAE,OAAgB;IAC3E,MAAM,sBAAsB,GAAI,UAAmC,CAAC,mBAAmB,CAAC;IACxF,IAAI,sBAAsB;QACvB,OAA6B,CAAC,mBAAmB;YAChD,0BAA0B,CAAC,sBAAsB,CAAC,CAAC;AACzD,CAAC;AALD,oDAKC;AAED,SAAgB,qBAAqB,CAAC,QAA2B;IAC/D,MAAM,KAAK,GAA6B,EAAE,CAAC;IAC3C,IAAI,CAAC,IAAA,qCAA6B,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC7C,gCAAgC;QAChC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,KAAK,CAAC,MAAM,GAAG,IAAI,sBAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAChD,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAXD,sDAWC;AAED,SAAgB,mBAAmB,CAAC,KAAqB;IACvD,MAAM,QAAQ,GAAgC,EAAE,CAAC;IACjD,IAAI,CAAC,IAAA,kCAA0B,EAAC,KAAK,CAAC,EAAE,CAAC;QACvC,gCAAgC;QAChC,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;QACjB,QAAQ,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAXD,kDAWC"}
@@ -0,0 +1,10 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import type { MultiversXAccount, Transaction } from "./types";
3
+ import { MultiversXSigner } from "./signer";
4
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
5
+ /**
6
+ * Sign Transaction with Ledger hardware
7
+ */
8
+ export declare const buildSignOperation: (signerContext: SignerContext<MultiversXSigner>) => AccountBridge<Transaction, MultiversXAccount>["signOperation"];
9
+ export default buildSignOperation;
10
+ //# sourceMappingURL=signOperation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../src/signOperation.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,OAAO,KAAK,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAI9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE;;GAEG;AACH,eAAO,MAAM,kBAAkB,kBAEZ,cAAc,gBAAgB,CAAC,KAC7C,cAAc,WAAW,EAAE,iBAAiB,CAAC,CAAC,eAAe,CA8E5D,CAAC;AAEP,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.buildSignOperation = void 0;
4
+ const rxjs_1 = require("rxjs");
5
+ const errors_1 = require("@ledgerhq/errors");
6
+ const buildOptimisticOperation_1 = require("./buildOptimisticOperation");
7
+ const buildTransaction_1 = require("./buildTransaction");
8
+ const account_1 = require("@ledgerhq/coin-framework/account");
9
+ const logic_1 = require("./logic");
10
+ const constants_1 = require("./constants");
11
+ /**
12
+ * Sign Transaction with Ledger hardware
13
+ */
14
+ const buildSignOperation = (signerContext) => ({ account, transaction, deviceId }) => new rxjs_1.Observable(o => {
15
+ let cancelled = false;
16
+ async function main() {
17
+ if (!transaction.fees) {
18
+ throw new errors_1.FeeNotLoaded();
19
+ }
20
+ // Collect data for an ESDT transfer
21
+ const { subAccounts } = account;
22
+ const { subAccountId } = transaction;
23
+ const tokenAccount = !subAccountId
24
+ ? null
25
+ : subAccounts && subAccounts.find(ta => ta.id === subAccountId);
26
+ await signerContext(deviceId, signer => signer.setAddress(account.freshAddressPath));
27
+ if (tokenAccount) {
28
+ const { token } = (0, account_1.decodeTokenAccountId)(tokenAccount.id);
29
+ if (token == null) {
30
+ throw new Error("Invalid token");
31
+ }
32
+ await signerContext(deviceId, signer => signer.provideESDTInfo(token.ticker, (0, logic_1.extractTokenId)(token.id), token.units[0].magnitude, constants_1.CHAIN_ID, token.ledgerSignature));
33
+ }
34
+ const unsignedTx = await (0, buildTransaction_1.buildTransactionToSign)(account, transaction);
35
+ o.next({
36
+ type: "device-signature-requested",
37
+ });
38
+ const { signature } = await signerContext(deviceId, signer => signer.sign(account.freshAddressPath, unsignedTx));
39
+ if (cancelled)
40
+ return;
41
+ o.next({
42
+ type: "device-signature-granted",
43
+ });
44
+ if (!signature) {
45
+ throw new Error("No signature");
46
+ }
47
+ const parsedUnsignedTx = JSON.parse(unsignedTx);
48
+ const operation = (0, buildOptimisticOperation_1.buildOptimisticOperation)(account, transaction, parsedUnsignedTx);
49
+ o.next({
50
+ type: "signed",
51
+ signedOperation: {
52
+ operation,
53
+ signature: signature.toString("hex"),
54
+ rawData: parsedUnsignedTx,
55
+ },
56
+ });
57
+ }
58
+ main().then(() => o.complete(), e => o.error(e));
59
+ return () => {
60
+ cancelled = true;
61
+ };
62
+ });
63
+ exports.buildSignOperation = buildSignOperation;
64
+ exports.default = exports.buildSignOperation;
65
+ //# sourceMappingURL=signOperation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../src/signOperation.ts"],"names":[],"mappings":";;;AAAA,+BAAkC;AAClC,6CAAgD;AAEhD,yEAAsE;AACtE,yDAA4D;AAE5D,8DAAwE;AACxE,mCAAyC;AACzC,2CAAuC;AAIvC;;GAEG;AACI,MAAM,kBAAkB,GAC7B,CACE,aAA8C,EACkB,EAAE,CACpE,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,EAAE,CACrC,IAAI,iBAAU,CAAC,CAAC,CAAC,EAAE;IACjB,IAAI,SAAS,GAAG,KAAK,CAAC;IAEtB,KAAK,UAAU,IAAI;QACjB,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;YACtB,MAAM,IAAI,qBAAY,EAAE,CAAC;QAC3B,CAAC;QAED,oCAAoC;QACpC,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;QAChC,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC;QACrC,MAAM,YAAY,GAAG,CAAC,YAAY;YAChC,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,WAAW,IAAI,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,YAAY,CAAC,CAAC;QAElE,MAAM,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAErF,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,8BAAoB,EAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YACxD,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;gBAClB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;YACnC,CAAC;YAED,MAAM,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CACrC,MAAM,CAAC,eAAe,CACpB,KAAK,CAAC,MAAM,EACZ,IAAA,sBAAc,EAAC,KAAK,CAAC,EAAE,CAAC,EACxB,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,EACxB,oBAAQ,EACR,KAAK,CAAC,eAAe,CACtB,CACF,CAAC;QACJ,CAAC;QAED,MAAM,UAAU,GAAW,MAAM,IAAA,yCAAsB,EAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAE9E,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,4BAA4B;SACnC,CAAC,CAAC;QAEH,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CAC3D,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,UAAU,CAAC,CAClD,CAAC;QAEF,IAAI,SAAS;YAAE,OAAO;QAEtB,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,0BAA0B;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;QAClC,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,SAAS,GAAG,IAAA,mDAAwB,EAAC,OAAO,EAAE,WAAW,EAAE,gBAAgB,CAAC,CAAC;QAEnF,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,QAAQ;YACd,eAAe,EAAE;gBACf,SAAS;gBACT,SAAS,EAAE,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACpC,OAAO,EAAE,gBAAgB;aAC1B;SACF,CAAC,CAAC;IACL,CAAC;IAED,IAAI,EAAE,CAAC,IAAI,CACT,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,EAClB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAChB,CAAC;IAEF,OAAO,GAAG,EAAE;QACV,SAAS,GAAG,IAAI,CAAC;IACnB,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AAjFM,QAAA,kBAAkB,sBAiFxB;AAEP,kBAAe,0BAAkB,CAAC"}
@@ -0,0 +1,16 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ export type MultiversXAddress = {
4
+ publicKey: string;
5
+ address: string;
6
+ };
7
+ export type MultiversXSignature = {
8
+ signature: null | Buffer;
9
+ };
10
+ export interface MultiversXSigner {
11
+ getAddress(path: string, boolDisplay?: boolean): Promise<MultiversXAddress>;
12
+ setAddress(path: string, boolDisplay?: boolean): Promise<void>;
13
+ sign(path: string, message: string): Promise<MultiversXSignature>;
14
+ provideESDTInfo(ticker?: string, id?: string, decimals?: number, chainId?: string, signature?: string): Promise<any>;
15
+ }
16
+ //# sourceMappingURL=signer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":";;AAAA,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,EAAE,IAAI,GAAG,MAAM,CAAC;CAC1B,CAAC;AAEF,MAAM,WAAW,gBAAgB;IAC/B,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;IAC5E,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAClE,eAAe,CACb,MAAM,CAAC,EAAE,MAAM,EACf,EAAE,CAAC,EAAE,MAAM,EACX,QAAQ,CAAC,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE,MAAM,EAChB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,GAAG,CAAC,CAAC;CACjB"}
package/lib/signer.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=signer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.js","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":""}
package/lib/specs.d.ts ADDED
@@ -0,0 +1,7 @@
1
+ import type { Transaction } from "./types";
2
+ import type { AppSpec } from "@ledgerhq/coin-framework/bot/types";
3
+ declare const _default: {
4
+ multiversx: AppSpec<Transaction>;
5
+ };
6
+ export default _default;
7
+ //# sourceMappingURL=specs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specs.d.ts","sourceRoot":"","sources":["../src/specs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAIV,WAAW,EACZ,MAAM,SAAS,CAAC;AAKjB,OAAO,KAAK,EAAE,OAAO,EAAwB,MAAM,oCAAoC,CAAC;;;;AAsXxF,wBAEE"}
package/lib/specs.js ADDED
@@ -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 invariant_1 = __importDefault(require("invariant"));
7
+ const currencies_1 = require("@ledgerhq/coin-framework/currencies");
8
+ const currencies_2 = require("@ledgerhq/cryptoassets/currencies");
9
+ const specs_1 = require("@ledgerhq/coin-framework/bot/specs");
10
+ const serialization_1 = require("@ledgerhq/coin-framework/serialization");
11
+ const devices_1 = require("@ledgerhq/devices");
12
+ const expect_1 = __importDefault(require("expect"));
13
+ const speculos_deviceActions_1 = require("./speculos-deviceActions");
14
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
15
+ const constants_1 = require("./constants");
16
+ const sample_1 = __importDefault(require("lodash/sample"));
17
+ const currency = (0, currencies_2.getCryptoCurrencyById)("elrond");
18
+ const minimalAmount = (0, currencies_1.parseCurrencyUnit)(currency.units[0], "0.001");
19
+ const maxAccounts = 6;
20
+ const MULTIVERSX_MIN_ACTIVATION_SAFE = new bignumber_js_1.default(10000);
21
+ const UNCAPPED_PROVIDER = "erd1qqqqqqqqqqqqqqqpqqqqqqqqqqqqqqqqqqqqqqqqqqqqqlhllllsr0pd0j";
22
+ function expectCorrectBalanceChange(input) {
23
+ const { account, operation, accountBeforeTransaction } = input;
24
+ (0, specs_1.botTest)("EGLD balance change is correct", () => (0, expect_1.default)(account.balance.toFixed()).toStrictEqual(accountBeforeTransaction.balance.minus(operation.value).toFixed()));
25
+ }
26
+ function expectCorrectEsdtBalanceChange(input) {
27
+ const { account, operation, accountBeforeTransaction, transaction } = input;
28
+ const { subAccountId } = transaction;
29
+ const subAccounts = account.subAccounts ?? [];
30
+ const subAccountsBefore = accountBeforeTransaction.subAccounts ?? [];
31
+ const tokenAccount = subAccounts.find(ta => ta.id === subAccountId);
32
+ const tokenAccountBefore = subAccountsBefore.find(ta => ta.id === subAccountId);
33
+ const subOperation = operation.subOperations?.find(sa => sa.id === operation.id);
34
+ if (tokenAccount && tokenAccountBefore && subOperation) {
35
+ (0, specs_1.botTest)("ESDT balance change is correct", () => (0, expect_1.default)(tokenAccount.balance.toFixed()).toStrictEqual(tokenAccountBefore.balance.minus(subOperation.value).toFixed()));
36
+ }
37
+ }
38
+ function expectCorrectOptimisticOperation(input) {
39
+ const { operation, optimisticOperation, transaction } = input;
40
+ const opExpected = (0, serialization_1.toOperationRaw)({
41
+ ...optimisticOperation,
42
+ });
43
+ delete opExpected.value;
44
+ delete opExpected.fee;
45
+ delete opExpected.date;
46
+ delete opExpected.blockHash;
47
+ delete opExpected.blockHeight;
48
+ if (operation.type !== "OUT") {
49
+ delete opExpected.senders;
50
+ delete opExpected.recipients;
51
+ delete opExpected.contract;
52
+ }
53
+ (0, specs_1.botTest)("optimistic operation matches id", () => (0, expect_1.default)(operation.id).toStrictEqual(optimisticOperation.id));
54
+ (0, specs_1.botTest)("optimistic operation matches hash", () => (0, expect_1.default)(operation.hash).toStrictEqual(optimisticOperation.hash));
55
+ (0, specs_1.botTest)("optimistic operation matches accountId", () => (0, expect_1.default)(operation.accountId).toStrictEqual(optimisticOperation.accountId));
56
+ // On ESDT transactions the fee can decrease when the transaction is executed
57
+ if (!transaction.subAccountId) {
58
+ (0, specs_1.botTest)("optimistic operation matches fee", () => (0, expect_1.default)(operation.fee.toFixed()).toStrictEqual(optimisticOperation.fee.toFixed()));
59
+ }
60
+ (0, specs_1.botTest)("optimistic operation matches type", () => (0, expect_1.default)(operation.type).toStrictEqual(optimisticOperation.type));
61
+ if (operation.type === "OUT") {
62
+ (0, specs_1.botTest)("optimistic operation matches contract", () => (0, expect_1.default)(operation.contract).toStrictEqual(optimisticOperation.contract));
63
+ (0, specs_1.botTest)("optimistic operation matches senders", () => (0, expect_1.default)(operation.senders).toStrictEqual(optimisticOperation.senders));
64
+ (0, specs_1.botTest)("optimistic operation matches recipients", () => (0, expect_1.default)(operation.recipients).toStrictEqual(optimisticOperation.recipients));
65
+ if (!transaction.subAccountId) {
66
+ (0, specs_1.botTest)("optimistic operation matches value", () => (0, expect_1.default)(operation.value.toFixed()).toStrictEqual(optimisticOperation.value.toFixed()));
67
+ }
68
+ }
69
+ (0, specs_1.botTest)("optimistic operation matches transactionSequenceNumber", () => (0, expect_1.default)(operation.transactionSequenceNumber).toStrictEqual(optimisticOperation.transactionSequenceNumber));
70
+ (0, specs_1.botTest)("raw optimistic operation matches", () => (0, expect_1.default)((0, serialization_1.toOperationRaw)(operation)).toMatchObject(opExpected));
71
+ }
72
+ function expectCorrectSpendableBalanceChange(input) {
73
+ const { account, accountBeforeTransaction } = input;
74
+ const operation = input.operation;
75
+ let value = operation.value;
76
+ if (operation.extra.amount) {
77
+ if (operation.type === "DELEGATE") {
78
+ value = value.plus(operation.extra.amount);
79
+ }
80
+ else if (operation.type === "WITHDRAW_UNBONDED") {
81
+ value = value.minus(operation.extra.amount);
82
+ }
83
+ }
84
+ (0, specs_1.botTest)("EGLD spendable balance change is correct", () => (0, expect_1.default)(account.spendableBalance.toFixed()).toStrictEqual(accountBeforeTransaction.spendableBalance.minus(value).toFixed()));
85
+ }
86
+ function expectCorrectBalanceFeeChange(input) {
87
+ const { account, operation, accountBeforeTransaction } = input;
88
+ (0, specs_1.botTest)("Only change on balance is fees", () => (0, expect_1.default)(account.balance.toFixed()).toStrictEqual(accountBeforeTransaction.balance.minus(operation.fee).toFixed()));
89
+ }
90
+ const multiversx = {
91
+ name: "MultiversX",
92
+ currency: (0, currencies_2.getCryptoCurrencyById)("elrond"),
93
+ appQuery: {
94
+ model: devices_1.DeviceModelId.nanoS,
95
+ appName: "MultiversX",
96
+ },
97
+ genericDeviceAction: speculos_deviceActions_1.acceptMoveBalanceTransaction,
98
+ genericDeviceActionForSubAccountTransfers: speculos_deviceActions_1.acceptEsdtTransferTransaction,
99
+ testTimeout: 2 * 60 * 1000,
100
+ minViableAmount: minimalAmount,
101
+ transactionCheck: ({ maxSpendable }) => {
102
+ (0, invariant_1.default)(maxSpendable.gt(minimalAmount), "balance is too low");
103
+ },
104
+ test: input => {
105
+ expectCorrectOptimisticOperation(input);
106
+ },
107
+ mutations: [
108
+ {
109
+ name: "send 50%~",
110
+ feature: "send",
111
+ maxRun: 1,
112
+ deviceAction: speculos_deviceActions_1.acceptMoveBalanceTransaction,
113
+ transaction: ({ account, siblings, bridge }) => {
114
+ (0, invariant_1.default)(account.spendableBalance.gt(0), "balance is 0");
115
+ const sibling = (0, specs_1.pickSiblings)(siblings, maxAccounts);
116
+ let amount = account.spendableBalance.div(1.9 + 0.2 * Math.random()).integerValue();
117
+ if (!sibling.used && amount.lt(MULTIVERSX_MIN_ACTIVATION_SAFE)) {
118
+ (0, invariant_1.default)(account.spendableBalance.gt(MULTIVERSX_MIN_ACTIVATION_SAFE), "send is too low to activate account");
119
+ amount = MULTIVERSX_MIN_ACTIVATION_SAFE;
120
+ }
121
+ return {
122
+ transaction: bridge.createTransaction(account),
123
+ updates: [
124
+ {
125
+ recipient: sibling.freshAddress,
126
+ },
127
+ {
128
+ amount,
129
+ },
130
+ ],
131
+ };
132
+ },
133
+ testDestination: specs_1.genericTestDestination,
134
+ test: input => {
135
+ expectCorrectBalanceChange(input);
136
+ },
137
+ },
138
+ {
139
+ name: "send max",
140
+ feature: "sendMax",
141
+ maxRun: 1,
142
+ deviceAction: speculos_deviceActions_1.acceptMoveBalanceTransaction,
143
+ transaction: ({ account, siblings, bridge }) => {
144
+ (0, invariant_1.default)(account.spendableBalance.gt(0), "balance is 0");
145
+ const sibling = (0, specs_1.pickSiblings)(siblings, maxAccounts);
146
+ if (!sibling.used) {
147
+ (0, invariant_1.default)(account.spendableBalance.gt(MULTIVERSX_MIN_ACTIVATION_SAFE), "send is too low to activate account");
148
+ }
149
+ return {
150
+ transaction: bridge.createTransaction(account),
151
+ updates: [
152
+ {
153
+ recipient: sibling.freshAddress,
154
+ },
155
+ {
156
+ useAllAmount: true,
157
+ },
158
+ ],
159
+ };
160
+ },
161
+ testDestination: specs_1.genericTestDestination,
162
+ test: input => {
163
+ expectCorrectBalanceChange(input);
164
+ },
165
+ },
166
+ {
167
+ name: "move some ESDT",
168
+ feature: "tokens",
169
+ maxRun: 1,
170
+ deviceAction: speculos_deviceActions_1.acceptEsdtTransferTransaction,
171
+ transaction: ({ account, siblings, bridge }) => {
172
+ const esdtAccount = (0, sample_1.default)((account.subAccounts || []).filter(a => a.balance.gt(0)));
173
+ (0, invariant_1.default)(esdtAccount, "no esdt account");
174
+ (0, invariant_1.default)(esdtAccount?.balance.gt(0), "esdt balance is 0");
175
+ const sibling = (0, specs_1.pickSiblings)(siblings, 2);
176
+ const recipient = sibling.freshAddress;
177
+ const amount = esdtAccount?.balance.times(Math.random()).integerValue();
178
+ return {
179
+ transaction: bridge.createTransaction(account),
180
+ updates: [
181
+ {
182
+ subAccountId: esdtAccount?.id,
183
+ },
184
+ {
185
+ recipient,
186
+ },
187
+ {
188
+ amount,
189
+ },
190
+ ],
191
+ };
192
+ },
193
+ test: input => {
194
+ expectCorrectEsdtBalanceChange(input);
195
+ expectCorrectBalanceFeeChange(input);
196
+ },
197
+ },
198
+ {
199
+ name: "delegate 1 EGLD",
200
+ feature: "staking",
201
+ maxRun: 1,
202
+ deviceAction: speculos_deviceActions_1.acceptDelegateTransaction,
203
+ transaction: ({ account, bridge }) => {
204
+ (0, invariant_1.default)(account.spendableBalance.gt(constants_1.MIN_DELEGATION_AMOUNT), `spendable balance is less than minimum delegation amount`);
205
+ const amount = constants_1.MIN_DELEGATION_AMOUNT;
206
+ return {
207
+ transaction: bridge.createTransaction(account),
208
+ updates: [
209
+ {
210
+ recipient: UNCAPPED_PROVIDER,
211
+ mode: "delegate",
212
+ amount,
213
+ },
214
+ ],
215
+ };
216
+ },
217
+ test: input => {
218
+ expectCorrectSpendableBalanceChange(input);
219
+ expectCorrectBalanceFeeChange(input);
220
+ },
221
+ },
222
+ {
223
+ name: "unDelegate 1 EGLD",
224
+ feature: "staking",
225
+ maxRun: 1,
226
+ deviceAction: speculos_deviceActions_1.acceptUndelegateTransaction,
227
+ transaction: ({ account, bridge }) => {
228
+ const delegations = account?.multiversxResources?.delegations;
229
+ (0, invariant_1.default)(delegations?.length, "account doesn't have any delegations");
230
+ (0, invariant_1.default)(delegations.some(d => new bignumber_js_1.default(d.userActiveStake).gt(0)), "no active stake for account");
231
+ const amount = constants_1.MIN_DELEGATION_AMOUNT;
232
+ return {
233
+ transaction: bridge.createTransaction(account),
234
+ updates: [
235
+ {
236
+ recipient: UNCAPPED_PROVIDER,
237
+ mode: "unDelegate",
238
+ amount,
239
+ },
240
+ ],
241
+ };
242
+ },
243
+ test: input => {
244
+ expectCorrectSpendableBalanceChange(input);
245
+ expectCorrectBalanceFeeChange(input);
246
+ },
247
+ },
248
+ {
249
+ name: "withdraw all EGLD",
250
+ feature: "staking",
251
+ maxRun: 1,
252
+ deviceAction: speculos_deviceActions_1.acceptWithdrawTransaction,
253
+ transaction: ({ account, bridge }) => {
254
+ const delegations = account?.multiversxResources?.delegations;
255
+ (0, invariant_1.default)(delegations?.length, "account doesn't have any delegations");
256
+ (0, invariant_1.default)(
257
+ // among all delegations
258
+ delegations.some(d =>
259
+ // among all undelegating amounts
260
+ d.userUndelegatedList?.some(u => new bignumber_js_1.default(u.amount).gt(0) && // the undelegation has a positive amount
261
+ new bignumber_js_1.default(u.seconds).eq(0))), "no withdrawable stake for account");
262
+ return {
263
+ transaction: bridge.createTransaction(account),
264
+ updates: [
265
+ {
266
+ recipient: UNCAPPED_PROVIDER,
267
+ mode: "withdraw",
268
+ amount: new bignumber_js_1.default(0),
269
+ },
270
+ ],
271
+ };
272
+ },
273
+ test: input => {
274
+ expectCorrectSpendableBalanceChange(input);
275
+ expectCorrectBalanceFeeChange(input);
276
+ },
277
+ },
278
+ // TODO
279
+ // "reDelegateRewards"
280
+ // "claimRewards"
281
+ ],
282
+ };
283
+ exports.default = {
284
+ multiversx,
285
+ };
286
+ //# sourceMappingURL=specs.js.map