@atomiqlabs/chain-starknet 4.0.0-dev.12 → 4.0.0-dev.13

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 -27
  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 -20
  29. package/dist/starknet/chain/modules/StarknetBlocks.js +64 -64
  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 +102 -98
  38. package/dist/starknet/chain/modules/StarknetTransactions.d.ts +93 -93
  39. package/dist/starknet/chain/modules/StarknetTransactions.js +261 -260
  40. package/dist/starknet/contract/StarknetContractBase.d.ts +13 -13
  41. package/dist/starknet/contract/StarknetContractBase.js +20 -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 +89 -90
  49. package/dist/starknet/events/StarknetChainEventsBrowser.js +296 -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 -66
  55. package/dist/starknet/spv_swap/StarknetSpvVaultContract.js +382 -382
  56. package/dist/starknet/spv_swap/StarknetSpvVaultData.d.ts +49 -49
  57. package/dist/starknet/spv_swap/StarknetSpvVaultData.js +145 -145
  58. package/dist/starknet/spv_swap/StarknetSpvWithdrawalData.d.ts +25 -25
  59. package/dist/starknet/spv_swap/StarknetSpvWithdrawalData.js +72 -72
  60. package/dist/starknet/swaps/EscrowManagerAbi.d.ts +431 -431
  61. package/dist/starknet/swaps/EscrowManagerAbi.js +583 -583
  62. package/dist/starknet/swaps/StarknetSwapContract.d.ts +191 -191
  63. package/dist/starknet/swaps/StarknetSwapContract.js +424 -424
  64. package/dist/starknet/swaps/StarknetSwapData.d.ts +74 -74
  65. package/dist/starknet/swaps/StarknetSwapData.js +325 -325
  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 +94 -87
  89. package/dist/starknet/swaps/modules/StarknetSwapInit.js +235 -225
  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 +35 -30
  94. package/dist/starknet/wallet/StarknetSigner.d.ts +12 -12
  95. package/dist/starknet/wallet/StarknetSigner.js +47 -46
  96. package/dist/utils/Utils.d.ts +37 -37
  97. package/dist/utils/Utils.js +260 -261
  98. package/package.json +43 -37
  99. package/src/index.ts +47 -47
  100. package/src/starknet/StarknetChainType.ts +28 -28
  101. package/src/starknet/StarknetInitializer.ts +108 -108
  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 +75 -74
  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 +120 -116
  117. package/src/starknet/chain/modules/StarknetTransactions.ts +285 -283
  118. package/src/starknet/contract/StarknetContractBase.ts +30 -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 +411 -411
  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 -483
  126. package/src/starknet/spv_swap/StarknetSpvVaultData.ts +195 -195
  127. package/src/starknet/spv_swap/StarknetSpvWithdrawalData.ts +79 -79
  128. package/src/starknet/swaps/EscrowManagerAbi.ts +582 -582
  129. package/src/starknet/swaps/StarknetSwapContract.ts +647 -647
  130. package/src/starknet/swaps/StarknetSwapData.ts +455 -455
  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 +300 -287
  143. package/src/starknet/swaps/modules/StarknetSwapRefund.ts +196 -196
  144. package/src/starknet/wallet/StarknetKeypairWallet.ts +44 -39
  145. package/src/starknet/wallet/StarknetSigner.ts +55 -55
  146. package/src/utils/Utils.ts +251 -252
@@ -1,197 +1,197 @@
1
- import {SignatureVerificationError, SwapDataVerificationError} from "@atomiqlabs/base";
2
- import {toHex, tryWithRetries} from "../../../utils/Utils";
3
- import {StarknetSwapModule} from "../StarknetSwapModule";
4
- import {StarknetSwapData} from "../StarknetSwapData";
5
- import {StarknetAction} from "../../chain/StarknetAction";
6
- import {IHandler} from "../handlers/IHandler";
7
- import {BigNumberish} from "starknet";
8
- import {StarknetTx} from "../../chain/modules/StarknetTransactions";
9
- import {StarknetSigner} from "../../wallet/StarknetSigner";
10
- import {StarknetFees, StarknetGas, starknetGasAdd} from "../../chain/modules/StarknetFees";
11
-
12
- const Refund = [
13
- { name: 'Swap hash', type: 'felt' },
14
- { name: 'Timeout', type: 'timestamp' }
15
- ];
16
-
17
- export class StarknetSwapRefund extends StarknetSwapModule {
18
-
19
- private static readonly GasCosts = {
20
- REFUND: {l1DataGas: 750, l2Gas: 4_000_000, l1Gas: 0},
21
- REFUND_PAY_OUT: {l1DataGas: 900, l2Gas: 6_000_000, l1Gas: 0}
22
- };
23
-
24
- /**
25
- * Action for generic Refund instruction
26
- *
27
- * @param signer
28
- * @param swapData
29
- * @param witness
30
- * @param handlerGas
31
- * @constructor
32
- * @private
33
- */
34
- private Refund(
35
- signer: string,
36
- swapData: StarknetSwapData,
37
- witness: BigNumberish[],
38
- handlerGas?: StarknetGas
39
- ): StarknetAction {
40
- return new StarknetAction(signer, this.root,
41
- this.swapContract.populateTransaction.refund(swapData.toEscrowStruct(), witness),
42
- starknetGasAdd(swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND, handlerGas)
43
- );
44
- }
45
-
46
- /**
47
- * Action for cooperative refunding with signature
48
- *
49
- * @param sender
50
- * @param swapData
51
- * @param timeout
52
- * @param signature
53
- * @constructor
54
- * @private
55
- */
56
- private RefundWithSignature(
57
- sender: string,
58
- swapData: StarknetSwapData,
59
- timeout: string,
60
- signature: BigNumberish[]
61
- ): StarknetAction {
62
- return new StarknetAction(sender, this.root,
63
- this.swapContract.populateTransaction.cooperative_refund(swapData.toEscrowStruct(), signature, BigInt(timeout)),
64
- swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND
65
- );
66
- }
67
-
68
- public async signSwapRefund(
69
- signer: StarknetSigner,
70
- swapData: StarknetSwapData,
71
- authorizationTimeout: number
72
- ): Promise<{ prefix: string; timeout: string; signature: string }> {
73
- const authPrefix = "refund";
74
- const authTimeout = Math.floor(Date.now()/1000)+authorizationTimeout;
75
-
76
- const signature = await this.root.Signatures.signTypedMessage(signer, Refund, "Refund", {
77
- "Swap hash": "0x"+swapData.getEscrowHash(),
78
- "Timeout": toHex(authTimeout)
79
- });
80
-
81
- return {
82
- prefix: authPrefix,
83
- timeout: authTimeout.toString(10),
84
- signature: signature
85
- };
86
- }
87
-
88
- public async isSignatureValid(
89
- swapData: StarknetSwapData,
90
- timeout: string,
91
- prefix: string,
92
- signature: string
93
- ): Promise<null> {
94
- if(prefix!=="refund") throw new SignatureVerificationError("Invalid prefix");
95
-
96
- const expiryTimestamp = BigInt(timeout);
97
- const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
98
-
99
- const isExpired = (expiryTimestamp - currentTimestamp) < BigInt(this.contract.authGracePeriod);
100
- if(isExpired) throw new SignatureVerificationError("Authorization expired!");
101
-
102
- const valid = await this.root.Signatures.isValidSignature(signature, swapData.claimer, Refund, "Refund", {
103
- "Swap hash": "0x"+swapData.getEscrowHash(),
104
- "Timeout": toHex(expiryTimestamp)
105
- });
106
-
107
- if(!valid) {
108
- throw new SignatureVerificationError("Invalid signature!");
109
- }
110
-
111
- return null;
112
- }
113
-
114
- /**
115
- * Creates transactions required for refunding timed out swap
116
- *
117
- * @param signer
118
- * @param swapData swap data to refund
119
- * @param check whether to check if swap is already expired and refundable
120
- * @param feeRate fee rate to be used for the transactions
121
- * @param witnessData
122
- */
123
- public async txsRefund<T>(
124
- signer: string,
125
- swapData: StarknetSwapData,
126
- check?: boolean,
127
- feeRate?: string,
128
- witnessData?: T
129
- ): Promise<StarknetTx[]> {
130
- const refundHandler: IHandler<any, T> = this.contract.refundHandlersByAddress[swapData.refundHandler.toLowerCase()];
131
- if(refundHandler==null) throw new Error("Invalid refund handler");
132
-
133
- if(check && !await tryWithRetries(() => this.contract.isRequestRefundable(swapData.offerer.toString(), swapData), this.retryPolicy)) {
134
- throw new SwapDataVerificationError("Not refundable yet!");
135
- }
136
-
137
- feeRate ??= await this.root.Fees.getFeeRate();
138
-
139
- const {initialTxns, witness} = await refundHandler.getWitness(signer, swapData, witnessData, feeRate);
140
-
141
- const action = this.Refund(signer, swapData, witness, refundHandler.getGas(swapData));
142
- await action.addToTxs(initialTxns, feeRate);
143
-
144
- this.logger.debug("txsRefund(): creating refund transaction, swap: "+swapData.getClaimHash());
145
-
146
- return initialTxns;
147
- }
148
-
149
- /**
150
- * Creates transactions required for refunding the swap with authorization signature, also unwraps WSOL to SOL
151
- *
152
- * @param signer
153
- * @param swapData swap data to refund
154
- * @param timeout signature timeout
155
- * @param prefix signature prefix of the counterparty
156
- * @param signature signature of the counterparty
157
- * @param check whether to check if swap is committed before attempting refund
158
- * @param feeRate fee rate to be used for the transactions
159
- */
160
- public async txsRefundWithAuthorization(
161
- signer: string,
162
- swapData: StarknetSwapData,
163
- timeout: string,
164
- prefix: string,
165
- signature: string,
166
- check?: boolean,
167
- feeRate?: string
168
- ): Promise<StarknetTx[]> {
169
- if(check && !await tryWithRetries(() => this.contract.isCommited(swapData), this.retryPolicy)) {
170
- throw new SwapDataVerificationError("Not correctly committed");
171
- }
172
- await tryWithRetries(
173
- () => this.isSignatureValid(swapData, timeout, prefix, signature),
174
- this.retryPolicy,
175
- (e) => e instanceof SignatureVerificationError
176
- );
177
-
178
- const action = this.RefundWithSignature(signer, swapData, timeout, JSON.parse(signature));
179
-
180
- feeRate ??= await this.root.Fees.getFeeRate();
181
-
182
- this.logger.debug("txsRefundWithAuthorization(): creating refund transaction, swap: "+swapData.getClaimHash()+
183
- " auth expiry: "+timeout+" signature: "+signature);
184
-
185
- return [await action.tx(feeRate)];
186
- }
187
-
188
- /**
189
- * Get the estimated solana transaction fee of the refund transaction, in the worst case scenario in case where the
190
- * ATA needs to be initialized again (i.e. adding the ATA rent exempt lamports to the fee)
191
- */
192
- async getRefundFee(swapData: StarknetSwapData, feeRate?: string): Promise<bigint> {
193
- feeRate ??= await this.root.Fees.getFeeRate();
194
- return StarknetFees.getGasFee(swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND, feeRate);
195
- }
196
-
1
+ import {SignatureVerificationError, SwapDataVerificationError} from "@atomiqlabs/base";
2
+ import {toHex, tryWithRetries} from "../../../utils/Utils";
3
+ import {StarknetSwapModule} from "../StarknetSwapModule";
4
+ import {StarknetSwapData} from "../StarknetSwapData";
5
+ import {StarknetAction} from "../../chain/StarknetAction";
6
+ import {IHandler} from "../handlers/IHandler";
7
+ import {BigNumberish} from "starknet";
8
+ import {StarknetTx} from "../../chain/modules/StarknetTransactions";
9
+ import {StarknetSigner} from "../../wallet/StarknetSigner";
10
+ import {StarknetFees, StarknetGas, starknetGasAdd} from "../../chain/modules/StarknetFees";
11
+
12
+ const Refund = [
13
+ { name: 'Swap hash', type: 'felt' },
14
+ { name: 'Timeout', type: 'timestamp' }
15
+ ];
16
+
17
+ export class StarknetSwapRefund extends StarknetSwapModule {
18
+
19
+ private static readonly GasCosts = {
20
+ REFUND: {l1DataGas: 750, l2Gas: 4_000_000, l1Gas: 0},
21
+ REFUND_PAY_OUT: {l1DataGas: 900, l2Gas: 6_000_000, l1Gas: 0}
22
+ };
23
+
24
+ /**
25
+ * Action for generic Refund instruction
26
+ *
27
+ * @param signer
28
+ * @param swapData
29
+ * @param witness
30
+ * @param handlerGas
31
+ * @constructor
32
+ * @private
33
+ */
34
+ private Refund(
35
+ signer: string,
36
+ swapData: StarknetSwapData,
37
+ witness: BigNumberish[],
38
+ handlerGas?: StarknetGas
39
+ ): StarknetAction {
40
+ return new StarknetAction(signer, this.root,
41
+ this.swapContract.populateTransaction.refund(swapData.toEscrowStruct(), witness),
42
+ starknetGasAdd(swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND, handlerGas)
43
+ );
44
+ }
45
+
46
+ /**
47
+ * Action for cooperative refunding with signature
48
+ *
49
+ * @param sender
50
+ * @param swapData
51
+ * @param timeout
52
+ * @param signature
53
+ * @constructor
54
+ * @private
55
+ */
56
+ private RefundWithSignature(
57
+ sender: string,
58
+ swapData: StarknetSwapData,
59
+ timeout: string,
60
+ signature: BigNumberish[]
61
+ ): StarknetAction {
62
+ return new StarknetAction(sender, this.root,
63
+ this.swapContract.populateTransaction.cooperative_refund(swapData.toEscrowStruct(), signature, BigInt(timeout)),
64
+ swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND
65
+ );
66
+ }
67
+
68
+ public async signSwapRefund(
69
+ signer: StarknetSigner,
70
+ swapData: StarknetSwapData,
71
+ authorizationTimeout: number
72
+ ): Promise<{ prefix: string; timeout: string; signature: string }> {
73
+ const authPrefix = "refund";
74
+ const authTimeout = Math.floor(Date.now()/1000)+authorizationTimeout;
75
+
76
+ const signature = await this.root.Signatures.signTypedMessage(signer, Refund, "Refund", {
77
+ "Swap hash": "0x"+swapData.getEscrowHash(),
78
+ "Timeout": toHex(authTimeout)
79
+ });
80
+
81
+ return {
82
+ prefix: authPrefix,
83
+ timeout: authTimeout.toString(10),
84
+ signature: signature
85
+ };
86
+ }
87
+
88
+ public async isSignatureValid(
89
+ swapData: StarknetSwapData,
90
+ timeout: string,
91
+ prefix: string,
92
+ signature: string
93
+ ): Promise<null> {
94
+ if(prefix!=="refund") throw new SignatureVerificationError("Invalid prefix");
95
+
96
+ const expiryTimestamp = BigInt(timeout);
97
+ const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
98
+
99
+ const isExpired = (expiryTimestamp - currentTimestamp) < BigInt(this.contract.authGracePeriod);
100
+ if(isExpired) throw new SignatureVerificationError("Authorization expired!");
101
+
102
+ const valid = await this.root.Signatures.isValidSignature(signature, swapData.claimer, Refund, "Refund", {
103
+ "Swap hash": "0x"+swapData.getEscrowHash(),
104
+ "Timeout": toHex(expiryTimestamp)
105
+ });
106
+
107
+ if(!valid) {
108
+ throw new SignatureVerificationError("Invalid signature!");
109
+ }
110
+
111
+ return null;
112
+ }
113
+
114
+ /**
115
+ * Creates transactions required for refunding timed out swap
116
+ *
117
+ * @param signer
118
+ * @param swapData swap data to refund
119
+ * @param check whether to check if swap is already expired and refundable
120
+ * @param feeRate fee rate to be used for the transactions
121
+ * @param witnessData
122
+ */
123
+ public async txsRefund<T>(
124
+ signer: string,
125
+ swapData: StarknetSwapData,
126
+ check?: boolean,
127
+ feeRate?: string,
128
+ witnessData?: T
129
+ ): Promise<StarknetTx[]> {
130
+ const refundHandler: IHandler<any, T> = this.contract.refundHandlersByAddress[swapData.refundHandler.toLowerCase()];
131
+ if(refundHandler==null) throw new Error("Invalid refund handler");
132
+
133
+ if(check && !await tryWithRetries(() => this.contract.isRequestRefundable(swapData.offerer.toString(), swapData), this.retryPolicy)) {
134
+ throw new SwapDataVerificationError("Not refundable yet!");
135
+ }
136
+
137
+ feeRate ??= await this.root.Fees.getFeeRate();
138
+
139
+ const {initialTxns, witness} = await refundHandler.getWitness(signer, swapData, witnessData, feeRate);
140
+
141
+ const action = this.Refund(signer, swapData, witness, refundHandler.getGas(swapData));
142
+ await action.addToTxs(initialTxns, feeRate);
143
+
144
+ this.logger.debug("txsRefund(): creating refund transaction, swap: "+swapData.getClaimHash());
145
+
146
+ return initialTxns;
147
+ }
148
+
149
+ /**
150
+ * Creates transactions required for refunding the swap with authorization signature, also unwraps WSOL to SOL
151
+ *
152
+ * @param signer
153
+ * @param swapData swap data to refund
154
+ * @param timeout signature timeout
155
+ * @param prefix signature prefix of the counterparty
156
+ * @param signature signature of the counterparty
157
+ * @param check whether to check if swap is committed before attempting refund
158
+ * @param feeRate fee rate to be used for the transactions
159
+ */
160
+ public async txsRefundWithAuthorization(
161
+ signer: string,
162
+ swapData: StarknetSwapData,
163
+ timeout: string,
164
+ prefix: string,
165
+ signature: string,
166
+ check?: boolean,
167
+ feeRate?: string
168
+ ): Promise<StarknetTx[]> {
169
+ if(check && !await tryWithRetries(() => this.contract.isCommited(swapData), this.retryPolicy)) {
170
+ throw new SwapDataVerificationError("Not correctly committed");
171
+ }
172
+ await tryWithRetries(
173
+ () => this.isSignatureValid(swapData, timeout, prefix, signature),
174
+ this.retryPolicy,
175
+ (e) => e instanceof SignatureVerificationError
176
+ );
177
+
178
+ const action = this.RefundWithSignature(signer, swapData, timeout, JSON.parse(signature));
179
+
180
+ feeRate ??= await this.root.Fees.getFeeRate();
181
+
182
+ this.logger.debug("txsRefundWithAuthorization(): creating refund transaction, swap: "+swapData.getClaimHash()+
183
+ " auth expiry: "+timeout+" signature: "+signature);
184
+
185
+ return [await action.tx(feeRate)];
186
+ }
187
+
188
+ /**
189
+ * Get the estimated solana transaction fee of the refund transaction, in the worst case scenario in case where the
190
+ * ATA needs to be initialized again (i.e. adding the ATA rent exempt lamports to the fee)
191
+ */
192
+ async getRefundFee(swapData: StarknetSwapData, feeRate?: string): Promise<bigint> {
193
+ feeRate ??= await this.root.Fees.getFeeRate();
194
+ return StarknetFees.getGasFee(swapData.payIn ? StarknetSwapRefund.GasCosts.REFUND_PAY_OUT : StarknetSwapRefund.GasCosts.REFUND, feeRate);
195
+ }
196
+
197
197
  }
@@ -1,39 +1,44 @@
1
- import {Account, CallData, DeployAccountContractPayload, ec, hash, Provider} from "starknet";
2
- import {toHex} from "../../utils/Utils";
3
- import {Buffer} from "buffer";
4
-
5
- const OZaccountClassHash = '0x00261c293c8084cd79086214176b33e5911677cec55104fddc8d25b0b736dcad';
6
-
7
- //Openzeppelin Account wallet
8
- export class StarknetKeypairWallet extends Account {
9
-
10
- public readonly publicKey: string;
11
-
12
- constructor(provider: Provider, privateKey: string) {
13
- const publicKey = ec.starkCurve.getStarkKey(toHex(privateKey));
14
- // Calculate future address of the account
15
- const OZaccountConstructorCallData = CallData.compile({ publicKey });
16
- const OZcontractAddress = hash.calculateContractAddressFromHash(
17
- publicKey,
18
- OZaccountClassHash,
19
- OZaccountConstructorCallData,
20
- 0
21
- );
22
- super(provider, OZcontractAddress, privateKey, "1");
23
- this.publicKey = publicKey;
24
- }
25
-
26
- public getDeploymentData(): DeployAccountContractPayload {
27
- return {
28
- classHash: OZaccountClassHash,
29
- constructorCalldata: CallData.compile({ publicKey: this.publicKey }),
30
- addressSalt: this.publicKey,
31
- contractAddress: this.address
32
- }
33
- }
34
-
35
- public static generateRandomPrivateKey(): string {
36
- return "0x"+Buffer.from(ec.starkCurve.utils.randomPrivateKey()).toString("hex");
37
- }
38
-
39
- }
1
+ import {Account, CallData, DeployAccountContractPayload, ec, hash, Provider} from "starknet";
2
+ import {toHex} from "../../utils/Utils";
3
+ import {Buffer} from "buffer";
4
+
5
+ const OZaccountClassHash = '0x00261c293c8084cd79086214176b33e5911677cec55104fddc8d25b0b736dcad';
6
+
7
+ //Openzeppelin Account wallet
8
+ export class StarknetKeypairWallet extends Account {
9
+
10
+ public readonly publicKey: string;
11
+
12
+ constructor(provider: Provider, privateKey: string) {
13
+ const publicKey = ec.starkCurve.getStarkKey(toHex(privateKey));
14
+ // Calculate future address of the account
15
+ const OZaccountConstructorCallData = CallData.compile({ publicKey });
16
+ const OZcontractAddress = hash.calculateContractAddressFromHash(
17
+ publicKey,
18
+ OZaccountClassHash,
19
+ OZaccountConstructorCallData,
20
+ 0
21
+ );
22
+ super({
23
+ provider,
24
+ address: OZcontractAddress,
25
+ signer: privateKey,
26
+ cairoVersion: "1"
27
+ });
28
+ this.publicKey = publicKey;
29
+ }
30
+
31
+ public getDeploymentData(): DeployAccountContractPayload {
32
+ return {
33
+ classHash: OZaccountClassHash,
34
+ constructorCalldata: CallData.compile({ publicKey: this.publicKey }),
35
+ addressSalt: this.publicKey,
36
+ contractAddress: this.address
37
+ }
38
+ }
39
+
40
+ public static generateRandomPrivateKey(): string {
41
+ return "0x"+Buffer.from(ec.starkCurve.utils.randomPrivateKey()).toString("hex");
42
+ }
43
+
44
+ }
@@ -1,55 +1,55 @@
1
- import {AbstractSigner} from "@atomiqlabs/base";
2
- import {Account, DeployAccountContractPayload} from "starknet";
3
- import {toHex} from "../../utils/Utils";
4
-
5
- export class StarknetSigner implements AbstractSigner {
6
-
7
- account: Account;
8
-
9
- isDeployed: boolean = null;
10
-
11
- constructor(account: Account) {
12
- this.account = account;
13
- }
14
-
15
- getPublicKey(): Promise<string> {
16
- return this.account.signer.getPubKey();
17
- }
18
-
19
- getAddress(): string {
20
- return toHex(this.account.address);
21
- }
22
-
23
- isWalletAccount() {
24
- return (this.account as any).walletProvider!=null;
25
- }
26
-
27
- //TODO: Introduce proper nonce management!
28
- async getNonce(): Promise<bigint> {
29
- try {
30
- return BigInt(await this.account.getNonceForAddress(this.getAddress(), "pending"));
31
- } catch (e) {
32
- if(e.message!=null && e.message.includes("20: Contract not found")) {
33
- return BigInt(0);
34
- }
35
- throw e;
36
- }
37
- }
38
-
39
- async checkAndGetDeployPayload(nonce?: bigint): Promise<DeployAccountContractPayload | null> {
40
- if(this.isDeployed) return null;
41
-
42
- const _account: Account & {getDeploymentData?: () => DeployAccountContractPayload} = this.account;
43
- if(_account.getDeploymentData!=null) {
44
- //Check if deployed
45
- nonce ??= BigInt(await this.getNonce());
46
- this.isDeployed = nonce!=BigInt(0);
47
- if(!this.isDeployed ) {
48
- return _account.getDeploymentData();
49
- }
50
- }
51
-
52
- return null;
53
- }
54
-
55
- }
1
+ import {AbstractSigner} from "@atomiqlabs/base";
2
+ import {Account, DeployAccountContractPayload, BlockTag} from "starknet";
3
+ import {toHex} from "../../utils/Utils";
4
+
5
+ export class StarknetSigner implements AbstractSigner {
6
+
7
+ account: Account;
8
+
9
+ isDeployed: boolean = null;
10
+
11
+ constructor(account: Account) {
12
+ this.account = account;
13
+ }
14
+
15
+ getPublicKey(): Promise<string> {
16
+ return this.account.signer.getPubKey();
17
+ }
18
+
19
+ getAddress(): string {
20
+ return toHex(this.account.address);
21
+ }
22
+
23
+ isWalletAccount() {
24
+ return (this.account as any).walletProvider!=null;
25
+ }
26
+
27
+ //TODO: Introduce proper nonce management!
28
+ async getNonce(): Promise<bigint> {
29
+ try {
30
+ return BigInt(await this.account.getNonceForAddress(this.getAddress(), BlockTag.PRE_CONFIRMED));
31
+ } catch (e) {
32
+ if(e.message!=null && e.message.includes("20: Contract not found")) {
33
+ return BigInt(0);
34
+ }
35
+ throw e;
36
+ }
37
+ }
38
+
39
+ async checkAndGetDeployPayload(nonce?: bigint): Promise<DeployAccountContractPayload | null> {
40
+ if(this.isDeployed) return null;
41
+
42
+ const _account: Account & {getDeploymentData?: () => DeployAccountContractPayload} = this.account;
43
+ if(_account.getDeploymentData!=null) {
44
+ //Check if deployed
45
+ nonce ??= BigInt(await this.getNonce());
46
+ this.isDeployed = nonce!=BigInt(0);
47
+ if(!this.isDeployed ) {
48
+ return _account.getDeploymentData();
49
+ }
50
+ }
51
+
52
+ return null;
53
+ }
54
+
55
+ }