index

package
v1.32.0-rc2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 13, 2024 License: Apache-2.0, MIT Imports: 30 Imported by: 4

Documentation

Index

Constants

View Source
const DefaultDbFilename = "chainindex.db"

Variables

View Source
var ErrChainForked = xerrors.New("chain forked")
View Source
var ErrClosed = errors.New("index closed")
View Source
var ErrMaxResultsReached = fmt.Errorf("filter matches too many events, try a more restricted filter")
View Source
var ErrNotFound = errors.New("not found in index")

Functions

func PopulateFromSnapshot added in v1.31.0

func PopulateFromSnapshot(ctx context.Context, path string, cs ChainStore) error

PopulateFromSnapshot initializes and populates the chain index from a snapshot.

This function creates a new Index at the specified path and populates it by using the chain state from the provided ChainStore. It starts from the heaviest tipset and works backwards, indexing each tipset until it reaches the genesis block or encounters a tipset for which it is unable to find messages in the chain store.

Important Notes:

  1. This function assumes that the snapshot has already been imported into the ChainStore.
  2. Events are not populated in the index because snapshots do not contain event data, and messages are not re-executed during this process. The resulting index will only contain tipsets and messages.
  3. This function will delete any existing database at the specified path before creating a new one.

Types

type ActorToDelegatedAddressFunc added in v1.31.0

type ActorToDelegatedAddressFunc func(ctx context.Context, emitter abi.ActorID, ts *types.TipSet) (address.Address, bool)

ActorToDelegatedAddressFunc is a function type that resolves an actor ID to a DelegatedAddress if one exists for that actor, otherwise returns nil

type ChainStore

type ChainStore interface {
	MessagesForTipset(ctx context.Context, ts *types.TipSet) ([]types.ChainMsg, error)
	GetHeaviestTipSet() *types.TipSet
	GetTipSetByCid(ctx context.Context, tsKeyCid cid.Cid) (*types.TipSet, error)
	GetTipSetFromKey(ctx context.Context, tsk types.TipSetKey) (*types.TipSet, error)
	MessagesForBlock(ctx context.Context, b *types.BlockHeader) ([]*types.Message, []*types.SignedMessage, error)
	ActorStore(ctx context.Context) adt.Store
	GetTipsetByHeight(ctx context.Context, h abi.ChainEpoch, ts *types.TipSet, prev bool) (*types.TipSet, error)
	IsStoringEvents() bool
}

type CollectedEvent added in v1.31.0

type CollectedEvent struct {
	Entries     []types.EventEntry
	EmitterAddr address.Address // address of emitter
	EventIdx    int             // index of the event within the list of emitted events in a given tipset
	Reverted    bool
	Height      abi.ChainEpoch
	TipSetKey   types.TipSetKey // tipset that contained the message
	MsgIdx      int             // index of the message in the tipset
	MsgCid      cid.Cid         // cid of message that produced event
}

type EventFilter added in v1.31.0

type EventFilter struct {
	MinHeight abi.ChainEpoch // minimum epoch to apply filter or -1 if no minimum
	MaxHeight abi.ChainEpoch // maximum epoch to apply filter or -1 if no maximum
	TipsetCid cid.Cid
	Addresses []address.Address // list of actor addresses that are extpected to emit the event

	KeysWithCodec map[string][]types.ActorEventBlock // map of key names to a list of alternate values that may match
	MaxResults    int                                // maximum number of results to collect, 0 is unlimited

	Codec multicodec.Code // optional codec filter, only used if KeysWithCodec is not set
}

type Indexer added in v1.31.0

type Indexer interface {
	Start()
	ReconcileWithChain(ctx context.Context, currHead *types.TipSet) error
	IndexSignedMessage(ctx context.Context, msg *types.SignedMessage) error
	IndexEthTxHash(ctx context.Context, txHash ethtypes.EthHash, c cid.Cid) error

	SetActorToDelegatedAddresFunc(idToRobustAddrFunc ActorToDelegatedAddressFunc)
	SetRecomputeTipSetStateFunc(f RecomputeTipSetStateFunc)

	Apply(ctx context.Context, from, to *types.TipSet) error
	Revert(ctx context.Context, from, to *types.TipSet) error

	// Returns (cid.Undef, nil) if the message was not found
	GetCidFromHash(ctx context.Context, hash ethtypes.EthHash) (cid.Cid, error)
	// Returns (nil, ErrNotFound) if the message was not found
	GetMsgInfo(ctx context.Context, m cid.Cid) (*MsgInfo, error)

	GetEventsForFilter(ctx context.Context, f *EventFilter) ([]*CollectedEvent, error)

	ChainValidateIndex(ctx context.Context, epoch abi.ChainEpoch, backfill bool) (*types.IndexValidation, error)

	Close() error
}

type MsgInfo

type MsgInfo struct {
	// the message this record refers to
	Message cid.Cid
	// the tipset where this message was included
	TipSet cid.Cid
	// the epoch where this message was included
	Epoch abi.ChainEpoch
}

MsgInfo is the Message metadata the index tracks.

type RecomputeTipSetStateFunc added in v1.31.0

type RecomputeTipSetStateFunc func(ctx context.Context, ts *types.TipSet) error

type SqliteIndexer added in v1.31.0

type SqliteIndexer struct {
	// contains filtered or unexported fields
}

func NewSqliteIndexer added in v1.31.0

func NewSqliteIndexer(path string, cs ChainStore, gcRetentionEpochs int64, reconcileEmptyIndex bool,
	maxReconcileTipsets uint64) (si *SqliteIndexer, err error)

func (*SqliteIndexer) Apply added in v1.31.0

func (si *SqliteIndexer) Apply(ctx context.Context, from, to *types.TipSet) error

func (*SqliteIndexer) ChainValidateIndex added in v1.31.0

func (si *SqliteIndexer) ChainValidateIndex(ctx context.Context, epoch abi.ChainEpoch, backfill bool) (*types.IndexValidation, error)

func (*SqliteIndexer) Close added in v1.31.0

func (si *SqliteIndexer) Close() error

func (*SqliteIndexer) GetCidFromHash added in v1.31.0

func (si *SqliteIndexer) GetCidFromHash(ctx context.Context, txHash ethtypes.EthHash) (cid.Cid, error)

func (*SqliteIndexer) GetEventsForFilter added in v1.31.0

func (si *SqliteIndexer) GetEventsForFilter(ctx context.Context, f *EventFilter) ([]*CollectedEvent, error)

GetEventsForFilter returns matching events for the given filter Returns nil, nil if the filter has no matching events Returns nil, ErrNotFound if the filter has no matching events and the tipset is not indexed Returns nil, err for all other errors

func (*SqliteIndexer) GetMsgInfo added in v1.31.0

func (si *SqliteIndexer) GetMsgInfo(ctx context.Context, messageCid cid.Cid) (*MsgInfo, error)

func (*SqliteIndexer) IndexEthTxHash added in v1.31.0

func (si *SqliteIndexer) IndexEthTxHash(ctx context.Context, txHash ethtypes.EthHash, msgCid cid.Cid) error

func (*SqliteIndexer) IndexSignedMessage added in v1.31.0

func (si *SqliteIndexer) IndexSignedMessage(ctx context.Context, msg *types.SignedMessage) error

func (*SqliteIndexer) ReconcileWithChain added in v1.31.0

func (si *SqliteIndexer) ReconcileWithChain(ctx context.Context, head *types.TipSet) error

ReconcileWithChain ensures that the index is consistent with the current chain state. It performs the following steps:

  1. Checks if the index is empty. If so, it returns immediately as there's nothing to reconcile.
  2. Finds the lowest non-reverted height in the index.
  3. Walks backwards from the current chain head until it finds a tipset that exists in the index and is not marked as reverted.
  4. Sets a boundary epoch just above this found tipset.
  5. Marks all tipsets above this boundary as reverted, ensuring consistency with the current chain state.
  6. Applies all missing un-indexed tipsets starting from the last matching tipset b/w index and canonical chain to the current chain head.

This function is crucial for maintaining index integrity, especially after chain reorgs. It ensures that the index accurately reflects the current state of the blockchain.

func (*SqliteIndexer) Revert added in v1.31.0

func (si *SqliteIndexer) Revert(ctx context.Context, from, to *types.TipSet) error

func (*SqliteIndexer) SetActorToDelegatedAddresFunc added in v1.31.0

func (si *SqliteIndexer) SetActorToDelegatedAddresFunc(actorToDelegatedAddresFunc ActorToDelegatedAddressFunc)

func (*SqliteIndexer) SetRecomputeTipSetStateFunc added in v1.31.0

func (si *SqliteIndexer) SetRecomputeTipSetStateFunc(f RecomputeTipSetStateFunc)

func (*SqliteIndexer) Start added in v1.31.0

func (si *SqliteIndexer) Start()

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL