@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
@@ -0,0 +1,36 @@
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 bridge_fixture_1 = require("../types/bridge.fixture");
7
+ const config_1 = __importDefault(require("../config"));
8
+ const broadcast_1 = require("./broadcast");
9
+ const config_2 = require("../test/config");
10
+ const mockInjectOperation = jest.fn();
11
+ jest.mock("@taquito/taquito", () => ({
12
+ TezosToolkit: jest.fn().mockReturnValue({
13
+ rpc: {
14
+ injectOperation: () => mockInjectOperation(),
15
+ },
16
+ }),
17
+ }));
18
+ describe("broadcast", () => {
19
+ beforeAll(() => {
20
+ config_1.default.setCoinConfig(() => config_2.mockConfig);
21
+ });
22
+ it("calls 'injectOperation' from TezosToolkit and returns its hash computation", async () => {
23
+ // GIVEN
24
+ const signedOperation = {
25
+ operation: (0, bridge_fixture_1.createFixtureOperation)(),
26
+ signature: "SIGNATURE",
27
+ };
28
+ mockInjectOperation.mockResolvedValue("SIGN_HASH");
29
+ // WHEN
30
+ const op = await (0, broadcast_1.broadcast)({ signedOperation, account: {} });
31
+ // THEN
32
+ expect(mockInjectOperation).toHaveBeenCalledTimes(1);
33
+ expect(op.hash).toEqual("SIGN_HASH");
34
+ });
35
+ });
36
+ //# 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,4DAAiE;AACjE,uDAAyD;AACzD,2CAAwC;AACxC,2CAA4C;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,gBAAM,CAAC,aAAa,CAAC,GAAoB,EAAE,CAAC,mBAA6B,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,QAAQ;QACR,MAAM,eAAe,GAAoB;YACvC,SAAS,EAAE,IAAA,uCAAsB,GAAE;YACnC,SAAS,EAAE,WAAW;SACvB,CAAC;QACF,mBAAmB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEnD,OAAO;QACP,MAAM,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,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,28 @@
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.buildOptimisticOperation = void 0;
7
+ const operation_1 = require("@ledgerhq/coin-framework/operation");
8
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
+ const buildOptimisticOperation = (account, transaction, operationType) => {
10
+ const txHash = ""; // resolved at broadcast time
11
+ const { id: accountId } = account;
12
+ return {
13
+ id: (0, operation_1.encodeOperationId)(accountId, txHash, operationType),
14
+ hash: txHash,
15
+ type: operationType,
16
+ value: transaction.amount,
17
+ fee: transaction.fees || new bignumber_js_1.default(0),
18
+ extra: {},
19
+ blockHash: null,
20
+ blockHeight: null,
21
+ senders: [account.freshAddress],
22
+ recipients: [transaction.recipient],
23
+ accountId,
24
+ date: new Date(),
25
+ };
26
+ };
27
+ exports.buildOptimisticOperation = buildOptimisticOperation;
28
+ //# sourceMappingURL=buildOptimisticOperation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":";;;;;;AACA,kEAAuE;AAEvE,gEAAqC;AAE9B,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,IAAA,6BAAiB,EAAC,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,sBAAS,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;AAtBW,QAAA,wBAAwB,4BAsBnC"}
@@ -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,24 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.createTransaction = void 0;
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ const createTransaction = () => {
9
+ return {
10
+ family: "tezos",
11
+ mode: "send",
12
+ amount: new bignumber_js_1.default(0),
13
+ fees: null,
14
+ gasLimit: null,
15
+ storageLimit: null,
16
+ recipient: "",
17
+ networkInfo: null,
18
+ useAllAmount: false,
19
+ taquitoError: null,
20
+ estimatedFees: null,
21
+ };
22
+ };
23
+ exports.createTransaction = createTransaction;
24
+ //# sourceMappingURL=createTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAI9B,MAAM,iBAAiB,GAAoD,GAAG,EAAE;IACrF,OAAO;QACL,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,sBAAS,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;AAdW,QAAA,iBAAiB,qBAc5B"}
@@ -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,30 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.estimateMaxSpendable = void 0;
7
+ const index_1 = require("@ledgerhq/coin-framework/account/index");
8
+ const prepareTransaction_1 = require("./prepareTransaction");
9
+ const createTransaction_1 = require("./createTransaction");
10
+ const getFeesForTransaction_1 = __importDefault(require("./getFeesForTransaction"));
11
+ const TEZOS_BURN_ADDRESS = "tz1burnburnburnburnburnburnburjAYjjX";
12
+ const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
13
+ const mainAccount = (0, index_1.getMainAccount)(account, parentAccount);
14
+ const tx = await (0, prepareTransaction_1.prepareTransaction)(mainAccount, {
15
+ ...(0, createTransaction_1.createTransaction)(account),
16
+ ...transaction,
17
+ // estimate using a burn address that exists so we don't enter into NotEnoughBalanceBecauseDestinationNotCreated
18
+ recipient: transaction?.recipient || TEZOS_BURN_ADDRESS,
19
+ useAllAmount: true,
20
+ });
21
+ const estimation = await (0, getFeesForTransaction_1.default)({
22
+ account: mainAccount,
23
+ transaction: tx,
24
+ });
25
+ // As we use `useAllAmount`, we know we will receive an amount value.
26
+ return estimation.amount;
27
+ };
28
+ exports.estimateMaxSpendable = estimateMaxSpendable;
29
+ exports.default = exports.estimateMaxSpendable;
30
+ //# sourceMappingURL=estimateMaxSpendable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;;AAEA,kEAAwE;AAExE,6DAA0D;AAC1D,2DAAwD;AACxD,oFAAuD;AAEvD,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AAE3D,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GAKZ,EAAsB,EAAE;IACvB,MAAM,WAAW,GAAG,IAAA,sBAAc,EAAC,OAAO,EAAE,aAAa,CAAiB,CAAC;IAC3E,MAAM,EAAE,GAAG,MAAM,IAAA,uCAAkB,EAAC,WAAW,EAAE;QAC/C,GAAG,IAAA,qCAAiB,EAAC,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,IAAA,+BAAgB,EAAC;QACxC,OAAO,EAAE,WAAW;QACpB,WAAW,EAAE,EAAE;KAChB,CAAC,CAAC;IAEH,qEAAqE;IACrE,OAAO,UAAU,CAAC,MAAO,CAAC;AAC5B,CAAC,CAAC;AAxBW,QAAA,oBAAoB,wBAwB/B;AAEF,kBAAe,4BAAoB,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,39 @@
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.default = getEstimatedFees;
7
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
+ const logic_1 = require("../logic");
9
+ /**
10
+ * Fetch the transaction fees for a transaction
11
+ *
12
+ * @param {Account} a
13
+ * @param {Transaction} t
14
+ */
15
+ async function getEstimatedFees({ account, transaction, }) {
16
+ const estimate = await (0, logic_1.estimateFees)({
17
+ account: {
18
+ xpub: account.xpub,
19
+ address: account.freshAddress,
20
+ balance: BigInt(account.balance.toString()),
21
+ revealed: account.tezosResources.revealed,
22
+ },
23
+ transaction: {
24
+ mode: transaction.mode,
25
+ recipient: transaction.recipient,
26
+ amount: BigInt(transaction.amount.toString()),
27
+ useAllAmount: transaction.useAllAmount,
28
+ },
29
+ });
30
+ return {
31
+ fees: (0, bignumber_js_1.default)(estimate.fees.toString()),
32
+ gasLimit: (0, bignumber_js_1.default)(estimate.gasLimit.toString()),
33
+ storageLimit: (0, bignumber_js_1.default)(estimate.storageLimit.toString()),
34
+ estimatedFees: (0, bignumber_js_1.default)(estimate.estimatedFees.toString()),
35
+ amount: estimate.amount !== undefined ? (0, bignumber_js_1.default)(estimate.amount.toString()) : (0, bignumber_js_1.default)(0),
36
+ taquitoError: estimate.taquitoError,
37
+ };
38
+ }
39
+ //# sourceMappingURL=getFeesForTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFeesForTransaction.js","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":";;;;;AAkBA,mCA8BC;AAhDD,gEAAqC;AAErC,oCAAwC;AAUxC;;;;;GAKG;AACY,KAAK,UAAU,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GAIZ;IACC,MAAM,QAAQ,GAAG,MAAM,IAAA,oBAAY,EAAC;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,IAAA,sBAAS,EAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzC,QAAQ,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACjD,YAAY,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACzD,aAAa,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,IAAA,sBAAS,EAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAA,sBAAS,EAAC,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,108 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getTransactionStatus = void 0;
7
+ const errors_1 = require("@ledgerhq/errors");
8
+ const logs_1 = require("@ledgerhq/logs");
9
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
+ const errors_2 = require("../types/errors");
11
+ const logic_1 = require("../logic");
12
+ const bakers_1 = require("../network/bakers");
13
+ const tzkt_1 = __importDefault(require("../network/tzkt"));
14
+ const EXISTENTIAL_DEPOSIT = new bignumber_js_1.default(275000);
15
+ const getTransactionStatus = async (account, transaction) => {
16
+ const errors = {};
17
+ const warnings = {};
18
+ let resetTotalSpent = false;
19
+ // Recipient validation logic
20
+ if (transaction.mode !== "undelegate") {
21
+ if (account.freshAddress === transaction.recipient) {
22
+ errors.recipient = new errors_1.InvalidAddressBecauseDestinationIsAlsoSource();
23
+ }
24
+ else {
25
+ const { recipientError, recipientWarning } = await (0, logic_1.validateRecipient)(transaction.recipient);
26
+ if (recipientError) {
27
+ errors.recipient = recipientError;
28
+ }
29
+ if (recipientWarning) {
30
+ warnings.recipient = recipientWarning;
31
+ }
32
+ }
33
+ }
34
+ // Pre validation of amount field
35
+ const estimatedFees = transaction.estimatedFees || new bignumber_js_1.default(0);
36
+ if (transaction.mode === "send") {
37
+ if (!errors.amount && transaction.amount.eq(0) && !transaction.useAllAmount) {
38
+ resetTotalSpent = true;
39
+ errors.amount = new errors_1.AmountRequired();
40
+ }
41
+ else if (transaction.amount.gt(0) && estimatedFees.times(10).gt(transaction.amount)) {
42
+ warnings.feeTooHigh = new errors_1.FeeTooHigh();
43
+ }
44
+ const thresholdWarning = 0.5 * 10 ** account.currency.units[0].magnitude;
45
+ if (!errors.amount &&
46
+ account.balance.minus(transaction.amount).minus(estimatedFees).lt(thresholdWarning)) {
47
+ if ((0, bakers_1.isAccountDelegating)(account)) {
48
+ if (transaction.useAllAmount) {
49
+ errors.amount = new errors_1.RecommendUndelegation();
50
+ }
51
+ else {
52
+ warnings.amount = new errors_1.RecommendUndelegation();
53
+ }
54
+ }
55
+ }
56
+ }
57
+ // effective amount
58
+ // if we also have taquitoError, we interprete them and they override the previously inferred errors
59
+ if (transaction.taquitoError) {
60
+ (0, logs_1.log)("taquitoerror", String(transaction.taquitoError));
61
+ // remap taquito errors
62
+ if (transaction.taquitoError.endsWith("balance_too_low") ||
63
+ transaction.taquitoError.endsWith("subtraction_underflow")) {
64
+ if (transaction.mode === "send") {
65
+ resetTotalSpent = true;
66
+ errors.amount = new errors_1.NotEnoughBalance();
67
+ }
68
+ else {
69
+ errors.amount = new errors_1.NotEnoughBalanceToDelegate();
70
+ }
71
+ }
72
+ else if (transaction.taquitoError.endsWith("delegate.unchanged")) {
73
+ errors.recipient = new errors_2.InvalidAddressBecauseAlreadyDelegated();
74
+ }
75
+ else if (!errors.amount) {
76
+ // unidentified error case
77
+ errors.amount = new Error(transaction.taquitoError);
78
+ resetTotalSpent = true;
79
+ }
80
+ }
81
+ if (!errors.amount && account.balance.lte(0)) {
82
+ resetTotalSpent = true;
83
+ errors.amount = new errors_1.NotEnoughBalance();
84
+ }
85
+ if (!errors.amount && transaction.mode === "delegate" && account.balance.lte(estimatedFees)) {
86
+ resetTotalSpent = true;
87
+ errors.amount = new errors_1.NotEnoughBalance();
88
+ }
89
+ // Catch a specific case that requires a minimum amount
90
+ if (!errors.amount &&
91
+ transaction.mode === "send" &&
92
+ transaction.amount.lt(EXISTENTIAL_DEPOSIT) &&
93
+ (await tzkt_1.default.getAccountByAddress(transaction.recipient)).type === "empty") {
94
+ resetTotalSpent = true;
95
+ errors.amount = new errors_1.NotEnoughBalanceBecauseDestinationNotCreated("", {
96
+ minimalAmount: "0.275 XTZ",
97
+ });
98
+ }
99
+ return {
100
+ errors,
101
+ warnings,
102
+ estimatedFees,
103
+ amount: transaction.amount,
104
+ totalSpent: resetTotalSpent ? new bignumber_js_1.default(0) : transaction.amount.plus(estimatedFees),
105
+ };
106
+ };
107
+ exports.getTransactionStatus = getTransactionStatus;
108
+ //# 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,107 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
7
+ const getTransactionStatus_1 = require("./getTransactionStatus");
8
+ const logic_1 = require("../logic");
9
+ const bakers_1 = require("../network/bakers");
10
+ const tzkt_1 = __importDefault(require("../network/tzkt"));
11
+ const errors_1 = require("@ledgerhq/errors");
12
+ jest.mock("../logic", () => ({
13
+ validateRecipient: jest.fn(),
14
+ }));
15
+ jest.mock("../network/bakers", () => ({
16
+ isAccountDelegating: jest.fn(),
17
+ }));
18
+ jest.mock("../network/tzkt", () => ({
19
+ getAccountByAddress: jest.fn(),
20
+ }));
21
+ describe("getTransactionStatus", () => {
22
+ const mockAccount = {
23
+ type: "Account",
24
+ freshAddress: "tz1SourceAddress",
25
+ balance: new bignumber_js_1.default(1000000),
26
+ currency: {
27
+ type: "CryptoCurrency",
28
+ units: [
29
+ {
30
+ name: "tezos",
31
+ code: "XTZ",
32
+ magnitude: 6,
33
+ },
34
+ ],
35
+ },
36
+ tezosResources: {
37
+ revealed: true,
38
+ counter: 0,
39
+ },
40
+ };
41
+ const mockTransaction = {
42
+ family: "tezos",
43
+ mode: "send",
44
+ amount: new bignumber_js_1.default(500000),
45
+ recipient: "tz1RecipientAddress",
46
+ estimatedFees: new bignumber_js_1.default(1000),
47
+ useAllAmount: false,
48
+ };
49
+ beforeEach(() => {
50
+ jest.clearAllMocks();
51
+ logic_1.validateRecipient.mockResolvedValue({
52
+ recipientError: null,
53
+ recipientWarning: null,
54
+ });
55
+ tzkt_1.default.getAccountByAddress.mockResolvedValue({ type: "empty" });
56
+ });
57
+ it("should return an error if the recipient is the same as the source address", async () => {
58
+ const transaction = { ...mockTransaction, recipient: mockAccount.freshAddress };
59
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
60
+ expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddressBecauseDestinationIsAlsoSource);
61
+ });
62
+ it("should return an error if the amount is zero and useAllAmount is false", async () => {
63
+ const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(0) };
64
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
65
+ expect(result.errors.amount).toBeInstanceOf(errors_1.AmountRequired);
66
+ });
67
+ it("should return a warning if the fees are too high compared to the amount", async () => {
68
+ const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(1000) };
69
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
70
+ expect(result.warnings.feeTooHigh).toBeInstanceOf(errors_1.FeeTooHigh);
71
+ });
72
+ it("should return a warning if the balance after transaction is below the threshold", async () => {
73
+ bakers_1.isAccountDelegating.mockReturnValue(true);
74
+ const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(999000) };
75
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
76
+ expect(result.warnings.amount).toBeInstanceOf(errors_1.RecommendUndelegation);
77
+ });
78
+ it("should map taquito errors to appropriate errors", async () => {
79
+ const transaction = { ...mockTransaction, taquitoError: "balance_too_low" };
80
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
81
+ expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
82
+ });
83
+ it("should return an error if the account balance is zero or less", async () => {
84
+ const account = { ...mockAccount, balance: new bignumber_js_1.default(0) };
85
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, mockTransaction);
86
+ expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
87
+ });
88
+ it("should return an error if the account balance is less than the estimated fees for delegation", async () => {
89
+ const transaction = { ...mockTransaction, mode: "delegate" };
90
+ const account = { ...mockAccount, balance: new bignumber_js_1.default(500) };
91
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, transaction);
92
+ expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
93
+ });
94
+ it("should return an error if the recipient account is empty and the amount is below the existential deposit", async () => {
95
+ const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(100000) };
96
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
97
+ expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalanceBecauseDestinationNotCreated);
98
+ });
99
+ it("should return no errors or warnings for a valid transaction", async () => {
100
+ const account = { ...mockAccount, balance: new bignumber_js_1.default(2000000) };
101
+ const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(500000) };
102
+ const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, transaction);
103
+ expect(result.errors).toEqual({});
104
+ expect(result.warnings).toEqual({});
105
+ });
106
+ });
107
+ //# 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,59 @@
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.createBridges = createBridges;
7
+ const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
8
+ const getAddressWrapper_1 = __importDefault(require("@ledgerhq/coin-framework/bridge/getAddressWrapper"));
9
+ const serialization_1 = require("./serialization");
10
+ const preload_1 = require("./preload");
11
+ const estimateMaxSpendable_1 = require("./estimateMaxSpendable");
12
+ const getTransactionStatus_1 = require("./getTransactionStatus");
13
+ const prepareTransaction_1 = require("./prepareTransaction");
14
+ const synchronization_1 = require("./synchronization");
15
+ const createTransaction_1 = require("./createTransaction");
16
+ const signOperation_1 = require("./signOperation");
17
+ const signer_1 = __importDefault(require("../signer"));
18
+ const broadcast_1 = require("./broadcast");
19
+ const config_1 = __importDefault(require("../config"));
20
+ function buildCurrencyBridge(signerContext) {
21
+ const getAddress = (0, signer_1.default)(signerContext);
22
+ const scanAccounts = (0, jsHelpers_1.makeScanAccounts)({
23
+ getAccountShape: synchronization_1.getAccountShape,
24
+ getAddressFn: (0, getAddressWrapper_1.default)(getAddress),
25
+ });
26
+ return {
27
+ getPreloadStrategy: preload_1.getPreloadStrategy,
28
+ preload: preload_1.preload,
29
+ hydrate: preload_1.hydrate,
30
+ scanAccounts,
31
+ };
32
+ }
33
+ function buildAccountBridge(signerContext) {
34
+ const getAddress = (0, signer_1.default)(signerContext);
35
+ const receive = (0, jsHelpers_1.makeAccountBridgeReceive)((0, getAddressWrapper_1.default)(getAddress));
36
+ const signOperation = (0, signOperation_1.buildSignOperation)(signerContext);
37
+ return {
38
+ estimateMaxSpendable: estimateMaxSpendable_1.estimateMaxSpendable,
39
+ createTransaction: createTransaction_1.createTransaction,
40
+ updateTransaction: jsHelpers_1.updateTransaction,
41
+ getTransactionStatus: getTransactionStatus_1.getTransactionStatus,
42
+ prepareTransaction: prepareTransaction_1.prepareTransaction,
43
+ sync: synchronization_1.sync,
44
+ receive,
45
+ signOperation,
46
+ broadcast: broadcast_1.broadcast,
47
+ assignFromAccountRaw: serialization_1.assignFromAccountRaw,
48
+ assignToAccountRaw: serialization_1.assignToAccountRaw,
49
+ getSerializedAddressParameters: jsHelpers_1.getSerializedAddressParameters,
50
+ };
51
+ }
52
+ function createBridges(signerContext, coinConfig) {
53
+ config_1.default.setCoinConfig(coinConfig);
54
+ return {
55
+ currencyBridge: buildCurrencyBridge(signerContext),
56
+ accountBridge: buildAccountBridge(signerContext),
57
+ };
58
+ }
59
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;AA+DA,sCAUC;AAzED,yEAKmD;AAInD,0GAAkF;AAElF,mDAA2E;AAC3E,uCAAiE;AACjE,iEAA8D;AAC9D,iEAA8D;AAC9D,6DAA0D;AAC1D,uDAA0D;AAC1D,2DAAwD;AACxD,mDAAqD;AACrD,uDAAyC;AACzC,2CAAwC;AACxC,uDAA6D;AAE7D,SAAS,mBAAmB,CAAC,aAAyC;IACpE,MAAM,UAAU,GAAG,IAAA,gBAAgB,EAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,IAAA,4BAAgB,EAAC;QACpC,eAAe,EAAf,iCAAe;QACf,YAAY,EAAE,IAAA,2BAAiB,EAAC,UAAU,CAAC;KAC5C,CAAC,CAAC;IAEH,OAAO;QACL,kBAAkB,EAAlB,4BAAkB;QAClB,OAAO,EAAP,iBAAO;QACP,OAAO,EAAP,iBAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CACzB,aAAyC;IAEzC,MAAM,UAAU,GAAG,IAAA,gBAAgB,EAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,IAAA,oCAAwB,EAAC,IAAA,2BAAiB,EAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,IAAA,kCAAkB,EAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB,EAApB,2CAAoB;QACpB,iBAAiB,EAAjB,qCAAiB;QACjB,iBAAiB,EAAjB,6BAAiB;QACjB,oBAAoB,EAApB,2CAAoB;QACpB,kBAAkB,EAAlB,uCAAkB;QAClB,IAAI,EAAJ,sBAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS,EAAT,qBAAS;QACT,oBAAoB,EAApB,oCAAoB;QACpB,kBAAkB,EAAlB,kCAAkB;QAClB,8BAA8B,EAA9B,0CAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,SAAgB,aAAa,CAC3B,aAAyC,EACzC,UAAuC;IAEvC,gBAAe,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"}