Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Engine ¶
type Engine struct { *models.EngineStatus // contains filtered or unexported fields }
Engine is an implementation of the event ingestion engine.
This engine monitors the Flow network for two types of EVM events:
- block executed: emitted anytime a new block is created on the network, it is representation of an EVM block and contains all the consensus information.
- transaction executed: emitted anytime a new transaction is executed independently of block event. This is similar to EVM transaction receipt and contains information about the transaction execution, like result, gas used etc.
The ingested events explained above are then indexed in a local database and used in any queries from the RPC APIs. Ingestion of the events is idempotent so if a reindex needs to happen it can, since it will just overwrite the current indexed data. Idempotency is an important requirement of the implementation of this engine.
func NewEventIngestionEngine ¶
func NewEventIngestionEngine( subscriber EventSubscriber, store *pebble.Storage, blocks storage.BlockIndexer, receipts storage.ReceiptIndexer, transactions storage.TransactionIndexer, accounts storage.AccountIndexer, blocksPublisher *models.Publisher[*models.Block], logsPublisher *models.Publisher[[]*gethTypes.Log], log zerolog.Logger, collector metrics.Collector, ) *Engine
func (*Engine) Run ¶
Run the Cadence event ingestion engine.
Cadence event ingestion engine subscribes to all new EVM related events on Flow network, currently there are two types of events: - evm.BlockExecuted: this event is emitted when a new EVM block is created (usually with any new transactions) - evm.TransactionExecuted: this event is emitted when a new EVM transaction is executed (even if failed) Each event that is received should contain at least block event, but usually also transaction events. There can be multiple transaction events for a single Cadence height, but only a single block event. Events are after indexed in-order, first block event and then all transaction events.
Expected errors: there is a disconnected error which is a recoverable error that can be expected and should be handled by restarting the engine. This can happen if the client connection to the event subscription drops. All other errors are unexpected.
type EventSubscriber ¶
type EventSubscriber interface { // Subscribe to EVM events from the provided height, and return a chanel with the events. // // The BlockEvents type will contain an optional error in case // the error happens, the consumer of the chanel should handle it. Subscribe(ctx context.Context, height uint64) <-chan models.BlockEvents }
type RPCSubscriber ¶
type RPCSubscriber struct {
// contains filtered or unexported fields
}
func NewRPCSubscriber ¶
func NewRPCSubscriber( client *requester.CrossSporkClient, heartbeatInterval uint64, chainID flowGo.ChainID, logger zerolog.Logger, ) *RPCSubscriber
func (*RPCSubscriber) Subscribe ¶
func (r *RPCSubscriber) Subscribe(ctx context.Context, height uint64) <-chan models.BlockEvents
Subscribe will retrieve all the events from the provided height. If the height is from previous sporks, it will first backfill all the events in all the previous sporks, and then continue to listen all new events in the current spork.
If error is encountered during backfill the subscription will end and the response chanel will be closed.