@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,122 +1,122 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BotanixInitializer = exports.initializeBotanix = exports.BotanixAssets = 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 EVMFees_1 = require("../../evm/chain/modules/EVMFees");
|
|
8
|
-
const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
|
|
9
|
-
const EVMSwapContract_1 = require("../../evm/swaps/EVMSwapContract");
|
|
10
|
-
const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
|
|
11
|
-
const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
|
|
12
|
-
const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
|
|
13
|
-
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
14
|
-
const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
|
|
15
|
-
const BotanixChainIds = {
|
|
16
|
-
MAINNET: null,
|
|
17
|
-
TESTNET: 3636
|
|
18
|
-
};
|
|
19
|
-
const BotanixContractAddresses = {
|
|
20
|
-
MAINNET: {
|
|
21
|
-
executionContract: "",
|
|
22
|
-
swapContract: "",
|
|
23
|
-
btcRelayContract: "",
|
|
24
|
-
btcRelayDeploymentHeight: 0,
|
|
25
|
-
spvVaultContract: "",
|
|
26
|
-
spvVaultDeploymentHeight: 0,
|
|
27
|
-
handlerContracts: {
|
|
28
|
-
refund: {
|
|
29
|
-
timelock: ""
|
|
30
|
-
},
|
|
31
|
-
claim: {
|
|
32
|
-
[base_1.ChainSwapType.HTLC]: "",
|
|
33
|
-
[base_1.ChainSwapType.CHAIN_TXID]: "",
|
|
34
|
-
[base_1.ChainSwapType.CHAIN]: "",
|
|
35
|
-
[base_1.ChainSwapType.CHAIN_NONCED]: ""
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
TESTNET: {
|
|
40
|
-
executionContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
|
|
41
|
-
swapContract: "0xf61D1da542111216337FeEA5586022130D468842",
|
|
42
|
-
btcRelayContract: "0xba7E78011909e3501027FBc226a04DCC837a555D",
|
|
43
|
-
btcRelayDeploymentHeight: 3462466,
|
|
44
|
-
spvVaultContract: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
|
|
45
|
-
spvVaultDeploymentHeight: 3425257,
|
|
46
|
-
handlerContracts: {
|
|
47
|
-
refund: {
|
|
48
|
-
timelock: "0xEf227Caf24681FcEDa5fC26777B81964D404e239"
|
|
49
|
-
},
|
|
50
|
-
claim: {
|
|
51
|
-
[base_1.ChainSwapType.HTLC]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
|
|
52
|
-
[base_1.ChainSwapType.CHAIN_TXID]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0",
|
|
53
|
-
[base_1.ChainSwapType.CHAIN]: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137",
|
|
54
|
-
[base_1.ChainSwapType.CHAIN_NONCED]: "0xfd0FbA128244f502678251b07dEa0fb4EcE959F3"
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
exports.BotanixAssets = {
|
|
60
|
-
BBTC: {
|
|
61
|
-
address: "0x0000000000000000000000000000000000000000",
|
|
62
|
-
decimals: 18,
|
|
63
|
-
displayDecimals: 8
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
|
-
function initializeBotanix(options, bitcoinRpc, network) {
|
|
67
|
-
if (options.chainType == null) {
|
|
68
|
-
switch (network) {
|
|
69
|
-
case base_1.BitcoinNetwork.MAINNET:
|
|
70
|
-
options.chainType = "MAINNET";
|
|
71
|
-
break;
|
|
72
|
-
case base_1.BitcoinNetwork.TESTNET:
|
|
73
|
-
options.chainType = "TESTNET";
|
|
74
|
-
break;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
const defaultContractAddresses = BotanixContractAddresses[options.chainType];
|
|
78
|
-
const chainId = BotanixChainIds[options.chainType];
|
|
79
|
-
const provider = typeof (options.rpcUrl) === "string" ?
|
|
80
|
-
(options.rpcUrl.startsWith("ws")
|
|
81
|
-
? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Botanix", chainId })
|
|
82
|
-
: new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Botanix", chainId })) :
|
|
83
|
-
options.rpcUrl;
|
|
84
|
-
const Fees = options.fees ?? new EVMFees_1.EVMFees(provider, 2n * 1000000000n, 1000000n);
|
|
85
|
-
const chainInterface = new EVMChainInterface_1.EVMChainInterface("BOTANIX", chainId, provider, {
|
|
86
|
-
safeBlockTag: "finalized",
|
|
87
|
-
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
88
|
-
}, options.retryPolicy, Fees);
|
|
89
|
-
const btcRelay = new EVMBtcRelay_1.EVMBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
90
|
-
const swapContract = new EVMSwapContract_1.EVMSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
91
|
-
refund: {
|
|
92
|
-
...defaultContractAddresses.handlerContracts.refund,
|
|
93
|
-
...options?.handlerContracts?.refund
|
|
94
|
-
},
|
|
95
|
-
claim: {
|
|
96
|
-
...defaultContractAddresses.handlerContracts.claim,
|
|
97
|
-
...options?.handlerContracts?.claim
|
|
98
|
-
}
|
|
99
|
-
});
|
|
100
|
-
const spvVaultContract = new EVMSpvVaultContract_1.EVMSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
101
|
-
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
102
|
-
return {
|
|
103
|
-
chainId: "BOTANIX",
|
|
104
|
-
btcRelay,
|
|
105
|
-
chainInterface,
|
|
106
|
-
swapContract,
|
|
107
|
-
chainEvents,
|
|
108
|
-
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
109
|
-
spvVaultContract,
|
|
110
|
-
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
111
|
-
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
112
|
-
};
|
|
113
|
-
}
|
|
114
|
-
exports.initializeBotanix = initializeBotanix;
|
|
115
|
-
;
|
|
116
|
-
exports.BotanixInitializer = {
|
|
117
|
-
chainId: "BOTANIX",
|
|
118
|
-
chainType: null,
|
|
119
|
-
initializer: initializeBotanix,
|
|
120
|
-
tokens: exports.BotanixAssets,
|
|
121
|
-
options: null
|
|
122
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BotanixInitializer = exports.initializeBotanix = exports.BotanixAssets = 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 EVMFees_1 = require("../../evm/chain/modules/EVMFees");
|
|
8
|
+
const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
|
|
9
|
+
const EVMSwapContract_1 = require("../../evm/swaps/EVMSwapContract");
|
|
10
|
+
const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
|
|
11
|
+
const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
|
|
12
|
+
const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
|
|
13
|
+
const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
|
|
14
|
+
const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
|
|
15
|
+
const BotanixChainIds = {
|
|
16
|
+
MAINNET: null,
|
|
17
|
+
TESTNET: 3636
|
|
18
|
+
};
|
|
19
|
+
const BotanixContractAddresses = {
|
|
20
|
+
MAINNET: {
|
|
21
|
+
executionContract: "",
|
|
22
|
+
swapContract: "",
|
|
23
|
+
btcRelayContract: "",
|
|
24
|
+
btcRelayDeploymentHeight: 0,
|
|
25
|
+
spvVaultContract: "",
|
|
26
|
+
spvVaultDeploymentHeight: 0,
|
|
27
|
+
handlerContracts: {
|
|
28
|
+
refund: {
|
|
29
|
+
timelock: ""
|
|
30
|
+
},
|
|
31
|
+
claim: {
|
|
32
|
+
[base_1.ChainSwapType.HTLC]: "",
|
|
33
|
+
[base_1.ChainSwapType.CHAIN_TXID]: "",
|
|
34
|
+
[base_1.ChainSwapType.CHAIN]: "",
|
|
35
|
+
[base_1.ChainSwapType.CHAIN_NONCED]: ""
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
TESTNET: {
|
|
40
|
+
executionContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
|
|
41
|
+
swapContract: "0xf61D1da542111216337FeEA5586022130D468842",
|
|
42
|
+
btcRelayContract: "0xba7E78011909e3501027FBc226a04DCC837a555D",
|
|
43
|
+
btcRelayDeploymentHeight: 3462466,
|
|
44
|
+
spvVaultContract: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
|
|
45
|
+
spvVaultDeploymentHeight: 3425257,
|
|
46
|
+
handlerContracts: {
|
|
47
|
+
refund: {
|
|
48
|
+
timelock: "0xEf227Caf24681FcEDa5fC26777B81964D404e239"
|
|
49
|
+
},
|
|
50
|
+
claim: {
|
|
51
|
+
[base_1.ChainSwapType.HTLC]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
|
|
52
|
+
[base_1.ChainSwapType.CHAIN_TXID]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0",
|
|
53
|
+
[base_1.ChainSwapType.CHAIN]: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137",
|
|
54
|
+
[base_1.ChainSwapType.CHAIN_NONCED]: "0xfd0FbA128244f502678251b07dEa0fb4EcE959F3"
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
exports.BotanixAssets = {
|
|
60
|
+
BBTC: {
|
|
61
|
+
address: "0x0000000000000000000000000000000000000000",
|
|
62
|
+
decimals: 18,
|
|
63
|
+
displayDecimals: 8
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
function initializeBotanix(options, bitcoinRpc, network) {
|
|
67
|
+
if (options.chainType == null) {
|
|
68
|
+
switch (network) {
|
|
69
|
+
case base_1.BitcoinNetwork.MAINNET:
|
|
70
|
+
options.chainType = "MAINNET";
|
|
71
|
+
break;
|
|
72
|
+
case base_1.BitcoinNetwork.TESTNET:
|
|
73
|
+
options.chainType = "TESTNET";
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
const defaultContractAddresses = BotanixContractAddresses[options.chainType];
|
|
78
|
+
const chainId = BotanixChainIds[options.chainType];
|
|
79
|
+
const provider = typeof (options.rpcUrl) === "string" ?
|
|
80
|
+
(options.rpcUrl.startsWith("ws")
|
|
81
|
+
? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Botanix", chainId })
|
|
82
|
+
: new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Botanix", chainId })) :
|
|
83
|
+
options.rpcUrl;
|
|
84
|
+
const Fees = options.fees ?? new EVMFees_1.EVMFees(provider, 2n * 1000000000n, 1000000n);
|
|
85
|
+
const chainInterface = new EVMChainInterface_1.EVMChainInterface("BOTANIX", chainId, provider, {
|
|
86
|
+
safeBlockTag: "finalized",
|
|
87
|
+
maxLogsBlockRange: options.maxLogsBlockRange ?? 500
|
|
88
|
+
}, options.retryPolicy, Fees);
|
|
89
|
+
const btcRelay = new EVMBtcRelay_1.EVMBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
|
|
90
|
+
const swapContract = new EVMSwapContract_1.EVMSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
|
|
91
|
+
refund: {
|
|
92
|
+
...defaultContractAddresses.handlerContracts.refund,
|
|
93
|
+
...options?.handlerContracts?.refund
|
|
94
|
+
},
|
|
95
|
+
claim: {
|
|
96
|
+
...defaultContractAddresses.handlerContracts.claim,
|
|
97
|
+
...options?.handlerContracts?.claim
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
const spvVaultContract = new EVMSpvVaultContract_1.EVMSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
|
|
101
|
+
const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
|
|
102
|
+
return {
|
|
103
|
+
chainId: "BOTANIX",
|
|
104
|
+
btcRelay,
|
|
105
|
+
chainInterface,
|
|
106
|
+
swapContract,
|
|
107
|
+
chainEvents,
|
|
108
|
+
swapDataConstructor: EVMSwapData_1.EVMSwapData,
|
|
109
|
+
spvVaultContract,
|
|
110
|
+
spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
|
|
111
|
+
spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
exports.initializeBotanix = initializeBotanix;
|
|
115
|
+
;
|
|
116
|
+
exports.BotanixInitializer = {
|
|
117
|
+
chainId: "BOTANIX",
|
|
118
|
+
chainType: null,
|
|
119
|
+
initializer: initializeBotanix,
|
|
120
|
+
tokens: exports.BotanixAssets,
|
|
121
|
+
options: null
|
|
122
|
+
};
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { EVMBtcRelay } from "../../evm/btcrelay/EVMBtcRelay";
|
|
2
|
-
import { BtcBlock } from "@atomiqlabs/base";
|
|
3
|
-
export declare class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
|
|
4
|
-
static StateDiffSize: {
|
|
5
|
-
STATE_DIFF_PER_BLOCKHEADER: number;
|
|
6
|
-
STATE_DIFF_BASE: number;
|
|
7
|
-
};
|
|
8
|
-
/**
|
|
9
|
-
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
10
|
-
*
|
|
11
|
-
* @param requiredBlockheight
|
|
12
|
-
* @param feeRate
|
|
13
|
-
*/
|
|
14
|
-
estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint>;
|
|
15
|
-
/**
|
|
16
|
-
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
17
|
-
*
|
|
18
|
-
* @param feeRate
|
|
19
|
-
*/
|
|
20
|
-
getFeePerBlock(feeRate?: string): Promise<bigint>;
|
|
21
|
-
}
|
|
1
|
+
import { EVMBtcRelay } from "../../evm/btcrelay/EVMBtcRelay";
|
|
2
|
+
import { BtcBlock } from "@atomiqlabs/base";
|
|
3
|
+
export declare class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
|
|
4
|
+
static StateDiffSize: {
|
|
5
|
+
STATE_DIFF_PER_BLOCKHEADER: number;
|
|
6
|
+
STATE_DIFF_BASE: number;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
10
|
+
*
|
|
11
|
+
* @param requiredBlockheight
|
|
12
|
+
* @param feeRate
|
|
13
|
+
*/
|
|
14
|
+
estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint>;
|
|
15
|
+
/**
|
|
16
|
+
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
17
|
+
*
|
|
18
|
+
* @param feeRate
|
|
19
|
+
*/
|
|
20
|
+
getFeePerBlock(feeRate?: string): Promise<bigint>;
|
|
21
|
+
}
|
|
@@ -1,43 +1,43 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CitreaBtcRelay = void 0;
|
|
4
|
-
const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
|
|
5
|
-
const Utils_1 = require("../../utils/Utils");
|
|
6
|
-
const CitreaFees_1 = require("./CitreaFees");
|
|
7
|
-
const logger = (0, Utils_1.getLogger)("CitreaBtcRelay: ");
|
|
8
|
-
class CitreaBtcRelay extends EVMBtcRelay_1.EVMBtcRelay {
|
|
9
|
-
/**
|
|
10
|
-
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
11
|
-
*
|
|
12
|
-
* @param requiredBlockheight
|
|
13
|
-
* @param feeRate
|
|
14
|
-
*/
|
|
15
|
-
async estimateSynchronizeFee(requiredBlockheight, feeRate) {
|
|
16
|
-
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
17
|
-
const tipData = await this.getTipData();
|
|
18
|
-
const currBlockheight = tipData.blockheight;
|
|
19
|
-
const blockheightDelta = requiredBlockheight - currBlockheight;
|
|
20
|
-
if (blockheightDelta <= 0)
|
|
21
|
-
return 0n;
|
|
22
|
-
const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
|
|
23
|
-
const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
|
|
24
|
-
+ CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs);
|
|
25
|
-
logger.debug("estimateSynchronizeFee(): required blockheight: " + requiredBlockheight +
|
|
26
|
-
" blockheight delta: " + blockheightDelta + " fee: " + synchronizationFee.toString(10));
|
|
27
|
-
return synchronizationFee;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
31
|
-
*
|
|
32
|
-
* @param feeRate
|
|
33
|
-
*/
|
|
34
|
-
async getFeePerBlock(feeRate) {
|
|
35
|
-
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
36
|
-
return CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
exports.CitreaBtcRelay = CitreaBtcRelay;
|
|
40
|
-
CitreaBtcRelay.StateDiffSize = {
|
|
41
|
-
STATE_DIFF_PER_BLOCKHEADER: 22,
|
|
42
|
-
STATE_DIFF_BASE: 30
|
|
43
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CitreaBtcRelay = void 0;
|
|
4
|
+
const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
|
|
5
|
+
const Utils_1 = require("../../utils/Utils");
|
|
6
|
+
const CitreaFees_1 = require("./CitreaFees");
|
|
7
|
+
const logger = (0, Utils_1.getLogger)("CitreaBtcRelay: ");
|
|
8
|
+
class CitreaBtcRelay extends EVMBtcRelay_1.EVMBtcRelay {
|
|
9
|
+
/**
|
|
10
|
+
* Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
|
|
11
|
+
*
|
|
12
|
+
* @param requiredBlockheight
|
|
13
|
+
* @param feeRate
|
|
14
|
+
*/
|
|
15
|
+
async estimateSynchronizeFee(requiredBlockheight, feeRate) {
|
|
16
|
+
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
17
|
+
const tipData = await this.getTipData();
|
|
18
|
+
const currBlockheight = tipData.blockheight;
|
|
19
|
+
const blockheightDelta = requiredBlockheight - currBlockheight;
|
|
20
|
+
if (blockheightDelta <= 0)
|
|
21
|
+
return 0n;
|
|
22
|
+
const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
|
|
23
|
+
const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
|
|
24
|
+
+ CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs);
|
|
25
|
+
logger.debug("estimateSynchronizeFee(): required blockheight: " + requiredBlockheight +
|
|
26
|
+
" blockheight delta: " + blockheightDelta + " fee: " + synchronizationFee.toString(10));
|
|
27
|
+
return synchronizationFee;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Returns fee required (in native token) to synchronize a single block to btc relay
|
|
31
|
+
*
|
|
32
|
+
* @param feeRate
|
|
33
|
+
*/
|
|
34
|
+
async getFeePerBlock(feeRate) {
|
|
35
|
+
feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
|
|
36
|
+
return CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.CitreaBtcRelay = CitreaBtcRelay;
|
|
40
|
+
CitreaBtcRelay.StateDiffSize = {
|
|
41
|
+
STATE_DIFF_PER_BLOCKHEADER: 22,
|
|
42
|
+
STATE_DIFF_BASE: 30
|
|
43
|
+
};
|
|
@@ -1,13 +1,13 @@
|
|
|
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
|
-
export type CitreaChainType = ChainType<"CITREA", never, EVMPreFetchVerification, EVMTx, EVMSigner, EVMSwapData, CitreaSwapContract, EVMChainInterface<"CITREA", 5115>, EVMChainEventsBrowser, CitreaBtcRelay<any>, EVMSpvVaultData, EVMSpvWithdrawalData, CitreaSpvVaultContract>;
|
|
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
|
+
export type CitreaChainType = ChainType<"CITREA", never, EVMPreFetchVerification, EVMTx, EVMSigner, EVMSwapData, CitreaSwapContract, EVMChainInterface<"CITREA", 5115>, EVMChainEventsBrowser, CitreaBtcRelay<any>, EVMSpvVaultData, EVMSpvWithdrawalData, CitreaSpvVaultContract>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import { EVMFees } from "../../evm/chain/modules/EVMFees";
|
|
2
|
-
export declare class CitreaFees extends EVMFees {
|
|
3
|
-
static readonly StateDiffSize: {
|
|
4
|
-
APPROVE_DIFF_SIZE: number;
|
|
5
|
-
};
|
|
6
|
-
protected readonly logger: import("../../utils/Utils").LoggerType;
|
|
7
|
-
private _blockFeeCache;
|
|
8
|
-
/**
|
|
9
|
-
* Gets evm fee rate
|
|
10
|
-
*
|
|
11
|
-
* @private
|
|
12
|
-
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
13
|
-
*/
|
|
14
|
-
private __getFeeRate;
|
|
15
|
-
/**
|
|
16
|
-
* Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
|
|
17
|
-
*
|
|
18
|
-
* @private
|
|
19
|
-
*/
|
|
20
|
-
getFeeRate(): Promise<string>;
|
|
21
|
-
/**
|
|
22
|
-
* Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
|
|
23
|
-
*
|
|
24
|
-
* @param gas
|
|
25
|
-
* @param stateDiffSize
|
|
26
|
-
* @param feeRate
|
|
27
|
-
*/
|
|
28
|
-
static getGasFee(gas: number, feeRate: string, stateDiffSize?: number): bigint;
|
|
29
|
-
}
|
|
1
|
+
import { EVMFees } from "../../evm/chain/modules/EVMFees";
|
|
2
|
+
export declare class CitreaFees extends EVMFees {
|
|
3
|
+
static readonly StateDiffSize: {
|
|
4
|
+
APPROVE_DIFF_SIZE: number;
|
|
5
|
+
};
|
|
6
|
+
protected readonly logger: import("../../utils/Utils").LoggerType;
|
|
7
|
+
private _blockFeeCache;
|
|
8
|
+
/**
|
|
9
|
+
* Gets evm fee rate
|
|
10
|
+
*
|
|
11
|
+
* @private
|
|
12
|
+
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
13
|
+
*/
|
|
14
|
+
private __getFeeRate;
|
|
15
|
+
/**
|
|
16
|
+
* Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
|
|
17
|
+
*
|
|
18
|
+
* @private
|
|
19
|
+
*/
|
|
20
|
+
getFeeRate(): Promise<string>;
|
|
21
|
+
/**
|
|
22
|
+
* Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
|
|
23
|
+
*
|
|
24
|
+
* @param gas
|
|
25
|
+
* @param stateDiffSize
|
|
26
|
+
* @param feeRate
|
|
27
|
+
*/
|
|
28
|
+
static getGasFee(gas: number, feeRate: string, stateDiffSize?: number): bigint;
|
|
29
|
+
}
|
|
@@ -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
|
+
};
|