@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
|
@@ -1,67 +1,67 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CitreaFees = void 0;
|
|
4
|
-
const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
|
|
5
|
-
const Utils_1 = require("../../utils/Utils");
|
|
6
|
-
class CitreaFees extends EVMFees_1.EVMFees {
|
|
7
|
-
constructor() {
|
|
8
|
-
super(...arguments);
|
|
9
|
-
this.logger = (0, Utils_1.getLogger)("CitreaFees: ");
|
|
10
|
-
this._blockFeeCache = null;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Gets evm fee rate
|
|
14
|
-
*
|
|
15
|
-
* @private
|
|
16
|
-
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
17
|
-
*/
|
|
18
|
-
async __getFeeRate() {
|
|
19
|
-
const res = await this.provider.send("eth_getBlockByNumber", ["latest", false]);
|
|
20
|
-
const l1Fee = BigInt(res.l1FeeRate);
|
|
21
|
-
const baseFee = BigInt(res.baseFeePerGas) * this.feeMultiplierPPM / 1000000n;
|
|
22
|
-
this.logger.debug("__getFeeRate(): Base fee rate: " + baseFee.toString(10) + ", l1 fee rate: " + l1Fee.toString(10));
|
|
23
|
-
return { baseFee, l1Fee };
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
|
|
27
|
-
*
|
|
28
|
-
* @private
|
|
29
|
-
*/
|
|
30
|
-
async getFeeRate() {
|
|
31
|
-
if (this._blockFeeCache == null || Date.now() - this._blockFeeCache.timestamp > this.MAX_FEE_AGE) {
|
|
32
|
-
let obj = {
|
|
33
|
-
timestamp: Date.now(),
|
|
34
|
-
feeRate: null
|
|
35
|
-
};
|
|
36
|
-
obj.feeRate = this.__getFeeRate().catch(e => {
|
|
37
|
-
if (this._blockFeeCache === obj)
|
|
38
|
-
this._blockFeeCache = null;
|
|
39
|
-
throw e;
|
|
40
|
-
});
|
|
41
|
-
this._blockFeeCache = obj;
|
|
42
|
-
}
|
|
43
|
-
let { baseFee, l1Fee } = await this._blockFeeCache.feeRate;
|
|
44
|
-
if (baseFee > this.maxFeeRatePerGas)
|
|
45
|
-
baseFee = this.maxFeeRatePerGas;
|
|
46
|
-
const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10) + "," + l1Fee.toString(10);
|
|
47
|
-
this.logger.debug("getFeeRate(): calculated fee: " + fee);
|
|
48
|
-
return fee;
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
|
|
52
|
-
*
|
|
53
|
-
* @param gas
|
|
54
|
-
* @param stateDiffSize
|
|
55
|
-
* @param feeRate
|
|
56
|
-
*/
|
|
57
|
-
static getGasFee(gas, feeRate, stateDiffSize = 0) {
|
|
58
|
-
if (feeRate == null)
|
|
59
|
-
return 0n;
|
|
60
|
-
const [maxFee, priorityFee, l1StateDiffFee] = feeRate.split(",");
|
|
61
|
-
return (BigInt(gas) * BigInt(maxFee)) + (BigInt(stateDiffSize) * BigInt(l1StateDiffFee ?? 0n));
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
exports.CitreaFees = CitreaFees;
|
|
65
|
-
CitreaFees.StateDiffSize = {
|
|
66
|
-
APPROVE_DIFF_SIZE: 40,
|
|
67
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CitreaFees = void 0;
|
|
4
|
+
const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
|
|
5
|
+
const Utils_1 = require("../../utils/Utils");
|
|
6
|
+
class CitreaFees extends EVMFees_1.EVMFees {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this.logger = (0, Utils_1.getLogger)("CitreaFees: ");
|
|
10
|
+
this._blockFeeCache = null;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Gets evm fee rate
|
|
14
|
+
*
|
|
15
|
+
* @private
|
|
16
|
+
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
17
|
+
*/
|
|
18
|
+
async __getFeeRate() {
|
|
19
|
+
const res = await this.provider.send("eth_getBlockByNumber", ["latest", false]);
|
|
20
|
+
const l1Fee = BigInt(res.l1FeeRate);
|
|
21
|
+
const baseFee = BigInt(res.baseFeePerGas) * this.feeMultiplierPPM / 1000000n;
|
|
22
|
+
this.logger.debug("__getFeeRate(): Base fee rate: " + baseFee.toString(10) + ", l1 fee rate: " + l1Fee.toString(10));
|
|
23
|
+
return { baseFee, l1Fee };
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
|
|
27
|
+
*
|
|
28
|
+
* @private
|
|
29
|
+
*/
|
|
30
|
+
async getFeeRate() {
|
|
31
|
+
if (this._blockFeeCache == null || Date.now() - this._blockFeeCache.timestamp > this.MAX_FEE_AGE) {
|
|
32
|
+
let obj = {
|
|
33
|
+
timestamp: Date.now(),
|
|
34
|
+
feeRate: null
|
|
35
|
+
};
|
|
36
|
+
obj.feeRate = this.__getFeeRate().catch(e => {
|
|
37
|
+
if (this._blockFeeCache === obj)
|
|
38
|
+
this._blockFeeCache = null;
|
|
39
|
+
throw e;
|
|
40
|
+
});
|
|
41
|
+
this._blockFeeCache = obj;
|
|
42
|
+
}
|
|
43
|
+
let { baseFee, l1Fee } = await this._blockFeeCache.feeRate;
|
|
44
|
+
if (baseFee > this.maxFeeRatePerGas)
|
|
45
|
+
baseFee = this.maxFeeRatePerGas;
|
|
46
|
+
const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10) + "," + l1Fee.toString(10);
|
|
47
|
+
this.logger.debug("getFeeRate(): calculated fee: " + fee);
|
|
48
|
+
return fee;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
|
|
52
|
+
*
|
|
53
|
+
* @param gas
|
|
54
|
+
* @param stateDiffSize
|
|
55
|
+
* @param feeRate
|
|
56
|
+
*/
|
|
57
|
+
static getGasFee(gas, feeRate, stateDiffSize = 0) {
|
|
58
|
+
if (feeRate == null)
|
|
59
|
+
return 0n;
|
|
60
|
+
const [maxFee, priorityFee, l1StateDiffFee] = feeRate.split(",");
|
|
61
|
+
return (BigInt(gas) * BigInt(maxFee)) + (BigInt(stateDiffSize) * BigInt(l1StateDiffFee ?? 0n));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
exports.CitreaFees = CitreaFees;
|
|
65
|
+
CitreaFees.StateDiffSize = {
|
|
66
|
+
APPROVE_DIFF_SIZE: 40,
|
|
67
|
+
};
|
|
@@ -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,127 +1,127 @@
|
|
|
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
|
-
new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Citrea", chainId }) :
|
|
87
|
-
options.rpcUrl;
|
|
88
|
-
const Fees = options.fees ?? new CitreaFees_1.CitreaFees(provider, 2n * 1000000000n, 1000000n);
|
|
89
|
-
const chainInterface = new EVMChainInterface_1.EVMChainInterface("CITREA", chainId, provider, {
|
|
90
|
-
safeBlockTag: "latest",
|
|
91
|
-
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
92
|
-
}, options.retryPolicy, Fees);
|
|
93
|
-
chainInterface.Tokens = new CitreaTokens_1.CitreaTokens(chainInterface); //Override with custom token module allowing l1 state diff based fee calculation
|
|
94
|
-
const btcRelay = new CitreaBtcRelay_1.CitreaBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
95
|
-
const swapContract = new CitreaSwapContract_1.CitreaSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
96
|
-
refund: {
|
|
97
|
-
...defaultContractAddresses.handlerContracts.refund,
|
|
98
|
-
...options?.handlerContracts?.refund
|
|
99
|
-
},
|
|
100
|
-
claim: {
|
|
101
|
-
...defaultContractAddresses.handlerContracts.claim,
|
|
102
|
-
...options?.handlerContracts?.claim
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
const spvVaultContract = new CitreaSpvVaultContract_1.CitreaSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
106
|
-
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
107
|
-
return {
|
|
108
|
-
chainId: "CITREA",
|
|
109
|
-
btcRelay,
|
|
110
|
-
chainInterface,
|
|
111
|
-
swapContract,
|
|
112
|
-
chainEvents,
|
|
113
|
-
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
114
|
-
spvVaultContract,
|
|
115
|
-
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
116
|
-
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
exports.initializeCitrea = initializeCitrea;
|
|
120
|
-
;
|
|
121
|
-
exports.CitreaInitializer = {
|
|
122
|
-
chainId: "CITREA",
|
|
123
|
-
chainType: null,
|
|
124
|
-
initializer: initializeCitrea,
|
|
125
|
-
tokens: exports.CitreaAssets,
|
|
126
|
-
options: null
|
|
127
|
-
};
|
|
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
|
+
new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Citrea", chainId }) :
|
|
87
|
+
options.rpcUrl;
|
|
88
|
+
const Fees = options.fees ?? new CitreaFees_1.CitreaFees(provider, 2n * 1000000000n, 1000000n);
|
|
89
|
+
const chainInterface = new EVMChainInterface_1.EVMChainInterface("CITREA", chainId, provider, {
|
|
90
|
+
safeBlockTag: "latest",
|
|
91
|
+
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
92
|
+
}, options.retryPolicy, Fees);
|
|
93
|
+
chainInterface.Tokens = new CitreaTokens_1.CitreaTokens(chainInterface); //Override with custom token module allowing l1 state diff based fee calculation
|
|
94
|
+
const btcRelay = new CitreaBtcRelay_1.CitreaBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
95
|
+
const swapContract = new CitreaSwapContract_1.CitreaSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
96
|
+
refund: {
|
|
97
|
+
...defaultContractAddresses.handlerContracts.refund,
|
|
98
|
+
...options?.handlerContracts?.refund
|
|
99
|
+
},
|
|
100
|
+
claim: {
|
|
101
|
+
...defaultContractAddresses.handlerContracts.claim,
|
|
102
|
+
...options?.handlerContracts?.claim
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
const spvVaultContract = new CitreaSpvVaultContract_1.CitreaSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
106
|
+
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
107
|
+
return {
|
|
108
|
+
chainId: "CITREA",
|
|
109
|
+
btcRelay,
|
|
110
|
+
chainInterface,
|
|
111
|
+
swapContract,
|
|
112
|
+
chainEvents,
|
|
113
|
+
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
114
|
+
spvVaultContract,
|
|
115
|
+
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
116
|
+
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
exports.initializeCitrea = initializeCitrea;
|
|
120
|
+
;
|
|
121
|
+
exports.CitreaInitializer = {
|
|
122
|
+
chainId: "CITREA",
|
|
123
|
+
chainType: null,
|
|
124
|
+
initializer: initializeCitrea,
|
|
125
|
+
tokens: exports.CitreaAssets,
|
|
126
|
+
options: null
|
|
127
|
+
};
|
|
@@ -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
|
+
};
|