indexer

package
v1.0.0 Latest Latest
Warning

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

Go to latest
Published: Dec 16, 2024 License: Apache-2.0 Imports: 10 Imported by: 2

README

Indexer Framework

Defining an Indexer

Indexer implementations should be registered with the indexer.Register function with a unique type name. Indexers take the configuration options defined by indexer.Config which defines a common set of configuration options as well as indexer-specific options under the config sub-key. Indexers do not need to manage the common filtering options specified in Config - the indexer manager will manage these for the indexer. Indexer implementations just need to return a correct InitResult response.

Integrating the Indexer Manager

The indexer manager should be used for managing all indexers and should be integrated directly with applications wishing to support indexing. The StartIndexing function is used to start the manager. The configuration options for the manager and all indexer targets should be passed as the ManagerOptions.Config field and should match the json structure of ManagerConfig. An example configuration section in app.toml might look like this:

[indexer.target.postgres]
type = "postgres"
config.database_url = "postgres://user:password@localhost:5432/dbname"

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Register

func Register(indexerType string, descriptor Initializer)

Register registers an indexer type with the given initialization function.

Types

type Config

type Config struct {
	// Type is the name of the indexer type as registered with Register.
	Type string `mapstructure:"type" toml:"type" json:"type" comment:"The name of the registered indexer type."`

	// Config are the indexer specific config options specified by the user.
	Config interface{} `mapstructure:"config" toml:"config" json:"config,omitempty" comment:"Indexer specific configuration options."`

	// Filter is the filter configuration for the indexer.
	Filter *FilterConfig `` /* 130-byte string literal not displayed */
}

Config species the configuration passed to an indexer initialization function. It includes both common configuration options related to include or excluding parts of the data stream as well as indexer specific options under the config subsection.

NOTE: it is an error for an indexer to change its common options, such as adding or removing indexed modules, after the indexer has been initialized because this could result in an inconsistent state.

type FilterConfig added in v0.4.0

type FilterConfig struct {
	// ExcludeState specifies that the indexer will not receive state updates.
	ExcludeState bool `mapstructure:"exclude_state" toml:"exclude_state" json:"exclude_state" comment:"Exclude all state updates."`

	// ExcludeEvents specifies that the indexer will not receive events.
	ExcludeEvents bool `mapstructure:"exclude_events" toml:"exclude_events" json:"exclude_events" comment:"Exclude all events."`

	// ExcludeTxs specifies that the indexer will not receive transaction's.
	ExcludeTxs bool `mapstructure:"exclude_txs" toml:"exclude_txs" json:"exclude_txs" comment:"Exclude all transactions."`

	// ExcludeBlockHeaders specifies that the indexer will not receive block headers,
	// although it will still receive StartBlock and Commit callbacks, just without
	// the header data.
	ExcludeBlockHeaders bool `` /* 131-byte string literal not displayed */

	Modules *ModuleFilterConfig `mapstructure:"modules" toml:"modules" json:"modules,omitempty" comment:"Module filter configuration."`
}

FilterConfig specifies the configuration for filtering the data stream

type IndexerInfo added in v0.4.0

type IndexerInfo struct {
	// View is the view returned by the indexer in its InitResult. It is optional and may be nil.
	View view.AppData
}

IndexerInfo contains data returned by a specific indexer after initialization that maybe useful for the app.

type IndexingConfig added in v0.4.0

type IndexingConfig struct {
	// Target is a map of named indexer targets to their configuration.
	Target map[string]Config `mapstructure:"target" toml:"target" json:"target" comment:"Target is a map of named indexer targets to their configuration."`

	// ChannelBufferSize is the buffer size of the channels used for buffering data sent to indexer go routines.
	// It defaults to 1024.
	ChannelBufferSize int `` /* 189-byte string literal not displayed */
}

IndexingConfig is the configuration of the indexer manager and contains the configuration for each indexer target.

type IndexingOptions added in v0.4.0

type IndexingOptions struct {
	// Config is the user configuration for all indexing. It should generally be an instance map[string]interface{}
	// or json.RawMessage and match the json structure of IndexingConfig, or it can be an instance of IndexingConfig.
	// The manager will attempt to convert it to IndexingConfig.
	Config interface{}

	// Resolver is the decoder resolver that will be used to decode the data. It is required.
	Resolver decoding.DecoderResolver

	// SyncSource is a representation of the current state of key-value data to be used in a catch-up sync.
	// Catch-up syncs will be performed at initialization when necessary. SyncSource is optional but if
	// it is omitted, indexers will only be able to start indexing state from genesis.
	SyncSource decoding.SyncSource

	// Logger is the logger that indexers can use to write logs. It is optional.
	Logger logutil.Logger

	// Context is the context that indexers should use for shutdown signals via Context.Done(). It can also
	// be used to pass down other parameters to indexers if necessary. If it is omitted, context.Background
	// will be used.
	Context context.Context

	// AddressCodec is the address codec that indexers can use to encode and decode addresses. It should always be
	// provided, but if it is omitted, the indexer manager will use a default codec which encodes and decodes addresses
	// as hex strings.
	AddressCodec addressutil.AddressCodec

	// DoneWaitGroup is a wait group that all indexer manager go routines will wait on before returning when the context
	// is done.
	// It is optional.
	DoneWaitGroup *sync.WaitGroup
}

IndexingOptions are the options for starting the indexer manager.

type IndexingTarget added in v0.4.0

type IndexingTarget struct {
	// Listener is the root listener to which app data should be sent.
	// It will do all processing in the background so updates should be sent synchronously.
	Listener appdata.Listener

	// ModuleFilter returns the root module filter which an app can use to exclude modules at the storage level,
	// if such a filter is set.
	ModuleFilter *ModuleFilterConfig

	IndexerInfos map[string]IndexerInfo
}

IndexingTarget returns the indexing target listener and associated data. The returned listener is the root listener to which app data should be sent.

func StartIndexing added in v0.4.0

func StartIndexing(opts IndexingOptions) (IndexingTarget, error)

StartIndexing starts the indexer manager with the given options. The state machine should write all relevant app data to the returned listener.

type InitFunc

type InitFunc = func(InitParams) (InitResult, error)

type InitParams

type InitParams struct {
	// Config is the indexer config.
	Config Config

	// Context is the context that the indexer should use to listen for a shutdown signal via Context.Done(). Other
	// parameters may also be passed through context from the app if necessary. It is expected to be non-nil.
	Context context.Context

	// Logger is a logger the indexer can use to write log messages. It may be nil if the indexer does not need
	// to write logs.
	Logger logutil.Logger

	// AddressCodec is the address codec that the indexer can use to encode and decode addresses. It is
	// expected to be non-nil.
	AddressCodec addressutil.AddressCodec
}

InitParams is the input to the indexer initialization function.

type InitResult

type InitResult struct {
	// Listener is the indexer's app data listener.
	Listener appdata.Listener

	// View is a view of indexed data that indexers can provide. It is optional and may be nil.
	// If it is provided it can be used for automated testing and other purposes.
	// At indexer start-up, the block number returned by the view will be used to determine the
	// starting block for the indexer. If the block number is 0, the indexer manager will attempt
	// to perform a catch-up sync of state. Historical events will not be replayed, but an accurate
	// representation of the current state at the height at which indexing began can be reproduced.
	// If the block number is non-zero but does not match the current chain height, a runtime error
	// will occur because this is an unsafe condition that indicates lost data.
	View view.AppData
}

InitResult is the indexer initialization result and includes the indexer's listener implementation.

type Initializer added in v0.4.0

type Initializer struct {
	// InitFunc is the function that initializes the indexer.
	InitFunc InitFunc

	// ConfigType is the type of the configuration object that the indexer expects.
	ConfigType interface{}
}

Initializer describes an indexer initialization function and other metadata.

type ModuleFilterConfig added in v0.4.0

type ModuleFilterConfig struct {
	// Include specifies a list of modules whose state the indexer will
	// receive state updates for.
	// Only one of include or exclude modules should be specified.
	Include []string `` /* 142-byte string literal not displayed */

	// Exclude specifies a list of modules whose state the indexer will not
	// receive state updates for.
	// Only one of include or exclude modules should be specified.
	Exclude []string `` /* 142-byte string literal not displayed */
}

ModuleFilterConfig specifies the configuration for filtering modules.

Jump to

Keyboard shortcuts

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