@atomiqlabs/chain-evm 1.0.0-dev.75 → 1.0.0-dev.77
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/botanix/BotanixChainType.d.ts +13 -13
- package/dist/chains/botanix/BotanixChainType.js +2 -2
- package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
- package/dist/chains/botanix/BotanixInitializer.js +122 -122
- 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 +129 -129
- 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 +197 -197
- package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
- 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 +74 -74
- 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 -70
- package/dist/evm/chain/modules/EVMTokens.js +142 -142
- package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
- package/dist/evm/chain/modules/EVMTransactions.js +286 -286
- 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 +69 -69
- package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
- package/dist/evm/events/EVMChainEventsBrowser.js +413 -404
- package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +15 -15
- package/dist/evm/providers/JsonRpcProviderWithRetries.js +19 -19
- package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
- package/dist/evm/providers/ReconnectingWebSocketProvider.js +87 -87
- package/dist/evm/providers/SocketProvider.d.ts +111 -111
- package/dist/evm/providers/SocketProvider.js +334 -334
- package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
- package/dist/evm/providers/WebSocketProviderWithRetries.js +19 -19
- package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +79 -79
- package/dist/evm/spv_swap/EVMSpvVaultContract.js +482 -482
- package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
- package/dist/evm/spv_swap/EVMSpvVaultData.js +0 -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 +378 -378
- 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 -134
- 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 -274
- 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/EVMBrowserSigner.d.ts +5 -5
- package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
- package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
- package/dist/evm/wallet/EVMPersistentSigner.js +222 -222
- package/dist/evm/wallet/EVMSigner.d.ts +11 -11
- package/dist/evm/wallet/EVMSigner.js +24 -24
- package/dist/index.d.ts +44 -44
- package/dist/index.js +60 -60
- package/dist/utils/Utils.d.ts +17 -17
- package/dist/utils/Utils.js +81 -81
- package/package.json +39 -39
- package/src/chains/botanix/BotanixChainType.ts +28 -28
- package/src/chains/botanix/BotanixInitializer.ts +171 -171
- 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 +537 -537
- 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 -155
- package/src/evm/chain/modules/EVMTransactions.ts +325 -325
- 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 +82 -82
- package/src/evm/events/EVMChainEventsBrowser.ts +534 -525
- package/src/evm/providers/JsonRpcProviderWithRetries.ts +24 -24
- package/src/evm/providers/ReconnectingWebSocketProvider.ts +101 -101
- package/src/evm/providers/SocketProvider.ts +368 -368
- package/src/evm/providers/WebSocketProviderWithRetries.ts +27 -27
- package/src/evm/spv_swap/EVMSpvVaultContract.ts +615 -615
- 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 +600 -600
- 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 -154
- package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
- package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
- package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
- package/src/evm/typechain/common.ts +131 -131
- package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
- package/src/evm/wallet/EVMPersistentSigner.ts +298 -298
- package/src/evm/wallet/EVMSigner.ts +31 -31
- package/src/index.ts +53 -53
- package/src/utils/Utils.ts +92 -92
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import { BaseTokenType, BitcoinNetwork, BitcoinRpc, ChainData, ChainInitializer, ChainSwapType } from "@atomiqlabs/base";
|
|
2
|
-
import { JsonRpcApiProvider } from "ethers";
|
|
3
|
-
import { EVMRetryPolicy } from "../../evm/chain/EVMChainInterface";
|
|
4
|
-
import { CitreaChainType } from "./CitreaChainType";
|
|
5
|
-
import { CitreaFees } from "./CitreaFees";
|
|
6
|
-
export type CitreaAssetsType = BaseTokenType<"CBTC" | "USDC">;
|
|
7
|
-
export declare const CitreaAssets: CitreaAssetsType;
|
|
8
|
-
export type CitreaOptions = {
|
|
9
|
-
rpcUrl: string | JsonRpcApiProvider;
|
|
10
|
-
retryPolicy?: EVMRetryPolicy;
|
|
11
|
-
chainType?: "MAINNET" | "TESTNET4";
|
|
12
|
-
maxLogsBlockRange?: number;
|
|
13
|
-
swapContract?: string;
|
|
14
|
-
btcRelayContract?: string;
|
|
15
|
-
btcRelayDeploymentHeight?: number;
|
|
16
|
-
spvVaultContract?: string;
|
|
17
|
-
spvVaultDeploymentHeight?: number;
|
|
18
|
-
handlerContracts?: {
|
|
19
|
-
refund?: {
|
|
20
|
-
timelock?: string;
|
|
21
|
-
};
|
|
22
|
-
claim?: {
|
|
23
|
-
[type in ChainSwapType]?: string;
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
fees?: CitreaFees;
|
|
27
|
-
};
|
|
28
|
-
export declare function initializeCitrea(options: CitreaOptions, bitcoinRpc: BitcoinRpc<any>, network: BitcoinNetwork): ChainData<CitreaChainType>;
|
|
29
|
-
export type CitreaInitializerType = ChainInitializer<CitreaOptions, CitreaChainType, CitreaAssetsType>;
|
|
30
|
-
export declare const CitreaInitializer: CitreaInitializerType;
|
|
1
|
+
import { BaseTokenType, BitcoinNetwork, BitcoinRpc, ChainData, ChainInitializer, ChainSwapType } from "@atomiqlabs/base";
|
|
2
|
+
import { JsonRpcApiProvider } from "ethers";
|
|
3
|
+
import { EVMRetryPolicy } from "../../evm/chain/EVMChainInterface";
|
|
4
|
+
import { CitreaChainType } from "./CitreaChainType";
|
|
5
|
+
import { CitreaFees } from "./CitreaFees";
|
|
6
|
+
export type CitreaAssetsType = BaseTokenType<"CBTC" | "USDC">;
|
|
7
|
+
export declare const CitreaAssets: CitreaAssetsType;
|
|
8
|
+
export type CitreaOptions = {
|
|
9
|
+
rpcUrl: string | JsonRpcApiProvider;
|
|
10
|
+
retryPolicy?: EVMRetryPolicy;
|
|
11
|
+
chainType?: "MAINNET" | "TESTNET4";
|
|
12
|
+
maxLogsBlockRange?: number;
|
|
13
|
+
swapContract?: string;
|
|
14
|
+
btcRelayContract?: string;
|
|
15
|
+
btcRelayDeploymentHeight?: number;
|
|
16
|
+
spvVaultContract?: string;
|
|
17
|
+
spvVaultDeploymentHeight?: number;
|
|
18
|
+
handlerContracts?: {
|
|
19
|
+
refund?: {
|
|
20
|
+
timelock?: string;
|
|
21
|
+
};
|
|
22
|
+
claim?: {
|
|
23
|
+
[type in ChainSwapType]?: string;
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
fees?: CitreaFees;
|
|
27
|
+
};
|
|
28
|
+
export declare function initializeCitrea(options: CitreaOptions, bitcoinRpc: BitcoinRpc<any>, network: BitcoinNetwork): ChainData<CitreaChainType>;
|
|
29
|
+
export type CitreaInitializerType = ChainInitializer<CitreaOptions, CitreaChainType, CitreaAssetsType>;
|
|
30
|
+
export declare const CitreaInitializer: CitreaInitializerType;
|
|
@@ -1,129 +1,129 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CitreaInitializer = exports.initializeCitrea = exports.CitreaAssets = void 0;
|
|
4
|
-
const base_1 = require("@atomiqlabs/base");
|
|
5
|
-
const ethers_1 = require("ethers");
|
|
6
|
-
const EVMChainInterface_1 = require("../../evm/chain/EVMChainInterface");
|
|
7
|
-
const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
|
|
8
|
-
const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
|
|
9
|
-
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
10
|
-
const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
|
|
11
|
-
const CitreaFees_1 = require("./CitreaFees");
|
|
12
|
-
const CitreaBtcRelay_1 = require("./CitreaBtcRelay");
|
|
13
|
-
const CitreaSwapContract_1 = require("./CitreaSwapContract");
|
|
14
|
-
const CitreaTokens_1 = require("./CitreaTokens");
|
|
15
|
-
const CitreaSpvVaultContract_1 = require("./CitreaSpvVaultContract");
|
|
16
|
-
const CitreaChainIds = {
|
|
17
|
-
MAINNET: null,
|
|
18
|
-
TESTNET4: 5115
|
|
19
|
-
};
|
|
20
|
-
const CitreaContractAddresses = {
|
|
21
|
-
MAINNET: {
|
|
22
|
-
executionContract: "",
|
|
23
|
-
swapContract: "",
|
|
24
|
-
btcRelayContract: "",
|
|
25
|
-
btcRelayDeploymentHeight: 0,
|
|
26
|
-
spvVaultContract: "",
|
|
27
|
-
spvVaultDeploymentHeight: 0,
|
|
28
|
-
handlerContracts: {
|
|
29
|
-
refund: {
|
|
30
|
-
timelock: ""
|
|
31
|
-
},
|
|
32
|
-
claim: {
|
|
33
|
-
[base_1.ChainSwapType.HTLC]: "",
|
|
34
|
-
[base_1.ChainSwapType.CHAIN_TXID]: "",
|
|
35
|
-
[base_1.ChainSwapType.CHAIN]: "",
|
|
36
|
-
[base_1.ChainSwapType.CHAIN_NONCED]: ""
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
},
|
|
40
|
-
TESTNET4: {
|
|
41
|
-
executionContract: "0x9e289512965A0842b342A6BB3F3c41F22a555Cfe",
|
|
42
|
-
swapContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
|
|
43
|
-
btcRelayContract: "0x00D122E9f9766cd81a38D2dd44f9AFfb94c67Af7",
|
|
44
|
-
btcRelayDeploymentHeight: 12346223,
|
|
45
|
-
spvVaultContract: "0x9Bf990C6088F716279797a602b05941c40591533",
|
|
46
|
-
spvVaultDeploymentHeight: 12346223,
|
|
47
|
-
handlerContracts: {
|
|
48
|
-
refund: {
|
|
49
|
-
timelock: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137"
|
|
50
|
-
},
|
|
51
|
-
claim: {
|
|
52
|
-
[base_1.ChainSwapType.HTLC]: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
|
|
53
|
-
[base_1.ChainSwapType.CHAIN_TXID]: "0xf61D1da542111216337FeEA5586022130D468842",
|
|
54
|
-
[base_1.ChainSwapType.CHAIN]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
|
|
55
|
-
[base_1.ChainSwapType.CHAIN_NONCED]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0"
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
exports.CitreaAssets = {
|
|
61
|
-
CBTC: {
|
|
62
|
-
address: "0x0000000000000000000000000000000000000000",
|
|
63
|
-
decimals: 18,
|
|
64
|
-
displayDecimals: 8
|
|
65
|
-
},
|
|
66
|
-
USDC: {
|
|
67
|
-
address: "0x2C8abD2A528D19AFc33d2ebA507c0F405c131335",
|
|
68
|
-
decimals: 6,
|
|
69
|
-
displayDecimals: 6
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
function initializeCitrea(options, bitcoinRpc, network) {
|
|
73
|
-
if (options.chainType == null) {
|
|
74
|
-
switch (network) {
|
|
75
|
-
case base_1.BitcoinNetwork.TESTNET4:
|
|
76
|
-
options.chainType = "TESTNET4";
|
|
77
|
-
break;
|
|
78
|
-
case base_1.BitcoinNetwork.MAINNET:
|
|
79
|
-
options.chainType = "MAINNET";
|
|
80
|
-
break;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
const defaultContractAddresses = CitreaContractAddresses[options.chainType];
|
|
84
|
-
const chainId = CitreaChainIds[options.chainType];
|
|
85
|
-
const provider = typeof (options.rpcUrl) === "string" ?
|
|
86
|
-
(options.rpcUrl.startsWith("ws")
|
|
87
|
-
? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Citrea", chainId })
|
|
88
|
-
: new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Citrea", chainId })) :
|
|
89
|
-
options.rpcUrl;
|
|
90
|
-
const Fees = options.fees ?? new CitreaFees_1.CitreaFees(provider, 2n * 1000000000n, 1000000n);
|
|
91
|
-
const chainInterface = new EVMChainInterface_1.EVMChainInterface("CITREA", chainId, provider, {
|
|
92
|
-
safeBlockTag: "latest",
|
|
93
|
-
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
94
|
-
}, options.retryPolicy, Fees);
|
|
95
|
-
chainInterface.Tokens = new CitreaTokens_1.CitreaTokens(chainInterface); //Override with custom token module allowing l1 state diff based fee calculation
|
|
96
|
-
const btcRelay = new CitreaBtcRelay_1.CitreaBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
97
|
-
const swapContract = new CitreaSwapContract_1.CitreaSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
98
|
-
refund: {
|
|
99
|
-
...defaultContractAddresses.handlerContracts.refund,
|
|
100
|
-
...options?.handlerContracts?.refund
|
|
101
|
-
},
|
|
102
|
-
claim: {
|
|
103
|
-
...defaultContractAddresses.handlerContracts.claim,
|
|
104
|
-
...options?.handlerContracts?.claim
|
|
105
|
-
}
|
|
106
|
-
});
|
|
107
|
-
const spvVaultContract = new CitreaSpvVaultContract_1.CitreaSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
108
|
-
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
109
|
-
return {
|
|
110
|
-
chainId: "CITREA",
|
|
111
|
-
btcRelay,
|
|
112
|
-
chainInterface,
|
|
113
|
-
swapContract,
|
|
114
|
-
chainEvents,
|
|
115
|
-
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
116
|
-
spvVaultContract,
|
|
117
|
-
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
118
|
-
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
exports.initializeCitrea = initializeCitrea;
|
|
122
|
-
;
|
|
123
|
-
exports.CitreaInitializer = {
|
|
124
|
-
chainId: "CITREA",
|
|
125
|
-
chainType: null,
|
|
126
|
-
initializer: initializeCitrea,
|
|
127
|
-
tokens: exports.CitreaAssets,
|
|
128
|
-
options: null
|
|
129
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CitreaInitializer = exports.initializeCitrea = exports.CitreaAssets = void 0;
|
|
4
|
+
const base_1 = require("@atomiqlabs/base");
|
|
5
|
+
const ethers_1 = require("ethers");
|
|
6
|
+
const EVMChainInterface_1 = require("../../evm/chain/EVMChainInterface");
|
|
7
|
+
const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
|
|
8
|
+
const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
|
|
9
|
+
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
10
|
+
const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
|
|
11
|
+
const CitreaFees_1 = require("./CitreaFees");
|
|
12
|
+
const CitreaBtcRelay_1 = require("./CitreaBtcRelay");
|
|
13
|
+
const CitreaSwapContract_1 = require("./CitreaSwapContract");
|
|
14
|
+
const CitreaTokens_1 = require("./CitreaTokens");
|
|
15
|
+
const CitreaSpvVaultContract_1 = require("./CitreaSpvVaultContract");
|
|
16
|
+
const CitreaChainIds = {
|
|
17
|
+
MAINNET: null,
|
|
18
|
+
TESTNET4: 5115
|
|
19
|
+
};
|
|
20
|
+
const CitreaContractAddresses = {
|
|
21
|
+
MAINNET: {
|
|
22
|
+
executionContract: "",
|
|
23
|
+
swapContract: "",
|
|
24
|
+
btcRelayContract: "",
|
|
25
|
+
btcRelayDeploymentHeight: 0,
|
|
26
|
+
spvVaultContract: "",
|
|
27
|
+
spvVaultDeploymentHeight: 0,
|
|
28
|
+
handlerContracts: {
|
|
29
|
+
refund: {
|
|
30
|
+
timelock: ""
|
|
31
|
+
},
|
|
32
|
+
claim: {
|
|
33
|
+
[base_1.ChainSwapType.HTLC]: "",
|
|
34
|
+
[base_1.ChainSwapType.CHAIN_TXID]: "",
|
|
35
|
+
[base_1.ChainSwapType.CHAIN]: "",
|
|
36
|
+
[base_1.ChainSwapType.CHAIN_NONCED]: ""
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
TESTNET4: {
|
|
41
|
+
executionContract: "0x9e289512965A0842b342A6BB3F3c41F22a555Cfe",
|
|
42
|
+
swapContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
|
|
43
|
+
btcRelayContract: "0x00D122E9f9766cd81a38D2dd44f9AFfb94c67Af7",
|
|
44
|
+
btcRelayDeploymentHeight: 12346223,
|
|
45
|
+
spvVaultContract: "0x9Bf990C6088F716279797a602b05941c40591533",
|
|
46
|
+
spvVaultDeploymentHeight: 12346223,
|
|
47
|
+
handlerContracts: {
|
|
48
|
+
refund: {
|
|
49
|
+
timelock: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137"
|
|
50
|
+
},
|
|
51
|
+
claim: {
|
|
52
|
+
[base_1.ChainSwapType.HTLC]: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
|
|
53
|
+
[base_1.ChainSwapType.CHAIN_TXID]: "0xf61D1da542111216337FeEA5586022130D468842",
|
|
54
|
+
[base_1.ChainSwapType.CHAIN]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
|
|
55
|
+
[base_1.ChainSwapType.CHAIN_NONCED]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0"
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
exports.CitreaAssets = {
|
|
61
|
+
CBTC: {
|
|
62
|
+
address: "0x0000000000000000000000000000000000000000",
|
|
63
|
+
decimals: 18,
|
|
64
|
+
displayDecimals: 8
|
|
65
|
+
},
|
|
66
|
+
USDC: {
|
|
67
|
+
address: "0x2C8abD2A528D19AFc33d2ebA507c0F405c131335",
|
|
68
|
+
decimals: 6,
|
|
69
|
+
displayDecimals: 6
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
function initializeCitrea(options, bitcoinRpc, network) {
|
|
73
|
+
if (options.chainType == null) {
|
|
74
|
+
switch (network) {
|
|
75
|
+
case base_1.BitcoinNetwork.TESTNET4:
|
|
76
|
+
options.chainType = "TESTNET4";
|
|
77
|
+
break;
|
|
78
|
+
case base_1.BitcoinNetwork.MAINNET:
|
|
79
|
+
options.chainType = "MAINNET";
|
|
80
|
+
break;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
const defaultContractAddresses = CitreaContractAddresses[options.chainType];
|
|
84
|
+
const chainId = CitreaChainIds[options.chainType];
|
|
85
|
+
const provider = typeof (options.rpcUrl) === "string" ?
|
|
86
|
+
(options.rpcUrl.startsWith("ws")
|
|
87
|
+
? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Citrea", chainId })
|
|
88
|
+
: new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Citrea", chainId })) :
|
|
89
|
+
options.rpcUrl;
|
|
90
|
+
const Fees = options.fees ?? new CitreaFees_1.CitreaFees(provider, 2n * 1000000000n, 1000000n);
|
|
91
|
+
const chainInterface = new EVMChainInterface_1.EVMChainInterface("CITREA", chainId, provider, {
|
|
92
|
+
safeBlockTag: "latest",
|
|
93
|
+
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
94
|
+
}, options.retryPolicy, Fees);
|
|
95
|
+
chainInterface.Tokens = new CitreaTokens_1.CitreaTokens(chainInterface); //Override with custom token module allowing l1 state diff based fee calculation
|
|
96
|
+
const btcRelay = new CitreaBtcRelay_1.CitreaBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
97
|
+
const swapContract = new CitreaSwapContract_1.CitreaSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
98
|
+
refund: {
|
|
99
|
+
...defaultContractAddresses.handlerContracts.refund,
|
|
100
|
+
...options?.handlerContracts?.refund
|
|
101
|
+
},
|
|
102
|
+
claim: {
|
|
103
|
+
...defaultContractAddresses.handlerContracts.claim,
|
|
104
|
+
...options?.handlerContracts?.claim
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
const spvVaultContract = new CitreaSpvVaultContract_1.CitreaSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
108
|
+
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
109
|
+
return {
|
|
110
|
+
chainId: "CITREA",
|
|
111
|
+
btcRelay,
|
|
112
|
+
chainInterface,
|
|
113
|
+
swapContract,
|
|
114
|
+
chainEvents,
|
|
115
|
+
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
116
|
+
spvVaultContract,
|
|
117
|
+
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
118
|
+
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
exports.initializeCitrea = initializeCitrea;
|
|
122
|
+
;
|
|
123
|
+
exports.CitreaInitializer = {
|
|
124
|
+
chainId: "CITREA",
|
|
125
|
+
chainType: null,
|
|
126
|
+
initializer: initializeCitrea,
|
|
127
|
+
tokens: exports.CitreaAssets,
|
|
128
|
+
options: null
|
|
129
|
+
};
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { EVMSpvVaultContract } from "../../evm/spv_swap/EVMSpvVaultContract";
|
|
2
|
-
import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
|
|
3
|
-
import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
|
|
4
|
-
export declare class CitreaSpvVaultContract extends EVMSpvVaultContract<"CITREA"> {
|
|
5
|
-
static readonly StateDiffSize: {
|
|
6
|
-
BASE_DIFF_SIZE: number;
|
|
7
|
-
ERC_20_TRANSFER_DIFF_SIZE: number;
|
|
8
|
-
NATIVE_SELF_TRANSFER_DIFF_SIZE: number;
|
|
9
|
-
NATIVE_TRANSFER_DIFF_SIZE: number;
|
|
10
|
-
EXECUTION_SCHEDULE_DIFF_SIZE: number;
|
|
11
|
-
};
|
|
12
|
-
private calculateStateDiff;
|
|
13
|
-
getClaimFee(signer: string, vault?: EVMSpvVaultData, data?: EVMSpvWithdrawalData, feeRate?: string): Promise<bigint>;
|
|
14
|
-
getFrontFee(signer: string, vault?: EVMSpvVaultData, data?: EVMSpvWithdrawalData, feeRate?: string): Promise<bigint>;
|
|
15
|
-
}
|
|
1
|
+
import { EVMSpvVaultContract } from "../../evm/spv_swap/EVMSpvVaultContract";
|
|
2
|
+
import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
|
|
3
|
+
import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
|
|
4
|
+
export declare class CitreaSpvVaultContract extends EVMSpvVaultContract<"CITREA"> {
|
|
5
|
+
static readonly StateDiffSize: {
|
|
6
|
+
BASE_DIFF_SIZE: number;
|
|
7
|
+
ERC_20_TRANSFER_DIFF_SIZE: number;
|
|
8
|
+
NATIVE_SELF_TRANSFER_DIFF_SIZE: number;
|
|
9
|
+
NATIVE_TRANSFER_DIFF_SIZE: number;
|
|
10
|
+
EXECUTION_SCHEDULE_DIFF_SIZE: number;
|
|
11
|
+
};
|
|
12
|
+
private calculateStateDiff;
|
|
13
|
+
getClaimFee(signer: string, vault?: EVMSpvVaultData, data?: EVMSpvWithdrawalData, feeRate?: string): Promise<bigint>;
|
|
14
|
+
getFrontFee(signer: string, vault?: EVMSpvVaultData, data?: EVMSpvWithdrawalData, feeRate?: string): Promise<bigint>;
|
|
15
|
+
}
|
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CitreaSpvVaultContract = void 0;
|
|
4
|
-
const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
|
|
5
|
-
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
6
|
-
const ethers_1 = require("ethers");
|
|
7
|
-
const CitreaFees_1 = require("./CitreaFees");
|
|
8
|
-
const EVMAddresses_1 = require("../../evm/chain/modules/EVMAddresses");
|
|
9
|
-
class CitreaSpvVaultContract extends EVMSpvVaultContract_1.EVMSpvVaultContract {
|
|
10
|
-
calculateStateDiff(signer, tokenStateChanges) {
|
|
11
|
-
let stateDiffSize = 0;
|
|
12
|
-
tokenStateChanges.forEach(val => {
|
|
13
|
-
const [address, token] = val.split(":");
|
|
14
|
-
if (token.toLowerCase() === this.Chain.getNativeCurrencyAddress().toLowerCase()) {
|
|
15
|
-
stateDiffSize += address.toLowerCase() === signer?.toLowerCase() ? CitreaSpvVaultContract.StateDiffSize.NATIVE_SELF_TRANSFER_DIFF_SIZE : CitreaSpvVaultContract.StateDiffSize.NATIVE_TRANSFER_DIFF_SIZE;
|
|
16
|
-
}
|
|
17
|
-
else {
|
|
18
|
-
stateDiffSize += CitreaSpvVaultContract.StateDiffSize.ERC_20_TRANSFER_DIFF_SIZE;
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
return stateDiffSize;
|
|
22
|
-
}
|
|
23
|
-
async getClaimFee(signer, vault, data, feeRate) {
|
|
24
|
-
vault ?? (vault = EVMSpvVaultData_1.EVMSpvVaultData.randomVault());
|
|
25
|
-
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
26
|
-
const tokenStateChanges = new Set();
|
|
27
|
-
let diffSize = CitreaSpvVaultContract.StateDiffSize.BASE_DIFF_SIZE;
|
|
28
|
-
const recipient = data != null ? data.recipient : EVMAddresses_1.EVMAddresses.randomAddress();
|
|
29
|
-
if (data == null || (data.rawAmounts[0] != null && data.rawAmounts[0] > 0n)) {
|
|
30
|
-
tokenStateChanges.add(recipient.toLowerCase() + ":" + vault.token0.token.toLowerCase());
|
|
31
|
-
if (data == null || data.frontingFeeRate > 0n)
|
|
32
|
-
tokenStateChanges.add(ethers_1.ZeroAddress + ":" + vault.token0.token.toLowerCase()); //Also needs to pay out to fronter
|
|
33
|
-
if (data == null || data.callerFeeRate > 0n)
|
|
34
|
-
tokenStateChanges.add(signer + ":" + vault.token0.token.toLowerCase()); //Also needs to pay out to caller
|
|
35
|
-
}
|
|
36
|
-
if (data == null || (data.rawAmounts[1] != null && data.rawAmounts[1] > 0n)) {
|
|
37
|
-
tokenStateChanges.add(recipient.toLowerCase() + ":" + vault.token1.token.toLowerCase());
|
|
38
|
-
if (data == null || data.frontingFeeRate > 0n)
|
|
39
|
-
tokenStateChanges.add(ethers_1.ZeroAddress + ":" + vault.token1.token.toLowerCase()); //Also needs to pay out to fronter
|
|
40
|
-
if (data == null || data.callerFeeRate > 0n)
|
|
41
|
-
tokenStateChanges.add(signer + ":" + vault.token1.token.toLowerCase()); //Also needs to pay out to caller
|
|
42
|
-
}
|
|
43
|
-
diffSize += this.calculateStateDiff(signer, tokenStateChanges);
|
|
44
|
-
if (data == null || (data.executionHash != null && data.executionHash !== ethers_1.ZeroHash))
|
|
45
|
-
diffSize += CitreaSpvVaultContract.StateDiffSize.EXECUTION_SCHEDULE_DIFF_SIZE;
|
|
46
|
-
const gasFee = await super.getClaimFee(signer, vault, data, feeRate);
|
|
47
|
-
return gasFee + CitreaFees_1.CitreaFees.getGasFee(0, feeRate, diffSize);
|
|
48
|
-
}
|
|
49
|
-
async getFrontFee(signer, vault, data, feeRate) {
|
|
50
|
-
vault ?? (vault = EVMSpvVaultData_1.EVMSpvVaultData.randomVault());
|
|
51
|
-
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
52
|
-
const tokenStateChanges = new Set();
|
|
53
|
-
let diffSize = CitreaSpvVaultContract.StateDiffSize.BASE_DIFF_SIZE;
|
|
54
|
-
if (data == null || (data.rawAmounts[0] != null && data.rawAmounts[0] > 0n)) {
|
|
55
|
-
tokenStateChanges.add(signer + ":" + vault.token0.token.toLowerCase());
|
|
56
|
-
}
|
|
57
|
-
if (data == null || (data.rawAmounts[1] != null && data.rawAmounts[1] > 0n)) {
|
|
58
|
-
tokenStateChanges.add(signer + ":" + vault.token1.token.toLowerCase());
|
|
59
|
-
}
|
|
60
|
-
diffSize += this.calculateStateDiff(signer, tokenStateChanges);
|
|
61
|
-
if (data == null || (data.executionHash != null && data.executionHash !== ethers_1.ZeroHash))
|
|
62
|
-
diffSize += CitreaSpvVaultContract.StateDiffSize.EXECUTION_SCHEDULE_DIFF_SIZE;
|
|
63
|
-
const gasFee = await super.getFrontFee(signer, vault, data, feeRate);
|
|
64
|
-
return gasFee + CitreaFees_1.CitreaFees.getGasFee(0, feeRate, diffSize);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
exports.CitreaSpvVaultContract = CitreaSpvVaultContract;
|
|
68
|
-
CitreaSpvVaultContract.StateDiffSize = {
|
|
69
|
-
BASE_DIFF_SIZE: 50,
|
|
70
|
-
ERC_20_TRANSFER_DIFF_SIZE: 50,
|
|
71
|
-
NATIVE_SELF_TRANSFER_DIFF_SIZE: 20,
|
|
72
|
-
NATIVE_TRANSFER_DIFF_SIZE: 30,
|
|
73
|
-
EXECUTION_SCHEDULE_DIFF_SIZE: 40
|
|
74
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CitreaSpvVaultContract = void 0;
|
|
4
|
+
const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
|
|
5
|
+
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
6
|
+
const ethers_1 = require("ethers");
|
|
7
|
+
const CitreaFees_1 = require("./CitreaFees");
|
|
8
|
+
const EVMAddresses_1 = require("../../evm/chain/modules/EVMAddresses");
|
|
9
|
+
class CitreaSpvVaultContract extends EVMSpvVaultContract_1.EVMSpvVaultContract {
|
|
10
|
+
calculateStateDiff(signer, tokenStateChanges) {
|
|
11
|
+
let stateDiffSize = 0;
|
|
12
|
+
tokenStateChanges.forEach(val => {
|
|
13
|
+
const [address, token] = val.split(":");
|
|
14
|
+
if (token.toLowerCase() === this.Chain.getNativeCurrencyAddress().toLowerCase()) {
|
|
15
|
+
stateDiffSize += address.toLowerCase() === signer?.toLowerCase() ? CitreaSpvVaultContract.StateDiffSize.NATIVE_SELF_TRANSFER_DIFF_SIZE : CitreaSpvVaultContract.StateDiffSize.NATIVE_TRANSFER_DIFF_SIZE;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
stateDiffSize += CitreaSpvVaultContract.StateDiffSize.ERC_20_TRANSFER_DIFF_SIZE;
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
return stateDiffSize;
|
|
22
|
+
}
|
|
23
|
+
async getClaimFee(signer, vault, data, feeRate) {
|
|
24
|
+
vault ?? (vault = EVMSpvVaultData_1.EVMSpvVaultData.randomVault());
|
|
25
|
+
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
26
|
+
const tokenStateChanges = new Set();
|
|
27
|
+
let diffSize = CitreaSpvVaultContract.StateDiffSize.BASE_DIFF_SIZE;
|
|
28
|
+
const recipient = data != null ? data.recipient : EVMAddresses_1.EVMAddresses.randomAddress();
|
|
29
|
+
if (data == null || (data.rawAmounts[0] != null && data.rawAmounts[0] > 0n)) {
|
|
30
|
+
tokenStateChanges.add(recipient.toLowerCase() + ":" + vault.token0.token.toLowerCase());
|
|
31
|
+
if (data == null || data.frontingFeeRate > 0n)
|
|
32
|
+
tokenStateChanges.add(ethers_1.ZeroAddress + ":" + vault.token0.token.toLowerCase()); //Also needs to pay out to fronter
|
|
33
|
+
if (data == null || data.callerFeeRate > 0n)
|
|
34
|
+
tokenStateChanges.add(signer + ":" + vault.token0.token.toLowerCase()); //Also needs to pay out to caller
|
|
35
|
+
}
|
|
36
|
+
if (data == null || (data.rawAmounts[1] != null && data.rawAmounts[1] > 0n)) {
|
|
37
|
+
tokenStateChanges.add(recipient.toLowerCase() + ":" + vault.token1.token.toLowerCase());
|
|
38
|
+
if (data == null || data.frontingFeeRate > 0n)
|
|
39
|
+
tokenStateChanges.add(ethers_1.ZeroAddress + ":" + vault.token1.token.toLowerCase()); //Also needs to pay out to fronter
|
|
40
|
+
if (data == null || data.callerFeeRate > 0n)
|
|
41
|
+
tokenStateChanges.add(signer + ":" + vault.token1.token.toLowerCase()); //Also needs to pay out to caller
|
|
42
|
+
}
|
|
43
|
+
diffSize += this.calculateStateDiff(signer, tokenStateChanges);
|
|
44
|
+
if (data == null || (data.executionHash != null && data.executionHash !== ethers_1.ZeroHash))
|
|
45
|
+
diffSize += CitreaSpvVaultContract.StateDiffSize.EXECUTION_SCHEDULE_DIFF_SIZE;
|
|
46
|
+
const gasFee = await super.getClaimFee(signer, vault, data, feeRate);
|
|
47
|
+
return gasFee + CitreaFees_1.CitreaFees.getGasFee(0, feeRate, diffSize);
|
|
48
|
+
}
|
|
49
|
+
async getFrontFee(signer, vault, data, feeRate) {
|
|
50
|
+
vault ?? (vault = EVMSpvVaultData_1.EVMSpvVaultData.randomVault());
|
|
51
|
+
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
52
|
+
const tokenStateChanges = new Set();
|
|
53
|
+
let diffSize = CitreaSpvVaultContract.StateDiffSize.BASE_DIFF_SIZE;
|
|
54
|
+
if (data == null || (data.rawAmounts[0] != null && data.rawAmounts[0] > 0n)) {
|
|
55
|
+
tokenStateChanges.add(signer + ":" + vault.token0.token.toLowerCase());
|
|
56
|
+
}
|
|
57
|
+
if (data == null || (data.rawAmounts[1] != null && data.rawAmounts[1] > 0n)) {
|
|
58
|
+
tokenStateChanges.add(signer + ":" + vault.token1.token.toLowerCase());
|
|
59
|
+
}
|
|
60
|
+
diffSize += this.calculateStateDiff(signer, tokenStateChanges);
|
|
61
|
+
if (data == null || (data.executionHash != null && data.executionHash !== ethers_1.ZeroHash))
|
|
62
|
+
diffSize += CitreaSpvVaultContract.StateDiffSize.EXECUTION_SCHEDULE_DIFF_SIZE;
|
|
63
|
+
const gasFee = await super.getFrontFee(signer, vault, data, feeRate);
|
|
64
|
+
return gasFee + CitreaFees_1.CitreaFees.getGasFee(0, feeRate, diffSize);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.CitreaSpvVaultContract = CitreaSpvVaultContract;
|
|
68
|
+
CitreaSpvVaultContract.StateDiffSize = {
|
|
69
|
+
BASE_DIFF_SIZE: 50,
|
|
70
|
+
ERC_20_TRANSFER_DIFF_SIZE: 50,
|
|
71
|
+
NATIVE_SELF_TRANSFER_DIFF_SIZE: 20,
|
|
72
|
+
NATIVE_TRANSFER_DIFF_SIZE: 30,
|
|
73
|
+
EXECUTION_SCHEDULE_DIFF_SIZE: 40
|
|
74
|
+
};
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import { EVMSwapContract } from "../../evm/swaps/EVMSwapContract";
|
|
2
|
-
import { EVMSwapData } from "../../evm/swaps/EVMSwapData";
|
|
3
|
-
export declare class CitreaSwapContract extends EVMSwapContract<"CITREA"> {
|
|
4
|
-
static readonly StateDiffSize: {
|
|
5
|
-
BASE_DIFF_SIZE: number;
|
|
6
|
-
REPUTATION_UPDATE_DIFF_SIZE: number;
|
|
7
|
-
LP_VAULT_UPDATE_DIFF_SIZE: number;
|
|
8
|
-
ERC_20_TRANSFER_DIFF_SIZE: number;
|
|
9
|
-
NATIVE_SELF_TRANSFER_DIFF_SIZE: number;
|
|
10
|
-
NATIVE_TRANSFER_DIFF_SIZE: number;
|
|
11
|
-
};
|
|
12
|
-
private calculateStateDiff;
|
|
13
|
-
/**
|
|
14
|
-
* Get the estimated solana fee of the commit transaction
|
|
15
|
-
*/
|
|
16
|
-
getCommitFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
17
|
-
getClaimFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
18
|
-
/**
|
|
19
|
-
* Get the estimated solana transaction fee of the refund transaction
|
|
20
|
-
*/
|
|
21
|
-
getRefundFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
22
|
-
}
|
|
1
|
+
import { EVMSwapContract } from "../../evm/swaps/EVMSwapContract";
|
|
2
|
+
import { EVMSwapData } from "../../evm/swaps/EVMSwapData";
|
|
3
|
+
export declare class CitreaSwapContract extends EVMSwapContract<"CITREA"> {
|
|
4
|
+
static readonly StateDiffSize: {
|
|
5
|
+
BASE_DIFF_SIZE: number;
|
|
6
|
+
REPUTATION_UPDATE_DIFF_SIZE: number;
|
|
7
|
+
LP_VAULT_UPDATE_DIFF_SIZE: number;
|
|
8
|
+
ERC_20_TRANSFER_DIFF_SIZE: number;
|
|
9
|
+
NATIVE_SELF_TRANSFER_DIFF_SIZE: number;
|
|
10
|
+
NATIVE_TRANSFER_DIFF_SIZE: number;
|
|
11
|
+
};
|
|
12
|
+
private calculateStateDiff;
|
|
13
|
+
/**
|
|
14
|
+
* Get the estimated solana fee of the commit transaction
|
|
15
|
+
*/
|
|
16
|
+
getCommitFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
17
|
+
getClaimFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
18
|
+
/**
|
|
19
|
+
* Get the estimated solana transaction fee of the refund transaction
|
|
20
|
+
*/
|
|
21
|
+
getRefundFee(signer: string, swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
|
|
22
|
+
}
|