batching

package
v1.5.0 Latest Latest
Warning

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

Go to latest
Published: Jan 31, 2024 License: MIT Imports: 14 Imported by: 3

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrUnknownMethod = errors.New("unknown method")
	ErrInvalidCall   = errors.New("invalid call")
)
View Source
var (
	BlockPending   = Block{"pending"}
	BlockLatest    = Block{"latest"}
	BlockSafe      = Block{"safe"}
	BlockFinalized = Block{"finalized"}
)
View Source
var DefaultBatchSize = 100

Functions

This section is empty.

Types

type BatchCallContextFn

type BatchCallContextFn func(ctx context.Context, b []rpc.BatchElem) error

type Block

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

Block represents the block ref value in RPC calls. It can be either a label (e.g. latest), a block number or block hash.

func BlockByHash

func BlockByHash(hash common.Hash) Block

BlockByHash references a block by hash. Canonical or non-canonical blocks may be referenced.

func BlockByNumber

func BlockByNumber(blockNum uint64) Block

BlockByNumber references a canonical block by number.

func (Block) ArgValue

func (b Block) ArgValue() any

type BoundContract

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

func NewBoundContract

func NewBoundContract(abi *abi.ABI, addr common.Address) *BoundContract

func (*BoundContract) Call

func (b *BoundContract) Call(method string, args ...interface{}) *ContractCall

func (*BoundContract) DecodeCall added in v1.5.0

func (b *BoundContract) DecodeCall(data []byte) (string, *CallResult, error)

type CallContextFn

type CallContextFn func(ctx context.Context, result any, method string, args ...any) error

type CallResult

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

func ReadArray added in v1.5.0

func ReadArray(ctx context.Context, caller *MultiCaller, block Block, countCall *ContractCall, getCall func(i *big.Int) *ContractCall) ([]*CallResult, error)

ReadArray uses batch calls to load all entries from an array. countCall is used to retrieve the current array length, then getCall is used to create calls for each element which are sent in a batch call. The returned *CallResult slice, contains a result for each entry in the array, in the same order as in the contract.

func (*CallResult) GetAddress

func (c *CallResult) GetAddress(i int) common.Address

func (*CallResult) GetBigInt

func (c *CallResult) GetBigInt(i int) *big.Int

func (*CallResult) GetBool

func (c *CallResult) GetBool(i int) bool

func (*CallResult) GetBytes added in v1.5.0

func (c *CallResult) GetBytes(i int) []byte

func (*CallResult) GetBytes32 added in v1.5.0

func (c *CallResult) GetBytes32(i int) [32]byte

func (*CallResult) GetBytes32Slice added in v1.5.0

func (c *CallResult) GetBytes32Slice(i int) [][32]byte

func (*CallResult) GetHash

func (c *CallResult) GetHash(i int) common.Hash

func (*CallResult) GetStruct

func (c *CallResult) GetStruct(i int, target interface{})

func (*CallResult) GetUint32

func (c *CallResult) GetUint32(i int) uint32

func (*CallResult) GetUint64

func (c *CallResult) GetUint64(i int) uint64

func (*CallResult) GetUint8

func (c *CallResult) GetUint8(i int) uint8

type ContractCall

type ContractCall struct {
	Abi    *abi.ABI
	Addr   common.Address
	Method string
	Args   []interface{}
}

func NewContractCall

func NewContractCall(abi *abi.ABI, addr common.Address, method string, args ...interface{}) *ContractCall

func (*ContractCall) Pack

func (c *ContractCall) Pack() ([]byte, error)

func (*ContractCall) ToCallArgs

func (c *ContractCall) ToCallArgs() (interface{}, error)

func (*ContractCall) ToTxCandidate

func (c *ContractCall) ToTxCandidate() (txmgr.TxCandidate, error)

func (*ContractCall) Unpack

func (c *ContractCall) Unpack(hex hexutil.Bytes) (*CallResult, error)

type EthRpc

type EthRpc interface {
	CallContext(ctx context.Context, out interface{}, method string, args ...interface{}) error
	BatchCallContext(ctx context.Context, b []rpc.BatchElem) error
}

type IterativeBatchCall

type IterativeBatchCall[K any, V any] struct {
	// contains filtered or unexported fields
}

IterativeBatchCall batches many RPC requests with safe and easy parallelization. Request errors are handled and re-tried, and the batch size is configurable. Executing IterativeBatchCall is as simple as calling Fetch repeatedly until it returns io.EOF.

func NewIterativeBatchCall

func NewIterativeBatchCall[K any, V any](
	requestsKeys []K,
	makeRequest func(K) (V, rpc.BatchElem),
	getBatch BatchCallContextFn,
	getSingle CallContextFn,
	batchSize int) *IterativeBatchCall[K, V]

NewIterativeBatchCall constructs a batch call, fetching the values with the given keys, and transforms them into a verified final result.

func (*IterativeBatchCall[K, V]) Complete

func (ibc *IterativeBatchCall[K, V]) Complete() bool

Complete indicates if the batch call is done.

func (*IterativeBatchCall[K, V]) Fetch

func (ibc *IterativeBatchCall[K, V]) Fetch(ctx context.Context) error

Fetch fetches more of the data, and returns io.EOF when all data has been fetched. This method is safe to call concurrently; it will parallelize the fetching work. If no work is available, but the fetching is not done yet, then Fetch will block until the next thing can be fetched, or until the context expires.

func (*IterativeBatchCall[K, V]) Reset

func (ibc *IterativeBatchCall[K, V]) Reset()

Reset will clear the batch call, to start fetching all contents from scratch.

func (*IterativeBatchCall[K, V]) Result

func (ibc *IterativeBatchCall[K, V]) Result() ([]V, error)

Result returns the fetched values, checked and transformed to the final output type, if available. If the check fails, the IterativeBatchCall will Reset itself, to be ready for a re-attempt in fetching new data.

type MultiCaller

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

func NewMultiCaller

func NewMultiCaller(rpc EthRpc, batchSize int) *MultiCaller

func (*MultiCaller) Call

func (m *MultiCaller) Call(ctx context.Context, block Block, calls ...*ContractCall) ([]*CallResult, error)

func (*MultiCaller) SingleCall

func (m *MultiCaller) SingleCall(ctx context.Context, block Block, call *ContractCall) (*CallResult, error)

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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