@atomiqlabs/chain-evm 1.0.0-dev.38 → 1.0.0-dev.40
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 -0
- package/dist/chains/botanix/BotanixChainType.js +2 -0
- package/dist/chains/botanix/BotanixInitializer.d.ts +30 -0
- package/dist/chains/botanix/BotanixInitializer.js +117 -0
- package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
- package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
- package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
- package/dist/chains/citrea/CitreaChainType.js +2 -2
- package/dist/chains/citrea/CitreaFees.d.ts +29 -29
- package/dist/chains/citrea/CitreaFees.js +67 -67
- package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
- package/dist/chains/citrea/CitreaInitializer.js +127 -127
- package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
- package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
- package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
- package/dist/chains/citrea/CitreaSwapContract.js +96 -96
- package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
- package/dist/chains/citrea/CitreaTokens.js +20 -20
- package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
- package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
- package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
- package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
- package/dist/evm/btcrelay/EVMBtcRelay.d.ts +195 -195
- package/dist/evm/btcrelay/EVMBtcRelay.js +423 -423
- package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
- package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
- package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
- package/dist/evm/chain/EVMChainInterface.js +89 -89
- package/dist/evm/chain/EVMModule.d.ts +9 -9
- package/dist/evm/chain/EVMModule.js +13 -13
- package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
- package/dist/evm/chain/modules/ERC20Abi.js +225 -225
- package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
- package/dist/evm/chain/modules/EVMAddresses.js +30 -30
- package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
- package/dist/evm/chain/modules/EVMBlocks.js +64 -64
- package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
- package/dist/evm/chain/modules/EVMEvents.js +122 -122
- package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
- package/dist/evm/chain/modules/EVMFees.js +73 -73
- package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
- package/dist/evm/chain/modules/EVMSignatures.js +68 -68
- package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
- package/dist/evm/chain/modules/EVMTokens.js +142 -142
- package/dist/evm/chain/modules/EVMTransactions.d.ts +89 -89
- package/dist/evm/chain/modules/EVMTransactions.js +230 -230
- package/dist/evm/contract/EVMContractBase.d.ts +22 -22
- package/dist/evm/contract/EVMContractBase.js +34 -34
- package/dist/evm/contract/EVMContractModule.d.ts +8 -8
- package/dist/evm/contract/EVMContractModule.js +11 -11
- package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
- package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
- package/dist/evm/events/EVMChainEvents.d.ts +22 -22
- package/dist/evm/events/EVMChainEvents.js +67 -67
- package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -86
- package/dist/evm/events/EVMChainEventsBrowser.js +294 -294
- package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +78 -78
- package/dist/evm/spv_swap/EVMSpvVaultContract.js +478 -478
- package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
- package/dist/evm/spv_swap/EVMSpvVaultData.js +180 -180
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
- package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
- package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
- package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
- package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
- package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
- package/dist/evm/swaps/EVMSwapContract.js +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/EVMSigner.d.ts +10 -10
- package/dist/evm/wallet/EVMSigner.js +17 -17
- package/dist/index.d.ts +40 -38
- package/dist/index.js +56 -54
- package/dist/utils/Utils.d.ts +15 -15
- package/dist/utils/Utils.js +71 -71
- package/package.json +37 -37
- package/src/chains/botanix/BotanixChainType.ts +28 -0
- package/src/chains/botanix/BotanixInitializer.ts +164 -0
- package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
- package/src/chains/citrea/CitreaChainType.ts +28 -28
- package/src/chains/citrea/CitreaFees.ts +77 -77
- package/src/chains/citrea/CitreaInitializer.ts +178 -178
- package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
- package/src/chains/citrea/CitreaSwapContract.ts +102 -102
- package/src/chains/citrea/CitreaTokens.ts +21 -21
- package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
- package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
- package/src/evm/btcrelay/EVMBtcRelay.ts +522 -522
- package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
- package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
- package/src/evm/chain/EVMChainInterface.ts +155 -155
- package/src/evm/chain/EVMModule.ts +21 -21
- package/src/evm/chain/modules/ERC20Abi.ts +222 -222
- package/src/evm/chain/modules/EVMAddresses.ts +28 -28
- package/src/evm/chain/modules/EVMBlocks.ts +75 -75
- package/src/evm/chain/modules/EVMEvents.ts +139 -139
- package/src/evm/chain/modules/EVMFees.ts +104 -104
- package/src/evm/chain/modules/EVMSignatures.ts +76 -76
- package/src/evm/chain/modules/EVMTokens.ts +155 -155
- package/src/evm/chain/modules/EVMTransactions.ts +257 -257
- package/src/evm/contract/EVMContractBase.ts +63 -63
- package/src/evm/contract/EVMContractModule.ts +16 -16
- package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
- package/src/evm/events/EVMChainEvents.ts +81 -81
- package/src/evm/events/EVMChainEventsBrowser.ts +390 -390
- package/src/evm/spv_swap/EVMSpvVaultContract.ts +608 -608
- 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/EVMSigner.ts +25 -25
- package/src/index.ts +48 -45
- package/src/utils/Utils.ts +81 -81
|
@@ -1,42 +1,42 @@
|
|
|
1
|
-
import { BaseContract } 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
|
-
private toTypedEvents;
|
|
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 } 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
|
+
private toTypedEvents;
|
|
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,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,67 +1,67 @@
|
|
|
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
|
-
await this.setupPoll(lastState, (newState) => this.saveLastEventData(newState));
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
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
|
+
await this.setupPoll(lastState, (newState) => this.saveLastEventData(newState));
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.EVMChainEvents = EVMChainEvents;
|
|
@@ -1,86 +1,86 @@
|
|
|
1
|
-
import { ChainEvents, ClaimEvent, EventListener, InitializeEvent, RefundEvent, SpvVaultClaimEvent, SpvVaultCloseEvent, SpvVaultDepositEvent, SpvVaultFrontEvent, SpvVaultOpenEvent } from "@atomiqlabs/base";
|
|
2
|
-
import { IClaimHandler } from "../swaps/handlers/claim/ClaimHandlers";
|
|
3
|
-
import { EVMSwapData } from "../swaps/EVMSwapData";
|
|
4
|
-
import { Block, JsonRpcApiProvider } from "ethers";
|
|
5
|
-
import { EVMSwapContract } from "../swaps/EVMSwapContract";
|
|
6
|
-
import { EVMSpvVaultContract } from "../spv_swap/EVMSpvVaultContract";
|
|
7
|
-
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
8
|
-
import { TypedEventLog } from "../typechain/common";
|
|
9
|
-
import { EscrowManager } from "../swaps/EscrowManagerTypechain";
|
|
10
|
-
import { SpvVaultManager } from "../spv_swap/SpvVaultContractTypechain";
|
|
11
|
-
import { EVMTxTrace } from "../chain/modules/EVMTransactions";
|
|
12
|
-
export type EVMEventListenerState = {
|
|
13
|
-
lastBlockNumber: number;
|
|
14
|
-
lastEvent?: {
|
|
15
|
-
blockHash: string;
|
|
16
|
-
logIndex: number;
|
|
17
|
-
};
|
|
18
|
-
};
|
|
19
|
-
/**
|
|
20
|
-
* EVM on-chain event handler for front-end systems without access to fs, uses WS or long-polling to subscribe, might lose
|
|
21
|
-
* out on some events if the network is unreliable, front-end systems should take this into consideration and not
|
|
22
|
-
* rely purely on events
|
|
23
|
-
*/
|
|
24
|
-
export declare class EVMChainEventsBrowser implements ChainEvents<EVMSwapData> {
|
|
25
|
-
protected readonly listeners: EventListener<EVMSwapData>[];
|
|
26
|
-
protected readonly provider: JsonRpcApiProvider;
|
|
27
|
-
protected readonly chainInterface: EVMChainInterface;
|
|
28
|
-
protected readonly evmSwapContract: EVMSwapContract;
|
|
29
|
-
protected readonly evmSpvVaultContract: EVMSpvVaultContract<any>;
|
|
30
|
-
protected readonly logger: import("../../utils/Utils").LoggerType;
|
|
31
|
-
protected stopped: boolean;
|
|
32
|
-
protected pollIntervalSeconds: number;
|
|
33
|
-
private timeout;
|
|
34
|
-
constructor(chainInterface: EVMChainInterface, evmSwapContract: EVMSwapContract, evmSpvVaultContract: EVMSpvVaultContract<any>, pollIntervalSeconds?: number);
|
|
35
|
-
findInitSwapData(call: EVMTxTrace, escrowHash: string, claimHandler: IClaimHandler<any, any>): EVMSwapData;
|
|
36
|
-
/**
|
|
37
|
-
* Returns async getter for fetching on-demand initialize event swap data
|
|
38
|
-
*
|
|
39
|
-
* @param event
|
|
40
|
-
* @param claimHandler
|
|
41
|
-
* @private
|
|
42
|
-
* @returns {() => Promise<EVMSwapData>} getter to be passed to InitializeEvent constructor
|
|
43
|
-
*/
|
|
44
|
-
private getSwapDataGetter;
|
|
45
|
-
protected parseInitializeEvent(event: TypedEventLog<EscrowManager["filters"]["Initialize"]>): InitializeEvent<EVMSwapData>;
|
|
46
|
-
protected parseRefundEvent(event: TypedEventLog<EscrowManager["filters"]["Refund"]>): RefundEvent<EVMSwapData>;
|
|
47
|
-
protected parseClaimEvent(event: TypedEventLog<EscrowManager["filters"]["Claim"]>): ClaimEvent<EVMSwapData>;
|
|
48
|
-
protected parseSpvOpenEvent(event: TypedEventLog<SpvVaultManager["filters"]["Opened"]>): SpvVaultOpenEvent;
|
|
49
|
-
protected parseSpvDepositEvent(event: TypedEventLog<SpvVaultManager["filters"]["Deposited"]>): SpvVaultDepositEvent;
|
|
50
|
-
protected parseSpvFrontEvent(event: TypedEventLog<SpvVaultManager["filters"]["Fronted"]>): SpvVaultFrontEvent;
|
|
51
|
-
protected parseSpvClaimEvent(event: TypedEventLog<SpvVaultManager["filters"]["Claimed"]>): SpvVaultClaimEvent;
|
|
52
|
-
protected parseSpvCloseEvent(event: TypedEventLog<SpvVaultManager["filters"]["Closed"]>): SpvVaultCloseEvent;
|
|
53
|
-
/**
|
|
54
|
-
* Processes event as received from the chain, parses it & calls event listeners
|
|
55
|
-
*
|
|
56
|
-
* @param events
|
|
57
|
-
* @param currentBlock
|
|
58
|
-
* @protected
|
|
59
|
-
*/
|
|
60
|
-
protected processEvents(events: (TypedEventLog<EscrowManager["filters"]["Initialize" | "Refund" | "Claim"]> | TypedEventLog<SpvVaultManager["filters"]["Opened" | "Deposited" | "Fronted" | "Claimed" | "Closed"]>)[], currentBlock: Block): Promise<void>;
|
|
61
|
-
protected checkEventsEcrowManager(currentBlock: Block, lastProcessedEvent?: {
|
|
62
|
-
blockHash: string;
|
|
63
|
-
logIndex: number;
|
|
64
|
-
}, lastBlockNumber?: number): Promise<[{
|
|
65
|
-
blockHash: string;
|
|
66
|
-
logIndex: number;
|
|
67
|
-
}, number]>;
|
|
68
|
-
protected checkEventsSpvVaults(currentBlock: Block, lastProcessedEvent?: {
|
|
69
|
-
blockHash: string;
|
|
70
|
-
logIndex: number;
|
|
71
|
-
}, lastBlockNumber?: number): Promise<[{
|
|
72
|
-
blockHash: string;
|
|
73
|
-
logIndex: number;
|
|
74
|
-
}, number]>;
|
|
75
|
-
protected checkEvents(lastState: EVMEventListenerState[]): Promise<EVMEventListenerState[]>;
|
|
76
|
-
/**
|
|
77
|
-
* Sets up event handlers listening for swap events over websocket
|
|
78
|
-
*
|
|
79
|
-
* @protected
|
|
80
|
-
*/
|
|
81
|
-
protected setupPoll(lastState?: EVMEventListenerState[], saveLatestProcessedBlockNumber?: (newState: EVMEventListenerState[]) => Promise<void>): Promise<void>;
|
|
82
|
-
init(): Promise<void>;
|
|
83
|
-
stop(): Promise<void>;
|
|
84
|
-
registerListener(cbk: EventListener<EVMSwapData>): void;
|
|
85
|
-
unregisterListener(cbk: EventListener<EVMSwapData>): boolean;
|
|
86
|
-
}
|
|
1
|
+
import { ChainEvents, ClaimEvent, EventListener, InitializeEvent, RefundEvent, SpvVaultClaimEvent, SpvVaultCloseEvent, SpvVaultDepositEvent, SpvVaultFrontEvent, SpvVaultOpenEvent } from "@atomiqlabs/base";
|
|
2
|
+
import { IClaimHandler } from "../swaps/handlers/claim/ClaimHandlers";
|
|
3
|
+
import { EVMSwapData } from "../swaps/EVMSwapData";
|
|
4
|
+
import { Block, JsonRpcApiProvider } from "ethers";
|
|
5
|
+
import { EVMSwapContract } from "../swaps/EVMSwapContract";
|
|
6
|
+
import { EVMSpvVaultContract } from "../spv_swap/EVMSpvVaultContract";
|
|
7
|
+
import { EVMChainInterface } from "../chain/EVMChainInterface";
|
|
8
|
+
import { TypedEventLog } from "../typechain/common";
|
|
9
|
+
import { EscrowManager } from "../swaps/EscrowManagerTypechain";
|
|
10
|
+
import { SpvVaultManager } from "../spv_swap/SpvVaultContractTypechain";
|
|
11
|
+
import { EVMTxTrace } from "../chain/modules/EVMTransactions";
|
|
12
|
+
export type EVMEventListenerState = {
|
|
13
|
+
lastBlockNumber: number;
|
|
14
|
+
lastEvent?: {
|
|
15
|
+
blockHash: string;
|
|
16
|
+
logIndex: number;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* EVM on-chain event handler for front-end systems without access to fs, uses WS or long-polling to subscribe, might lose
|
|
21
|
+
* out on some events if the network is unreliable, front-end systems should take this into consideration and not
|
|
22
|
+
* rely purely on events
|
|
23
|
+
*/
|
|
24
|
+
export declare class EVMChainEventsBrowser implements ChainEvents<EVMSwapData> {
|
|
25
|
+
protected readonly listeners: EventListener<EVMSwapData>[];
|
|
26
|
+
protected readonly provider: JsonRpcApiProvider;
|
|
27
|
+
protected readonly chainInterface: EVMChainInterface;
|
|
28
|
+
protected readonly evmSwapContract: EVMSwapContract;
|
|
29
|
+
protected readonly evmSpvVaultContract: EVMSpvVaultContract<any>;
|
|
30
|
+
protected readonly logger: import("../../utils/Utils").LoggerType;
|
|
31
|
+
protected stopped: boolean;
|
|
32
|
+
protected pollIntervalSeconds: number;
|
|
33
|
+
private timeout;
|
|
34
|
+
constructor(chainInterface: EVMChainInterface, evmSwapContract: EVMSwapContract, evmSpvVaultContract: EVMSpvVaultContract<any>, pollIntervalSeconds?: number);
|
|
35
|
+
findInitSwapData(call: EVMTxTrace, escrowHash: string, claimHandler: IClaimHandler<any, any>): EVMSwapData;
|
|
36
|
+
/**
|
|
37
|
+
* Returns async getter for fetching on-demand initialize event swap data
|
|
38
|
+
*
|
|
39
|
+
* @param event
|
|
40
|
+
* @param claimHandler
|
|
41
|
+
* @private
|
|
42
|
+
* @returns {() => Promise<EVMSwapData>} getter to be passed to InitializeEvent constructor
|
|
43
|
+
*/
|
|
44
|
+
private getSwapDataGetter;
|
|
45
|
+
protected parseInitializeEvent(event: TypedEventLog<EscrowManager["filters"]["Initialize"]>): InitializeEvent<EVMSwapData>;
|
|
46
|
+
protected parseRefundEvent(event: TypedEventLog<EscrowManager["filters"]["Refund"]>): RefundEvent<EVMSwapData>;
|
|
47
|
+
protected parseClaimEvent(event: TypedEventLog<EscrowManager["filters"]["Claim"]>): ClaimEvent<EVMSwapData>;
|
|
48
|
+
protected parseSpvOpenEvent(event: TypedEventLog<SpvVaultManager["filters"]["Opened"]>): SpvVaultOpenEvent;
|
|
49
|
+
protected parseSpvDepositEvent(event: TypedEventLog<SpvVaultManager["filters"]["Deposited"]>): SpvVaultDepositEvent;
|
|
50
|
+
protected parseSpvFrontEvent(event: TypedEventLog<SpvVaultManager["filters"]["Fronted"]>): SpvVaultFrontEvent;
|
|
51
|
+
protected parseSpvClaimEvent(event: TypedEventLog<SpvVaultManager["filters"]["Claimed"]>): SpvVaultClaimEvent;
|
|
52
|
+
protected parseSpvCloseEvent(event: TypedEventLog<SpvVaultManager["filters"]["Closed"]>): SpvVaultCloseEvent;
|
|
53
|
+
/**
|
|
54
|
+
* Processes event as received from the chain, parses it & calls event listeners
|
|
55
|
+
*
|
|
56
|
+
* @param events
|
|
57
|
+
* @param currentBlock
|
|
58
|
+
* @protected
|
|
59
|
+
*/
|
|
60
|
+
protected processEvents(events: (TypedEventLog<EscrowManager["filters"]["Initialize" | "Refund" | "Claim"]> | TypedEventLog<SpvVaultManager["filters"]["Opened" | "Deposited" | "Fronted" | "Claimed" | "Closed"]>)[], currentBlock: Block): Promise<void>;
|
|
61
|
+
protected checkEventsEcrowManager(currentBlock: Block, lastProcessedEvent?: {
|
|
62
|
+
blockHash: string;
|
|
63
|
+
logIndex: number;
|
|
64
|
+
}, lastBlockNumber?: number): Promise<[{
|
|
65
|
+
blockHash: string;
|
|
66
|
+
logIndex: number;
|
|
67
|
+
}, number]>;
|
|
68
|
+
protected checkEventsSpvVaults(currentBlock: Block, lastProcessedEvent?: {
|
|
69
|
+
blockHash: string;
|
|
70
|
+
logIndex: number;
|
|
71
|
+
}, lastBlockNumber?: number): Promise<[{
|
|
72
|
+
blockHash: string;
|
|
73
|
+
logIndex: number;
|
|
74
|
+
}, number]>;
|
|
75
|
+
protected checkEvents(lastState: EVMEventListenerState[]): Promise<EVMEventListenerState[]>;
|
|
76
|
+
/**
|
|
77
|
+
* Sets up event handlers listening for swap events over websocket
|
|
78
|
+
*
|
|
79
|
+
* @protected
|
|
80
|
+
*/
|
|
81
|
+
protected setupPoll(lastState?: EVMEventListenerState[], saveLatestProcessedBlockNumber?: (newState: EVMEventListenerState[]) => Promise<void>): Promise<void>;
|
|
82
|
+
init(): Promise<void>;
|
|
83
|
+
stop(): Promise<void>;
|
|
84
|
+
registerListener(cbk: EventListener<EVMSwapData>): void;
|
|
85
|
+
unregisterListener(cbk: EventListener<EVMSwapData>): boolean;
|
|
86
|
+
}
|