@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,34 +1,34 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMContractBase = void 0;
|
|
4
|
-
const ethers_1 = require("ethers");
|
|
5
|
-
const EVMContractEvents_1 = require("./modules/EVMContractEvents");
|
|
6
|
-
/**
|
|
7
|
-
* Base class providing program specific utilities
|
|
8
|
-
*/
|
|
9
|
-
class EVMContractBase {
|
|
10
|
-
constructor(chainInterface, contractAddress, contractAbi, contractDeploymentHeight) {
|
|
11
|
-
this.Chain = chainInterface;
|
|
12
|
-
this.contract = new ethers_1.Contract(contractAddress, contractAbi, chainInterface.provider);
|
|
13
|
-
this.Events = new EVMContractEvents_1.EVMContractEvents(chainInterface, this);
|
|
14
|
-
this.contractAddress = contractAddress;
|
|
15
|
-
this.contractDeploymentHeight = contractDeploymentHeight;
|
|
16
|
-
}
|
|
17
|
-
toTypedEvent(log) {
|
|
18
|
-
let foundFragment;
|
|
19
|
-
try {
|
|
20
|
-
foundFragment = this.contract.interface.getEvent(log.topics[0]);
|
|
21
|
-
}
|
|
22
|
-
catch (error) { }
|
|
23
|
-
if (!foundFragment)
|
|
24
|
-
return null;
|
|
25
|
-
try {
|
|
26
|
-
return new ethers_1.EventLog(log, this.contract.interface, foundFragment);
|
|
27
|
-
}
|
|
28
|
-
catch (error) { }
|
|
29
|
-
}
|
|
30
|
-
parseCalldata(calldata) {
|
|
31
|
-
return this.contract.interface.parseTransaction({ data: calldata });
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
exports.EVMContractBase = EVMContractBase;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMContractBase = void 0;
|
|
4
|
+
const ethers_1 = require("ethers");
|
|
5
|
+
const EVMContractEvents_1 = require("./modules/EVMContractEvents");
|
|
6
|
+
/**
|
|
7
|
+
* Base class providing program specific utilities
|
|
8
|
+
*/
|
|
9
|
+
class EVMContractBase {
|
|
10
|
+
constructor(chainInterface, contractAddress, contractAbi, contractDeploymentHeight) {
|
|
11
|
+
this.Chain = chainInterface;
|
|
12
|
+
this.contract = new ethers_1.Contract(contractAddress, contractAbi, chainInterface.provider);
|
|
13
|
+
this.Events = new EVMContractEvents_1.EVMContractEvents(chainInterface, this);
|
|
14
|
+
this.contractAddress = contractAddress;
|
|
15
|
+
this.contractDeploymentHeight = contractDeploymentHeight;
|
|
16
|
+
}
|
|
17
|
+
toTypedEvent(log) {
|
|
18
|
+
let foundFragment;
|
|
19
|
+
try {
|
|
20
|
+
foundFragment = this.contract.interface.getEvent(log.topics[0]);
|
|
21
|
+
}
|
|
22
|
+
catch (error) { }
|
|
23
|
+
if (!foundFragment)
|
|
24
|
+
return null;
|
|
25
|
+
try {
|
|
26
|
+
return new ethers_1.EventLog(log, this.contract.interface, foundFragment);
|
|
27
|
+
}
|
|
28
|
+
catch (error) { }
|
|
29
|
+
}
|
|
30
|
+
parseCalldata(calldata) {
|
|
31
|
+
return this.contract.interface.parseTransaction({ data: calldata });
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.EVMContractBase = EVMContractBase;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { BaseContract } from "ethers";
|
|
2
|
-
import { EVMModule } from "../chain/EVMModule";
|
|
3
|
-
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
4
|
-
import { EVMContractBase } from "./EVMContractBase";
|
|
5
|
-
export declare class EVMContractModule<T extends BaseContract> extends EVMModule<any> {
|
|
6
|
-
readonly contract: EVMContractBase<T>;
|
|
7
|
-
constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
|
|
8
|
-
}
|
|
1
|
+
import { BaseContract } from "ethers";
|
|
2
|
+
import { EVMModule } from "../chain/EVMModule";
|
|
3
|
+
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
4
|
+
import { EVMContractBase } from "./EVMContractBase";
|
|
5
|
+
export declare class EVMContractModule<T extends BaseContract> extends EVMModule<any> {
|
|
6
|
+
readonly contract: EVMContractBase<T>;
|
|
7
|
+
constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
|
|
8
|
+
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMContractModule = void 0;
|
|
4
|
-
const EVMModule_1 = require("../chain/EVMModule");
|
|
5
|
-
class EVMContractModule extends EVMModule_1.EVMModule {
|
|
6
|
-
constructor(chainInterface, contract) {
|
|
7
|
-
super(chainInterface);
|
|
8
|
-
this.contract = contract;
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
exports.EVMContractModule = EVMContractModule;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMContractModule = void 0;
|
|
4
|
+
const EVMModule_1 = require("../chain/EVMModule");
|
|
5
|
+
class EVMContractModule extends EVMModule_1.EVMModule {
|
|
6
|
+
constructor(chainInterface, contract) {
|
|
7
|
+
super(chainInterface);
|
|
8
|
+
this.contract = contract;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.EVMContractModule = EVMContractModule;
|
|
@@ -1,42 +1,42 @@
|
|
|
1
|
-
import { BaseContract, Log } from "ethers";
|
|
2
|
-
import { EVMEvents } from "../../chain/modules/EVMEvents";
|
|
3
|
-
import { EVMContractBase } from "../EVMContractBase";
|
|
4
|
-
import { EVMChainInterface } from "../../chain/EVMChainInterface";
|
|
5
|
-
import { TypedEventLog } from "../../typechain/common";
|
|
6
|
-
export declare class EVMContractEvents<T extends BaseContract> extends EVMEvents {
|
|
7
|
-
readonly contract: EVMContractBase<T>;
|
|
8
|
-
readonly baseContract: T;
|
|
9
|
-
constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
|
|
10
|
-
toTypedEvents<TEventName extends keyof T["filters"]>(blockEvents: Log[]): TypedEventLog<T["filters"][TEventName]>[];
|
|
11
|
-
private toFilter;
|
|
12
|
-
/**
|
|
13
|
-
* Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
|
|
14
|
-
* returns pending events if no startHeight & endHeight is passed
|
|
15
|
-
*
|
|
16
|
-
* @param events
|
|
17
|
-
* @param keys
|
|
18
|
-
* @param startBlockHeight
|
|
19
|
-
* @param endBlockHeight
|
|
20
|
-
*/
|
|
21
|
-
getContractBlockEvents<TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], startBlockHeight?: number, endBlockHeight?: number): Promise<TypedEventLog<T["filters"][TEventName]>[]>;
|
|
22
|
-
/**
|
|
23
|
-
* Runs a search backwards in time, processing the events for a specific topic public key
|
|
24
|
-
*
|
|
25
|
-
* @param events
|
|
26
|
-
* @param keys
|
|
27
|
-
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
28
|
-
* if the search should continue
|
|
29
|
-
* @param abortSignal
|
|
30
|
-
*/
|
|
31
|
-
findInContractEvents<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
|
|
32
|
-
/**
|
|
33
|
-
* Runs a search forwards in time, processing the events for a specific topic
|
|
34
|
-
*
|
|
35
|
-
* @param events
|
|
36
|
-
* @param keys
|
|
37
|
-
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
38
|
-
* if the search should continue
|
|
39
|
-
* @param abortSignal
|
|
40
|
-
*/
|
|
41
|
-
findInContractEventsForward<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
|
|
42
|
-
}
|
|
1
|
+
import { BaseContract, Log } from "ethers";
|
|
2
|
+
import { EVMEvents } from "../../chain/modules/EVMEvents";
|
|
3
|
+
import { EVMContractBase } from "../EVMContractBase";
|
|
4
|
+
import { EVMChainInterface } from "../../chain/EVMChainInterface";
|
|
5
|
+
import { TypedEventLog } from "../../typechain/common";
|
|
6
|
+
export declare class EVMContractEvents<T extends BaseContract> extends EVMEvents {
|
|
7
|
+
readonly contract: EVMContractBase<T>;
|
|
8
|
+
readonly baseContract: T;
|
|
9
|
+
constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
|
|
10
|
+
toTypedEvents<TEventName extends keyof T["filters"]>(blockEvents: Log[]): TypedEventLog<T["filters"][TEventName]>[];
|
|
11
|
+
private toFilter;
|
|
12
|
+
/**
|
|
13
|
+
* Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
|
|
14
|
+
* returns pending events if no startHeight & endHeight is passed
|
|
15
|
+
*
|
|
16
|
+
* @param events
|
|
17
|
+
* @param keys
|
|
18
|
+
* @param startBlockHeight
|
|
19
|
+
* @param endBlockHeight
|
|
20
|
+
*/
|
|
21
|
+
getContractBlockEvents<TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], startBlockHeight?: number, endBlockHeight?: number): Promise<TypedEventLog<T["filters"][TEventName]>[]>;
|
|
22
|
+
/**
|
|
23
|
+
* Runs a search backwards in time, processing the events for a specific topic public key
|
|
24
|
+
*
|
|
25
|
+
* @param events
|
|
26
|
+
* @param keys
|
|
27
|
+
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
28
|
+
* if the search should continue
|
|
29
|
+
* @param abortSignal
|
|
30
|
+
*/
|
|
31
|
+
findInContractEvents<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: (string | string[])[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
|
|
32
|
+
/**
|
|
33
|
+
* Runs a search forwards in time, processing the events for a specific topic
|
|
34
|
+
*
|
|
35
|
+
* @param events
|
|
36
|
+
* @param keys
|
|
37
|
+
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
38
|
+
* if the search should continue
|
|
39
|
+
* @param abortSignal
|
|
40
|
+
*/
|
|
41
|
+
findInContractEventsForward<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: (string | string[])[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
|
|
42
|
+
}
|
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMContractEvents = void 0;
|
|
4
|
-
const EVMEvents_1 = require("../../chain/modules/EVMEvents");
|
|
5
|
-
class EVMContractEvents extends EVMEvents_1.EVMEvents {
|
|
6
|
-
constructor(chainInterface, contract) {
|
|
7
|
-
super(chainInterface);
|
|
8
|
-
this.contract = contract;
|
|
9
|
-
this.baseContract = contract.contract;
|
|
10
|
-
}
|
|
11
|
-
toTypedEvents(blockEvents) {
|
|
12
|
-
return blockEvents.map(log => this.contract.toTypedEvent(log));
|
|
13
|
-
}
|
|
14
|
-
toFilter(events, keys) {
|
|
15
|
-
const filterArray = [];
|
|
16
|
-
filterArray.push(events.map(name => {
|
|
17
|
-
return this.baseContract.getEvent(name).fragment.topicHash;
|
|
18
|
-
}));
|
|
19
|
-
if (keys != null)
|
|
20
|
-
keys.forEach(key => filterArray.push(key));
|
|
21
|
-
return filterArray;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
|
|
25
|
-
* returns pending events if no startHeight & endHeight is passed
|
|
26
|
-
*
|
|
27
|
-
* @param events
|
|
28
|
-
* @param keys
|
|
29
|
-
* @param startBlockHeight
|
|
30
|
-
* @param endBlockHeight
|
|
31
|
-
*/
|
|
32
|
-
async getContractBlockEvents(events, keys, startBlockHeight, endBlockHeight = startBlockHeight) {
|
|
33
|
-
const blockEvents = await super.getBlockEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), startBlockHeight, endBlockHeight);
|
|
34
|
-
return this.toTypedEvents(blockEvents);
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Runs a search backwards in time, processing the events for a specific topic public key
|
|
38
|
-
*
|
|
39
|
-
* @param events
|
|
40
|
-
* @param keys
|
|
41
|
-
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
42
|
-
* if the search should continue
|
|
43
|
-
* @param abortSignal
|
|
44
|
-
*/
|
|
45
|
-
async findInContractEvents(events, keys, processor, abortSignal) {
|
|
46
|
-
return this.findInEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
|
|
47
|
-
const parsedEvents = this.toTypedEvents(events);
|
|
48
|
-
for (let event of parsedEvents) {
|
|
49
|
-
const result = await processor(event);
|
|
50
|
-
if (result != null)
|
|
51
|
-
return result;
|
|
52
|
-
}
|
|
53
|
-
}, abortSignal, this.contract.contractDeploymentHeight);
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Runs a search forwards in time, processing the events for a specific topic
|
|
57
|
-
*
|
|
58
|
-
* @param events
|
|
59
|
-
* @param keys
|
|
60
|
-
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
61
|
-
* if the search should continue
|
|
62
|
-
* @param abortSignal
|
|
63
|
-
*/
|
|
64
|
-
async findInContractEventsForward(events, keys, processor, abortSignal) {
|
|
65
|
-
return this.findInEventsForward(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
|
|
66
|
-
const parsedEvents = this.toTypedEvents(events);
|
|
67
|
-
for (let event of parsedEvents) {
|
|
68
|
-
const result = await processor(event);
|
|
69
|
-
if (result != null)
|
|
70
|
-
return result;
|
|
71
|
-
}
|
|
72
|
-
}, abortSignal, this.contract.contractDeploymentHeight);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
exports.EVMContractEvents = EVMContractEvents;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMContractEvents = void 0;
|
|
4
|
+
const EVMEvents_1 = require("../../chain/modules/EVMEvents");
|
|
5
|
+
class EVMContractEvents extends EVMEvents_1.EVMEvents {
|
|
6
|
+
constructor(chainInterface, contract) {
|
|
7
|
+
super(chainInterface);
|
|
8
|
+
this.contract = contract;
|
|
9
|
+
this.baseContract = contract.contract;
|
|
10
|
+
}
|
|
11
|
+
toTypedEvents(blockEvents) {
|
|
12
|
+
return blockEvents.map(log => this.contract.toTypedEvent(log));
|
|
13
|
+
}
|
|
14
|
+
toFilter(events, keys) {
|
|
15
|
+
const filterArray = [];
|
|
16
|
+
filterArray.push(events.map(name => {
|
|
17
|
+
return this.baseContract.getEvent(name).fragment.topicHash;
|
|
18
|
+
}));
|
|
19
|
+
if (keys != null)
|
|
20
|
+
keys.forEach(key => filterArray.push(key));
|
|
21
|
+
return filterArray;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
|
|
25
|
+
* returns pending events if no startHeight & endHeight is passed
|
|
26
|
+
*
|
|
27
|
+
* @param events
|
|
28
|
+
* @param keys
|
|
29
|
+
* @param startBlockHeight
|
|
30
|
+
* @param endBlockHeight
|
|
31
|
+
*/
|
|
32
|
+
async getContractBlockEvents(events, keys, startBlockHeight, endBlockHeight = startBlockHeight) {
|
|
33
|
+
const blockEvents = await super.getBlockEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), startBlockHeight, endBlockHeight);
|
|
34
|
+
return this.toTypedEvents(blockEvents);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Runs a search backwards in time, processing the events for a specific topic public key
|
|
38
|
+
*
|
|
39
|
+
* @param events
|
|
40
|
+
* @param keys
|
|
41
|
+
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
42
|
+
* if the search should continue
|
|
43
|
+
* @param abortSignal
|
|
44
|
+
*/
|
|
45
|
+
async findInContractEvents(events, keys, processor, abortSignal) {
|
|
46
|
+
return this.findInEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
|
|
47
|
+
const parsedEvents = this.toTypedEvents(events);
|
|
48
|
+
for (let event of parsedEvents) {
|
|
49
|
+
const result = await processor(event);
|
|
50
|
+
if (result != null)
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
}, abortSignal, this.contract.contractDeploymentHeight);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Runs a search forwards in time, processing the events for a specific topic
|
|
57
|
+
*
|
|
58
|
+
* @param events
|
|
59
|
+
* @param keys
|
|
60
|
+
* @param processor called for every event, should return a value if the correct event was found, or null
|
|
61
|
+
* if the search should continue
|
|
62
|
+
* @param abortSignal
|
|
63
|
+
*/
|
|
64
|
+
async findInContractEventsForward(events, keys, processor, abortSignal) {
|
|
65
|
+
return this.findInEventsForward(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
|
|
66
|
+
const parsedEvents = this.toTypedEvents(events);
|
|
67
|
+
for (let event of parsedEvents) {
|
|
68
|
+
const result = await processor(event);
|
|
69
|
+
if (result != null)
|
|
70
|
+
return result;
|
|
71
|
+
}
|
|
72
|
+
}, abortSignal, this.contract.contractDeploymentHeight);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
exports.EVMContractEvents = EVMContractEvents;
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import { EVMChainEventsBrowser } from "./EVMChainEventsBrowser";
|
|
2
|
-
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
3
|
-
import { EVMSwapContract } from "../swaps/EVMSwapContract";
|
|
4
|
-
import { EVMSpvVaultContract } from "../spv_swap/EVMSpvVaultContract";
|
|
5
|
-
export declare class EVMChainEvents extends EVMChainEventsBrowser {
|
|
6
|
-
private readonly directory;
|
|
7
|
-
private readonly BLOCKHEIGHT_FILENAME;
|
|
8
|
-
constructor(directory: string, chainInterface: EVMChainInterface, evmSwapContract: EVMSwapContract, evmSpvVaultContract: EVMSpvVaultContract<any>, pollIntervalSeconds?: number);
|
|
9
|
-
/**
|
|
10
|
-
* Retrieves last signature & slot from filesystem
|
|
11
|
-
*
|
|
12
|
-
* @private
|
|
13
|
-
*/
|
|
14
|
-
private getLastEventData;
|
|
15
|
-
/**
|
|
16
|
-
* Saves last signature & slot to the filesystem
|
|
17
|
-
*
|
|
18
|
-
* @private
|
|
19
|
-
*/
|
|
20
|
-
private saveLastEventData;
|
|
21
|
-
init(): Promise<void>;
|
|
22
|
-
}
|
|
1
|
+
import { EVMChainEventsBrowser } from "./EVMChainEventsBrowser";
|
|
2
|
+
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
3
|
+
import { EVMSwapContract } from "../swaps/EVMSwapContract";
|
|
4
|
+
import { EVMSpvVaultContract } from "../spv_swap/EVMSpvVaultContract";
|
|
5
|
+
export declare class EVMChainEvents extends EVMChainEventsBrowser {
|
|
6
|
+
private readonly directory;
|
|
7
|
+
private readonly BLOCKHEIGHT_FILENAME;
|
|
8
|
+
constructor(directory: string, chainInterface: EVMChainInterface, evmSwapContract: EVMSwapContract, evmSpvVaultContract: EVMSpvVaultContract<any>, pollIntervalSeconds?: number);
|
|
9
|
+
/**
|
|
10
|
+
* Retrieves last signature & slot from filesystem
|
|
11
|
+
*
|
|
12
|
+
* @private
|
|
13
|
+
*/
|
|
14
|
+
private getLastEventData;
|
|
15
|
+
/**
|
|
16
|
+
* Saves last signature & slot to the filesystem
|
|
17
|
+
*
|
|
18
|
+
* @private
|
|
19
|
+
*/
|
|
20
|
+
private saveLastEventData;
|
|
21
|
+
init(): Promise<void>;
|
|
22
|
+
}
|
|
@@ -1,69 +1,69 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMChainEvents = void 0;
|
|
4
|
-
//@ts-ignore
|
|
5
|
-
const fs = require("fs/promises");
|
|
6
|
-
const EVMChainEventsBrowser_1 = require("./EVMChainEventsBrowser");
|
|
7
|
-
class EVMChainEvents extends EVMChainEventsBrowser_1.EVMChainEventsBrowser {
|
|
8
|
-
constructor(directory, chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds) {
|
|
9
|
-
super(chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds);
|
|
10
|
-
this.BLOCKHEIGHT_FILENAME = "/" + chainInterface.chainId + "-blockheight.txt";
|
|
11
|
-
this.directory = directory;
|
|
12
|
-
}
|
|
13
|
-
/**
|
|
14
|
-
* Retrieves last signature & slot from filesystem
|
|
15
|
-
*
|
|
16
|
-
* @private
|
|
17
|
-
*/
|
|
18
|
-
async getLastEventData() {
|
|
19
|
-
try {
|
|
20
|
-
const txt = (await fs.readFile(this.directory + this.BLOCKHEIGHT_FILENAME)).toString();
|
|
21
|
-
const arr = txt.split(";");
|
|
22
|
-
return arr.map(val => {
|
|
23
|
-
const stateResult = val.split(",");
|
|
24
|
-
if (stateResult.length >= 3) {
|
|
25
|
-
return {
|
|
26
|
-
lastBlockNumber: parseInt(stateResult[0]),
|
|
27
|
-
lastEvent: {
|
|
28
|
-
blockHash: stateResult[1],
|
|
29
|
-
logIndex: parseInt(stateResult[2])
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
else if (stateResult.length >= 1) {
|
|
34
|
-
return {
|
|
35
|
-
lastBlockNumber: parseInt(stateResult[0])
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
return null;
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
catch (e) {
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Saves last signature & slot to the filesystem
|
|
49
|
-
*
|
|
50
|
-
* @private
|
|
51
|
-
*/
|
|
52
|
-
saveLastEventData(newState) {
|
|
53
|
-
return fs.writeFile(this.directory + this.BLOCKHEIGHT_FILENAME, newState.map(val => {
|
|
54
|
-
if (val.lastEvent == null) {
|
|
55
|
-
return val.lastBlockNumber.toString(10);
|
|
56
|
-
}
|
|
57
|
-
else {
|
|
58
|
-
return val.lastBlockNumber.toString(10) + "," + val.lastEvent.blockHash + "," + val.lastEvent.logIndex.toString(10);
|
|
59
|
-
}
|
|
60
|
-
}).join(";"));
|
|
61
|
-
}
|
|
62
|
-
async init() {
|
|
63
|
-
const lastState = await this.getLastEventData();
|
|
64
|
-
if (this.provider.websocket != null)
|
|
65
|
-
await this.setupWebsocket();
|
|
66
|
-
await this.setupPoll(lastState, (newState) => this.saveLastEventData(newState));
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
exports.EVMChainEvents = EVMChainEvents;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMChainEvents = void 0;
|
|
4
|
+
//@ts-ignore
|
|
5
|
+
const fs = require("fs/promises");
|
|
6
|
+
const EVMChainEventsBrowser_1 = require("./EVMChainEventsBrowser");
|
|
7
|
+
class EVMChainEvents extends EVMChainEventsBrowser_1.EVMChainEventsBrowser {
|
|
8
|
+
constructor(directory, chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds) {
|
|
9
|
+
super(chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds);
|
|
10
|
+
this.BLOCKHEIGHT_FILENAME = "/" + chainInterface.chainId + "-blockheight.txt";
|
|
11
|
+
this.directory = directory;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Retrieves last signature & slot from filesystem
|
|
15
|
+
*
|
|
16
|
+
* @private
|
|
17
|
+
*/
|
|
18
|
+
async getLastEventData() {
|
|
19
|
+
try {
|
|
20
|
+
const txt = (await fs.readFile(this.directory + this.BLOCKHEIGHT_FILENAME)).toString();
|
|
21
|
+
const arr = txt.split(";");
|
|
22
|
+
return arr.map(val => {
|
|
23
|
+
const stateResult = val.split(",");
|
|
24
|
+
if (stateResult.length >= 3) {
|
|
25
|
+
return {
|
|
26
|
+
lastBlockNumber: parseInt(stateResult[0]),
|
|
27
|
+
lastEvent: {
|
|
28
|
+
blockHash: stateResult[1],
|
|
29
|
+
logIndex: parseInt(stateResult[2])
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
else if (stateResult.length >= 1) {
|
|
34
|
+
return {
|
|
35
|
+
lastBlockNumber: parseInt(stateResult[0])
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
return null;
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
catch (e) {
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Saves last signature & slot to the filesystem
|
|
49
|
+
*
|
|
50
|
+
* @private
|
|
51
|
+
*/
|
|
52
|
+
saveLastEventData(newState) {
|
|
53
|
+
return fs.writeFile(this.directory + this.BLOCKHEIGHT_FILENAME, newState.map(val => {
|
|
54
|
+
if (val.lastEvent == null) {
|
|
55
|
+
return val.lastBlockNumber.toString(10);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
return val.lastBlockNumber.toString(10) + "," + val.lastEvent.blockHash + "," + val.lastEvent.logIndex.toString(10);
|
|
59
|
+
}
|
|
60
|
+
}).join(";"));
|
|
61
|
+
}
|
|
62
|
+
async init() {
|
|
63
|
+
const lastState = await this.getLastEventData();
|
|
64
|
+
if (this.provider.websocket != null)
|
|
65
|
+
await this.setupWebsocket();
|
|
66
|
+
await this.setupPoll(lastState, (newState) => this.saveLastEventData(newState));
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
exports.EVMChainEvents = EVMChainEvents;
|