fetch_logs.go 1.22 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
package source

import (
	"context"
	"fmt"

	"github.com/ethereum-optimism/optimism/op-service/eth"
	"github.com/ethereum/go-ethereum/common"
	"github.com/ethereum/go-ethereum/core/types"
)

type LogSource interface {
	FetchReceipts(ctx context.Context, blockHash common.Hash) (eth.BlockInfo, types.Receipts, error)
}

type ReceiptProcessor interface {
	ProcessLogs(ctx context.Context, block eth.L1BlockRef, rcpts types.Receipts) error
}

type ReceiptProcessorFn func(ctx context.Context, block eth.L1BlockRef, rcpts types.Receipts) error

func (r ReceiptProcessorFn) ProcessLogs(ctx context.Context, block eth.L1BlockRef, rcpts types.Receipts) error {
	return r(ctx, block, rcpts)
}

type logFetcher struct {
	client    LogSource
	processor ReceiptProcessor
}

func newLogFetcher(client LogSource, processor ReceiptProcessor) *logFetcher {
	return &logFetcher{
		client:    client,
		processor: processor,
	}
}

var _ BlockProcessor = (*logFetcher)(nil)

func (l *logFetcher) ProcessBlock(ctx context.Context, block eth.L1BlockRef) error {
	_, rcpts, err := l.client.FetchReceipts(ctx, block.Hash)
	if err != nil {
		return fmt.Errorf("failed to fetch receipts for block %v: %w", block, err)
	}
	return l.processor.ProcessLogs(ctx, block, rcpts)
}