@ledgerhq/coin-tezos 6.6.0-nightly.1 → 6.6.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 (331) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/.unimportedrc.json +30 -4
  3. package/CHANGELOG.md +17 -8
  4. package/jest.integ.config.js +0 -1
  5. package/lib/api/index.d.ts.map +1 -1
  6. package/lib/api/index.js +40 -188
  7. package/lib/api/index.js.map +1 -1
  8. package/lib/api/index.test.js +10 -79
  9. package/lib/api/index.test.js.map +1 -1
  10. package/lib/api/types.d.ts +5 -7
  11. package/lib/api/types.d.ts.map +1 -1
  12. package/lib/bridge/broadcast.d.ts +4 -0
  13. package/lib/bridge/broadcast.d.ts.map +1 -0
  14. package/lib/bridge/broadcast.js +11 -0
  15. package/lib/bridge/broadcast.js.map +1 -0
  16. package/lib/bridge/broadcast.test.d.ts +2 -0
  17. package/lib/bridge/broadcast.test.d.ts.map +1 -0
  18. package/lib/bridge/broadcast.test.js +36 -0
  19. package/lib/bridge/broadcast.test.js.map +1 -0
  20. package/lib/bridge/buildOptimisticOperation.d.ts +4 -0
  21. package/lib/bridge/buildOptimisticOperation.d.ts.map +1 -0
  22. package/lib/bridge/buildOptimisticOperation.js +28 -0
  23. package/lib/bridge/buildOptimisticOperation.js.map +1 -0
  24. package/lib/bridge/createTransaction.d.ts +4 -0
  25. package/lib/bridge/createTransaction.d.ts.map +1 -0
  26. package/lib/bridge/createTransaction.js +24 -0
  27. package/lib/bridge/createTransaction.js.map +1 -0
  28. package/lib/bridge/estimateMaxSpendable.d.ts +5 -0
  29. package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
  30. package/lib/bridge/estimateMaxSpendable.js +30 -0
  31. package/lib/bridge/estimateMaxSpendable.js.map +1 -0
  32. package/lib/bridge/getFeesForTransaction.d.ts +21 -0
  33. package/lib/bridge/getFeesForTransaction.d.ts.map +1 -0
  34. package/lib/bridge/getFeesForTransaction.js +39 -0
  35. package/lib/bridge/getFeesForTransaction.js.map +1 -0
  36. package/lib/bridge/getTransactionStatus.d.ts +4 -0
  37. package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
  38. package/lib/bridge/getTransactionStatus.js +108 -0
  39. package/lib/bridge/getTransactionStatus.js.map +1 -0
  40. package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
  41. package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
  42. package/lib/bridge/getTransactionStatus.test.js +107 -0
  43. package/lib/bridge/getTransactionStatus.test.js.map +1 -0
  44. package/lib/bridge/index.d.ts +10 -0
  45. package/lib/bridge/index.d.ts.map +1 -0
  46. package/lib/bridge/index.js +59 -0
  47. package/lib/bridge/index.js.map +1 -0
  48. package/lib/bridge/logic.d.ts +10 -0
  49. package/lib/bridge/logic.d.ts.map +1 -0
  50. package/lib/bridge/logic.js +155 -0
  51. package/lib/bridge/logic.js.map +1 -0
  52. package/lib/bridge/preload.d.ts +9 -0
  53. package/lib/bridge/preload.d.ts.map +1 -0
  54. package/lib/bridge/preload.js +23 -0
  55. package/lib/bridge/preload.js.map +1 -0
  56. package/lib/bridge/prepareTransaction.d.ts +5 -0
  57. package/lib/bridge/prepareTransaction.d.ts.map +1 -0
  58. package/lib/bridge/prepareTransaction.integ.test.d.ts +2 -0
  59. package/lib/bridge/prepareTransaction.integ.test.d.ts.map +1 -0
  60. package/lib/bridge/prepareTransaction.integ.test.js +34 -0
  61. package/lib/bridge/prepareTransaction.integ.test.js.map +1 -0
  62. package/lib/bridge/prepareTransaction.js +57 -0
  63. package/lib/bridge/prepareTransaction.js.map +1 -0
  64. package/lib/bridge/prepareTransaction.test.d.ts +2 -0
  65. package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
  66. package/lib/bridge/prepareTransaction.test.js +178 -0
  67. package/lib/bridge/prepareTransaction.test.js.map +1 -0
  68. package/lib/bridge/serialization.d.ts +7 -0
  69. package/lib/bridge/serialization.d.ts.map +1 -0
  70. package/lib/bridge/serialization.js +26 -0
  71. package/lib/bridge/serialization.js.map +1 -0
  72. package/lib/bridge/signOperation.d.ts +16 -0
  73. package/lib/bridge/signOperation.d.ts.map +1 -0
  74. package/lib/bridge/signOperation.js +88 -0
  75. package/lib/bridge/signOperation.js.map +1 -0
  76. package/lib/bridge/signOperation.test.d.ts +2 -0
  77. package/lib/bridge/signOperation.test.d.ts.map +1 -0
  78. package/lib/bridge/signOperation.test.js +283 -0
  79. package/lib/bridge/signOperation.test.js.map +1 -0
  80. package/lib/bridge/synchronization.d.ts +5 -0
  81. package/lib/bridge/synchronization.d.ts.map +1 -0
  82. package/lib/bridge/synchronization.integ.test.d.ts +2 -0
  83. package/lib/bridge/synchronization.integ.test.d.ts.map +1 -0
  84. package/lib/bridge/synchronization.integ.test.js +32 -0
  85. package/lib/bridge/synchronization.integ.test.js.map +1 -0
  86. package/lib/bridge/synchronization.js +100 -0
  87. package/lib/bridge/synchronization.js.map +1 -0
  88. package/lib/{transaction.d.ts → bridge/transaction.d.ts} +1 -1
  89. package/lib/bridge/transaction.d.ts.map +1 -0
  90. package/lib/{transaction.js → bridge/transaction.js} +3 -3
  91. package/lib/bridge/transaction.js.map +1 -0
  92. package/lib/config.d.ts +3 -4
  93. package/lib/config.d.ts.map +1 -1
  94. package/lib/config.js.map +1 -1
  95. package/lib/index.d.ts +1 -1
  96. package/lib/index.d.ts.map +1 -1
  97. package/lib/index.js +3 -1
  98. package/lib/index.js.map +1 -1
  99. package/lib/logic/craftTransaction.d.ts.map +1 -1
  100. package/lib/logic/craftTransaction.js +0 -7
  101. package/lib/logic/craftTransaction.js.map +1 -1
  102. package/lib/logic/craftTransaction.test.js +0 -1
  103. package/lib/logic/craftTransaction.test.js.map +1 -1
  104. package/lib/logic/estimateFees.d.ts.map +1 -1
  105. package/lib/logic/estimateFees.integ.test.js +2 -8
  106. package/lib/logic/estimateFees.integ.test.js.map +1 -1
  107. package/lib/logic/estimateFees.js +45 -119
  108. package/lib/logic/estimateFees.js.map +1 -1
  109. package/lib/logic/getBalance.js +1 -1
  110. package/lib/logic/getBalance.js.map +1 -1
  111. package/lib/logic/index.d.ts +0 -2
  112. package/lib/logic/index.d.ts.map +1 -1
  113. package/lib/logic/index.js +1 -5
  114. package/lib/logic/index.js.map +1 -1
  115. package/lib/logic/listOperations.d.ts.map +1 -1
  116. package/lib/logic/listOperations.js +10 -56
  117. package/lib/logic/listOperations.js.map +1 -1
  118. package/lib/logic/listOperations.test.js +10 -14
  119. package/lib/logic/listOperations.test.js.map +1 -1
  120. package/lib/types/bridge.d.ts +0 -3
  121. package/lib/types/bridge.d.ts.map +1 -1
  122. package/lib/types/bridge.fixture.d.ts.map +1 -1
  123. package/lib/types/bridge.fixture.js +0 -1
  124. package/lib/types/bridge.fixture.js.map +1 -1
  125. package/lib/types/bridge.js.map +1 -1
  126. package/lib-es/api/index.d.ts.map +1 -1
  127. package/lib-es/api/index.js +41 -189
  128. package/lib-es/api/index.js.map +1 -1
  129. package/lib-es/api/index.test.js +10 -79
  130. package/lib-es/api/index.test.js.map +1 -1
  131. package/lib-es/api/types.d.ts +5 -7
  132. package/lib-es/api/types.d.ts.map +1 -1
  133. package/lib-es/bridge/broadcast.d.ts +4 -0
  134. package/lib-es/bridge/broadcast.d.ts.map +1 -0
  135. package/lib-es/bridge/broadcast.js +7 -0
  136. package/lib-es/bridge/broadcast.js.map +1 -0
  137. package/lib-es/bridge/broadcast.test.d.ts +2 -0
  138. package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
  139. package/lib-es/bridge/broadcast.test.js +31 -0
  140. package/lib-es/bridge/broadcast.test.js.map +1 -0
  141. package/lib-es/bridge/buildOptimisticOperation.d.ts +4 -0
  142. package/lib-es/bridge/buildOptimisticOperation.d.ts.map +1 -0
  143. package/lib-es/bridge/buildOptimisticOperation.js +21 -0
  144. package/lib-es/bridge/buildOptimisticOperation.js.map +1 -0
  145. package/lib-es/bridge/createTransaction.d.ts +4 -0
  146. package/lib-es/bridge/createTransaction.d.ts.map +1 -0
  147. package/lib-es/bridge/createTransaction.js +17 -0
  148. package/lib-es/bridge/createTransaction.js.map +1 -0
  149. package/lib-es/bridge/estimateMaxSpendable.d.ts +5 -0
  150. package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
  151. package/lib-es/bridge/estimateMaxSpendable.js +23 -0
  152. package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
  153. package/lib-es/bridge/getFeesForTransaction.d.ts +21 -0
  154. package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -0
  155. package/lib-es/bridge/getFeesForTransaction.js +33 -0
  156. package/lib-es/bridge/getFeesForTransaction.js.map +1 -0
  157. package/lib-es/bridge/getTransactionStatus.d.ts +4 -0
  158. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
  159. package/lib-es/bridge/getTransactionStatus.js +101 -0
  160. package/lib-es/bridge/getTransactionStatus.js.map +1 -0
  161. package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
  162. package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
  163. package/lib-es/bridge/getTransactionStatus.test.js +102 -0
  164. package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
  165. package/lib-es/bridge/index.d.ts +10 -0
  166. package/lib-es/bridge/index.d.ts.map +1 -0
  167. package/lib-es/bridge/index.js +53 -0
  168. package/lib-es/bridge/index.js.map +1 -0
  169. package/lib-es/bridge/logic.d.ts +10 -0
  170. package/lib-es/bridge/logic.d.ts.map +1 -0
  171. package/lib-es/bridge/logic.js +145 -0
  172. package/lib-es/bridge/logic.js.map +1 -0
  173. package/lib-es/bridge/preload.d.ts +9 -0
  174. package/lib-es/bridge/preload.d.ts.map +1 -0
  175. package/lib-es/bridge/preload.js +17 -0
  176. package/lib-es/bridge/preload.js.map +1 -0
  177. package/lib-es/bridge/prepareTransaction.d.ts +5 -0
  178. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
  179. package/lib-es/bridge/prepareTransaction.integ.test.d.ts +2 -0
  180. package/lib-es/bridge/prepareTransaction.integ.test.d.ts.map +1 -0
  181. package/lib-es/bridge/prepareTransaction.integ.test.js +29 -0
  182. package/lib-es/bridge/prepareTransaction.integ.test.js.map +1 -0
  183. package/lib-es/bridge/prepareTransaction.js +50 -0
  184. package/lib-es/bridge/prepareTransaction.js.map +1 -0
  185. package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
  186. package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
  187. package/lib-es/bridge/prepareTransaction.test.js +173 -0
  188. package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
  189. package/lib-es/bridge/serialization.d.ts +7 -0
  190. package/lib-es/bridge/serialization.d.ts.map +1 -0
  191. package/lib-es/bridge/serialization.js +20 -0
  192. package/lib-es/bridge/serialization.js.map +1 -0
  193. package/lib-es/bridge/signOperation.d.ts +16 -0
  194. package/lib-es/bridge/signOperation.d.ts.map +1 -0
  195. package/lib-es/bridge/signOperation.js +83 -0
  196. package/lib-es/bridge/signOperation.js.map +1 -0
  197. package/lib-es/bridge/signOperation.test.d.ts +2 -0
  198. package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
  199. package/lib-es/bridge/signOperation.test.js +255 -0
  200. package/lib-es/bridge/signOperation.test.js.map +1 -0
  201. package/lib-es/bridge/synchronization.d.ts +5 -0
  202. package/lib-es/bridge/synchronization.d.ts.map +1 -0
  203. package/lib-es/bridge/synchronization.integ.test.d.ts +2 -0
  204. package/lib-es/bridge/synchronization.integ.test.d.ts.map +1 -0
  205. package/lib-es/bridge/synchronization.integ.test.js +27 -0
  206. package/lib-es/bridge/synchronization.integ.test.js.map +1 -0
  207. package/lib-es/bridge/synchronization.js +70 -0
  208. package/lib-es/bridge/synchronization.js.map +1 -0
  209. package/lib-es/{transaction.d.ts → bridge/transaction.d.ts} +1 -1
  210. package/lib-es/bridge/transaction.d.ts.map +1 -0
  211. package/lib-es/{transaction.js → bridge/transaction.js} +3 -3
  212. package/lib-es/bridge/transaction.js.map +1 -0
  213. package/lib-es/config.d.ts +3 -4
  214. package/lib-es/config.d.ts.map +1 -1
  215. package/lib-es/config.js.map +1 -1
  216. package/lib-es/index.d.ts +1 -1
  217. package/lib-es/index.d.ts.map +1 -1
  218. package/lib-es/index.js +1 -1
  219. package/lib-es/index.js.map +1 -1
  220. package/lib-es/logic/craftTransaction.d.ts.map +1 -1
  221. package/lib-es/logic/craftTransaction.js +0 -7
  222. package/lib-es/logic/craftTransaction.js.map +1 -1
  223. package/lib-es/logic/craftTransaction.test.js +0 -1
  224. package/lib-es/logic/craftTransaction.test.js.map +1 -1
  225. package/lib-es/logic/estimateFees.d.ts.map +1 -1
  226. package/lib-es/logic/estimateFees.integ.test.js +2 -8
  227. package/lib-es/logic/estimateFees.integ.test.js.map +1 -1
  228. package/lib-es/logic/estimateFees.js +45 -119
  229. package/lib-es/logic/estimateFees.js.map +1 -1
  230. package/lib-es/logic/getBalance.js +1 -1
  231. package/lib-es/logic/getBalance.js.map +1 -1
  232. package/lib-es/logic/index.d.ts +0 -2
  233. package/lib-es/logic/index.d.ts.map +1 -1
  234. package/lib-es/logic/index.js +0 -2
  235. package/lib-es/logic/index.js.map +1 -1
  236. package/lib-es/logic/listOperations.d.ts.map +1 -1
  237. package/lib-es/logic/listOperations.js +10 -56
  238. package/lib-es/logic/listOperations.js.map +1 -1
  239. package/lib-es/logic/listOperations.test.js +10 -14
  240. package/lib-es/logic/listOperations.test.js.map +1 -1
  241. package/lib-es/types/bridge.d.ts +0 -3
  242. package/lib-es/types/bridge.d.ts.map +1 -1
  243. package/lib-es/types/bridge.fixture.d.ts.map +1 -1
  244. package/lib-es/types/bridge.fixture.js +0 -1
  245. package/lib-es/types/bridge.fixture.js.map +1 -1
  246. package/lib-es/types/bridge.js.map +1 -1
  247. package/package.json +14 -11
  248. package/src/api/index.test.ts +15 -87
  249. package/src/api/index.ts +55 -204
  250. package/src/api/types.ts +6 -11
  251. package/src/bridge/broadcast.test.ts +36 -0
  252. package/src/bridge/broadcast.ts +13 -0
  253. package/src/bridge/buildOptimisticOperation.ts +28 -0
  254. package/src/bridge/createTransaction.ts +19 -0
  255. package/src/bridge/estimateMaxSpendable.ts +37 -0
  256. package/src/bridge/getFeesForTransaction.ts +49 -0
  257. package/src/bridge/getTransactionStatus.test.ts +124 -0
  258. package/src/bridge/getTransactionStatus.ts +123 -0
  259. package/src/bridge/index.ts +74 -0
  260. package/src/bridge/logic.ts +171 -0
  261. package/src/bridge/preload.ts +18 -0
  262. package/src/bridge/prepareTransaction.integ.test.ts +35 -0
  263. package/src/bridge/prepareTransaction.test.ts +205 -0
  264. package/src/bridge/prepareTransaction.ts +69 -0
  265. package/src/bridge/serialization.ts +27 -0
  266. package/src/bridge/signOperation.test.ts +284 -0
  267. package/src/bridge/signOperation.ts +130 -0
  268. package/src/bridge/synchronization.integ.test.ts +33 -0
  269. package/src/bridge/synchronization.ts +100 -0
  270. package/src/{transaction.ts → bridge/transaction.ts} +4 -4
  271. package/src/config.ts +2 -9
  272. package/src/index.ts +2 -1
  273. package/src/logic/craftTransaction.test.ts +0 -1
  274. package/src/logic/craftTransaction.ts +0 -8
  275. package/src/logic/estimateFees.integ.test.ts +2 -8
  276. package/src/logic/estimateFees.ts +49 -140
  277. package/src/logic/getBalance.ts +1 -1
  278. package/src/logic/index.ts +0 -2
  279. package/src/logic/listOperations.test.ts +54 -64
  280. package/src/logic/listOperations.ts +9 -57
  281. package/src/types/bridge.fixture.ts +0 -1
  282. package/src/types/bridge.ts +1 -6
  283. package/lib/logic/getStakes.d.ts +0 -3
  284. package/lib/logic/getStakes.d.ts.map +0 -1
  285. package/lib/logic/getStakes.js +0 -26
  286. package/lib/logic/getStakes.js.map +0 -1
  287. package/lib/logic/getStakes.test.d.ts +0 -2
  288. package/lib/logic/getStakes.test.d.ts.map +0 -1
  289. package/lib/logic/getStakes.test.js +0 -133
  290. package/lib/logic/getStakes.test.js.map +0 -1
  291. package/lib/logic/validateIntent.d.ts +0 -3
  292. package/lib/logic/validateIntent.d.ts.map +0 -1
  293. package/lib/logic/validateIntent.js +0 -179
  294. package/lib/logic/validateIntent.js.map +0 -1
  295. package/lib/logic/validateIntent.test.d.ts +0 -2
  296. package/lib/logic/validateIntent.test.d.ts.map +0 -1
  297. package/lib/logic/validateIntent.test.js +0 -249
  298. package/lib/logic/validateIntent.test.js.map +0 -1
  299. package/lib/transaction.d.ts.map +0 -1
  300. package/lib/transaction.js.map +0 -1
  301. package/lib/utils.d.ts +0 -48
  302. package/lib/utils.d.ts.map +0 -1
  303. package/lib/utils.js +0 -112
  304. package/lib/utils.js.map +0 -1
  305. package/lib-es/logic/getStakes.d.ts +0 -3
  306. package/lib-es/logic/getStakes.d.ts.map +0 -1
  307. package/lib-es/logic/getStakes.js +0 -20
  308. package/lib-es/logic/getStakes.js.map +0 -1
  309. package/lib-es/logic/getStakes.test.d.ts +0 -2
  310. package/lib-es/logic/getStakes.test.d.ts.map +0 -1
  311. package/lib-es/logic/getStakes.test.js +0 -128
  312. package/lib-es/logic/getStakes.test.js.map +0 -1
  313. package/lib-es/logic/validateIntent.d.ts +0 -3
  314. package/lib-es/logic/validateIntent.d.ts.map +0 -1
  315. package/lib-es/logic/validateIntent.js +0 -173
  316. package/lib-es/logic/validateIntent.js.map +0 -1
  317. package/lib-es/logic/validateIntent.test.d.ts +0 -2
  318. package/lib-es/logic/validateIntent.test.d.ts.map +0 -1
  319. package/lib-es/logic/validateIntent.test.js +0 -221
  320. package/lib-es/logic/validateIntent.test.js.map +0 -1
  321. package/lib-es/transaction.d.ts.map +0 -1
  322. package/lib-es/transaction.js.map +0 -1
  323. package/lib-es/utils.d.ts +0 -48
  324. package/lib-es/utils.d.ts.map +0 -1
  325. package/lib-es/utils.js +0 -105
  326. package/lib-es/utils.js.map +0 -1
  327. package/src/logic/getStakes.test.ts +0 -145
  328. package/src/logic/getStakes.ts +0 -20
  329. package/src/logic/validateIntent.test.ts +0 -262
  330. package/src/logic/validateIntent.ts +0 -207
  331. package/src/utils.ts +0 -115
@@ -1,17 +1,15 @@
1
- import type { Api, FeeEstimation, TransactionIntent } from "@ledgerhq/coin-framework/api/types";
1
+ import { AlpacaApi, FeeEstimation, TransactionIntent } from "@ledgerhq/coin-framework/api/types";
2
2
  export type TezosFeeParameters = {
3
3
  gasLimit: bigint;
4
4
  storageLimit: bigint;
5
- amount?: bigint;
6
- txFee?: bigint;
7
- };
8
- export type TezosFeeEstimation = FeeEstimation & {
9
- parameters?: TezosFeeParameters & Record<string, unknown>;
10
5
  };
6
+ export type TezosFeeEstimation = FeeEstimation;
11
7
  export type TezosSender = {
12
8
  address: string;
13
9
  xpub?: string;
14
10
  };
15
11
  export type TezosTransactionIntent = TransactionIntent;
16
- export type TezosApi = Api;
12
+ export type TezosApi = AlpacaApi & {
13
+ estimateFees: (transactionIntent: TezosTransactionIntent) => Promise<TezosFeeEstimation>;
14
+ };
17
15
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAEhG,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,MAAM,MAAM,kBAAkB,GAAG,aAAa,GAAG;IAC/C,UAAU,CAAC,EAAE,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC3D,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAC7D,MAAM,MAAM,sBAAsB,GAAG,iBAAiB,CAAC;AAEvD,MAAM,MAAM,QAAQ,GAAG,GAAG,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAEjG,MAAM,MAAM,kBAAkB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC;AAC5E,MAAM,MAAM,kBAAkB,GAAG,aAAa,CAAC;AAE/C,MAAM,MAAM,WAAW,GAAG;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAC7D,MAAM,MAAM,sBAAsB,GAAG,iBAAiB,CAAC;AAEvD,MAAM,MAAM,QAAQ,GAAG,SAAS,GAAG;IACjC,YAAY,EAAE,CAAC,iBAAiB,EAAE,sBAAsB,KAAK,OAAO,CAAC,kBAAkB,CAAC,CAAC;CAC1F,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const broadcast: AccountBridge<Transaction>["broadcast"];
4
+ //# sourceMappingURL=broadcast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAmB,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAO7D,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { patchOperationWithHash } from "@ledgerhq/coin-framework/operation";
2
+ import { broadcast as logicBroadcast } from "../logic";
3
+ export const broadcast = async ({ signedOperation: { operation, signature }, }) => {
4
+ const hash = await logicBroadcast(signature);
5
+ return patchOperationWithHash(operation, hash);
6
+ };
7
+ //# sourceMappingURL=broadcast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAG5E,OAAO,EAAE,SAAS,IAAI,cAAc,EAAE,MAAM,UAAU,CAAC;AAEvD,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAG1C,EAAE,EAAE;IACH,MAAM,IAAI,GAAG,MAAM,cAAc,CAAC,SAAS,CAAC,CAAC;IAC7C,OAAO,sBAAsB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,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,31 @@
1
+ import { createFixtureOperation } from "../types/bridge.fixture";
2
+ import config from "../config";
3
+ import { broadcast } from "./broadcast";
4
+ import { mockConfig } from "../test/config";
5
+ const mockInjectOperation = jest.fn();
6
+ jest.mock("@taquito/taquito", () => ({
7
+ TezosToolkit: jest.fn().mockReturnValue({
8
+ rpc: {
9
+ injectOperation: () => mockInjectOperation(),
10
+ },
11
+ }),
12
+ }));
13
+ describe("broadcast", () => {
14
+ beforeAll(() => {
15
+ config.setCoinConfig(() => mockConfig);
16
+ });
17
+ it("calls 'injectOperation' from TezosToolkit and returns its hash computation", async () => {
18
+ // GIVEN
19
+ const signedOperation = {
20
+ operation: createFixtureOperation(),
21
+ signature: "SIGNATURE",
22
+ };
23
+ mockInjectOperation.mockResolvedValue("SIGN_HASH");
24
+ // WHEN
25
+ const op = await broadcast({ signedOperation, account: {} });
26
+ // THEN
27
+ expect(mockInjectOperation).toHaveBeenCalledTimes(1);
28
+ expect(op.hash).toEqual("SIGN_HASH");
29
+ });
30
+ });
31
+ //# sourceMappingURL=broadcast.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,MAAgC,MAAM,WAAW,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,MAAM,mBAAmB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACtC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC;QACtC,GAAG,EAAE;YACH,eAAe,EAAE,GAAG,EAAE,CAAC,mBAAmB,EAAE;SAC7C;KACF,CAAC;CACH,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,CAAC,aAAa,CAAC,GAAoB,EAAE,CAAC,UAA6B,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,QAAQ;QACR,MAAM,eAAe,GAAoB;YACvC,SAAS,EAAE,sBAAsB,EAAE;YACnC,SAAS,EAAE,WAAW;SACvB,CAAC;QACF,mBAAmB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEnD,OAAO;QACP,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,EAAS,EAAE,CAAC,CAAC;QAEpE,OAAO;QACP,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { OperationType } from "@ledgerhq/types-live";
2
+ import { TezosAccount, TezosOperation, Transaction } from "../types";
3
+ export declare const buildOptimisticOperation: (account: TezosAccount, transaction: Transaction, operationType: OperationType) => TezosOperation;
4
+ //# sourceMappingURL=buildOptimisticOperation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGrE,eAAO,MAAM,wBAAwB,YAC1B,YAAY,eACR,WAAW,iBACT,aAAa,KAC3B,cAkBF,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
2
+ import BigNumber from "bignumber.js";
3
+ export const buildOptimisticOperation = (account, transaction, operationType) => {
4
+ const txHash = ""; // resolved at broadcast time
5
+ const { id: accountId } = account;
6
+ return {
7
+ id: encodeOperationId(accountId, txHash, operationType),
8
+ hash: txHash,
9
+ type: operationType,
10
+ value: transaction.amount,
11
+ fee: transaction.fees || new BigNumber(0),
12
+ extra: {},
13
+ blockHash: null,
14
+ blockHeight: null,
15
+ senders: [account.freshAddress],
16
+ recipients: [transaction.recipient],
17
+ accountId,
18
+ date: new Date(),
19
+ };
20
+ };
21
+ //# sourceMappingURL=buildOptimisticOperation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAEvE,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,OAAqB,EACrB,WAAwB,EACxB,aAA4B,EACZ,EAAE;IAClB,MAAM,MAAM,GAAG,EAAE,CAAC,CAAC,6BAA6B;IAChD,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IAElC,OAAO;QACL,EAAE,EAAE,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,aAAa,CAAC;QACvD,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,aAAa;QACnB,KAAK,EAAE,WAAW,CAAC,MAAM;QACzB,GAAG,EAAE,WAAW,CAAC,IAAI,IAAI,IAAI,SAAS,CAAC,CAAC,CAAC;QACzC,KAAK,EAAE,EAAE;QACT,SAAS,EAAE,IAAI;QACf,WAAW,EAAE,IAAI;QACjB,OAAO,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC;QAC/B,UAAU,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC;QACnC,SAAS;QACT,IAAI,EAAE,IAAI,IAAI,EAAE;KACjB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const createTransaction: AccountBridge<Transaction>["createTransaction"];
4
+ //# sourceMappingURL=createTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAc7E,CAAC"}
@@ -0,0 +1,17 @@
1
+ import BigNumber from "bignumber.js";
2
+ export const createTransaction = () => {
3
+ return {
4
+ family: "tezos",
5
+ mode: "send",
6
+ amount: new BigNumber(0),
7
+ fees: null,
8
+ gasLimit: null,
9
+ storageLimit: null,
10
+ recipient: "",
11
+ networkInfo: null,
12
+ useAllAmount: false,
13
+ taquitoError: null,
14
+ estimatedFees: null,
15
+ };
16
+ };
17
+ //# sourceMappingURL=createTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAIrC,MAAM,CAAC,MAAM,iBAAiB,GAAoD,GAAG,EAAE;IACrF,OAAO;QACL,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;QACxB,IAAI,EAAE,IAAI;QACV,QAAQ,EAAE,IAAI;QACd,YAAY,EAAE,IAAI;QAClB,SAAS,EAAE,EAAE;QACb,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,KAAK;QACnB,YAAY,EAAE,IAAI;QAClB,aAAa,EAAE,IAAI;KACpB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const estimateMaxSpendable: AccountBridge<Transaction>["estimateMaxSpendable"];
4
+ export default estimateMaxSpendable;
5
+ //# sourceMappingURL=estimateMaxSpendable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAe,MAAM,sBAAsB,CAAC;AAE3E,OAAO,EAAgB,WAAW,EAAE,MAAM,UAAU,CAAC;AAOrD,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAwBnF,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { getMainAccount } from "@ledgerhq/coin-framework/account/index";
2
+ import { prepareTransaction } from "./prepareTransaction";
3
+ import { createTransaction } from "./createTransaction";
4
+ import getEstimatedFees from "./getFeesForTransaction";
5
+ const TEZOS_BURN_ADDRESS = "tz1burnburnburnburnburnburnburjAYjjX";
6
+ export const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
7
+ const mainAccount = getMainAccount(account, parentAccount);
8
+ const tx = await prepareTransaction(mainAccount, {
9
+ ...createTransaction(account),
10
+ ...transaction,
11
+ // estimate using a burn address that exists so we don't enter into NotEnoughBalanceBecauseDestinationNotCreated
12
+ recipient: transaction?.recipient || TEZOS_BURN_ADDRESS,
13
+ useAllAmount: true,
14
+ });
15
+ const estimation = await getEstimatedFees({
16
+ account: mainAccount,
17
+ transaction: tx,
18
+ });
19
+ // As we use `useAllAmount`, we know we will receive an amount value.
20
+ return estimation.amount;
21
+ };
22
+ export default estimateMaxSpendable;
23
+ //# sourceMappingURL=estimateMaxSpendable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AAExE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,gBAAgB,MAAM,yBAAyB,CAAC;AAEvD,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AAElE,MAAM,CAAC,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GAKZ,EAAsB,EAAE;IACvB,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAiB,CAAC;IAC3E,MAAM,EAAE,GAAG,MAAM,kBAAkB,CAAC,WAAW,EAAE;QAC/C,GAAG,iBAAiB,CAAC,OAAO,CAAC;QAC7B,GAAG,WAAW;QACd,gHAAgH;QAChH,SAAS,EAAE,WAAW,EAAE,SAAS,IAAI,kBAAkB;QACvD,YAAY,EAAE,IAAI;KACnB,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,MAAM,gBAAgB,CAAC;QACxC,OAAO,EAAE,WAAW;QACpB,WAAW,EAAE,EAAE;KAChB,CAAC,CAAC;IAEH,qEAAqE;IACrE,OAAO,UAAU,CAAC,MAAO,CAAC;AAC5B,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -0,0 +1,21 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { TezosAccount, Transaction } from "../types";
3
+ export type EstimatedFees = {
4
+ fees: BigNumber;
5
+ gasLimit: BigNumber;
6
+ storageLimit: BigNumber;
7
+ estimatedFees: BigNumber;
8
+ amount?: BigNumber;
9
+ taquitoError?: string;
10
+ };
11
+ /**
12
+ * Fetch the transaction fees for a transaction
13
+ *
14
+ * @param {Account} a
15
+ * @param {Transaction} t
16
+ */
17
+ export default function getEstimatedFees({ account, transaction, }: {
18
+ account: TezosAccount;
19
+ transaction: Transaction;
20
+ }): Promise<EstimatedFees>;
21
+ //# sourceMappingURL=getFeesForTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFeesForTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGrD,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,SAAS,CAAC;IAChB,QAAQ,EAAE,SAAS,CAAC;IACpB,YAAY,EAAE,SAAS,CAAC;IACxB,aAAa,EAAE,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AACF;;;;;GAKG;AACH,wBAA8B,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GACZ,EAAE;IACD,OAAO,EAAE,YAAY,CAAC;IACtB,WAAW,EAAE,WAAW,CAAC;CAC1B,GAAG,OAAO,CAAC,aAAa,CAAC,CAwBzB"}
@@ -0,0 +1,33 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { estimateFees } from "../logic";
3
+ /**
4
+ * Fetch the transaction fees for a transaction
5
+ *
6
+ * @param {Account} a
7
+ * @param {Transaction} t
8
+ */
9
+ export default async function getEstimatedFees({ account, transaction, }) {
10
+ const estimate = await estimateFees({
11
+ account: {
12
+ xpub: account.xpub,
13
+ address: account.freshAddress,
14
+ balance: BigInt(account.balance.toString()),
15
+ revealed: account.tezosResources.revealed,
16
+ },
17
+ transaction: {
18
+ mode: transaction.mode,
19
+ recipient: transaction.recipient,
20
+ amount: BigInt(transaction.amount.toString()),
21
+ useAllAmount: transaction.useAllAmount,
22
+ },
23
+ });
24
+ return {
25
+ fees: BigNumber(estimate.fees.toString()),
26
+ gasLimit: BigNumber(estimate.gasLimit.toString()),
27
+ storageLimit: BigNumber(estimate.storageLimit.toString()),
28
+ estimatedFees: BigNumber(estimate.estimatedFees.toString()),
29
+ amount: estimate.amount !== undefined ? BigNumber(estimate.amount.toString()) : BigNumber(0),
30
+ taquitoError: estimate.taquitoError,
31
+ };
32
+ }
33
+ //# sourceMappingURL=getFeesForTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFeesForTransaction.js","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAUxC;;;;;GAKG;AACH,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GAIZ;IACC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC;QAClC,OAAO,EAAE;YACP,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,YAAY;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAC3C,QAAQ,EAAE,OAAO,CAAC,cAAc,CAAC,QAAQ;SAC1C;QACD,WAAW,EAAE;YACX,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,SAAS,EAAE,WAAW,CAAC,SAAS;YAChC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC7C,YAAY,EAAE,WAAW,CAAC,YAAY;SACvC;KACF,CAAC,CAAC;IAEH,OAAO;QACL,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzC,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACjD,YAAY,EAAE,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACzD,aAAa,EAAE,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5F,YAAY,EAAE,QAAQ,CAAC,YAAY;KACpC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
+ import { Transaction } from "../types";
3
+ export declare const getTransactionStatus: AccountBridge<Transaction>["getTransactionStatus"];
4
+ //# sourceMappingURL=getTransactionStatus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAKrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAIvC,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAsGnF,CAAC"}
@@ -0,0 +1,101 @@
1
+ import { AmountRequired, FeeTooHigh, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, NotEnoughBalanceBecauseDestinationNotCreated, NotEnoughBalanceToDelegate, RecommendUndelegation, } from "@ledgerhq/errors";
2
+ import { log } from "@ledgerhq/logs";
3
+ import BigNumber from "bignumber.js";
4
+ import { InvalidAddressBecauseAlreadyDelegated } from "../types/errors";
5
+ import { validateRecipient } from "../logic";
6
+ import { isAccountDelegating } from "../network/bakers";
7
+ import api from "../network/tzkt";
8
+ const EXISTENTIAL_DEPOSIT = new BigNumber(275000);
9
+ export const getTransactionStatus = async (account, transaction) => {
10
+ const errors = {};
11
+ const warnings = {};
12
+ let resetTotalSpent = false;
13
+ // Recipient validation logic
14
+ if (transaction.mode !== "undelegate") {
15
+ if (account.freshAddress === transaction.recipient) {
16
+ errors.recipient = new InvalidAddressBecauseDestinationIsAlsoSource();
17
+ }
18
+ else {
19
+ const { recipientError, recipientWarning } = await validateRecipient(transaction.recipient);
20
+ if (recipientError) {
21
+ errors.recipient = recipientError;
22
+ }
23
+ if (recipientWarning) {
24
+ warnings.recipient = recipientWarning;
25
+ }
26
+ }
27
+ }
28
+ // Pre validation of amount field
29
+ const estimatedFees = transaction.estimatedFees || new BigNumber(0);
30
+ if (transaction.mode === "send") {
31
+ if (!errors.amount && transaction.amount.eq(0) && !transaction.useAllAmount) {
32
+ resetTotalSpent = true;
33
+ errors.amount = new AmountRequired();
34
+ }
35
+ else if (transaction.amount.gt(0) && estimatedFees.times(10).gt(transaction.amount)) {
36
+ warnings.feeTooHigh = new FeeTooHigh();
37
+ }
38
+ const thresholdWarning = 0.5 * 10 ** account.currency.units[0].magnitude;
39
+ if (!errors.amount &&
40
+ account.balance.minus(transaction.amount).minus(estimatedFees).lt(thresholdWarning)) {
41
+ if (isAccountDelegating(account)) {
42
+ if (transaction.useAllAmount) {
43
+ errors.amount = new RecommendUndelegation();
44
+ }
45
+ else {
46
+ warnings.amount = new RecommendUndelegation();
47
+ }
48
+ }
49
+ }
50
+ }
51
+ // effective amount
52
+ // if we also have taquitoError, we interprete them and they override the previously inferred errors
53
+ if (transaction.taquitoError) {
54
+ log("taquitoerror", String(transaction.taquitoError));
55
+ // remap taquito errors
56
+ if (transaction.taquitoError.endsWith("balance_too_low") ||
57
+ transaction.taquitoError.endsWith("subtraction_underflow")) {
58
+ if (transaction.mode === "send") {
59
+ resetTotalSpent = true;
60
+ errors.amount = new NotEnoughBalance();
61
+ }
62
+ else {
63
+ errors.amount = new NotEnoughBalanceToDelegate();
64
+ }
65
+ }
66
+ else if (transaction.taquitoError.endsWith("delegate.unchanged")) {
67
+ errors.recipient = new InvalidAddressBecauseAlreadyDelegated();
68
+ }
69
+ else if (!errors.amount) {
70
+ // unidentified error case
71
+ errors.amount = new Error(transaction.taquitoError);
72
+ resetTotalSpent = true;
73
+ }
74
+ }
75
+ if (!errors.amount && account.balance.lte(0)) {
76
+ resetTotalSpent = true;
77
+ errors.amount = new NotEnoughBalance();
78
+ }
79
+ if (!errors.amount && transaction.mode === "delegate" && account.balance.lte(estimatedFees)) {
80
+ resetTotalSpent = true;
81
+ errors.amount = new NotEnoughBalance();
82
+ }
83
+ // Catch a specific case that requires a minimum amount
84
+ if (!errors.amount &&
85
+ transaction.mode === "send" &&
86
+ transaction.amount.lt(EXISTENTIAL_DEPOSIT) &&
87
+ (await api.getAccountByAddress(transaction.recipient)).type === "empty") {
88
+ resetTotalSpent = true;
89
+ errors.amount = new NotEnoughBalanceBecauseDestinationNotCreated("", {
90
+ minimalAmount: "0.275 XTZ",
91
+ });
92
+ }
93
+ return {
94
+ errors,
95
+ warnings,
96
+ estimatedFees,
97
+ amount: transaction.amount,
98
+ totalSpent: resetTotalSpent ? new BigNumber(0) : transaction.amount.plus(estimatedFees),
99
+ };
100
+ };
101
+ //# sourceMappingURL=getTransactionStatus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=getTransactionStatus.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,102 @@
1
+ import BigNumber from "bignumber.js";
2
+ import { getTransactionStatus } from "./getTransactionStatus";
3
+ import { validateRecipient } from "../logic";
4
+ import { isAccountDelegating } from "../network/bakers";
5
+ import api from "../network/tzkt";
6
+ import { AmountRequired, FeeTooHigh, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, NotEnoughBalanceBecauseDestinationNotCreated, RecommendUndelegation, } from "@ledgerhq/errors";
7
+ jest.mock("../logic", () => ({
8
+ validateRecipient: jest.fn(),
9
+ }));
10
+ jest.mock("../network/bakers", () => ({
11
+ isAccountDelegating: jest.fn(),
12
+ }));
13
+ jest.mock("../network/tzkt", () => ({
14
+ getAccountByAddress: jest.fn(),
15
+ }));
16
+ describe("getTransactionStatus", () => {
17
+ const mockAccount = {
18
+ type: "Account",
19
+ freshAddress: "tz1SourceAddress",
20
+ balance: new BigNumber(1000000),
21
+ currency: {
22
+ type: "CryptoCurrency",
23
+ units: [
24
+ {
25
+ name: "tezos",
26
+ code: "XTZ",
27
+ magnitude: 6,
28
+ },
29
+ ],
30
+ },
31
+ tezosResources: {
32
+ revealed: true,
33
+ counter: 0,
34
+ },
35
+ };
36
+ const mockTransaction = {
37
+ family: "tezos",
38
+ mode: "send",
39
+ amount: new BigNumber(500000),
40
+ recipient: "tz1RecipientAddress",
41
+ estimatedFees: new BigNumber(1000),
42
+ useAllAmount: false,
43
+ };
44
+ beforeEach(() => {
45
+ jest.clearAllMocks();
46
+ validateRecipient.mockResolvedValue({
47
+ recipientError: null,
48
+ recipientWarning: null,
49
+ });
50
+ api.getAccountByAddress.mockResolvedValue({ type: "empty" });
51
+ });
52
+ it("should return an error if the recipient is the same as the source address", async () => {
53
+ const transaction = { ...mockTransaction, recipient: mockAccount.freshAddress };
54
+ const result = await getTransactionStatus(mockAccount, transaction);
55
+ expect(result.errors.recipient).toBeInstanceOf(InvalidAddressBecauseDestinationIsAlsoSource);
56
+ });
57
+ it("should return an error if the amount is zero and useAllAmount is false", async () => {
58
+ const transaction = { ...mockTransaction, amount: new BigNumber(0) };
59
+ const result = await getTransactionStatus(mockAccount, transaction);
60
+ expect(result.errors.amount).toBeInstanceOf(AmountRequired);
61
+ });
62
+ it("should return a warning if the fees are too high compared to the amount", async () => {
63
+ const transaction = { ...mockTransaction, amount: new BigNumber(1000) };
64
+ const result = await getTransactionStatus(mockAccount, transaction);
65
+ expect(result.warnings.feeTooHigh).toBeInstanceOf(FeeTooHigh);
66
+ });
67
+ it("should return a warning if the balance after transaction is below the threshold", async () => {
68
+ isAccountDelegating.mockReturnValue(true);
69
+ const transaction = { ...mockTransaction, amount: new BigNumber(999000) };
70
+ const result = await getTransactionStatus(mockAccount, transaction);
71
+ expect(result.warnings.amount).toBeInstanceOf(RecommendUndelegation);
72
+ });
73
+ it("should map taquito errors to appropriate errors", async () => {
74
+ const transaction = { ...mockTransaction, taquitoError: "balance_too_low" };
75
+ const result = await getTransactionStatus(mockAccount, transaction);
76
+ expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
77
+ });
78
+ it("should return an error if the account balance is zero or less", async () => {
79
+ const account = { ...mockAccount, balance: new BigNumber(0) };
80
+ const result = await getTransactionStatus(account, mockTransaction);
81
+ expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
82
+ });
83
+ it("should return an error if the account balance is less than the estimated fees for delegation", async () => {
84
+ const transaction = { ...mockTransaction, mode: "delegate" };
85
+ const account = { ...mockAccount, balance: new BigNumber(500) };
86
+ const result = await getTransactionStatus(account, transaction);
87
+ expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
88
+ });
89
+ it("should return an error if the recipient account is empty and the amount is below the existential deposit", async () => {
90
+ const transaction = { ...mockTransaction, amount: new BigNumber(100000) };
91
+ const result = await getTransactionStatus(mockAccount, transaction);
92
+ expect(result.errors.amount).toBeInstanceOf(NotEnoughBalanceBecauseDestinationNotCreated);
93
+ });
94
+ it("should return no errors or warnings for a valid transaction", async () => {
95
+ const account = { ...mockAccount, balance: new BigNumber(2000000) };
96
+ const transaction = { ...mockTransaction, amount: new BigNumber(500000) };
97
+ const result = await getTransactionStatus(account, transaction);
98
+ expect(result.errors).toEqual({});
99
+ expect(result.warnings).toEqual({});
100
+ });
101
+ });
102
+ //# sourceMappingURL=getTransactionStatus.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTransactionStatus.test.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { CoinConfig } from "@ledgerhq/coin-framework/config";
2
+ import { SignerContext } from "@ledgerhq/coin-framework/signer";
3
+ import type { CurrencyBridge, AccountBridge } from "@ledgerhq/types-live";
4
+ import type { TezosAccount, TezosSigner, Transaction } from "../types";
5
+ import { TezosCoinConfig } from "../config";
6
+ export declare function createBridges(signerContext: SignerContext<TezosSigner>, coinConfig: CoinConfig<TezosCoinConfig>): {
7
+ currencyBridge: CurrencyBridge;
8
+ accountBridge: AccountBridge<Transaction, TezosAccount, import("@ledgerhq/types-live").TransactionStatusCommon>;
9
+ };
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAqB,MAAM,UAAU,CAAC;AAW1F,OAAwB,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AA0C7D,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,WAAW,CAAC,EACzC,UAAU,EAAE,UAAU,CAAC,eAAe,CAAC;;;EAQxC"}
@@ -0,0 +1,53 @@
1
+ import { getSerializedAddressParameters, updateTransaction, makeAccountBridgeReceive, makeScanAccounts, } from "@ledgerhq/coin-framework/bridge/jsHelpers";
2
+ import getAddressWrapper from "@ledgerhq/coin-framework/bridge/getAddressWrapper";
3
+ import { assignFromAccountRaw, assignToAccountRaw } from "./serialization";
4
+ import { getPreloadStrategy, hydrate, preload } from "./preload";
5
+ import { estimateMaxSpendable } from "./estimateMaxSpendable";
6
+ import { getTransactionStatus } from "./getTransactionStatus";
7
+ import { prepareTransaction } from "./prepareTransaction";
8
+ import { getAccountShape, sync } from "./synchronization";
9
+ import { createTransaction } from "./createTransaction";
10
+ import { buildSignOperation } from "./signOperation";
11
+ import signerGetAddress from "../signer";
12
+ import { broadcast } from "./broadcast";
13
+ import tezosCoinConfig from "../config";
14
+ function buildCurrencyBridge(signerContext) {
15
+ const getAddress = signerGetAddress(signerContext);
16
+ const scanAccounts = makeScanAccounts({
17
+ getAccountShape,
18
+ getAddressFn: getAddressWrapper(getAddress),
19
+ });
20
+ return {
21
+ getPreloadStrategy,
22
+ preload,
23
+ hydrate,
24
+ scanAccounts,
25
+ };
26
+ }
27
+ function buildAccountBridge(signerContext) {
28
+ const getAddress = signerGetAddress(signerContext);
29
+ const receive = makeAccountBridgeReceive(getAddressWrapper(getAddress));
30
+ const signOperation = buildSignOperation(signerContext);
31
+ return {
32
+ estimateMaxSpendable,
33
+ createTransaction,
34
+ updateTransaction,
35
+ getTransactionStatus,
36
+ prepareTransaction,
37
+ sync,
38
+ receive,
39
+ signOperation,
40
+ broadcast,
41
+ assignFromAccountRaw,
42
+ assignToAccountRaw,
43
+ getSerializedAddressParameters,
44
+ };
45
+ }
46
+ export function createBridges(signerContext, coinConfig) {
47
+ tezosCoinConfig.setCoinConfig(coinConfig);
48
+ return {
49
+ currencyBridge: buildCurrencyBridge(signerContext),
50
+ accountBridge: buildAccountBridge(signerContext),
51
+ };
52
+ }
53
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,iBAAiB,EACjB,wBAAwB,EACxB,gBAAgB,GACjB,MAAM,2CAA2C,CAAC;AAInD,OAAO,iBAAiB,MAAM,mDAAmD,CAAC;AAElF,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,gBAAgB,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,eAAoC,MAAM,WAAW,CAAC;AAE7D,SAAS,mBAAmB,CAAC,aAAyC;IACpE,MAAM,UAAU,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,gBAAgB,CAAC;QACpC,eAAe;QACf,YAAY,EAAE,iBAAiB,CAAC,UAAU,CAAC;KAC5C,CAAC,CAAC;IAEH,OAAO;QACL,kBAAkB;QAClB,OAAO;QACP,OAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CACzB,aAAyC;IAEzC,MAAM,UAAU,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,wBAAwB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB;QACpB,iBAAiB;QACjB,iBAAiB;QACjB,oBAAoB;QACpB,kBAAkB;QAClB,IAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS;QACT,oBAAoB;QACpB,kBAAkB;QAClB,8BAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,aAAyC,EACzC,UAAuC;IAEvC,eAAe,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAE1C,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { type APIOperation } from "../network/types";
2
+ import { TezosAccount, TezosOperation } from "../types";
3
+ export declare const txToOp: ({ address, accountId }: {
4
+ address: string;
5
+ accountId: string;
6
+ }) => (tx: APIOperation) => TezosOperation | null | undefined;
7
+ export declare function reconciliatePublicKey(publicKey: string | undefined, account: TezosAccount | undefined): string;
8
+ export declare function encodeAddress(publicKey: Buffer): string;
9
+ export declare function isStringHex(s: string): boolean;
10
+ //# sourceMappingURL=logic.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logic.d.ts","sourceRoot":"","sources":["../../src/bridge/logic.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAExD,eAAO,MAAM,MAAM,2BACQ;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,UAC1D,YAAY,KAAG,cAAc,GAAG,IAAI,GAAG,SAqH3C,CAAC;AAEJ,wBAAgB,qBAAqB,CACnC,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,EAAE,YAAY,GAAG,SAAS,GAChC,MAAM,CAOR;AAED,wBAAgB,aAAa,CAAC,SAAS,EAAE,MAAM,UAiB9C;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAS9C"}