@atomiqlabs/chain-evm 1.0.0-dev.89 → 1.0.0-dev.93
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 +125 -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 +132 -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 +54 -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 +46 -46
- package/dist/evm/chain/modules/EVMEvents.js +151 -137
- 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 +288 -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 +412 -412
- package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +16 -16
- package/dist/evm/providers/JsonRpcProviderWithRetries.js +27 -27
- package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
- package/dist/evm/providers/ReconnectingWebSocketProvider.js +91 -91
- package/dist/evm/providers/SocketProvider.d.ts +111 -111
- package/dist/evm/providers/SocketProvider.js +336 -336
- package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
- package/dist/evm/providers/WebSocketProviderWithRetries.js +23 -23
- package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +107 -79
- package/dist/evm/spv_swap/EVMSpvVaultContract.js +578 -482
- package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +40 -39
- package/dist/evm/spv_swap/EVMSpvVaultData.js +184 -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 +199 -193
- package/dist/evm/swaps/EVMSwapContract.js +394 -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 +230 -230
- 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 +19 -19
- package/dist/utils/Utils.js +98 -98
- package/package.json +39 -39
- package/src/chains/botanix/BotanixChainType.ts +28 -28
- package/src/chains/botanix/BotanixInitializer.ts +175 -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 +182 -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 +158 -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 +182 -156
- 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 +327 -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 +533 -533
- package/src/evm/providers/JsonRpcProviderWithRetries.ts +33 -33
- package/src/evm/providers/ReconnectingWebSocketProvider.ts +106 -106
- package/src/evm/providers/SocketProvider.ts +371 -371
- package/src/evm/providers/WebSocketProviderWithRetries.ts +34 -34
- package/src/evm/spv_swap/EVMSpvVaultContract.ts +723 -615
- package/src/evm/spv_swap/EVMSpvVaultData.ts +228 -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 +621 -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 +307 -307
- package/src/evm/wallet/EVMSigner.ts +31 -31
- package/src/index.ts +53 -53
- package/src/utils/Utils.ts +111 -111
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMFees = void 0;
|
|
4
|
-
const Utils_1 = require("../../../utils/Utils");
|
|
5
|
-
class EVMFees {
|
|
6
|
-
constructor(provider, maxFeeRatePerGas = 500n * 1000000000n, priorityFee = 1n * 1000000000n, feeMultiplier = 1.25) {
|
|
7
|
-
this.MAX_FEE_AGE = 5000;
|
|
8
|
-
this.logger = (0, Utils_1.getLogger)("EVMFees: ");
|
|
9
|
-
this.blockFeeCache = null;
|
|
10
|
-
this.provider = provider;
|
|
11
|
-
this.maxFeeRatePerGas = maxFeeRatePerGas;
|
|
12
|
-
this.priorityFee = priorityFee;
|
|
13
|
-
this.feeMultiplierPPM = BigInt(Math.floor(feeMultiplier * 1000000));
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Gets evm fee rate
|
|
17
|
-
*
|
|
18
|
-
* @private
|
|
19
|
-
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
20
|
-
*/
|
|
21
|
-
async _getFeeRate() {
|
|
22
|
-
const block = await this.provider.getBlock("latest");
|
|
23
|
-
const baseFee = block.baseFeePerGas * this.feeMultiplierPPM / 1000000n;
|
|
24
|
-
this.logger.debug("_getFeeRate(): Base fee rate: " + baseFee.toString(10));
|
|
25
|
-
return baseFee;
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
|
|
29
|
-
*
|
|
30
|
-
* @private
|
|
31
|
-
*/
|
|
32
|
-
async getFeeRate() {
|
|
33
|
-
if (this.blockFeeCache == null || Date.now() - this.blockFeeCache.timestamp > this.MAX_FEE_AGE) {
|
|
34
|
-
let obj = {
|
|
35
|
-
timestamp: Date.now(),
|
|
36
|
-
feeRate: null
|
|
37
|
-
};
|
|
38
|
-
obj.feeRate = this._getFeeRate().catch(e => {
|
|
39
|
-
if (this.blockFeeCache === obj)
|
|
40
|
-
this.blockFeeCache = null;
|
|
41
|
-
throw e;
|
|
42
|
-
});
|
|
43
|
-
this.blockFeeCache = obj;
|
|
44
|
-
}
|
|
45
|
-
let baseFee = await this.blockFeeCache.feeRate;
|
|
46
|
-
if (baseFee > this.maxFeeRatePerGas)
|
|
47
|
-
baseFee = this.maxFeeRatePerGas;
|
|
48
|
-
const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10);
|
|
49
|
-
this.logger.debug("getFeeRate(): calculated fee: " + fee);
|
|
50
|
-
return fee;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Calculates the total gas fee paid for a given gas limit at a given fee rate
|
|
54
|
-
*
|
|
55
|
-
* @param gas
|
|
56
|
-
* @param feeRate
|
|
57
|
-
*/
|
|
58
|
-
static getGasFee(gas, feeRate) {
|
|
59
|
-
if (feeRate == null)
|
|
60
|
-
return 0n;
|
|
61
|
-
const [baseFee, priorityFee] = feeRate.split(",");
|
|
62
|
-
return BigInt(gas) * (BigInt(baseFee) + BigInt(priorityFee));
|
|
63
|
-
}
|
|
64
|
-
static applyFeeRate(tx, gas, feeRate) {
|
|
65
|
-
if (feeRate == null)
|
|
66
|
-
return null;
|
|
67
|
-
const [baseFee, priorityFee] = feeRate.split(",");
|
|
68
|
-
tx.maxFeePerGas = BigInt(baseFee) + BigInt(priorityFee);
|
|
69
|
-
tx.maxPriorityFeePerGas = BigInt(priorityFee);
|
|
70
|
-
if (gas != null)
|
|
71
|
-
tx.gasLimit = BigInt(gas);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
exports.EVMFees = EVMFees;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMFees = void 0;
|
|
4
|
+
const Utils_1 = require("../../../utils/Utils");
|
|
5
|
+
class EVMFees {
|
|
6
|
+
constructor(provider, maxFeeRatePerGas = 500n * 1000000000n, priorityFee = 1n * 1000000000n, feeMultiplier = 1.25) {
|
|
7
|
+
this.MAX_FEE_AGE = 5000;
|
|
8
|
+
this.logger = (0, Utils_1.getLogger)("EVMFees: ");
|
|
9
|
+
this.blockFeeCache = null;
|
|
10
|
+
this.provider = provider;
|
|
11
|
+
this.maxFeeRatePerGas = maxFeeRatePerGas;
|
|
12
|
+
this.priorityFee = priorityFee;
|
|
13
|
+
this.feeMultiplierPPM = BigInt(Math.floor(feeMultiplier * 1000000));
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Gets evm fee rate
|
|
17
|
+
*
|
|
18
|
+
* @private
|
|
19
|
+
* @returns {Promise<bigint>} L1 gas price denominated in Wei
|
|
20
|
+
*/
|
|
21
|
+
async _getFeeRate() {
|
|
22
|
+
const block = await this.provider.getBlock("latest");
|
|
23
|
+
const baseFee = block.baseFeePerGas * this.feeMultiplierPPM / 1000000n;
|
|
24
|
+
this.logger.debug("_getFeeRate(): Base fee rate: " + baseFee.toString(10));
|
|
25
|
+
return baseFee;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
|
|
29
|
+
*
|
|
30
|
+
* @private
|
|
31
|
+
*/
|
|
32
|
+
async getFeeRate() {
|
|
33
|
+
if (this.blockFeeCache == null || Date.now() - this.blockFeeCache.timestamp > this.MAX_FEE_AGE) {
|
|
34
|
+
let obj = {
|
|
35
|
+
timestamp: Date.now(),
|
|
36
|
+
feeRate: null
|
|
37
|
+
};
|
|
38
|
+
obj.feeRate = this._getFeeRate().catch(e => {
|
|
39
|
+
if (this.blockFeeCache === obj)
|
|
40
|
+
this.blockFeeCache = null;
|
|
41
|
+
throw e;
|
|
42
|
+
});
|
|
43
|
+
this.blockFeeCache = obj;
|
|
44
|
+
}
|
|
45
|
+
let baseFee = await this.blockFeeCache.feeRate;
|
|
46
|
+
if (baseFee > this.maxFeeRatePerGas)
|
|
47
|
+
baseFee = this.maxFeeRatePerGas;
|
|
48
|
+
const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10);
|
|
49
|
+
this.logger.debug("getFeeRate(): calculated fee: " + fee);
|
|
50
|
+
return fee;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Calculates the total gas fee paid for a given gas limit at a given fee rate
|
|
54
|
+
*
|
|
55
|
+
* @param gas
|
|
56
|
+
* @param feeRate
|
|
57
|
+
*/
|
|
58
|
+
static getGasFee(gas, feeRate) {
|
|
59
|
+
if (feeRate == null)
|
|
60
|
+
return 0n;
|
|
61
|
+
const [baseFee, priorityFee] = feeRate.split(",");
|
|
62
|
+
return BigInt(gas) * (BigInt(baseFee) + BigInt(priorityFee));
|
|
63
|
+
}
|
|
64
|
+
static applyFeeRate(tx, gas, feeRate) {
|
|
65
|
+
if (feeRate == null)
|
|
66
|
+
return null;
|
|
67
|
+
const [baseFee, priorityFee] = feeRate.split(",");
|
|
68
|
+
tx.maxFeePerGas = BigInt(baseFee) + BigInt(priorityFee);
|
|
69
|
+
tx.maxPriorityFeePerGas = BigInt(priorityFee);
|
|
70
|
+
if (gas != null)
|
|
71
|
+
tx.gasLimit = BigInt(gas);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
exports.EVMFees = EVMFees;
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
|
-
import { EVMSigner } from "../../wallet/EVMSigner";
|
|
4
|
-
import { EVMModule } from "../EVMModule";
|
|
5
|
-
import { EVMChainInterface } from "../EVMChainInterface";
|
|
6
|
-
import { TypedDataField } from "ethers";
|
|
7
|
-
export declare class EVMSignatures extends EVMModule<any> {
|
|
8
|
-
private readonly domainName;
|
|
9
|
-
constructor(root: EVMChainInterface<any>, domainName?: string);
|
|
10
|
-
signTypedMessage(contract: string, signer: EVMSigner, type: TypedDataField[], typeName: string, message: object): Promise<string>;
|
|
11
|
-
isValidSignature(contract: string, signature: string, address: string, type: TypedDataField[], typeName: string, message: object): Promise<boolean>;
|
|
12
|
-
/**
|
|
13
|
-
* Produces a signature over the sha256 of a specified data Buffer, only works with providers which
|
|
14
|
-
* expose their private key (i.e. backend based, not browser wallet based)
|
|
15
|
-
*
|
|
16
|
-
* @param signer
|
|
17
|
-
* @param data data to sign
|
|
18
|
-
*/
|
|
19
|
-
getDataSignature(signer: EVMSigner, data: Buffer): Promise<string>;
|
|
20
|
-
/**
|
|
21
|
-
* Checks whether a signature is a valid signature produced by the account over a data message (computes
|
|
22
|
-
* sha256 hash of the message)
|
|
23
|
-
*
|
|
24
|
-
* @param data signed data
|
|
25
|
-
* @param signature data signature
|
|
26
|
-
* @param address public key of the signer
|
|
27
|
-
*/
|
|
28
|
-
isValidDataSignature(data: Buffer, signature: string, address: string): Promise<boolean>;
|
|
29
|
-
}
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { EVMSigner } from "../../wallet/EVMSigner";
|
|
4
|
+
import { EVMModule } from "../EVMModule";
|
|
5
|
+
import { EVMChainInterface } from "../EVMChainInterface";
|
|
6
|
+
import { TypedDataField } from "ethers";
|
|
7
|
+
export declare class EVMSignatures extends EVMModule<any> {
|
|
8
|
+
private readonly domainName;
|
|
9
|
+
constructor(root: EVMChainInterface<any>, domainName?: string);
|
|
10
|
+
signTypedMessage(contract: string, signer: EVMSigner, type: TypedDataField[], typeName: string, message: object): Promise<string>;
|
|
11
|
+
isValidSignature(contract: string, signature: string, address: string, type: TypedDataField[], typeName: string, message: object): Promise<boolean>;
|
|
12
|
+
/**
|
|
13
|
+
* Produces a signature over the sha256 of a specified data Buffer, only works with providers which
|
|
14
|
+
* expose their private key (i.e. backend based, not browser wallet based)
|
|
15
|
+
*
|
|
16
|
+
* @param signer
|
|
17
|
+
* @param data data to sign
|
|
18
|
+
*/
|
|
19
|
+
getDataSignature(signer: EVMSigner, data: Buffer): Promise<string>;
|
|
20
|
+
/**
|
|
21
|
+
* Checks whether a signature is a valid signature produced by the account over a data message (computes
|
|
22
|
+
* sha256 hash of the message)
|
|
23
|
+
*
|
|
24
|
+
* @param data signed data
|
|
25
|
+
* @param signature data signature
|
|
26
|
+
* @param address public key of the signer
|
|
27
|
+
*/
|
|
28
|
+
isValidDataSignature(data: Buffer, signature: string, address: string): Promise<boolean>;
|
|
29
|
+
}
|
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMSignatures = void 0;
|
|
4
|
-
const EVMModule_1 = require("../EVMModule");
|
|
5
|
-
const ethers_1 = require("ethers");
|
|
6
|
-
const DataHash = [
|
|
7
|
-
{ name: "dataHash", type: "bytes32" }
|
|
8
|
-
];
|
|
9
|
-
class EVMSignatures extends EVMModule_1.EVMModule {
|
|
10
|
-
constructor(root, domainName = "atomiq.exchange") {
|
|
11
|
-
super(root);
|
|
12
|
-
this.domainName = domainName;
|
|
13
|
-
}
|
|
14
|
-
async signTypedMessage(contract, signer, type, typeName, message) {
|
|
15
|
-
return signer.account.signTypedData({
|
|
16
|
-
name: this.domainName,
|
|
17
|
-
version: "1",
|
|
18
|
-
chainId: BigInt(this.root.evmChainId),
|
|
19
|
-
verifyingContract: contract
|
|
20
|
-
}, { [typeName]: type }, message);
|
|
21
|
-
}
|
|
22
|
-
async isValidSignature(contract, signature, address, type, typeName, message) {
|
|
23
|
-
return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
|
|
24
|
-
name: this.domainName,
|
|
25
|
-
version: "1",
|
|
26
|
-
chainId: BigInt(this.root.evmChainId),
|
|
27
|
-
verifyingContract: contract
|
|
28
|
-
}, { [typeName]: type }, message, signature));
|
|
29
|
-
}
|
|
30
|
-
///////////////////
|
|
31
|
-
//// Data signatures
|
|
32
|
-
/**
|
|
33
|
-
* Produces a signature over the sha256 of a specified data Buffer, only works with providers which
|
|
34
|
-
* expose their private key (i.e. backend based, not browser wallet based)
|
|
35
|
-
*
|
|
36
|
-
* @param signer
|
|
37
|
-
* @param data data to sign
|
|
38
|
-
*/
|
|
39
|
-
getDataSignature(signer, data) {
|
|
40
|
-
return signer.account.signTypedData({
|
|
41
|
-
name: this.domainName,
|
|
42
|
-
version: "1",
|
|
43
|
-
chainId: BigInt(this.root.evmChainId),
|
|
44
|
-
verifyingContract: "0x0000000000000000000000000000000000000000"
|
|
45
|
-
}, { DataHash }, {
|
|
46
|
-
dataHash: (0, ethers_1.sha256)(data)
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Checks whether a signature is a valid signature produced by the account over a data message (computes
|
|
51
|
-
* sha256 hash of the message)
|
|
52
|
-
*
|
|
53
|
-
* @param data signed data
|
|
54
|
-
* @param signature data signature
|
|
55
|
-
* @param address public key of the signer
|
|
56
|
-
*/
|
|
57
|
-
isValidDataSignature(data, signature, address) {
|
|
58
|
-
return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
|
|
59
|
-
name: this.domainName,
|
|
60
|
-
version: "1",
|
|
61
|
-
chainId: BigInt(this.root.evmChainId),
|
|
62
|
-
verifyingContract: "0x0000000000000000000000000000000000000000"
|
|
63
|
-
}, { DataHash }, {
|
|
64
|
-
dataHash: (0, ethers_1.sha256)(data)
|
|
65
|
-
}, signature));
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
exports.EVMSignatures = EVMSignatures;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMSignatures = void 0;
|
|
4
|
+
const EVMModule_1 = require("../EVMModule");
|
|
5
|
+
const ethers_1 = require("ethers");
|
|
6
|
+
const DataHash = [
|
|
7
|
+
{ name: "dataHash", type: "bytes32" }
|
|
8
|
+
];
|
|
9
|
+
class EVMSignatures extends EVMModule_1.EVMModule {
|
|
10
|
+
constructor(root, domainName = "atomiq.exchange") {
|
|
11
|
+
super(root);
|
|
12
|
+
this.domainName = domainName;
|
|
13
|
+
}
|
|
14
|
+
async signTypedMessage(contract, signer, type, typeName, message) {
|
|
15
|
+
return signer.account.signTypedData({
|
|
16
|
+
name: this.domainName,
|
|
17
|
+
version: "1",
|
|
18
|
+
chainId: BigInt(this.root.evmChainId),
|
|
19
|
+
verifyingContract: contract
|
|
20
|
+
}, { [typeName]: type }, message);
|
|
21
|
+
}
|
|
22
|
+
async isValidSignature(contract, signature, address, type, typeName, message) {
|
|
23
|
+
return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
|
|
24
|
+
name: this.domainName,
|
|
25
|
+
version: "1",
|
|
26
|
+
chainId: BigInt(this.root.evmChainId),
|
|
27
|
+
verifyingContract: contract
|
|
28
|
+
}, { [typeName]: type }, message, signature));
|
|
29
|
+
}
|
|
30
|
+
///////////////////
|
|
31
|
+
//// Data signatures
|
|
32
|
+
/**
|
|
33
|
+
* Produces a signature over the sha256 of a specified data Buffer, only works with providers which
|
|
34
|
+
* expose their private key (i.e. backend based, not browser wallet based)
|
|
35
|
+
*
|
|
36
|
+
* @param signer
|
|
37
|
+
* @param data data to sign
|
|
38
|
+
*/
|
|
39
|
+
getDataSignature(signer, data) {
|
|
40
|
+
return signer.account.signTypedData({
|
|
41
|
+
name: this.domainName,
|
|
42
|
+
version: "1",
|
|
43
|
+
chainId: BigInt(this.root.evmChainId),
|
|
44
|
+
verifyingContract: "0x0000000000000000000000000000000000000000"
|
|
45
|
+
}, { DataHash }, {
|
|
46
|
+
dataHash: (0, ethers_1.sha256)(data)
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Checks whether a signature is a valid signature produced by the account over a data message (computes
|
|
51
|
+
* sha256 hash of the message)
|
|
52
|
+
*
|
|
53
|
+
* @param data signed data
|
|
54
|
+
* @param signature data signature
|
|
55
|
+
* @param address public key of the signer
|
|
56
|
+
*/
|
|
57
|
+
isValidDataSignature(data, signature, address) {
|
|
58
|
+
return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
|
|
59
|
+
name: this.domainName,
|
|
60
|
+
version: "1",
|
|
61
|
+
chainId: BigInt(this.root.evmChainId),
|
|
62
|
+
verifyingContract: "0x0000000000000000000000000000000000000000"
|
|
63
|
+
}, { DataHash }, {
|
|
64
|
+
dataHash: (0, ethers_1.sha256)(data)
|
|
65
|
+
}, signature));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.EVMSignatures = EVMSignatures;
|
|
@@ -1,70 +1,70 @@
|
|
|
1
|
-
import { EVMModule } from "../EVMModule";
|
|
2
|
-
import { TransactionRequest } from "ethers";
|
|
3
|
-
export declare class EVMTokens extends EVMModule<any> {
|
|
4
|
-
static readonly ETH_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
5
|
-
static readonly GasCosts: {
|
|
6
|
-
TRANSFER: number;
|
|
7
|
-
APPROVE: number;
|
|
8
|
-
};
|
|
9
|
-
private getContract;
|
|
10
|
-
/**
|
|
11
|
-
* Checks if the provided string is a valid starknet token
|
|
12
|
-
*
|
|
13
|
-
* @param token
|
|
14
|
-
*/
|
|
15
|
-
isValidToken(token: string): boolean;
|
|
16
|
-
/**
|
|
17
|
-
* Returns the token balance of the address
|
|
18
|
-
*
|
|
19
|
-
* @param address
|
|
20
|
-
* @param token
|
|
21
|
-
*/
|
|
22
|
-
getTokenBalance(address: string, token: string): Promise<bigint>;
|
|
23
|
-
/**
|
|
24
|
-
* Returns the authorized allowance of specific address towards a spender contract
|
|
25
|
-
*
|
|
26
|
-
* @param spender A contract trying to spend user's erc20 balance
|
|
27
|
-
* @param address Wallet address
|
|
28
|
-
* @param token ERC-20 token
|
|
29
|
-
*/
|
|
30
|
-
getTokenAllowance(spender: string, address: string, token: string): Promise<bigint>;
|
|
31
|
-
/**
|
|
32
|
-
* Returns the native currency address
|
|
33
|
-
*/
|
|
34
|
-
getNativeCurrencyAddress(): string;
|
|
35
|
-
/**
|
|
36
|
-
* Creates transactions for sending the over the tokens
|
|
37
|
-
*
|
|
38
|
-
* @param signer
|
|
39
|
-
* @param token token to send
|
|
40
|
-
* @param amount amount of the token to send
|
|
41
|
-
* @param recipient recipient's address
|
|
42
|
-
* @param feeRate fee rate to use for the transactions
|
|
43
|
-
* @private
|
|
44
|
-
*/
|
|
45
|
-
Transfer(signer: string, token: string, amount: bigint, recipient: string, feeRate?: string): Promise<TransactionRequest>;
|
|
46
|
-
/**
|
|
47
|
-
* Creates transactions for approving spending of tokens
|
|
48
|
-
*
|
|
49
|
-
* @param signer
|
|
50
|
-
* @param token token to send
|
|
51
|
-
* @param amount amount of the token to send
|
|
52
|
-
* @param spender recipient's address
|
|
53
|
-
* @param feeRate fee rate to use for the transactions
|
|
54
|
-
* @private
|
|
55
|
-
*/
|
|
56
|
-
Approve(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest>;
|
|
57
|
-
/**
|
|
58
|
-
* Checks whether an approve transaction is required for a given token and either returns the tx
|
|
59
|
-
* or null in case the approve is not required
|
|
60
|
-
*
|
|
61
|
-
* @param signer
|
|
62
|
-
* @param token token to approve for
|
|
63
|
-
* @param amount amount of the token to send
|
|
64
|
-
* @param spender spending contract address
|
|
65
|
-
* @param feeRate fee rate to use for the transactions
|
|
66
|
-
*/
|
|
67
|
-
checkAndGetApproveTx(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest | null>;
|
|
68
|
-
getApproveFee(feeRate?: string): Promise<bigint>;
|
|
69
|
-
getTransferFee(feeRate?: string): Promise<bigint>;
|
|
70
|
-
}
|
|
1
|
+
import { EVMModule } from "../EVMModule";
|
|
2
|
+
import { TransactionRequest } from "ethers";
|
|
3
|
+
export declare class EVMTokens extends EVMModule<any> {
|
|
4
|
+
static readonly ETH_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
5
|
+
static readonly GasCosts: {
|
|
6
|
+
TRANSFER: number;
|
|
7
|
+
APPROVE: number;
|
|
8
|
+
};
|
|
9
|
+
private getContract;
|
|
10
|
+
/**
|
|
11
|
+
* Checks if the provided string is a valid starknet token
|
|
12
|
+
*
|
|
13
|
+
* @param token
|
|
14
|
+
*/
|
|
15
|
+
isValidToken(token: string): boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Returns the token balance of the address
|
|
18
|
+
*
|
|
19
|
+
* @param address
|
|
20
|
+
* @param token
|
|
21
|
+
*/
|
|
22
|
+
getTokenBalance(address: string, token: string): Promise<bigint>;
|
|
23
|
+
/**
|
|
24
|
+
* Returns the authorized allowance of specific address towards a spender contract
|
|
25
|
+
*
|
|
26
|
+
* @param spender A contract trying to spend user's erc20 balance
|
|
27
|
+
* @param address Wallet address
|
|
28
|
+
* @param token ERC-20 token
|
|
29
|
+
*/
|
|
30
|
+
getTokenAllowance(spender: string, address: string, token: string): Promise<bigint>;
|
|
31
|
+
/**
|
|
32
|
+
* Returns the native currency address
|
|
33
|
+
*/
|
|
34
|
+
getNativeCurrencyAddress(): string;
|
|
35
|
+
/**
|
|
36
|
+
* Creates transactions for sending the over the tokens
|
|
37
|
+
*
|
|
38
|
+
* @param signer
|
|
39
|
+
* @param token token to send
|
|
40
|
+
* @param amount amount of the token to send
|
|
41
|
+
* @param recipient recipient's address
|
|
42
|
+
* @param feeRate fee rate to use for the transactions
|
|
43
|
+
* @private
|
|
44
|
+
*/
|
|
45
|
+
Transfer(signer: string, token: string, amount: bigint, recipient: string, feeRate?: string): Promise<TransactionRequest>;
|
|
46
|
+
/**
|
|
47
|
+
* Creates transactions for approving spending of tokens
|
|
48
|
+
*
|
|
49
|
+
* @param signer
|
|
50
|
+
* @param token token to send
|
|
51
|
+
* @param amount amount of the token to send
|
|
52
|
+
* @param spender recipient's address
|
|
53
|
+
* @param feeRate fee rate to use for the transactions
|
|
54
|
+
* @private
|
|
55
|
+
*/
|
|
56
|
+
Approve(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest>;
|
|
57
|
+
/**
|
|
58
|
+
* Checks whether an approve transaction is required for a given token and either returns the tx
|
|
59
|
+
* or null in case the approve is not required
|
|
60
|
+
*
|
|
61
|
+
* @param signer
|
|
62
|
+
* @param token token to approve for
|
|
63
|
+
* @param amount amount of the token to send
|
|
64
|
+
* @param spender spending contract address
|
|
65
|
+
* @param feeRate fee rate to use for the transactions
|
|
66
|
+
*/
|
|
67
|
+
checkAndGetApproveTx(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest | null>;
|
|
68
|
+
getApproveFee(feeRate?: string): Promise<bigint>;
|
|
69
|
+
getTransferFee(feeRate?: string): Promise<bigint>;
|
|
70
|
+
}
|