import { Interface } from '@ethersproject/abi'; import type { DeepReadonly } from 'ts-essentials'; import type { BlockHeader, Log, Logger, MultiCallInput, MultiCallOutput } from '../../types'; import { StatefulEventSubscriber } from '../../stateful-event-subscriber'; import type { IDexHelper } from '../../dex-helper/idex-helper'; import type { MorphoOracleState } from './types'; export declare class MorphoOracleEventPool extends StatefulEventSubscriber { readonly parentName: string; protected network: number; protected dexHelper: IDexHelper; morphoOracle: string; handlers: { [event: string]: (event: any, state: DeepReadonly, log: Readonly, blockHeader: Readonly) => DeepReadonly | null; }; static morphoOracleIface: Interface; static erc20Iface: Interface; logDecoder: (log: Log) => any; addressesSubscribed: string[]; constructor(parentName: string, network: number, dexHelper: IDexHelper, morphoOracle: string, logger: Logger); /** * The function is called every time any of the subscribed * addresses release log. The function accepts the current * state, updates the state according to the log, and returns * the updated state. * @param state - Current state of event subscriber * @param log - Log released by one of the subscribed addresses * @returns Updates state of the event subscriber after the log */ protected processLog(state: DeepReadonly, log: Readonly, blockHeader: Readonly): DeepReadonly | null; /** * The function generates state using on-chain calls. This * function is called to regenerate state if the event based * system fails to fetch events and the local state is no * more correct. * @param blockNumber - Blocknumber for which the state should * should be generated * @returns state of the event subscriber at blocknumber */ generateState(blockNumber: number): Promise>; static getGenerateInfoMultiCallInput(morphoOracle: string): MultiCallInput[]; static generateInfo(multicallOutputs: MultiCallOutput[]): DeepReadonly; }