@atomiqlabs/chain-evm 1.0.0-dev.35 → 1.0.0-dev.37
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.
- package/LICENSE +201 -201
- package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
- package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
- package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
- package/dist/chains/citrea/CitreaChainType.js +2 -2
- package/dist/chains/citrea/CitreaFees.d.ts +29 -29
- package/dist/chains/citrea/CitreaFees.js +67 -67
- package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
- package/dist/chains/citrea/CitreaInitializer.js +127 -127
- package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
- package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
- package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
- package/dist/chains/citrea/CitreaSwapContract.js +96 -96
- package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
- package/dist/chains/citrea/CitreaTokens.js +20 -20
- package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
- package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
- package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
- package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
- package/dist/evm/btcrelay/EVMBtcRelay.d.ts +195 -195
- package/dist/evm/btcrelay/EVMBtcRelay.js +423 -423
- package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
- package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
- package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
- package/dist/evm/chain/EVMChainInterface.js +89 -89
- package/dist/evm/chain/EVMModule.d.ts +9 -9
- package/dist/evm/chain/EVMModule.js +13 -13
- package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
- package/dist/evm/chain/modules/ERC20Abi.js +225 -225
- package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
- package/dist/evm/chain/modules/EVMAddresses.js +30 -30
- package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
- package/dist/evm/chain/modules/EVMBlocks.js +64 -64
- package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
- package/dist/evm/chain/modules/EVMEvents.js +122 -122
- package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
- package/dist/evm/chain/modules/EVMFees.js +73 -73
- package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
- package/dist/evm/chain/modules/EVMSignatures.js +68 -68
- package/dist/evm/chain/modules/EVMTokens.d.ts +70 -51
- package/dist/evm/chain/modules/EVMTokens.js +142 -113
- package/dist/evm/chain/modules/EVMTransactions.d.ts +89 -89
- package/dist/evm/chain/modules/EVMTransactions.js +230 -216
- package/dist/evm/contract/EVMContractBase.d.ts +22 -22
- package/dist/evm/contract/EVMContractBase.js +34 -34
- package/dist/evm/contract/EVMContractModule.d.ts +8 -8
- package/dist/evm/contract/EVMContractModule.js +11 -11
- package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
- package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
- package/dist/evm/events/EVMChainEvents.d.ts +22 -22
- package/dist/evm/events/EVMChainEvents.js +67 -67
- package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -86
- package/dist/evm/events/EVMChainEventsBrowser.js +294 -294
- package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +78 -78
- package/dist/evm/spv_swap/EVMSpvVaultContract.js +478 -480
- package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
- package/dist/evm/spv_swap/EVMSpvVaultData.js +180 -180
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
- package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
- package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
- package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
- package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
- package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
- package/dist/evm/swaps/EVMSwapContract.js +374 -374
- package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
- package/dist/evm/swaps/EVMSwapData.js +260 -260
- package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
- package/dist/evm/swaps/EVMSwapModule.js +11 -11
- package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
- package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
- package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
- package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
- package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
- package/dist/evm/swaps/handlers/IHandler.js +2 -2
- package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
- package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
- package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
- package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
- package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
- package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
- package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
- package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
- package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
- package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
- package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
- package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
- package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
- package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
- package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
- package/dist/evm/swaps/modules/EVMLpVault.js +134 -131
- package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
- package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
- package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
- package/dist/evm/swaps/modules/EVMSwapInit.js +274 -275
- package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
- package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
- package/dist/evm/typechain/common.d.ts +50 -50
- package/dist/evm/typechain/common.js +2 -2
- package/dist/evm/wallet/EVMSigner.d.ts +10 -9
- package/dist/evm/wallet/EVMSigner.js +17 -16
- package/dist/index.d.ts +38 -38
- package/dist/index.js +54 -54
- package/dist/utils/Utils.d.ts +15 -15
- package/dist/utils/Utils.js +71 -71
- package/package.json +37 -37
- package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
- package/src/chains/citrea/CitreaChainType.ts +28 -28
- package/src/chains/citrea/CitreaFees.ts +77 -77
- package/src/chains/citrea/CitreaInitializer.ts +178 -178
- package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
- package/src/chains/citrea/CitreaSwapContract.ts +102 -102
- package/src/chains/citrea/CitreaTokens.ts +21 -21
- package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
- package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
- package/src/evm/btcrelay/EVMBtcRelay.ts +522 -522
- package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
- package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
- package/src/evm/chain/EVMChainInterface.ts +155 -155
- package/src/evm/chain/EVMModule.ts +21 -21
- package/src/evm/chain/modules/ERC20Abi.ts +222 -222
- package/src/evm/chain/modules/EVMAddresses.ts +28 -28
- package/src/evm/chain/modules/EVMBlocks.ts +75 -75
- package/src/evm/chain/modules/EVMEvents.ts +139 -139
- package/src/evm/chain/modules/EVMFees.ts +104 -104
- package/src/evm/chain/modules/EVMSignatures.ts +76 -76
- package/src/evm/chain/modules/EVMTokens.ts +155 -126
- package/src/evm/chain/modules/EVMTransactions.ts +257 -246
- package/src/evm/contract/EVMContractBase.ts +63 -63
- package/src/evm/contract/EVMContractModule.ts +16 -16
- package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
- package/src/evm/events/EVMChainEvents.ts +81 -81
- package/src/evm/events/EVMChainEventsBrowser.ts +390 -390
- package/src/evm/spv_swap/EVMSpvVaultContract.ts +608 -603
- package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
- package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
- package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
- package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
- package/src/evm/swaps/EVMSwapContract.ts +592 -592
- package/src/evm/swaps/EVMSwapData.ts +378 -378
- package/src/evm/swaps/EVMSwapModule.ts +16 -16
- package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
- package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
- package/src/evm/swaps/handlers/IHandler.ts +17 -17
- package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
- package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
- package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
- package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
- package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
- package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
- package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
- package/src/evm/swaps/modules/EVMLpVault.ts +154 -152
- package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
- package/src/evm/swaps/modules/EVMSwapInit.ts +328 -325
- package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
- package/src/evm/typechain/common.ts +131 -131
- package/src/evm/wallet/EVMSigner.ts +25 -23
- package/src/index.ts +45 -45
- package/src/utils/Utils.ts +81 -81
package/dist/index.d.ts
CHANGED
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
export * from "./evm/btcrelay/headers/EVMBtcHeader";
|
|
2
|
-
export * from "./evm/btcrelay/headers/EVMBtcStoredHeader";
|
|
3
|
-
export * from "./evm/btcrelay/EVMBtcRelay";
|
|
4
|
-
export * from "./evm/chain/EVMChainInterface";
|
|
5
|
-
export * from "./evm/chain/EVMModule";
|
|
6
|
-
export * from "./evm/chain/modules/EVMAddresses";
|
|
7
|
-
export * from "./evm/chain/modules/EVMBlocks";
|
|
8
|
-
export * from "./evm/chain/modules/EVMEvents";
|
|
9
|
-
export * from "./evm/chain/modules/EVMFees";
|
|
10
|
-
export * from "./evm/chain/modules/EVMSignatures";
|
|
11
|
-
export * from "./evm/chain/modules/EVMTokens";
|
|
12
|
-
export * from "./evm/chain/modules/EVMTransactions";
|
|
13
|
-
export * from "./evm/contract/modules/EVMContractEvents";
|
|
14
|
-
export * from "./evm/contract/EVMContractBase";
|
|
15
|
-
export * from "./evm/contract/EVMContractModule";
|
|
16
|
-
export * from "./evm/events/EVMChainEventsBrowser";
|
|
17
|
-
export * from "./evm/spv_swap/EVMSpvVaultContract";
|
|
18
|
-
export * from "./evm/spv_swap/EVMSpvWithdrawalData";
|
|
19
|
-
export * from "./evm/spv_swap/EVMSpvVaultData";
|
|
20
|
-
export * from "./evm/swaps/EVMSwapContract";
|
|
21
|
-
export * from "./evm/swaps/EVMSwapData";
|
|
22
|
-
export * from "./evm/swaps/EVMSwapModule";
|
|
23
|
-
export * from "./evm/swaps/modules/EVMLpVault";
|
|
24
|
-
export * from "./evm/swaps/modules/EVMSwapInit";
|
|
25
|
-
export * from "./evm/swaps/modules/EVMSwapClaim";
|
|
26
|
-
export * from "./evm/swaps/modules/EVMSwapRefund";
|
|
27
|
-
export * from "./evm/swaps/handlers/IHandler";
|
|
28
|
-
export * from "./evm/swaps/handlers/refund/TimelockRefundHandler";
|
|
29
|
-
export * from "./evm/swaps/handlers/claim/ClaimHandlers";
|
|
30
|
-
export * from "./evm/swaps/handlers/claim/HashlockClaimHandler";
|
|
31
|
-
export * from "./evm/swaps/handlers/claim/btc/IBitcoinClaimHandler";
|
|
32
|
-
export * from "./evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler";
|
|
33
|
-
export * from "./evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler";
|
|
34
|
-
export * from "./evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler";
|
|
35
|
-
export * from "./evm/wallet/EVMSigner";
|
|
36
|
-
export * from "./chains/citrea/CitreaInitializer";
|
|
37
|
-
export * from "./chains/citrea/CitreaChainType";
|
|
38
|
-
export * from "./chains/citrea/CitreaFees";
|
|
1
|
+
export * from "./evm/btcrelay/headers/EVMBtcHeader";
|
|
2
|
+
export * from "./evm/btcrelay/headers/EVMBtcStoredHeader";
|
|
3
|
+
export * from "./evm/btcrelay/EVMBtcRelay";
|
|
4
|
+
export * from "./evm/chain/EVMChainInterface";
|
|
5
|
+
export * from "./evm/chain/EVMModule";
|
|
6
|
+
export * from "./evm/chain/modules/EVMAddresses";
|
|
7
|
+
export * from "./evm/chain/modules/EVMBlocks";
|
|
8
|
+
export * from "./evm/chain/modules/EVMEvents";
|
|
9
|
+
export * from "./evm/chain/modules/EVMFees";
|
|
10
|
+
export * from "./evm/chain/modules/EVMSignatures";
|
|
11
|
+
export * from "./evm/chain/modules/EVMTokens";
|
|
12
|
+
export * from "./evm/chain/modules/EVMTransactions";
|
|
13
|
+
export * from "./evm/contract/modules/EVMContractEvents";
|
|
14
|
+
export * from "./evm/contract/EVMContractBase";
|
|
15
|
+
export * from "./evm/contract/EVMContractModule";
|
|
16
|
+
export * from "./evm/events/EVMChainEventsBrowser";
|
|
17
|
+
export * from "./evm/spv_swap/EVMSpvVaultContract";
|
|
18
|
+
export * from "./evm/spv_swap/EVMSpvWithdrawalData";
|
|
19
|
+
export * from "./evm/spv_swap/EVMSpvVaultData";
|
|
20
|
+
export * from "./evm/swaps/EVMSwapContract";
|
|
21
|
+
export * from "./evm/swaps/EVMSwapData";
|
|
22
|
+
export * from "./evm/swaps/EVMSwapModule";
|
|
23
|
+
export * from "./evm/swaps/modules/EVMLpVault";
|
|
24
|
+
export * from "./evm/swaps/modules/EVMSwapInit";
|
|
25
|
+
export * from "./evm/swaps/modules/EVMSwapClaim";
|
|
26
|
+
export * from "./evm/swaps/modules/EVMSwapRefund";
|
|
27
|
+
export * from "./evm/swaps/handlers/IHandler";
|
|
28
|
+
export * from "./evm/swaps/handlers/refund/TimelockRefundHandler";
|
|
29
|
+
export * from "./evm/swaps/handlers/claim/ClaimHandlers";
|
|
30
|
+
export * from "./evm/swaps/handlers/claim/HashlockClaimHandler";
|
|
31
|
+
export * from "./evm/swaps/handlers/claim/btc/IBitcoinClaimHandler";
|
|
32
|
+
export * from "./evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler";
|
|
33
|
+
export * from "./evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler";
|
|
34
|
+
export * from "./evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler";
|
|
35
|
+
export * from "./evm/wallet/EVMSigner";
|
|
36
|
+
export * from "./chains/citrea/CitreaInitializer";
|
|
37
|
+
export * from "./chains/citrea/CitreaChainType";
|
|
38
|
+
export * from "./chains/citrea/CitreaFees";
|
package/dist/index.js
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./evm/btcrelay/headers/EVMBtcHeader"), exports);
|
|
18
|
-
__exportStar(require("./evm/btcrelay/headers/EVMBtcStoredHeader"), exports);
|
|
19
|
-
__exportStar(require("./evm/btcrelay/EVMBtcRelay"), exports);
|
|
20
|
-
__exportStar(require("./evm/chain/EVMChainInterface"), exports);
|
|
21
|
-
__exportStar(require("./evm/chain/EVMModule"), exports);
|
|
22
|
-
__exportStar(require("./evm/chain/modules/EVMAddresses"), exports);
|
|
23
|
-
__exportStar(require("./evm/chain/modules/EVMBlocks"), exports);
|
|
24
|
-
__exportStar(require("./evm/chain/modules/EVMEvents"), exports);
|
|
25
|
-
__exportStar(require("./evm/chain/modules/EVMFees"), exports);
|
|
26
|
-
__exportStar(require("./evm/chain/modules/EVMSignatures"), exports);
|
|
27
|
-
__exportStar(require("./evm/chain/modules/EVMTokens"), exports);
|
|
28
|
-
__exportStar(require("./evm/chain/modules/EVMTransactions"), exports);
|
|
29
|
-
__exportStar(require("./evm/contract/modules/EVMContractEvents"), exports);
|
|
30
|
-
__exportStar(require("./evm/contract/EVMContractBase"), exports);
|
|
31
|
-
__exportStar(require("./evm/contract/EVMContractModule"), exports);
|
|
32
|
-
__exportStar(require("./evm/events/EVMChainEventsBrowser"), exports);
|
|
33
|
-
__exportStar(require("./evm/spv_swap/EVMSpvVaultContract"), exports);
|
|
34
|
-
__exportStar(require("./evm/spv_swap/EVMSpvWithdrawalData"), exports);
|
|
35
|
-
__exportStar(require("./evm/spv_swap/EVMSpvVaultData"), exports);
|
|
36
|
-
__exportStar(require("./evm/swaps/EVMSwapContract"), exports);
|
|
37
|
-
__exportStar(require("./evm/swaps/EVMSwapData"), exports);
|
|
38
|
-
__exportStar(require("./evm/swaps/EVMSwapModule"), exports);
|
|
39
|
-
__exportStar(require("./evm/swaps/modules/EVMLpVault"), exports);
|
|
40
|
-
__exportStar(require("./evm/swaps/modules/EVMSwapInit"), exports);
|
|
41
|
-
__exportStar(require("./evm/swaps/modules/EVMSwapClaim"), exports);
|
|
42
|
-
__exportStar(require("./evm/swaps/modules/EVMSwapRefund"), exports);
|
|
43
|
-
__exportStar(require("./evm/swaps/handlers/IHandler"), exports);
|
|
44
|
-
__exportStar(require("./evm/swaps/handlers/refund/TimelockRefundHandler"), exports);
|
|
45
|
-
__exportStar(require("./evm/swaps/handlers/claim/ClaimHandlers"), exports);
|
|
46
|
-
__exportStar(require("./evm/swaps/handlers/claim/HashlockClaimHandler"), exports);
|
|
47
|
-
__exportStar(require("./evm/swaps/handlers/claim/btc/IBitcoinClaimHandler"), exports);
|
|
48
|
-
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler"), exports);
|
|
49
|
-
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler"), exports);
|
|
50
|
-
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler"), exports);
|
|
51
|
-
__exportStar(require("./evm/wallet/EVMSigner"), exports);
|
|
52
|
-
__exportStar(require("./chains/citrea/CitreaInitializer"), exports);
|
|
53
|
-
__exportStar(require("./chains/citrea/CitreaChainType"), exports);
|
|
54
|
-
__exportStar(require("./chains/citrea/CitreaFees"), exports);
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./evm/btcrelay/headers/EVMBtcHeader"), exports);
|
|
18
|
+
__exportStar(require("./evm/btcrelay/headers/EVMBtcStoredHeader"), exports);
|
|
19
|
+
__exportStar(require("./evm/btcrelay/EVMBtcRelay"), exports);
|
|
20
|
+
__exportStar(require("./evm/chain/EVMChainInterface"), exports);
|
|
21
|
+
__exportStar(require("./evm/chain/EVMModule"), exports);
|
|
22
|
+
__exportStar(require("./evm/chain/modules/EVMAddresses"), exports);
|
|
23
|
+
__exportStar(require("./evm/chain/modules/EVMBlocks"), exports);
|
|
24
|
+
__exportStar(require("./evm/chain/modules/EVMEvents"), exports);
|
|
25
|
+
__exportStar(require("./evm/chain/modules/EVMFees"), exports);
|
|
26
|
+
__exportStar(require("./evm/chain/modules/EVMSignatures"), exports);
|
|
27
|
+
__exportStar(require("./evm/chain/modules/EVMTokens"), exports);
|
|
28
|
+
__exportStar(require("./evm/chain/modules/EVMTransactions"), exports);
|
|
29
|
+
__exportStar(require("./evm/contract/modules/EVMContractEvents"), exports);
|
|
30
|
+
__exportStar(require("./evm/contract/EVMContractBase"), exports);
|
|
31
|
+
__exportStar(require("./evm/contract/EVMContractModule"), exports);
|
|
32
|
+
__exportStar(require("./evm/events/EVMChainEventsBrowser"), exports);
|
|
33
|
+
__exportStar(require("./evm/spv_swap/EVMSpvVaultContract"), exports);
|
|
34
|
+
__exportStar(require("./evm/spv_swap/EVMSpvWithdrawalData"), exports);
|
|
35
|
+
__exportStar(require("./evm/spv_swap/EVMSpvVaultData"), exports);
|
|
36
|
+
__exportStar(require("./evm/swaps/EVMSwapContract"), exports);
|
|
37
|
+
__exportStar(require("./evm/swaps/EVMSwapData"), exports);
|
|
38
|
+
__exportStar(require("./evm/swaps/EVMSwapModule"), exports);
|
|
39
|
+
__exportStar(require("./evm/swaps/modules/EVMLpVault"), exports);
|
|
40
|
+
__exportStar(require("./evm/swaps/modules/EVMSwapInit"), exports);
|
|
41
|
+
__exportStar(require("./evm/swaps/modules/EVMSwapClaim"), exports);
|
|
42
|
+
__exportStar(require("./evm/swaps/modules/EVMSwapRefund"), exports);
|
|
43
|
+
__exportStar(require("./evm/swaps/handlers/IHandler"), exports);
|
|
44
|
+
__exportStar(require("./evm/swaps/handlers/refund/TimelockRefundHandler"), exports);
|
|
45
|
+
__exportStar(require("./evm/swaps/handlers/claim/ClaimHandlers"), exports);
|
|
46
|
+
__exportStar(require("./evm/swaps/handlers/claim/HashlockClaimHandler"), exports);
|
|
47
|
+
__exportStar(require("./evm/swaps/handlers/claim/btc/IBitcoinClaimHandler"), exports);
|
|
48
|
+
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler"), exports);
|
|
49
|
+
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler"), exports);
|
|
50
|
+
__exportStar(require("./evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler"), exports);
|
|
51
|
+
__exportStar(require("./evm/wallet/EVMSigner"), exports);
|
|
52
|
+
__exportStar(require("./chains/citrea/CitreaInitializer"), exports);
|
|
53
|
+
__exportStar(require("./chains/citrea/CitreaChainType"), exports);
|
|
54
|
+
__exportStar(require("./chains/citrea/CitreaFees"), exports);
|
package/dist/utils/Utils.d.ts
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
export type LoggerType = {
|
|
2
|
-
debug: (msg: string, ...args: any[]) => void;
|
|
3
|
-
info: (msg: string, ...args: any[]) => void;
|
|
4
|
-
warn: (msg: string, ...args: any[]) => void;
|
|
5
|
-
error: (msg: string, ...args: any[]) => void;
|
|
6
|
-
};
|
|
7
|
-
export declare function timeoutPromise(timeoutMillis: number, abortSignal?: AbortSignal): Promise<void>;
|
|
8
|
-
export declare function onceAsync<T>(executor: () => Promise<T>): () => Promise<T>;
|
|
9
|
-
export declare function getLogger(prefix: string): LoggerType;
|
|
10
|
-
export declare function tryWithRetries<T>(func: () => Promise<T>, retryPolicy?: {
|
|
11
|
-
maxRetries?: number;
|
|
12
|
-
delay?: number;
|
|
13
|
-
exponential?: boolean;
|
|
14
|
-
}, errorAllowed?: (e: any) => boolean, abortSignal?: AbortSignal): Promise<T>;
|
|
15
|
-
export declare function uint32ReverseEndianness(value: number): number;
|
|
1
|
+
export type LoggerType = {
|
|
2
|
+
debug: (msg: string, ...args: any[]) => void;
|
|
3
|
+
info: (msg: string, ...args: any[]) => void;
|
|
4
|
+
warn: (msg: string, ...args: any[]) => void;
|
|
5
|
+
error: (msg: string, ...args: any[]) => void;
|
|
6
|
+
};
|
|
7
|
+
export declare function timeoutPromise(timeoutMillis: number, abortSignal?: AbortSignal): Promise<void>;
|
|
8
|
+
export declare function onceAsync<T>(executor: () => Promise<T>): () => Promise<T>;
|
|
9
|
+
export declare function getLogger(prefix: string): LoggerType;
|
|
10
|
+
export declare function tryWithRetries<T>(func: () => Promise<T>, retryPolicy?: {
|
|
11
|
+
maxRetries?: number;
|
|
12
|
+
delay?: number;
|
|
13
|
+
exponential?: boolean;
|
|
14
|
+
}, errorAllowed?: (e: any) => boolean, abortSignal?: AbortSignal): Promise<T>;
|
|
15
|
+
export declare function uint32ReverseEndianness(value: number): number;
|
package/dist/utils/Utils.js
CHANGED
|
@@ -1,71 +1,71 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.uint32ReverseEndianness = exports.tryWithRetries = exports.getLogger = exports.onceAsync = exports.timeoutPromise = void 0;
|
|
4
|
-
function timeoutPromise(timeoutMillis, abortSignal) {
|
|
5
|
-
return new Promise((resolve, reject) => {
|
|
6
|
-
const timeout = setTimeout(resolve, timeoutMillis);
|
|
7
|
-
if (abortSignal != null)
|
|
8
|
-
abortSignal.addEventListener("abort", () => {
|
|
9
|
-
clearTimeout(timeout);
|
|
10
|
-
reject(new Error("Aborted"));
|
|
11
|
-
});
|
|
12
|
-
});
|
|
13
|
-
}
|
|
14
|
-
exports.timeoutPromise = timeoutPromise;
|
|
15
|
-
function onceAsync(executor) {
|
|
16
|
-
let promise;
|
|
17
|
-
return () => {
|
|
18
|
-
if (promise == null) {
|
|
19
|
-
promise = executor();
|
|
20
|
-
return promise;
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
return promise.catch(() => promise = executor());
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
exports.onceAsync = onceAsync;
|
|
28
|
-
function getLogger(prefix) {
|
|
29
|
-
return {
|
|
30
|
-
debug: (msg, ...args) => global.atomiqLogLevel >= 3 && console.debug(prefix + msg, ...args),
|
|
31
|
-
info: (msg, ...args) => global.atomiqLogLevel >= 2 && console.info(prefix + msg, ...args),
|
|
32
|
-
warn: (msg, ...args) => (global.atomiqLogLevel == null || global.atomiqLogLevel >= 1) && console.warn(prefix + msg, ...args),
|
|
33
|
-
error: (msg, ...args) => (global.atomiqLogLevel == null || global.atomiqLogLevel >= 0) && console.error(prefix + msg, ...args)
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
exports.getLogger = getLogger;
|
|
37
|
-
const logger = getLogger("Utils: ");
|
|
38
|
-
async function tryWithRetries(func, retryPolicy, errorAllowed, abortSignal) {
|
|
39
|
-
retryPolicy = retryPolicy || {};
|
|
40
|
-
retryPolicy.maxRetries = retryPolicy.maxRetries || 5;
|
|
41
|
-
retryPolicy.delay = retryPolicy.delay || 500;
|
|
42
|
-
retryPolicy.exponential = retryPolicy.exponential == null ? true : retryPolicy.exponential;
|
|
43
|
-
let err = null;
|
|
44
|
-
for (let i = 0; i < retryPolicy.maxRetries; i++) {
|
|
45
|
-
try {
|
|
46
|
-
const resp = await func();
|
|
47
|
-
return resp;
|
|
48
|
-
}
|
|
49
|
-
catch (e) {
|
|
50
|
-
if (errorAllowed != null && errorAllowed(e))
|
|
51
|
-
throw e;
|
|
52
|
-
err = e;
|
|
53
|
-
logger.error("tryWithRetries(): error on try number: " + i, e);
|
|
54
|
-
}
|
|
55
|
-
if (abortSignal != null && abortSignal.aborted)
|
|
56
|
-
throw new Error("Aborted");
|
|
57
|
-
if (i !== retryPolicy.maxRetries - 1) {
|
|
58
|
-
await timeoutPromise(retryPolicy.exponential ? retryPolicy.delay * Math.pow(2, i) : retryPolicy.delay, abortSignal);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
throw err;
|
|
62
|
-
}
|
|
63
|
-
exports.tryWithRetries = tryWithRetries;
|
|
64
|
-
function uint32ReverseEndianness(value) {
|
|
65
|
-
const valueBN = BigInt(value);
|
|
66
|
-
return Number(((valueBN & 0xffn) << 24n) |
|
|
67
|
-
((valueBN & 0xff00n) << 8n) |
|
|
68
|
-
((valueBN >> 8n) & 0xff00n) |
|
|
69
|
-
((valueBN >> 24n) & 0xffn));
|
|
70
|
-
}
|
|
71
|
-
exports.uint32ReverseEndianness = uint32ReverseEndianness;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.uint32ReverseEndianness = exports.tryWithRetries = exports.getLogger = exports.onceAsync = exports.timeoutPromise = void 0;
|
|
4
|
+
function timeoutPromise(timeoutMillis, abortSignal) {
|
|
5
|
+
return new Promise((resolve, reject) => {
|
|
6
|
+
const timeout = setTimeout(resolve, timeoutMillis);
|
|
7
|
+
if (abortSignal != null)
|
|
8
|
+
abortSignal.addEventListener("abort", () => {
|
|
9
|
+
clearTimeout(timeout);
|
|
10
|
+
reject(new Error("Aborted"));
|
|
11
|
+
});
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
exports.timeoutPromise = timeoutPromise;
|
|
15
|
+
function onceAsync(executor) {
|
|
16
|
+
let promise;
|
|
17
|
+
return () => {
|
|
18
|
+
if (promise == null) {
|
|
19
|
+
promise = executor();
|
|
20
|
+
return promise;
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
return promise.catch(() => promise = executor());
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
exports.onceAsync = onceAsync;
|
|
28
|
+
function getLogger(prefix) {
|
|
29
|
+
return {
|
|
30
|
+
debug: (msg, ...args) => global.atomiqLogLevel >= 3 && console.debug(prefix + msg, ...args),
|
|
31
|
+
info: (msg, ...args) => global.atomiqLogLevel >= 2 && console.info(prefix + msg, ...args),
|
|
32
|
+
warn: (msg, ...args) => (global.atomiqLogLevel == null || global.atomiqLogLevel >= 1) && console.warn(prefix + msg, ...args),
|
|
33
|
+
error: (msg, ...args) => (global.atomiqLogLevel == null || global.atomiqLogLevel >= 0) && console.error(prefix + msg, ...args)
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
exports.getLogger = getLogger;
|
|
37
|
+
const logger = getLogger("Utils: ");
|
|
38
|
+
async function tryWithRetries(func, retryPolicy, errorAllowed, abortSignal) {
|
|
39
|
+
retryPolicy = retryPolicy || {};
|
|
40
|
+
retryPolicy.maxRetries = retryPolicy.maxRetries || 5;
|
|
41
|
+
retryPolicy.delay = retryPolicy.delay || 500;
|
|
42
|
+
retryPolicy.exponential = retryPolicy.exponential == null ? true : retryPolicy.exponential;
|
|
43
|
+
let err = null;
|
|
44
|
+
for (let i = 0; i < retryPolicy.maxRetries; i++) {
|
|
45
|
+
try {
|
|
46
|
+
const resp = await func();
|
|
47
|
+
return resp;
|
|
48
|
+
}
|
|
49
|
+
catch (e) {
|
|
50
|
+
if (errorAllowed != null && errorAllowed(e))
|
|
51
|
+
throw e;
|
|
52
|
+
err = e;
|
|
53
|
+
logger.error("tryWithRetries(): error on try number: " + i, e);
|
|
54
|
+
}
|
|
55
|
+
if (abortSignal != null && abortSignal.aborted)
|
|
56
|
+
throw new Error("Aborted");
|
|
57
|
+
if (i !== retryPolicy.maxRetries - 1) {
|
|
58
|
+
await timeoutPromise(retryPolicy.exponential ? retryPolicy.delay * Math.pow(2, i) : retryPolicy.delay, abortSignal);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
throw err;
|
|
62
|
+
}
|
|
63
|
+
exports.tryWithRetries = tryWithRetries;
|
|
64
|
+
function uint32ReverseEndianness(value) {
|
|
65
|
+
const valueBN = BigInt(value);
|
|
66
|
+
return Number(((valueBN & 0xffn) << 24n) |
|
|
67
|
+
((valueBN & 0xff00n) << 8n) |
|
|
68
|
+
((valueBN >> 8n) & 0xff00n) |
|
|
69
|
+
((valueBN >> 24n) & 0xffn));
|
|
70
|
+
}
|
|
71
|
+
exports.uint32ReverseEndianness = uint32ReverseEndianness;
|
package/package.json
CHANGED
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@atomiqlabs/chain-evm",
|
|
3
|
-
"version": "1.0.0-dev.
|
|
4
|
-
"description": "EVM specific base implementation",
|
|
5
|
-
"main": "./dist/index.js",
|
|
6
|
-
"types:": "./dist/index.d.ts",
|
|
7
|
-
"scripts": {
|
|
8
|
-
"test": "echo \"Error: no test specified\" && exit 1"
|
|
9
|
-
},
|
|
10
|
-
"files": [
|
|
11
|
-
"/dist",
|
|
12
|
-
"/src"
|
|
13
|
-
],
|
|
14
|
-
"keywords": [
|
|
15
|
-
"EVM",
|
|
16
|
-
"Ethereum",
|
|
17
|
-
"Bitcoin",
|
|
18
|
-
"Cross-chain",
|
|
19
|
-
"Cryptocurrency",
|
|
20
|
-
"Bridge",
|
|
21
|
-
"Trustless"
|
|
22
|
-
],
|
|
23
|
-
"author": "adambor",
|
|
24
|
-
"license": "Apache-2.0",
|
|
25
|
-
"dependencies": {
|
|
26
|
-
"@atomiqlabs/base": "^10.0.0-dev.8",
|
|
27
|
-
"@noble/hashes": "^1.8.0",
|
|
28
|
-
"@scure/btc-signer": "1.6.0",
|
|
29
|
-
"buffer": "6.0.3"
|
|
30
|
-
},
|
|
31
|
-
"peerDependencies": {
|
|
32
|
-
"ethers": "^6.15.0"
|
|
33
|
-
},
|
|
34
|
-
"devDependencies": {
|
|
35
|
-
"typescript": "^5.8.3"
|
|
36
|
-
}
|
|
37
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@atomiqlabs/chain-evm",
|
|
3
|
+
"version": "1.0.0-dev.37",
|
|
4
|
+
"description": "EVM specific base implementation",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"types:": "./dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"test": "echo \"Error: no test specified\" && exit 1"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"/dist",
|
|
12
|
+
"/src"
|
|
13
|
+
],
|
|
14
|
+
"keywords": [
|
|
15
|
+
"EVM",
|
|
16
|
+
"Ethereum",
|
|
17
|
+
"Bitcoin",
|
|
18
|
+
"Cross-chain",
|
|
19
|
+
"Cryptocurrency",
|
|
20
|
+
"Bridge",
|
|
21
|
+
"Trustless"
|
|
22
|
+
],
|
|
23
|
+
"author": "adambor",
|
|
24
|
+
"license": "Apache-2.0",
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@atomiqlabs/base": "^10.0.0-dev.8",
|
|
27
|
+
"@noble/hashes": "^1.8.0",
|
|
28
|
+
"@scure/btc-signer": "1.6.0",
|
|
29
|
+
"buffer": "6.0.3"
|
|
30
|
+
},
|
|
31
|
+
"peerDependencies": {
|
|
32
|
+
"ethers": "^6.15.0"
|
|
33
|
+
},
|
|
34
|
+
"devDependencies": {
|
|
35
|
+
"typescript": "^5.8.3"
|
|
36
|
+
}
|
|
37
|
+
}
|
|
@@ -1,58 +1,58 @@
|
|
|
1
|
-
import {EVMBtcRelay} from "../../evm/btcrelay/EVMBtcRelay";
|
|
2
|
-
import {BtcBlock} from "@atomiqlabs/base";
|
|
3
|
-
import {getLogger} from "../../utils/Utils";
|
|
4
|
-
import {CitreaFees} from "./CitreaFees";
|
|
5
|
-
|
|
6
|
-
const logger = getLogger("CitreaBtcRelay: ");
|
|
7
|
-
|
|
8
|
-
export class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
|
|
9
|
-
|
|
10
|
-
public static StateDiffSize = {
|
|
11
|
-
STATE_DIFF_PER_BLOCKHEADER: 22,
|
|
12
|
-
STATE_DIFF_BASE: 30
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
17
|
-
*
|
|
18
|
-
* @param requiredBlockheight
|
|
19
|
-
* @param feeRate
|
|
20
|
-
*/
|
|
21
|
-
public async estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint> {
|
|
22
|
-
feeRate ??= await this.Chain.Fees.getFeeRate();
|
|
23
|
-
const tipData = await this.getTipData();
|
|
24
|
-
const currBlockheight = tipData.blockheight;
|
|
25
|
-
|
|
26
|
-
const blockheightDelta = requiredBlockheight-currBlockheight;
|
|
27
|
-
|
|
28
|
-
if(blockheightDelta<=0) return 0n;
|
|
29
|
-
|
|
30
|
-
const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
|
|
31
|
-
|
|
32
|
-
const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
|
|
33
|
-
+ CitreaFees.getGasFee(
|
|
34
|
-
EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs,
|
|
35
|
-
feeRate,
|
|
36
|
-
CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs
|
|
37
|
-
);
|
|
38
|
-
logger.debug("estimateSynchronizeFee(): required blockheight: "+requiredBlockheight+
|
|
39
|
-
" blockheight delta: "+blockheightDelta+" fee: "+synchronizationFee.toString(10));
|
|
40
|
-
|
|
41
|
-
return synchronizationFee;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
46
|
-
*
|
|
47
|
-
* @param feeRate
|
|
48
|
-
*/
|
|
49
|
-
public async getFeePerBlock(feeRate?: string): Promise<bigint> {
|
|
50
|
-
feeRate ??= await this.Chain.Fees.getFeeRate();
|
|
51
|
-
return CitreaFees.getGasFee(
|
|
52
|
-
EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER,
|
|
53
|
-
feeRate,
|
|
54
|
-
CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
|
|
1
|
+
import {EVMBtcRelay} from "../../evm/btcrelay/EVMBtcRelay";
|
|
2
|
+
import {BtcBlock} from "@atomiqlabs/base";
|
|
3
|
+
import {getLogger} from "../../utils/Utils";
|
|
4
|
+
import {CitreaFees} from "./CitreaFees";
|
|
5
|
+
|
|
6
|
+
const logger = getLogger("CitreaBtcRelay: ");
|
|
7
|
+
|
|
8
|
+
export class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
|
|
9
|
+
|
|
10
|
+
public static StateDiffSize = {
|
|
11
|
+
STATE_DIFF_PER_BLOCKHEADER: 22,
|
|
12
|
+
STATE_DIFF_BASE: 30
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
17
|
+
*
|
|
18
|
+
* @param requiredBlockheight
|
|
19
|
+
* @param feeRate
|
|
20
|
+
*/
|
|
21
|
+
public async estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint> {
|
|
22
|
+
feeRate ??= await this.Chain.Fees.getFeeRate();
|
|
23
|
+
const tipData = await this.getTipData();
|
|
24
|
+
const currBlockheight = tipData.blockheight;
|
|
25
|
+
|
|
26
|
+
const blockheightDelta = requiredBlockheight-currBlockheight;
|
|
27
|
+
|
|
28
|
+
if(blockheightDelta<=0) return 0n;
|
|
29
|
+
|
|
30
|
+
const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
|
|
31
|
+
|
|
32
|
+
const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
|
|
33
|
+
+ CitreaFees.getGasFee(
|
|
34
|
+
EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs,
|
|
35
|
+
feeRate,
|
|
36
|
+
CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs
|
|
37
|
+
);
|
|
38
|
+
logger.debug("estimateSynchronizeFee(): required blockheight: "+requiredBlockheight+
|
|
39
|
+
" blockheight delta: "+blockheightDelta+" fee: "+synchronizationFee.toString(10));
|
|
40
|
+
|
|
41
|
+
return synchronizationFee;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
46
|
+
*
|
|
47
|
+
* @param feeRate
|
|
48
|
+
*/
|
|
49
|
+
public async getFeePerBlock(feeRate?: string): Promise<bigint> {
|
|
50
|
+
feeRate ??= await this.Chain.Fees.getFeeRate();
|
|
51
|
+
return CitreaFees.getGasFee(
|
|
52
|
+
EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER,
|
|
53
|
+
feeRate,
|
|
54
|
+
CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER
|
|
55
|
+
);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
58
|
}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import {ChainType} from "@atomiqlabs/base";
|
|
2
|
-
import {EVMPreFetchVerification} from "../../evm/swaps/modules/EVMSwapInit";
|
|
3
|
-
import {EVMTx} from "../../evm/chain/modules/EVMTransactions";
|
|
4
|
-
import {EVMSigner} from "../../evm/wallet/EVMSigner";
|
|
5
|
-
import {EVMSwapData} from "../../evm/swaps/EVMSwapData";
|
|
6
|
-
import {EVMChainInterface} from "../../evm/chain/EVMChainInterface";
|
|
7
|
-
import {EVMChainEventsBrowser} from "../../evm/events/EVMChainEventsBrowser";
|
|
8
|
-
import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
|
|
9
|
-
import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
|
|
10
|
-
import {CitreaSwapContract} from "./CitreaSwapContract";
|
|
11
|
-
import {CitreaBtcRelay} from "./CitreaBtcRelay";
|
|
12
|
-
import {CitreaSpvVaultContract} from "./CitreaSpvVaultContract";
|
|
13
|
-
|
|
14
|
-
export type CitreaChainType = ChainType<
|
|
15
|
-
"CITREA",
|
|
16
|
-
never,
|
|
17
|
-
EVMPreFetchVerification,
|
|
18
|
-
EVMTx,
|
|
19
|
-
EVMSigner,
|
|
20
|
-
EVMSwapData,
|
|
21
|
-
CitreaSwapContract,
|
|
22
|
-
EVMChainInterface<"CITREA", 5115>,
|
|
23
|
-
EVMChainEventsBrowser,
|
|
24
|
-
CitreaBtcRelay<any>,
|
|
25
|
-
EVMSpvVaultData,
|
|
26
|
-
EVMSpvWithdrawalData,
|
|
27
|
-
CitreaSpvVaultContract
|
|
28
|
-
>;
|
|
1
|
+
import {ChainType} from "@atomiqlabs/base";
|
|
2
|
+
import {EVMPreFetchVerification} from "../../evm/swaps/modules/EVMSwapInit";
|
|
3
|
+
import {EVMTx} from "../../evm/chain/modules/EVMTransactions";
|
|
4
|
+
import {EVMSigner} from "../../evm/wallet/EVMSigner";
|
|
5
|
+
import {EVMSwapData} from "../../evm/swaps/EVMSwapData";
|
|
6
|
+
import {EVMChainInterface} from "../../evm/chain/EVMChainInterface";
|
|
7
|
+
import {EVMChainEventsBrowser} from "../../evm/events/EVMChainEventsBrowser";
|
|
8
|
+
import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
|
|
9
|
+
import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
|
|
10
|
+
import {CitreaSwapContract} from "./CitreaSwapContract";
|
|
11
|
+
import {CitreaBtcRelay} from "./CitreaBtcRelay";
|
|
12
|
+
import {CitreaSpvVaultContract} from "./CitreaSpvVaultContract";
|
|
13
|
+
|
|
14
|
+
export type CitreaChainType = ChainType<
|
|
15
|
+
"CITREA",
|
|
16
|
+
never,
|
|
17
|
+
EVMPreFetchVerification,
|
|
18
|
+
EVMTx,
|
|
19
|
+
EVMSigner,
|
|
20
|
+
EVMSwapData,
|
|
21
|
+
CitreaSwapContract,
|
|
22
|
+
EVMChainInterface<"CITREA", 5115>,
|
|
23
|
+
EVMChainEventsBrowser,
|
|
24
|
+
CitreaBtcRelay<any>,
|
|
25
|
+
EVMSpvVaultData,
|
|
26
|
+
EVMSpvWithdrawalData,
|
|
27
|
+
CitreaSpvVaultContract
|
|
28
|
+
>;
|