@atomiqlabs/chain-starknet 3.0.0-dev.8 → 4.0.0-dev.3

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 (146) hide show
  1. package/LICENSE +201 -201
  2. package/dist/index.d.ts +38 -38
  3. package/dist/index.js +54 -54
  4. package/dist/starknet/StarknetChainType.d.ts +13 -13
  5. package/dist/starknet/StarknetChainType.js +2 -2
  6. package/dist/starknet/StarknetInitializer.d.ts +27 -19
  7. package/dist/starknet/StarknetInitializer.js +69 -69
  8. package/dist/starknet/btcrelay/BtcRelayAbi.d.ts +250 -250
  9. package/dist/starknet/btcrelay/BtcRelayAbi.js +341 -341
  10. package/dist/starknet/btcrelay/StarknetBtcRelay.d.ts +186 -186
  11. package/dist/starknet/btcrelay/StarknetBtcRelay.js +379 -379
  12. package/dist/starknet/btcrelay/headers/StarknetBtcHeader.d.ts +31 -31
  13. package/dist/starknet/btcrelay/headers/StarknetBtcHeader.js +74 -74
  14. package/dist/starknet/btcrelay/headers/StarknetBtcStoredHeader.d.ts +51 -51
  15. package/dist/starknet/btcrelay/headers/StarknetBtcStoredHeader.js +113 -113
  16. package/dist/starknet/chain/StarknetAction.d.ts +19 -19
  17. package/dist/starknet/chain/StarknetAction.js +73 -73
  18. package/dist/starknet/chain/StarknetChainInterface.d.ts +52 -52
  19. package/dist/starknet/chain/StarknetChainInterface.js +91 -91
  20. package/dist/starknet/chain/StarknetModule.d.ts +14 -14
  21. package/dist/starknet/chain/StarknetModule.js +13 -13
  22. package/dist/starknet/chain/modules/ERC20Abi.d.ts +755 -755
  23. package/dist/starknet/chain/modules/ERC20Abi.js +1032 -1032
  24. package/dist/starknet/chain/modules/StarknetAccounts.d.ts +6 -6
  25. package/dist/starknet/chain/modules/StarknetAccounts.js +24 -24
  26. package/dist/starknet/chain/modules/StarknetAddresses.d.ts +9 -9
  27. package/dist/starknet/chain/modules/StarknetAddresses.js +26 -26
  28. package/dist/starknet/chain/modules/StarknetBlocks.d.ts +20 -19
  29. package/dist/starknet/chain/modules/StarknetBlocks.js +64 -49
  30. package/dist/starknet/chain/modules/StarknetEvents.d.ts +44 -44
  31. package/dist/starknet/chain/modules/StarknetEvents.js +88 -88
  32. package/dist/starknet/chain/modules/StarknetFees.d.ts +77 -77
  33. package/dist/starknet/chain/modules/StarknetFees.js +114 -114
  34. package/dist/starknet/chain/modules/StarknetSignatures.d.ts +29 -29
  35. package/dist/starknet/chain/modules/StarknetSignatures.js +72 -72
  36. package/dist/starknet/chain/modules/StarknetTokens.d.ts +69 -69
  37. package/dist/starknet/chain/modules/StarknetTokens.js +98 -98
  38. package/dist/starknet/chain/modules/StarknetTransactions.d.ts +93 -93
  39. package/dist/starknet/chain/modules/StarknetTransactions.js +255 -255
  40. package/dist/starknet/contract/StarknetContractBase.d.ts +13 -13
  41. package/dist/starknet/contract/StarknetContractBase.js +16 -16
  42. package/dist/starknet/contract/StarknetContractModule.d.ts +8 -8
  43. package/dist/starknet/contract/StarknetContractModule.js +11 -11
  44. package/dist/starknet/contract/modules/StarknetContractEvents.d.ts +51 -51
  45. package/dist/starknet/contract/modules/StarknetContractEvents.js +97 -97
  46. package/dist/starknet/events/StarknetChainEvents.d.ts +21 -21
  47. package/dist/starknet/events/StarknetChainEvents.js +52 -52
  48. package/dist/starknet/events/StarknetChainEventsBrowser.d.ts +90 -91
  49. package/dist/starknet/events/StarknetChainEventsBrowser.js +292 -294
  50. package/dist/starknet/provider/RpcProviderWithRetries.d.ts +21 -21
  51. package/dist/starknet/provider/RpcProviderWithRetries.js +32 -32
  52. package/dist/starknet/spv_swap/SpvVaultContractAbi.d.ts +488 -488
  53. package/dist/starknet/spv_swap/SpvVaultContractAbi.js +656 -656
  54. package/dist/starknet/spv_swap/StarknetSpvVaultContract.d.ts +66 -65
  55. package/dist/starknet/spv_swap/StarknetSpvVaultContract.js +382 -376
  56. package/dist/starknet/spv_swap/StarknetSpvVaultData.d.ts +49 -49
  57. package/dist/starknet/spv_swap/StarknetSpvVaultData.js +145 -144
  58. package/dist/starknet/spv_swap/StarknetSpvWithdrawalData.d.ts +25 -24
  59. package/dist/starknet/spv_swap/StarknetSpvWithdrawalData.js +72 -61
  60. package/dist/starknet/swaps/EscrowManagerAbi.d.ts +434 -434
  61. package/dist/starknet/swaps/EscrowManagerAbi.js +587 -587
  62. package/dist/starknet/swaps/StarknetSwapContract.d.ts +190 -196
  63. package/dist/starknet/swaps/StarknetSwapContract.js +409 -395
  64. package/dist/starknet/swaps/StarknetSwapData.d.ts +67 -67
  65. package/dist/starknet/swaps/StarknetSwapData.js +290 -290
  66. package/dist/starknet/swaps/StarknetSwapModule.d.ts +10 -10
  67. package/dist/starknet/swaps/StarknetSwapModule.js +11 -11
  68. package/dist/starknet/swaps/handlers/IHandler.d.ts +13 -13
  69. package/dist/starknet/swaps/handlers/IHandler.js +2 -2
  70. package/dist/starknet/swaps/handlers/claim/ClaimHandlers.d.ts +13 -13
  71. package/dist/starknet/swaps/handlers/claim/ClaimHandlers.js +13 -13
  72. package/dist/starknet/swaps/handlers/claim/HashlockClaimHandler.d.ts +21 -21
  73. package/dist/starknet/swaps/handlers/claim/HashlockClaimHandler.js +44 -44
  74. package/dist/starknet/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  75. package/dist/starknet/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +48 -48
  76. package/dist/starknet/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  77. package/dist/starknet/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +40 -40
  78. package/dist/starknet/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +20 -20
  79. package/dist/starknet/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +30 -30
  80. package/dist/starknet/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +45 -45
  81. package/dist/starknet/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +52 -52
  82. package/dist/starknet/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  83. package/dist/starknet/swaps/handlers/refund/TimelockRefundHandler.js +27 -27
  84. package/dist/starknet/swaps/modules/StarknetLpVault.d.ts +69 -69
  85. package/dist/starknet/swaps/modules/StarknetLpVault.js +122 -122
  86. package/dist/starknet/swaps/modules/StarknetSwapClaim.d.ts +53 -53
  87. package/dist/starknet/swaps/modules/StarknetSwapClaim.js +100 -100
  88. package/dist/starknet/swaps/modules/StarknetSwapInit.d.ts +86 -84
  89. package/dist/starknet/swaps/modules/StarknetSwapInit.js +224 -200
  90. package/dist/starknet/swaps/modules/StarknetSwapRefund.d.ts +62 -62
  91. package/dist/starknet/swaps/modules/StarknetSwapRefund.js +128 -128
  92. package/dist/starknet/wallet/StarknetKeypairWallet.d.ts +7 -7
  93. package/dist/starknet/wallet/StarknetKeypairWallet.js +30 -30
  94. package/dist/starknet/wallet/StarknetSigner.d.ts +12 -12
  95. package/dist/starknet/wallet/StarknetSigner.js +46 -46
  96. package/dist/utils/Utils.d.ts +37 -37
  97. package/dist/utils/Utils.js +261 -257
  98. package/package.json +37 -37
  99. package/src/index.ts +47 -47
  100. package/src/starknet/StarknetChainType.ts +28 -28
  101. package/src/starknet/StarknetInitializer.ts +108 -100
  102. package/src/starknet/btcrelay/BtcRelayAbi.ts +338 -338
  103. package/src/starknet/btcrelay/StarknetBtcRelay.ts +494 -494
  104. package/src/starknet/btcrelay/headers/StarknetBtcHeader.ts +100 -100
  105. package/src/starknet/btcrelay/headers/StarknetBtcStoredHeader.ts +141 -141
  106. package/src/starknet/chain/StarknetAction.ts +85 -85
  107. package/src/starknet/chain/StarknetChainInterface.ts +149 -149
  108. package/src/starknet/chain/StarknetModule.ts +19 -19
  109. package/src/starknet/chain/modules/ERC20Abi.ts +1029 -1029
  110. package/src/starknet/chain/modules/StarknetAccounts.ts +25 -25
  111. package/src/starknet/chain/modules/StarknetAddresses.ts +22 -22
  112. package/src/starknet/chain/modules/StarknetBlocks.ts +74 -58
  113. package/src/starknet/chain/modules/StarknetEvents.ts +104 -104
  114. package/src/starknet/chain/modules/StarknetFees.ts +154 -154
  115. package/src/starknet/chain/modules/StarknetSignatures.ts +91 -91
  116. package/src/starknet/chain/modules/StarknetTokens.ts +116 -116
  117. package/src/starknet/chain/modules/StarknetTransactions.ts +277 -277
  118. package/src/starknet/contract/StarknetContractBase.ts +26 -26
  119. package/src/starknet/contract/StarknetContractModule.ts +16 -16
  120. package/src/starknet/contract/modules/StarknetContractEvents.ts +134 -134
  121. package/src/starknet/events/StarknetChainEvents.ts +67 -67
  122. package/src/starknet/events/StarknetChainEventsBrowser.ts +410 -412
  123. package/src/starknet/provider/RpcProviderWithRetries.ts +43 -43
  124. package/src/starknet/spv_swap/SpvVaultContractAbi.ts +656 -656
  125. package/src/starknet/spv_swap/StarknetSpvVaultContract.ts +483 -477
  126. package/src/starknet/spv_swap/StarknetSpvVaultData.ts +195 -194
  127. package/src/starknet/spv_swap/StarknetSpvWithdrawalData.ts +79 -68
  128. package/src/starknet/swaps/EscrowManagerAbi.ts +586 -586
  129. package/src/starknet/swaps/StarknetSwapContract.ts +628 -605
  130. package/src/starknet/swaps/StarknetSwapData.ts +403 -403
  131. package/src/starknet/swaps/StarknetSwapModule.ts +17 -17
  132. package/src/starknet/swaps/handlers/IHandler.ts +20 -20
  133. package/src/starknet/swaps/handlers/claim/ClaimHandlers.ts +23 -23
  134. package/src/starknet/swaps/handlers/claim/HashlockClaimHandler.ts +53 -53
  135. package/src/starknet/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +73 -73
  136. package/src/starknet/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +67 -67
  137. package/src/starknet/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +50 -50
  138. package/src/starknet/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +102 -102
  139. package/src/starknet/swaps/handlers/refund/TimelockRefundHandler.ts +38 -38
  140. package/src/starknet/swaps/modules/StarknetLpVault.ts +147 -147
  141. package/src/starknet/swaps/modules/StarknetSwapClaim.ts +141 -141
  142. package/src/starknet/swaps/modules/StarknetSwapInit.ts +286 -260
  143. package/src/starknet/swaps/modules/StarknetSwapRefund.ts +196 -196
  144. package/src/starknet/wallet/StarknetKeypairWallet.ts +39 -39
  145. package/src/starknet/wallet/StarknetSigner.ts +55 -55
  146. package/src/utils/Utils.ts +252 -248
@@ -1,395 +1,409 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StarknetSwapContract = void 0;
4
- const base_1 = require("@atomiqlabs/base");
5
- const buffer_1 = require("buffer");
6
- const EscrowManagerAbi_1 = require("./EscrowManagerAbi");
7
- const StarknetContractBase_1 = require("../contract/StarknetContractBase");
8
- const starknet_1 = require("starknet");
9
- const StarknetSwapData_1 = require("./StarknetSwapData");
10
- const Utils_1 = require("../../utils/Utils");
11
- const TimelockRefundHandler_1 = require("./handlers/refund/TimelockRefundHandler");
12
- const StarknetLpVault_1 = require("./modules/StarknetLpVault");
13
- const StarknetSwapInit_1 = require("./modules/StarknetSwapInit");
14
- const StarknetSwapRefund_1 = require("./modules/StarknetSwapRefund");
15
- const ClaimHandlers_1 = require("./handlers/claim/ClaimHandlers");
16
- const StarknetSwapClaim_1 = require("./modules/StarknetSwapClaim");
17
- const sha2_1 = require("@noble/hashes/sha2");
18
- const ESCROW_STATE_COMMITTED = 1;
19
- const ESCROW_STATE_CLAIMED = 2;
20
- const ESCROW_STATE_REFUNDED = 3;
21
- const swapContractAddreses = {
22
- [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: "0x030ae7fc7bbce9b8c888b1117f5573c786dd8e1541c722227b8673ac7dda70c0",
23
- [starknet_1.constants.StarknetChainId.SN_MAIN]: "0x02e1070519f27ec94dde395c8d72a5fcb144d40a786cf60b9b45395d36cc2f69"
24
- };
25
- const defaultClaimAddresses = {
26
- [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: {
27
- [base_1.ChainSwapType.HTLC]: "0x04a57ea54d4637c352aad1bbee046868926a11702216a0aaf7eeec1568be2d7b",
28
- [base_1.ChainSwapType.CHAIN_TXID]: "0x04c7cde88359e14b6f6f779f8b9d8310cee37e91a6f143f855ae29fab33c396e",
29
- [base_1.ChainSwapType.CHAIN]: "0x051bef6f5fd12e2832a7d38653bdfc8eb84ba7eb7a4aada5b87ef38a9999cf17",
30
- [base_1.ChainSwapType.CHAIN_NONCED]: "0x050e50eacd16da414f2c3a7c3570fd5e248974c6fe757d41acbf72d2836fa0a1"
31
- },
32
- [starknet_1.constants.StarknetChainId.SN_MAIN]: {
33
- [base_1.ChainSwapType.HTLC]: "0x07b74b50a883ebee262b6db0e3c0c697670c6f30e3d610e75faf33a89c46aa2a",
34
- [base_1.ChainSwapType.CHAIN_TXID]: "0x016c2db2b03f39cf4fd7f871035000f66b62307d9983056e33a38315da8a44dc",
35
- [base_1.ChainSwapType.CHAIN]: "0x02c45a81c4a48d0645a0a199e620061e8a55dcc9c2b5946d050eaeeddba64e9a",
36
- [base_1.ChainSwapType.CHAIN_NONCED]: "0x0019b5480dd7ed8ded10a09437b0a7a30b8997b4ef139deb24ff8c86f995d84f"
37
- }
38
- };
39
- const defaultRefundAddresses = {
40
- [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: {
41
- timelock: "0x034b8f28b3ca979036cb2849cfa3af7f67207459224b6ca5ce2474aa398ec3e7"
42
- },
43
- [starknet_1.constants.StarknetChainId.SN_MAIN]: {
44
- timelock: "0x06a59659990c2aefbf7239f6d911617b3ae60b79cb3364f3bd242a6ca8f4f4f7"
45
- }
46
- };
47
- class StarknetSwapContract extends StarknetContractBase_1.StarknetContractBase {
48
- constructor(chainInterface, btcRelay, contractAddress = swapContractAddreses[chainInterface.starknetChainId], handlerAddresses) {
49
- super(chainInterface, contractAddress, EscrowManagerAbi_1.EscrowManagerAbi);
50
- ////////////////////////
51
- //// Constants
52
- this.chainId = "STARKNET";
53
- ////////////////////////
54
- //// Timeouts
55
- this.claimWithSecretTimeout = 180;
56
- this.claimWithTxDataTimeout = 180;
57
- this.refundTimeout = 180;
58
- this.claimGracePeriod = 10 * 60;
59
- this.refundGracePeriod = 10 * 60;
60
- this.authGracePeriod = 30;
61
- ////////////////////////
62
- //// Handlers
63
- this.claimHandlersByAddress = {};
64
- this.claimHandlersBySwapType = {};
65
- this.refundHandlersByAddress = {};
66
- this.Init = new StarknetSwapInit_1.StarknetSwapInit(chainInterface, this);
67
- this.Refund = new StarknetSwapRefund_1.StarknetSwapRefund(chainInterface, this);
68
- this.Claim = new StarknetSwapClaim_1.StarknetSwapClaim(chainInterface, this);
69
- this.LpVault = new StarknetLpVault_1.StarknetLpVault(chainInterface, this);
70
- this.btcRelay = btcRelay;
71
- handlerAddresses ?? (handlerAddresses = {});
72
- handlerAddresses.refund ?? (handlerAddresses.refund = {});
73
- handlerAddresses.refund = { ...defaultRefundAddresses[chainInterface.starknetChainId], ...handlerAddresses.refund };
74
- handlerAddresses.claim ?? (handlerAddresses.claim = {});
75
- handlerAddresses.claim = { ...defaultClaimAddresses[chainInterface.starknetChainId], ...handlerAddresses.claim };
76
- ClaimHandlers_1.claimHandlersList.forEach(handlerCtor => {
77
- const handler = new handlerCtor(handlerAddresses.claim[handlerCtor.type]);
78
- this.claimHandlersByAddress[handler.address] = handler;
79
- this.claimHandlersBySwapType[handlerCtor.type] = handler;
80
- });
81
- this.timelockRefundHandler = new TimelockRefundHandler_1.TimelockRefundHandler(handlerAddresses.refund.timelock);
82
- this.refundHandlersByAddress[this.timelockRefundHandler.address] = this.timelockRefundHandler;
83
- }
84
- async start() {
85
- }
86
- ////////////////////////////////////////////
87
- //// Signatures
88
- preFetchForInitSignatureVerification() {
89
- return this.Init.preFetchForInitSignatureVerification();
90
- }
91
- getInitSignature(signer, swapData, authorizationTimeout, preFetchedBlockData, feeRate) {
92
- return this.Init.signSwapInitialization(signer, swapData, authorizationTimeout);
93
- }
94
- isValidInitAuthorization(swapData, { timeout, prefix, signature }, feeRate, preFetchedData) {
95
- return this.Init.isSignatureValid(swapData, timeout, prefix, signature, preFetchedData);
96
- }
97
- getInitAuthorizationExpiry(swapData, { timeout, prefix, signature }, preFetchedData) {
98
- return this.Init.getSignatureExpiry(timeout);
99
- }
100
- isInitAuthorizationExpired(swapData, { timeout, prefix, signature }) {
101
- return this.Init.isSignatureExpired(timeout);
102
- }
103
- getRefundSignature(signer, swapData, authorizationTimeout) {
104
- return this.Refund.signSwapRefund(signer, swapData, authorizationTimeout);
105
- }
106
- isValidRefundAuthorization(swapData, { timeout, prefix, signature }) {
107
- return this.Refund.isSignatureValid(swapData, timeout, prefix, signature);
108
- }
109
- getDataSignature(signer, data) {
110
- return this.Chain.Signatures.getDataSignature(signer, data);
111
- }
112
- isValidDataSignature(data, signature, publicKey) {
113
- return this.Chain.Signatures.isValidDataSignature(data, signature, publicKey);
114
- }
115
- ////////////////////////////////////////////
116
- //// Swap data utils
117
- /**
118
- * Checks whether the claim is claimable by us, that means not expired, we are claimer & the swap is commited
119
- *
120
- * @param signer
121
- * @param data
122
- */
123
- async isClaimable(signer, data) {
124
- if (!data.isClaimer(signer))
125
- return false;
126
- if (await this.isExpired(signer, data))
127
- return false;
128
- return await this.isCommited(data);
129
- }
130
- /**
131
- * Checks whether a swap is commited, i.e. the swap still exists on-chain and was not claimed nor refunded
132
- *
133
- * @param swapData
134
- */
135
- async isCommited(swapData) {
136
- const data = await this.contract.get_hash_state("0x" + swapData.getEscrowHash());
137
- return Number(data.state) === ESCROW_STATE_COMMITTED;
138
- }
139
- /**
140
- * Checks whether the swap is expired, takes into consideration possible on-chain time skew, therefore for claimer
141
- * the swap expires a bit sooner than it should've & for the offerer it expires a bit later
142
- *
143
- * @param signer
144
- * @param data
145
- */
146
- isExpired(signer, data) {
147
- let currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
148
- if (data.isClaimer(signer))
149
- currentTimestamp = currentTimestamp + BigInt(this.claimGracePeriod);
150
- if (data.isOfferer(signer))
151
- currentTimestamp = currentTimestamp - BigInt(this.refundGracePeriod);
152
- return Promise.resolve(data.getExpiry() < currentTimestamp);
153
- }
154
- /**
155
- * Checks if the swap is refundable by us, checks if we are offerer, if the swap is already expired & if the swap
156
- * is still commited
157
- *
158
- * @param signer
159
- * @param data
160
- */
161
- async isRequestRefundable(signer, data) {
162
- //Swap can only be refunded by the offerer
163
- if (!data.isOfferer(signer))
164
- return false;
165
- if (!(await this.isExpired(signer, data)))
166
- return false;
167
- return await this.isCommited(data);
168
- }
169
- getHashForTxId(txId, confirmations) {
170
- return (0, Utils_1.bigNumberishToBuffer)(this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN_TXID].getCommitment({
171
- txId,
172
- confirmations,
173
- btcRelay: this.btcRelay
174
- }), 32);
175
- }
176
- /**
177
- * Get the swap payment hash to be used for an on-chain swap, uses poseidon hash of the value
178
- *
179
- * @param outputScript output script required to claim the swap
180
- * @param amount sats sent required to claim the swap
181
- * @param confirmations
182
- * @param nonce swap nonce uniquely identifying the transaction to prevent replay attacks
183
- */
184
- getHashForOnchain(outputScript, amount, confirmations, nonce) {
185
- let result;
186
- if (nonce == null || nonce === 0n) {
187
- result = this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN].getCommitment({
188
- output: outputScript,
189
- amount,
190
- confirmations,
191
- btcRelay: this.btcRelay
192
- });
193
- }
194
- else {
195
- result = this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN_NONCED].getCommitment({
196
- output: outputScript,
197
- amount,
198
- nonce,
199
- confirmations,
200
- btcRelay: this.btcRelay
201
- });
202
- }
203
- return (0, Utils_1.bigNumberishToBuffer)(result, 32);
204
- }
205
- /**
206
- * Get the swap payment hash to be used for a lightning htlc swap, uses poseidon hash of the sha256 hash of the preimage
207
- *
208
- * @param paymentHash payment hash of the HTLC
209
- */
210
- getHashForHtlc(paymentHash) {
211
- return (0, Utils_1.bigNumberishToBuffer)(this.claimHandlersBySwapType[base_1.ChainSwapType.HTLC].getCommitment(paymentHash), 32);
212
- }
213
- getExtraData(outputScript, amount, confirmations, nonce) {
214
- if (nonce == null)
215
- nonce = 0n;
216
- const txoHash = buffer_1.Buffer.from((0, sha2_1.sha256)(buffer_1.Buffer.concat([
217
- base_1.BigIntBufferUtils.toBuffer(amount, "le", 8),
218
- outputScript
219
- ])));
220
- return buffer_1.Buffer.concat([
221
- txoHash,
222
- base_1.BigIntBufferUtils.toBuffer(nonce, "be", 8),
223
- base_1.BigIntBufferUtils.toBuffer(BigInt(confirmations), "be", 2)
224
- ]);
225
- }
226
- ////////////////////////////////////////////
227
- //// Swap data getters
228
- /**
229
- * Gets the status of the specific swap, this also checks if we are offerer/claimer & checks for expiry (to see
230
- * if swap is refundable)
231
- *
232
- * @param signer
233
- * @param data
234
- */
235
- async getCommitStatus(signer, data) {
236
- const escrowHash = data.getEscrowHash();
237
- const stateData = await this.contract.get_hash_state("0x" + escrowHash);
238
- const state = Number(stateData.state);
239
- switch (state) {
240
- case ESCROW_STATE_COMMITTED:
241
- if (data.isOfferer(signer) && await this.isExpired(signer, data))
242
- return base_1.SwapCommitStatus.REFUNDABLE;
243
- return base_1.SwapCommitStatus.COMMITED;
244
- case ESCROW_STATE_CLAIMED:
245
- return base_1.SwapCommitStatus.PAID;
246
- default:
247
- if (await this.isExpired(signer, data))
248
- return base_1.SwapCommitStatus.EXPIRED;
249
- return base_1.SwapCommitStatus.NOT_COMMITED;
250
- }
251
- }
252
- /**
253
- * Checks the status of the specific payment hash
254
- *
255
- * @param paymentHash
256
- */
257
- async getPaymentHashStatus(paymentHash) {
258
- //TODO: Noop
259
- return base_1.SwapCommitStatus.NOT_COMMITED;
260
- }
261
- /**
262
- * Returns the data committed for a specific payment hash, or null if no data is currently commited for
263
- * the specific swap
264
- *
265
- * @param paymentHashHex
266
- */
267
- async getCommitedData(paymentHashHex) {
268
- //TODO: Noop
269
- return null;
270
- }
271
- ////////////////////////////////////////////
272
- //// Swap data initializer
273
- createSwapData(type, offerer, claimer, token, amount, paymentHash, sequence, expiry, payIn, payOut, securityDeposit, claimerBounty, depositToken = this.Chain.Tokens.getNativeCurrencyAddress()) {
274
- return Promise.resolve(new StarknetSwapData_1.StarknetSwapData(offerer, claimer, token, this.timelockRefundHandler.address, this.claimHandlersBySwapType?.[type]?.address, payOut, payIn, payIn, //For now track reputation for all payIn swaps
275
- sequence, "0x" + paymentHash, (0, Utils_1.toHex)(expiry), amount, depositToken, securityDeposit, claimerBounty, type, null));
276
- }
277
- ////////////////////////////////////////////
278
- //// Utils
279
- async getBalance(signer, tokenAddress, inContract) {
280
- if (inContract)
281
- return await this.getIntermediaryBalance(signer, tokenAddress);
282
- //TODO: For native token we should discount the cost of deploying an account if it is not deployed yet
283
- return await this.Chain.getBalance(signer, tokenAddress);
284
- }
285
- getIntermediaryData(address, token) {
286
- return this.LpVault.getIntermediaryData(address, token);
287
- }
288
- getIntermediaryReputation(address, token) {
289
- return this.LpVault.getIntermediaryReputation(address, token);
290
- }
291
- getIntermediaryBalance(address, token) {
292
- return this.LpVault.getIntermediaryBalance(address, token);
293
- }
294
- ////////////////////////////////////////////
295
- //// Transaction initializers
296
- async txsClaimWithSecret(signer, swapData, secret, checkExpiry, initAta, feeRate, skipAtaCheck) {
297
- return this.Claim.txsClaimWithSecret(typeof (signer) === "string" ? signer : signer.getAddress(), swapData, secret, checkExpiry, feeRate);
298
- }
299
- async txsClaimWithTxData(signer, swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, initAta, feeRate) {
300
- return this.Claim.txsClaimWithTxData(typeof (signer) === "string" ? signer : signer.getAddress(), swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, feeRate);
301
- }
302
- txsRefund(signer, swapData, check, initAta, feeRate) {
303
- return this.Refund.txsRefund(signer, swapData, check, feeRate);
304
- }
305
- txsRefundWithAuthorization(signer, swapData, { timeout, prefix, signature }, check, initAta, feeRate) {
306
- return this.Refund.txsRefundWithAuthorization(signer, swapData, timeout, prefix, signature, check, feeRate);
307
- }
308
- txsInit(swapData, { timeout, prefix, signature }, skipChecks, feeRate) {
309
- return this.Init.txsInit(swapData, timeout, prefix, signature, skipChecks, feeRate);
310
- }
311
- txsWithdraw(signer, token, amount, feeRate) {
312
- return this.LpVault.txsWithdraw(signer, token, amount, feeRate);
313
- }
314
- txsDeposit(signer, token, amount, feeRate) {
315
- return this.LpVault.txsDeposit(signer, token, amount, feeRate);
316
- }
317
- ////////////////////////////////////////////
318
- //// Executors
319
- async claimWithSecret(signer, swapData, secret, checkExpiry, initAta, txOptions) {
320
- const result = await this.Claim.txsClaimWithSecret(signer.getAddress(), swapData, secret, checkExpiry, txOptions?.feeRate);
321
- const [signature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
322
- return signature;
323
- }
324
- async claimWithTxData(signer, swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, initAta, txOptions) {
325
- const txs = await this.Claim.txsClaimWithTxData(signer.getAddress(), swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, txOptions?.feeRate);
326
- if (txs === null)
327
- throw new Error("Btc relay not synchronized to required blockheight!");
328
- //TODO: This doesn't return proper tx signature
329
- const [signature] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal);
330
- return signature;
331
- }
332
- async refund(signer, swapData, check, initAta, txOptions) {
333
- let result = await this.txsRefund(signer.getAddress(), swapData, check, initAta, txOptions?.feeRate);
334
- const [signature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
335
- return signature;
336
- }
337
- async refundWithAuthorization(signer, swapData, signature, check, initAta, txOptions) {
338
- let result = await this.txsRefundWithAuthorization(signer.getAddress(), swapData, signature, check, initAta, txOptions?.feeRate);
339
- const [txSignature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
340
- return txSignature;
341
- }
342
- async init(signer, swapData, signature, skipChecks, txOptions) {
343
- if (swapData.isPayIn()) {
344
- if (!swapData.isOfferer(signer.getAddress()))
345
- throw new Error("Invalid signer provided!");
346
- }
347
- else {
348
- if (!swapData.isClaimer(signer.getAddress()))
349
- throw new Error("Invalid signer provided!");
350
- }
351
- let result = await this.txsInit(swapData, signature, skipChecks, txOptions?.feeRate);
352
- const [txSignature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
353
- return txSignature;
354
- }
355
- async withdraw(signer, token, amount, txOptions) {
356
- const txs = await this.LpVault.txsWithdraw(signer.getAddress(), token, amount, txOptions?.feeRate);
357
- const [txId] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal, false);
358
- return txId;
359
- }
360
- async deposit(signer, token, amount, txOptions) {
361
- const txs = await this.LpVault.txsDeposit(signer.getAddress(), token, amount, txOptions?.feeRate);
362
- const [txId] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal, false);
363
- return txId;
364
- }
365
- ////////////////////////////////////////////
366
- //// Fees
367
- getInitPayInFeeRate(offerer, claimer, token, paymentHash) {
368
- return this.Chain.Fees.getFeeRate();
369
- }
370
- getInitFeeRate(offerer, claimer, token, paymentHash) {
371
- return this.Chain.Fees.getFeeRate();
372
- }
373
- getRefundFeeRate(swapData) {
374
- return this.Chain.Fees.getFeeRate();
375
- }
376
- getClaimFeeRate(signer, swapData) {
377
- return this.Chain.Fees.getFeeRate();
378
- }
379
- getClaimFee(signer, swapData, feeRate) {
380
- return this.Claim.getClaimFee(swapData, feeRate);
381
- }
382
- /**
383
- * Get the estimated solana fee of the commit transaction
384
- */
385
- getCommitFee(swapData, feeRate) {
386
- return this.Init.getInitFee(swapData, feeRate);
387
- }
388
- /**
389
- * Get the estimated solana transaction fee of the refund transaction
390
- */
391
- getRefundFee(swapData, feeRate) {
392
- return this.Refund.getRefundFee(swapData, feeRate);
393
- }
394
- }
395
- exports.StarknetSwapContract = StarknetSwapContract;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StarknetSwapContract = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const buffer_1 = require("buffer");
6
+ const EscrowManagerAbi_1 = require("./EscrowManagerAbi");
7
+ const StarknetContractBase_1 = require("../contract/StarknetContractBase");
8
+ const starknet_1 = require("starknet");
9
+ const StarknetSwapData_1 = require("./StarknetSwapData");
10
+ const Utils_1 = require("../../utils/Utils");
11
+ const TimelockRefundHandler_1 = require("./handlers/refund/TimelockRefundHandler");
12
+ const StarknetLpVault_1 = require("./modules/StarknetLpVault");
13
+ const StarknetSwapInit_1 = require("./modules/StarknetSwapInit");
14
+ const StarknetSwapRefund_1 = require("./modules/StarknetSwapRefund");
15
+ const ClaimHandlers_1 = require("./handlers/claim/ClaimHandlers");
16
+ const StarknetSwapClaim_1 = require("./modules/StarknetSwapClaim");
17
+ const sha2_1 = require("@noble/hashes/sha2");
18
+ const ESCROW_STATE_COMMITTED = 1;
19
+ const ESCROW_STATE_CLAIMED = 2;
20
+ const ESCROW_STATE_REFUNDED = 3;
21
+ const swapContractAddreses = {
22
+ [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: "0x030ae7fc7bbce9b8c888b1117f5573c786dd8e1541c722227b8673ac7dda70c0",
23
+ [starknet_1.constants.StarknetChainId.SN_MAIN]: "0x02e1070519f27ec94dde395c8d72a5fcb144d40a786cf60b9b45395d36cc2f69"
24
+ };
25
+ const defaultClaimAddresses = {
26
+ [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: {
27
+ [base_1.ChainSwapType.HTLC]: "0x04a57ea54d4637c352aad1bbee046868926a11702216a0aaf7eeec1568be2d7b",
28
+ [base_1.ChainSwapType.CHAIN_TXID]: "0x04c7cde88359e14b6f6f779f8b9d8310cee37e91a6f143f855ae29fab33c396e",
29
+ [base_1.ChainSwapType.CHAIN]: "0x051bef6f5fd12e2832a7d38653bdfc8eb84ba7eb7a4aada5b87ef38a9999cf17",
30
+ [base_1.ChainSwapType.CHAIN_NONCED]: "0x050e50eacd16da414f2c3a7c3570fd5e248974c6fe757d41acbf72d2836fa0a1"
31
+ },
32
+ [starknet_1.constants.StarknetChainId.SN_MAIN]: {
33
+ [base_1.ChainSwapType.HTLC]: "0x07b74b50a883ebee262b6db0e3c0c697670c6f30e3d610e75faf33a89c46aa2a",
34
+ [base_1.ChainSwapType.CHAIN_TXID]: "0x016c2db2b03f39cf4fd7f871035000f66b62307d9983056e33a38315da8a44dc",
35
+ [base_1.ChainSwapType.CHAIN]: "0x02c45a81c4a48d0645a0a199e620061e8a55dcc9c2b5946d050eaeeddba64e9a",
36
+ [base_1.ChainSwapType.CHAIN_NONCED]: "0x0019b5480dd7ed8ded10a09437b0a7a30b8997b4ef139deb24ff8c86f995d84f"
37
+ }
38
+ };
39
+ const defaultRefundAddresses = {
40
+ [starknet_1.constants.StarknetChainId.SN_SEPOLIA]: {
41
+ timelock: "0x034b8f28b3ca979036cb2849cfa3af7f67207459224b6ca5ce2474aa398ec3e7"
42
+ },
43
+ [starknet_1.constants.StarknetChainId.SN_MAIN]: {
44
+ timelock: "0x06a59659990c2aefbf7239f6d911617b3ae60b79cb3364f3bd242a6ca8f4f4f7"
45
+ }
46
+ };
47
+ class StarknetSwapContract extends StarknetContractBase_1.StarknetContractBase {
48
+ constructor(chainInterface, btcRelay, contractAddress = swapContractAddreses[chainInterface.starknetChainId], handlerAddresses) {
49
+ super(chainInterface, contractAddress, EscrowManagerAbi_1.EscrowManagerAbi);
50
+ ////////////////////////
51
+ //// Constants
52
+ this.chainId = "STARKNET";
53
+ ////////////////////////
54
+ //// Timeouts
55
+ this.claimWithSecretTimeout = 180;
56
+ this.claimWithTxDataTimeout = 180;
57
+ this.refundTimeout = 180;
58
+ this.claimGracePeriod = 10 * 60;
59
+ this.refundGracePeriod = 10 * 60;
60
+ this.authGracePeriod = 30;
61
+ ////////////////////////
62
+ //// Handlers
63
+ this.claimHandlersByAddress = {};
64
+ this.claimHandlersBySwapType = {};
65
+ this.refundHandlersByAddress = {};
66
+ this.Init = new StarknetSwapInit_1.StarknetSwapInit(chainInterface, this);
67
+ this.Refund = new StarknetSwapRefund_1.StarknetSwapRefund(chainInterface, this);
68
+ this.Claim = new StarknetSwapClaim_1.StarknetSwapClaim(chainInterface, this);
69
+ this.LpVault = new StarknetLpVault_1.StarknetLpVault(chainInterface, this);
70
+ this.btcRelay = btcRelay;
71
+ handlerAddresses ?? (handlerAddresses = {});
72
+ handlerAddresses.refund ?? (handlerAddresses.refund = {});
73
+ handlerAddresses.refund = { ...defaultRefundAddresses[chainInterface.starknetChainId], ...handlerAddresses.refund };
74
+ handlerAddresses.claim ?? (handlerAddresses.claim = {});
75
+ handlerAddresses.claim = { ...defaultClaimAddresses[chainInterface.starknetChainId], ...handlerAddresses.claim };
76
+ ClaimHandlers_1.claimHandlersList.forEach(handlerCtor => {
77
+ const handler = new handlerCtor(handlerAddresses.claim[handlerCtor.type]);
78
+ this.claimHandlersByAddress[handler.address] = handler;
79
+ this.claimHandlersBySwapType[handlerCtor.type] = handler;
80
+ });
81
+ this.timelockRefundHandler = new TimelockRefundHandler_1.TimelockRefundHandler(handlerAddresses.refund.timelock);
82
+ this.refundHandlersByAddress[this.timelockRefundHandler.address] = this.timelockRefundHandler;
83
+ }
84
+ async start() {
85
+ }
86
+ ////////////////////////////////////////////
87
+ //// Signatures
88
+ preFetchForInitSignatureVerification() {
89
+ return this.Init.preFetchForInitSignatureVerification();
90
+ }
91
+ getInitSignature(signer, swapData, authorizationTimeout, preFetchedBlockData, feeRate) {
92
+ return this.Init.signSwapInitialization(signer, swapData, authorizationTimeout);
93
+ }
94
+ isValidInitAuthorization(sender, swapData, { timeout, prefix, signature }, feeRate, preFetchedData) {
95
+ return this.Init.isSignatureValid(sender, swapData, timeout, prefix, signature, preFetchedData);
96
+ }
97
+ getInitAuthorizationExpiry(swapData, { timeout, prefix, signature }, preFetchedData) {
98
+ return this.Init.getSignatureExpiry(timeout);
99
+ }
100
+ isInitAuthorizationExpired(swapData, { timeout, prefix, signature }) {
101
+ return this.Init.isSignatureExpired(timeout);
102
+ }
103
+ getRefundSignature(signer, swapData, authorizationTimeout) {
104
+ return this.Refund.signSwapRefund(signer, swapData, authorizationTimeout);
105
+ }
106
+ isValidRefundAuthorization(swapData, { timeout, prefix, signature }) {
107
+ return this.Refund.isSignatureValid(swapData, timeout, prefix, signature);
108
+ }
109
+ getDataSignature(signer, data) {
110
+ return this.Chain.Signatures.getDataSignature(signer, data);
111
+ }
112
+ isValidDataSignature(data, signature, publicKey) {
113
+ return this.Chain.Signatures.isValidDataSignature(data, signature, publicKey);
114
+ }
115
+ ////////////////////////////////////////////
116
+ //// Swap data utils
117
+ /**
118
+ * Checks whether the claim is claimable by us, that means not expired, we are claimer & the swap is commited
119
+ *
120
+ * @param signer
121
+ * @param data
122
+ */
123
+ async isClaimable(signer, data) {
124
+ if (!data.isClaimer(signer))
125
+ return false;
126
+ if (await this.isExpired(signer, data))
127
+ return false;
128
+ return await this.isCommited(data);
129
+ }
130
+ /**
131
+ * Checks whether a swap is commited, i.e. the swap still exists on-chain and was not claimed nor refunded
132
+ *
133
+ * @param swapData
134
+ */
135
+ async isCommited(swapData) {
136
+ const data = await this.contract.get_hash_state("0x" + swapData.getEscrowHash());
137
+ return Number(data.state) === ESCROW_STATE_COMMITTED;
138
+ }
139
+ /**
140
+ * Checks whether the swap is expired, takes into consideration possible on-chain time skew, therefore for claimer
141
+ * the swap expires a bit sooner than it should've & for the offerer it expires a bit later
142
+ *
143
+ * @param signer
144
+ * @param data
145
+ */
146
+ isExpired(signer, data) {
147
+ let currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
148
+ if (data.isClaimer(signer))
149
+ currentTimestamp = currentTimestamp + BigInt(this.claimGracePeriod);
150
+ if (data.isOfferer(signer))
151
+ currentTimestamp = currentTimestamp - BigInt(this.refundGracePeriod);
152
+ return Promise.resolve(data.getExpiry() < currentTimestamp);
153
+ }
154
+ /**
155
+ * Checks if the swap is refundable by us, checks if we are offerer, if the swap is already expired & if the swap
156
+ * is still commited
157
+ *
158
+ * @param signer
159
+ * @param data
160
+ */
161
+ async isRequestRefundable(signer, data) {
162
+ //Swap can only be refunded by the offerer
163
+ if (!data.isOfferer(signer))
164
+ return false;
165
+ if (!(await this.isExpired(signer, data)))
166
+ return false;
167
+ return await this.isCommited(data);
168
+ }
169
+ getHashForTxId(txId, confirmations) {
170
+ return (0, Utils_1.bigNumberishToBuffer)(this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN_TXID].getCommitment({
171
+ txId,
172
+ confirmations,
173
+ btcRelay: this.btcRelay
174
+ }), 32);
175
+ }
176
+ /**
177
+ * Get the swap payment hash to be used for an on-chain swap, uses poseidon hash of the value
178
+ *
179
+ * @param outputScript output script required to claim the swap
180
+ * @param amount sats sent required to claim the swap
181
+ * @param confirmations
182
+ * @param nonce swap nonce uniquely identifying the transaction to prevent replay attacks
183
+ */
184
+ getHashForOnchain(outputScript, amount, confirmations, nonce) {
185
+ let result;
186
+ if (nonce == null || nonce === 0n) {
187
+ result = this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN].getCommitment({
188
+ output: outputScript,
189
+ amount,
190
+ confirmations,
191
+ btcRelay: this.btcRelay
192
+ });
193
+ }
194
+ else {
195
+ result = this.claimHandlersBySwapType[base_1.ChainSwapType.CHAIN_NONCED].getCommitment({
196
+ output: outputScript,
197
+ amount,
198
+ nonce,
199
+ confirmations,
200
+ btcRelay: this.btcRelay
201
+ });
202
+ }
203
+ return (0, Utils_1.bigNumberishToBuffer)(result, 32);
204
+ }
205
+ /**
206
+ * Get the swap payment hash to be used for a lightning htlc swap, uses poseidon hash of the sha256 hash of the preimage
207
+ *
208
+ * @param paymentHash payment hash of the HTLC
209
+ */
210
+ getHashForHtlc(paymentHash) {
211
+ return (0, Utils_1.bigNumberishToBuffer)(this.claimHandlersBySwapType[base_1.ChainSwapType.HTLC].getCommitment(paymentHash), 32);
212
+ }
213
+ getExtraData(outputScript, amount, confirmations, nonce) {
214
+ if (nonce == null)
215
+ nonce = 0n;
216
+ const txoHash = buffer_1.Buffer.from((0, sha2_1.sha256)(buffer_1.Buffer.concat([
217
+ base_1.BigIntBufferUtils.toBuffer(amount, "le", 8),
218
+ outputScript
219
+ ])));
220
+ return buffer_1.Buffer.concat([
221
+ txoHash,
222
+ base_1.BigIntBufferUtils.toBuffer(nonce, "be", 8),
223
+ base_1.BigIntBufferUtils.toBuffer(BigInt(confirmations), "be", 2)
224
+ ]);
225
+ }
226
+ ////////////////////////////////////////////
227
+ //// Swap data getters
228
+ /**
229
+ * Gets the status of the specific swap, this also checks if we are offerer/claimer & checks for expiry (to see
230
+ * if swap is refundable)
231
+ *
232
+ * @param signer
233
+ * @param data
234
+ */
235
+ async getCommitStatus(signer, data) {
236
+ const escrowHash = data.getEscrowHash();
237
+ const stateData = await this.contract.get_hash_state("0x" + escrowHash);
238
+ const state = Number(stateData.state);
239
+ const blockHeight = Number(stateData.finish_blockheight);
240
+ switch (state) {
241
+ case ESCROW_STATE_COMMITTED:
242
+ if (data.isOfferer(signer) && await this.isExpired(signer, data))
243
+ return { type: base_1.SwapCommitStateType.REFUNDABLE };
244
+ return { type: base_1.SwapCommitStateType.COMMITED };
245
+ case ESCROW_STATE_CLAIMED:
246
+ return {
247
+ type: base_1.SwapCommitStateType.PAID,
248
+ getTxBlock: async () => {
249
+ return {
250
+ blockTime: await this.Chain.Blocks.getBlockTime(blockHeight),
251
+ blockHeight: blockHeight
252
+ };
253
+ },
254
+ getClaimTxId: async () => {
255
+ const events = await this.Events.getContractBlockEvents(["escrow_manager::events::Claim"], [null, null, null, "0x" + escrowHash], blockHeight, blockHeight);
256
+ return events.length === 0 ? null : events[0].txHash;
257
+ }
258
+ };
259
+ default:
260
+ return {
261
+ type: await this.isExpired(signer, data) ? base_1.SwapCommitStateType.EXPIRED : base_1.SwapCommitStateType.NOT_COMMITED,
262
+ getTxBlock: async () => {
263
+ return {
264
+ blockTime: await this.Chain.Blocks.getBlockTime(blockHeight),
265
+ blockHeight: blockHeight
266
+ };
267
+ },
268
+ getClaimTxId: async () => {
269
+ const events = await this.Events.getContractBlockEvents(["escrow_manager::events::Refund"], [null, null, null, "0x" + escrowHash], blockHeight, blockHeight);
270
+ return events.length === 0 ? null : events[0].txHash;
271
+ }
272
+ };
273
+ }
274
+ }
275
+ /**
276
+ * Returns the data committed for a specific payment hash, or null if no data is currently commited for
277
+ * the specific swap
278
+ *
279
+ * @param paymentHashHex
280
+ */
281
+ async getCommitedData(paymentHashHex) {
282
+ //TODO: Noop
283
+ return null;
284
+ }
285
+ ////////////////////////////////////////////
286
+ //// Swap data initializer
287
+ createSwapData(type, offerer, claimer, token, amount, paymentHash, sequence, expiry, payIn, payOut, securityDeposit, claimerBounty, depositToken = this.Chain.Tokens.getNativeCurrencyAddress()) {
288
+ return Promise.resolve(new StarknetSwapData_1.StarknetSwapData(offerer, claimer, token, this.timelockRefundHandler.address, this.claimHandlersBySwapType?.[type]?.address, payOut, payIn, payIn, //For now track reputation for all payIn swaps
289
+ sequence, "0x" + paymentHash, (0, Utils_1.toHex)(expiry), amount, depositToken, securityDeposit, claimerBounty, type, null));
290
+ }
291
+ ////////////////////////////////////////////
292
+ //// Utils
293
+ async getBalance(signer, tokenAddress, inContract) {
294
+ if (inContract)
295
+ return await this.getIntermediaryBalance(signer, tokenAddress);
296
+ //TODO: For native token we should discount the cost of deploying an account if it is not deployed yet
297
+ return await this.Chain.getBalance(signer, tokenAddress);
298
+ }
299
+ getIntermediaryData(address, token) {
300
+ return this.LpVault.getIntermediaryData(address, token);
301
+ }
302
+ getIntermediaryReputation(address, token) {
303
+ return this.LpVault.getIntermediaryReputation(address, token);
304
+ }
305
+ getIntermediaryBalance(address, token) {
306
+ return this.LpVault.getIntermediaryBalance(address, token);
307
+ }
308
+ ////////////////////////////////////////////
309
+ //// Transaction initializers
310
+ async txsClaimWithSecret(signer, swapData, secret, checkExpiry, initAta, feeRate, skipAtaCheck) {
311
+ return this.Claim.txsClaimWithSecret(typeof (signer) === "string" ? signer : signer.getAddress(), swapData, secret, checkExpiry, feeRate);
312
+ }
313
+ async txsClaimWithTxData(signer, swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, initAta, feeRate) {
314
+ return this.Claim.txsClaimWithTxData(typeof (signer) === "string" ? signer : signer.getAddress(), swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, feeRate);
315
+ }
316
+ txsRefund(signer, swapData, check, initAta, feeRate) {
317
+ return this.Refund.txsRefund(signer, swapData, check, feeRate);
318
+ }
319
+ txsRefundWithAuthorization(signer, swapData, { timeout, prefix, signature }, check, initAta, feeRate) {
320
+ return this.Refund.txsRefundWithAuthorization(signer, swapData, timeout, prefix, signature, check, feeRate);
321
+ }
322
+ txsInit(sender, swapData, { timeout, prefix, signature }, skipChecks, feeRate) {
323
+ return this.Init.txsInit(sender, swapData, timeout, prefix, signature, skipChecks, feeRate);
324
+ }
325
+ txsWithdraw(signer, token, amount, feeRate) {
326
+ return this.LpVault.txsWithdraw(signer, token, amount, feeRate);
327
+ }
328
+ txsDeposit(signer, token, amount, feeRate) {
329
+ return this.LpVault.txsDeposit(signer, token, amount, feeRate);
330
+ }
331
+ ////////////////////////////////////////////
332
+ //// Executors
333
+ async claimWithSecret(signer, swapData, secret, checkExpiry, initAta, txOptions) {
334
+ const result = await this.Claim.txsClaimWithSecret(signer.getAddress(), swapData, secret, checkExpiry, txOptions?.feeRate);
335
+ const [signature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
336
+ return signature;
337
+ }
338
+ async claimWithTxData(signer, swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, initAta, txOptions) {
339
+ const txs = await this.Claim.txsClaimWithTxData(signer.getAddress(), swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, txOptions?.feeRate);
340
+ if (txs === null)
341
+ throw new Error("Btc relay not synchronized to required blockheight!");
342
+ //TODO: This doesn't return proper tx signature
343
+ const [signature] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal);
344
+ return signature;
345
+ }
346
+ async refund(signer, swapData, check, initAta, txOptions) {
347
+ let result = await this.txsRefund(signer.getAddress(), swapData, check, initAta, txOptions?.feeRate);
348
+ const [signature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
349
+ return signature;
350
+ }
351
+ async refundWithAuthorization(signer, swapData, signature, check, initAta, txOptions) {
352
+ let result = await this.txsRefundWithAuthorization(signer.getAddress(), swapData, signature, check, initAta, txOptions?.feeRate);
353
+ const [txSignature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
354
+ return txSignature;
355
+ }
356
+ async init(signer, swapData, signature, skipChecks, txOptions) {
357
+ if (swapData.isPayIn()) {
358
+ if (!swapData.isOfferer(signer.getAddress()))
359
+ throw new Error("Invalid signer provided!");
360
+ }
361
+ else {
362
+ if (!swapData.isClaimer(signer.getAddress()))
363
+ throw new Error("Invalid signer provided!");
364
+ }
365
+ let result = await this.txsInit(signer.getAddress(), swapData, signature, skipChecks, txOptions?.feeRate);
366
+ const [txSignature] = await this.Chain.sendAndConfirm(signer, result, txOptions?.waitForConfirmation, txOptions?.abortSignal);
367
+ return txSignature;
368
+ }
369
+ async withdraw(signer, token, amount, txOptions) {
370
+ const txs = await this.LpVault.txsWithdraw(signer.getAddress(), token, amount, txOptions?.feeRate);
371
+ const [txId] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal, false);
372
+ return txId;
373
+ }
374
+ async deposit(signer, token, amount, txOptions) {
375
+ const txs = await this.LpVault.txsDeposit(signer.getAddress(), token, amount, txOptions?.feeRate);
376
+ const [txId] = await this.Chain.sendAndConfirm(signer, txs, txOptions?.waitForConfirmation, txOptions?.abortSignal, false);
377
+ return txId;
378
+ }
379
+ ////////////////////////////////////////////
380
+ //// Fees
381
+ getInitPayInFeeRate(offerer, claimer, token, paymentHash) {
382
+ return this.Chain.Fees.getFeeRate();
383
+ }
384
+ getInitFeeRate(offerer, claimer, token, paymentHash) {
385
+ return this.Chain.Fees.getFeeRate();
386
+ }
387
+ getRefundFeeRate(swapData) {
388
+ return this.Chain.Fees.getFeeRate();
389
+ }
390
+ getClaimFeeRate(signer, swapData) {
391
+ return this.Chain.Fees.getFeeRate();
392
+ }
393
+ getClaimFee(signer, swapData, feeRate) {
394
+ return this.Claim.getClaimFee(swapData, feeRate);
395
+ }
396
+ /**
397
+ * Get the estimated solana fee of the commit transaction
398
+ */
399
+ getCommitFee(signer, swapData, feeRate) {
400
+ return this.Init.getInitFee(swapData, feeRate);
401
+ }
402
+ /**
403
+ * Get the estimated solana transaction fee of the refund transaction
404
+ */
405
+ getRefundFee(signer, swapData, feeRate) {
406
+ return this.Refund.getRefundFee(swapData, feeRate);
407
+ }
408
+ }
409
+ exports.StarknetSwapContract = StarknetSwapContract;