Documentation ¶
Index ¶
- Constants
- Variables
- func EthStoreConfig() *storeConfig
- func GetBlockByBlockNumberOrHash(ctx context.Context, w3c *web3go.Client, bnh types.BlockNumberOrHash, ...) (*types.Block, error)
- func IsBoundChecksEnabled(ctx context.Context) bool
- func MustInit()
- func NewContextWithBoundChecksDisabled(ctx context.Context) context.Context
- func NewSuggestedFilterQuerySetTooLargeError[T SuggestedFilterRange](suggestedRange *T) error
- func NewSuggestedFilterResultSetTooLargeError[T SuggestedFilterRange](suggestedRange *T) error
- func QueryEthReceipt(ctx context.Context, w3c *web3go.Client, bnh types.BlockNumberOrHash, ...) ([]*types.Receipt, error)
- func RequireContinuous(slice []*EpochData, currentEpoch uint64) error
- func StoreConfig() *storeConfig
- type Block
- type BlockExtra
- type BlockSummary
- type CacheStore
- type ChainDataDisabler
- type Configurable
- type EpochData
- type EpochDataOpAffects
- type EpochDataOpNumAlters
- type EpochDataType
- type EpochOpType
- type EpochRemoveOption
- type EthData
- type EthReceiptMethod
- type EthReceiptMethodDetector
- type EthReceiptOption
- type Log
- type LogExtra
- type LogFilter
- type LogSlice
- type Prunable
- type QueryOption
- type Readable
- type ReceiptExtra
- type StackOperable
- type Store
- type SuggestedBlockRange
- type SuggestedEpochRange
- type SuggestedFilterOversizedError
- type SuggestedFilterRange
- type Transaction
- type TransactionExtra
- type TransactionReceipt
- type VariadicValue
Constants ¶
const ( EthReceiptMethodAutoDetect = iota EthReceiptMethodEthBlockReceipts EthReceiptMethodParityBlockReceipts EthReceiptMethodEthTxnReceipt EthReceiptMethodEnd )
const ( // max number of event logs to return MaxLogLimit = uint64(10000) // max timeout to get event logs from store TimeoutGetLogs = 3 * time.Second )
const ( EpochRemoveAll EpochRemoveOption = 0xff EpochRemoveBlock = 0x01 << 0 EpochRemoveTransaction = 0x01 << 1 EpochRemoveLog = 0x01 << 2 )
Variables ¶
var ( ErrFilterQuerySetTooLarge = errors.New("the query set is too large, please narrow down your filter condition") ErrFilterResultSetTooLarge = errors.Errorf( "the result set exceeds the max limit of %v logs, please narrow down your filter conditions", MaxLogLimit, ) ErrGetLogsTimeout = errors.Errorf( "the query timed out after exceeding the maximum duration of %v seconds", TimeoutGetLogs, ) )
var ( MaxLogBlockHashesSize int MaxLogFilterAddrCount int MaxLogFilterTopicCount int MaxLogEpochRange uint64 MaxLogBlockRange uint64 )
var ( // custom errors ErrNotFound = errors.New("not found") ErrUnsupported = errors.New("not supported") ErrEpochPivotSwitched = errors.New("epoch pivot switched") ErrContinousEpochRequired = errors.New("continous epoch required") ErrAlreadyPruned = errors.New("data already pruned") ErrChainReorged = errors.New("chain re-orged") ErrLeaderRenewal = errors.New("leadership renewal failure") // operationable epoch data types OpEpochDataTypes = []EpochDataType{ EpochBlock, EpochTransaction, EpochLog, } )
Functions ¶
func EthStoreConfig ¶
func EthStoreConfig() *storeConfig
func IsBoundChecksEnabled ¶
IsBoundChecksEnabled checks if bound checks are enabled for getLogs Defaults to true if not explicitly disabled
func NewContextWithBoundChecksDisabled ¶
NewContextWithBoundChecksDisabled returns a context that marks bound checks as disabled for getLogs
func NewSuggestedFilterQuerySetTooLargeError ¶
func NewSuggestedFilterQuerySetTooLargeError[T SuggestedFilterRange](suggestedRange *T) error
func NewSuggestedFilterResultSetTooLargeError ¶
func NewSuggestedFilterResultSetTooLargeError[T SuggestedFilterRange](suggestedRange *T) error
func QueryEthReceipt ¶
func QueryEthReceipt( ctx context.Context, w3c *web3go.Client, bnh types.BlockNumberOrHash, opts ...EthReceiptOption, ) ([]*types.Receipt, error)
func RequireContinuous ¶
func StoreConfig ¶
func StoreConfig() *storeConfig
Types ¶
type Block ¶
type Block struct { CfxBlock *types.Block Extra *BlockExtra }
type BlockExtra ¶
type BlockExtra struct { // extended fields for ETH block MixHash *common.Hash `json:"mixHash,omitempty"` TotalDifficulty *hexutil.Big `json:"totalDifficulty,omitempty"` Sha3Uncles *common.Hash `json:"sha3Uncles,omitempty"` TxnExts []*TransactionExtra `json:"-"` }
custom block fields for extention
func ExtractEthBlockExt ¶
func ExtractEthBlockExt(ethBlock *web3Types.Block) *BlockExtra
type BlockSummary ¶
type BlockSummary struct { CfxBlockSummary *types.BlockSummary Extra *BlockExtra }
type CacheStore ¶
type ChainDataDisabler ¶
type Configurable ¶
type EpochData ¶
type EpochData struct { Number uint64 // epoch number Blocks []*types.Block // blocks in order and the last one is pivot block Receipts map[types.Hash]*types.TransactionReceipt // custom extra extentions BlockExts []*BlockExtra ReceiptExts map[types.Hash]*ReceiptExtra }
EpochData wraps the blockchain data of an epoch.
func QueryEpochData ¶
QueryEpochData queries blockchain data for the specified epoch number.
func (*EpochData) GetPivotBlock ¶
type EpochDataOpAffects ¶
type EpochDataOpAffects struct { OpType EpochOpType // op type PushUpFromEpoch uint64 // for push op PushUpToEpoch uint64 // for push op PopUntilEpoch uint64 // for pop op DequeueUntilEpoch uint64 // for dequeue op NumAlters EpochDataOpNumAlters // num of adds/deletes for epoch op }
EpochDataOpAffects to record affects for epoch data op
func NewEpochDataOpAffects ¶
func NewEpochDataOpAffects(opType EpochOpType, opEpochs ...uint64) *EpochDataOpAffects
func (EpochDataOpAffects) Merge ¶
func (affects EpochDataOpAffects) Merge(na EpochDataOpNumAlters)
Merge merges operation history into the receiver
func (EpochDataOpAffects) String ¶
func (affects EpochDataOpAffects) String() string
type EpochDataOpNumAlters ¶
type EpochDataOpNumAlters map[EpochDataType]int64
EpochDataOpNumAlters to record num of alters (add or delete) for epoch data op
type EpochDataType ¶
type EpochDataType uint
Epoch data type
const ( EpochDataNil EpochDataType = iota EpochTransaction EpochLog EpochBlock )
func (EpochDataType) Name ¶
func (edt EpochDataType) Name() string
func (EpochDataType) ToDequeOption ¶
func (edt EpochDataType) ToDequeOption() EpochOpType
func (EpochDataType) ToRemoveOption ¶
func (edt EpochDataType) ToRemoveOption() EpochRemoveOption
type EpochOpType ¶
type EpochOpType uint8
Epoch data operation type
const ( EpochOpPush EpochOpType = iota + 1 EpochOpPop EpochOpDequeueBlock EpochOpDequeueTx EpochOpDequeueLog )
type EthData ¶
type EthData struct { Number uint64 // block number Block *types.Block // block body Receipts map[common.Hash]*types.Receipt // receipts }
EthData wraps the evm space blockchain data.
func QueryEthData ¶
func QueryEthData( ctx context.Context, w3c *web3go.Client, blockNumber uint64, opts ...QueryOption, ) (*EthData, error)
QueryEthData queries blockchain data for the specified block number.
type EthReceiptMethod ¶
type EthReceiptMethod uint32
func (EthReceiptMethod) IsConcrete ¶
func (m EthReceiptMethod) IsConcrete() bool
IsConcrete returns true if the method is a concrete receipt retrieval method (excluding auto-detect).
func (EthReceiptMethod) String ¶
func (m EthReceiptMethod) String() string
String returns the string representation of the EthReceiptMethod
type EthReceiptMethodDetector ¶
type EthReceiptMethodDetector struct {
// contains filtered or unexported fields
}
EthReceiptMethodDetector detects the best method for retrieving Ethereum receipts. The detection occurs only once to optimize performance by caching the result.
func (*EthReceiptMethodDetector) Detect ¶
func (d *EthReceiptMethodDetector) Detect( ctx context.Context, client *web3go.Client, bnh types.BlockNumberOrHash, ) (EthReceiptMethod, error)
Detect determines the best receipt retrieval method. If a method has already been detected, it returns the cached method. Otherwise, it attempts to detect the best method.
type EthReceiptOption ¶
type EthReceiptOption struct { Method EthReceiptMethod Concurrency int // Pre-fetched data can be used to accelerate the query eg., block header etc. Prefetched interface{} }
var (
DefaultReceiptOption EthReceiptOption
)
type Log ¶
type LogExtra ¶
type LogExtra struct { // extended fields for ETH log LogType *string `json:"logType,omitempty"` Removed *bool `json:"removed,,omitempty"` }
custom event log fields for extention
func ExtractEthLogExt ¶
type LogFilter ¶
type LogFilter struct { BlockFrom uint64 BlockTo uint64 Contracts VariadicValue Topics []VariadicValue // event hash and indexed data 1, 2, 3 // contains filtered or unexported fields }
func ParseCfxLogFilter ¶
func ParseEthLogFilter ¶
func ParseEthLogFilter(blockFrom, blockTo uint64, filter *web3Types.FilterQuery, networkId uint32) LogFilter
ParseEthLogFilter parses store log filter from eSpace log filter but also with contract address bridged to core space
func ParseEthLogFilterRaw ¶
func ParseEthLogFilterRaw(blockFrom, blockTo uint64, filter *web3Types.FilterQuery) LogFilter
ParseEthLogFilterRaw parses store log filter from eSpace log filter without any bridge or mod
type Prunable ¶
type Prunable interface { GetBlockEpochRange() (uint64, uint64, error) GetTransactionEpochRange() (uint64, uint64, error) GetLogEpochRange() (uint64, uint64, error) GetNumBlocks() (uint64, error) GetNumTransactions() (uint64, error) GetNumLogs() (uint64, error) // DequeueBlocks removes epoch blocks from the store like dequeuing a queue, // which is deleting data from the oldest epoch to some new epoch DequeueBlocks(epochUntil uint64) error // DequeueTransactions removes epoch transactions from the store like dequeuing a queue, // which is deleting data from the oldest epoch to some new epoch DequeueTransactions(epochUntil uint64) error // DequeueLogs removes epoch logs from the store like dequeuing a queue, // which is deleting data from the oldest epoch to some new epoch DequeueLogs(epochUntil uint64) error }
Prunable is used to prune historical data.
type QueryOption ¶
type QueryOption struct { ReceiptConfig EthReceiptOption Disabler ChainDataDisabler EnableLogsOptimization bool // use `eth_getLogs` for better performance if possible }
type Readable ¶
type Readable interface { GetLogs(ctx context.Context, filter LogFilter) ([]*Log, error) GetTransaction(ctx context.Context, txHash types.Hash) (*Transaction, error) GetReceipt(ctx context.Context, txHash types.Hash) (*TransactionReceipt, error) GetBlocksByEpoch(ctx context.Context, epochNumber uint64) ([]types.Hash, error) GetBlockByEpoch(ctx context.Context, epochNumber uint64) (*Block, error) GetBlockSummaryByEpoch(ctx context.Context, epochNumber uint64) (*BlockSummary, error) GetBlockByHash(ctx context.Context, blockHash types.Hash) (*Block, error) GetBlockSummaryByHash(ctx context.Context, blockHash types.Hash) (*BlockSummary, error) GetBlockByBlockNumber(ctx context.Context, blockNumber uint64) (*Block, error) GetBlockSummaryByBlockNumber(ctx context.Context, blockNumber uint64) (*BlockSummary, error) }
Readable is used for RPC to read cached data from database.
type ReceiptExtra ¶
type ReceiptExtra struct { // extended fields for ETH receipt LogExts []*LogExtra `json:"-"` }
custom receipt fields for extention
func ExtractEthReceiptExt ¶
func ExtractEthReceiptExt(ethRcpt *web3Types.Receipt) *ReceiptExtra
type StackOperable ¶
type StackOperable interface { // Push appends epoch data to the store Push(data *EpochData) error Pushn(dataSlice []*EpochData) error // Pop removes epoch data from the store like popping a stack, which is deleting // data from the most recently appended epoch to some old epoch Popn(epochUntil uint64) error }
type Store ¶
type Store interface { Readable Prunable Configurable StackOperable io.Closer IsRecordNotFound(err error) bool GetGlobalEpochRange() (uint64, uint64, error) }
Store is implemented by any object that persist blockchain data, especially for event logs.
type SuggestedBlockRange ¶
type SuggestedBlockRange struct { citypes.RangeUint64 // the maximum possible epoch for suggesting an epoch range // a value of 0 indicates that no maximum epoch is provided MaxEndEpoch uint64 }
func NewSuggestedBlockRange ¶
func NewSuggestedBlockRange(from, to, maxEndEpoch uint64) SuggestedBlockRange
type SuggestedEpochRange ¶
type SuggestedEpochRange struct {
citypes.RangeUint64
}
func NewSuggestedEpochRange ¶
func NewSuggestedEpochRange(from, to uint64) SuggestedEpochRange
type SuggestedFilterOversizedError ¶
type SuggestedFilterOversizedError[T SuggestedFilterRange] struct { SuggestedRange T // contains filtered or unexported fields }
func NewSuggestedFilterOversizeError ¶
func NewSuggestedFilterOversizeError[T SuggestedFilterRange](inner error, suggestedRange T) *SuggestedFilterOversizedError[T]
func (*SuggestedFilterOversizedError[T]) Error ¶
func (e *SuggestedFilterOversizedError[T]) Error() string
func (*SuggestedFilterOversizedError[T]) Unwrap ¶
func (e *SuggestedFilterOversizedError[T]) Unwrap() error
type SuggestedFilterRange ¶
type SuggestedFilterRange interface { SuggestedBlockRange | SuggestedEpochRange }
type Transaction ¶
type Transaction struct { CfxTransaction *types.Transaction Extra *TransactionExtra }
type TransactionExtra ¶
type TransactionExtra struct { // extended fields for ETH transaction BlockNumber *hexutil.Big `json:"blockNumber,omitempty"` StandardV *hexutil.Big `json:"standardV,omitempty"` }
custom transaction fields for extention
func ExtractEthTransactionExt ¶
func ExtractEthTransactionExt(ethTxn *web3Types.TransactionDetail) *TransactionExtra
type TransactionReceipt ¶
type TransactionReceipt struct { CfxReceipt *types.TransactionReceipt Extra *ReceiptExtra }
type VariadicValue ¶
type VariadicValue struct {
// contains filtered or unexported fields
}
VariadicValue represents an union value, including null, single value or multiple values.
func NewVariadicValue ¶
func NewVariadicValue(values ...string) VariadicValue
func (*VariadicValue) Count ¶
func (vv *VariadicValue) Count() int
func (*VariadicValue) FlatMultiple ¶
func (vv *VariadicValue) FlatMultiple() ([]string, bool)
func (*VariadicValue) IsNull ¶
func (vv *VariadicValue) IsNull() bool
func (*VariadicValue) Single ¶
func (vv *VariadicValue) Single() (string, bool)
func (*VariadicValue) ToSlice ¶
func (vv *VariadicValue) ToSlice() []string