Documentation ¶
Index ¶
- Constants
- Variables
- type CheckL2BlockHash
- func (p *CheckL2BlockHash) CheckL2Block(ctx context.Context, dbTx pgx.Tx) error
- func (p *CheckL2BlockHash) GetL2Blocks(ctx context.Context, blockNumber uint64, dbTx pgx.Tx) (*state.L2Block, *types.Block, error)
- func (p *CheckL2BlockHash) GetMinimumL2BlockToCheck() uint64
- func (p *CheckL2BlockHash) GetNextL2BlockToCheck(lastLocalL2BlockNumber, minL2BlockNumberToCheck uint64) (bool, uint64)
- type CheckL2BlockProcessorDecorator
- type ForkIdType
- type L1EventProcessor
- type ProcessorBase
Constants ¶
const ( // WildcardForkId It match for all forkIds WildcardForkId ForkIdType = 0 // ForkIDIncaberry is the forkId for incaberry ForkIDIncaberry = ForkIdType(6) // nolint:gomnd // ForkIDEtrog is the forkId for etrog ForkIDEtrog = ForkIdType(7) //nolint:gomnd // ForkIDElderberry is the forkId for Elderberry ForkIDElderberry = ForkIdType(8) //nolint:gomnd // ForkID9 is the forkId for 9 ForkID9 = ForkIdType(9) //nolint:gomnd // ForkID10 is the forkId for 10 (support more counters) ForkID10 = ForkIdType(10) //nolint:gomnd // ForkID11 is the forkId for 11 (support even more counters) ForkID11 = ForkIdType(11) //nolint:gomnd )
Variables ¶
var ( // ForksIdAll support all forkIds ForksIdAll = []ForkIdType{WildcardForkId} // ForksIdOnlyElderberry support only elderberry forkId ForksIdOnlyElderberry = []ForkIdType{ForkIDElderberry, ForkID9, ForkID10, ForkID11} // ForksIdOnlyEtrog support only etrog forkId ForksIdOnlyEtrog = []ForkIdType{ForkIDEtrog} // ForksIdToIncaberry support all forkIds till incaberry ForksIdToIncaberry = []ForkIdType{1, 2, 3, 4, 5, ForkIDIncaberry} )
var ( // ErrInvalidParams is used when the object is not found ErrInvalidParams = errors.New("invalid params") )
Functions ¶
This section is empty.
Types ¶
type CheckL2BlockHash ¶ added in v0.6.3
type CheckL2BlockHash struct {
// contains filtered or unexported fields
}
CheckL2BlockHash is a struct that implements a checker of L2Block hash
func NewCheckL2BlockHash ¶ added in v0.6.3
func NewCheckL2BlockHash(state stateGetL2Block, trustedClient trustedRPCGetL2Block, initialL2BlockNumber uint64, modulusBlockNumber uint64) (*CheckL2BlockHash, error)
NewCheckL2BlockHash creates a new CheckL2BlockHash
func (*CheckL2BlockHash) CheckL2Block ¶ added in v0.6.3
func (p *CheckL2BlockHash) CheckL2Block(ctx context.Context, dbTx pgx.Tx) error
CheckL2Block checks the L2Block hash between the local and the trusted
func (*CheckL2BlockHash) GetL2Blocks ¶ added in v0.6.3
func (p *CheckL2BlockHash) GetL2Blocks(ctx context.Context, blockNumber uint64, dbTx pgx.Tx) (*state.L2Block, *types.Block, error)
GetL2Blocks returns localL2Block and trustedL2Block
func (*CheckL2BlockHash) GetMinimumL2BlockToCheck ¶ added in v0.6.3
func (p *CheckL2BlockHash) GetMinimumL2BlockToCheck() uint64
GetMinimumL2BlockToCheck returns the minimum L2Block to check
func (*CheckL2BlockHash) GetNextL2BlockToCheck ¶ added in v0.6.3
func (p *CheckL2BlockHash) GetNextL2BlockToCheck(lastLocalL2BlockNumber, minL2BlockNumberToCheck uint64) (bool, uint64)
GetNextL2BlockToCheck returns true is need to check and the blocknumber
type CheckL2BlockProcessorDecorator ¶ added in v0.6.3
type CheckL2BlockProcessorDecorator struct { L1EventProcessor // contains filtered or unexported fields }
CheckL2BlockProcessorDecorator This class is just a decorator to call CheckL2Block
func NewCheckL2BlockDecorator ¶ added in v0.6.3
func NewCheckL2BlockDecorator(l1EventProcessor L1EventProcessor, l2blockChecker *CheckL2BlockHash) *CheckL2BlockProcessorDecorator
NewCheckL2BlockDecorator creates a new CheckL2BlockDecorator
type L1EventProcessor ¶
type L1EventProcessor interface { // Name of the processor Name() string // SupportedForkIds list of forkId that support (you could use WildcardForkId) SupportedForkIds() []ForkIdType // SupportedEvents list of events that support (typically one) SupportedEvents() []etherman.EventOrder // Process a incomming event Process(ctx context.Context, order etherman.Order, l1Block *etherman.Block, dbTx pgx.Tx) error }
L1EventProcessor is the interface for a processor of L1 events The main function is Process that must execute the event
type ProcessorBase ¶
type ProcessorBase[T any] struct { SupportedEvent []etherman.EventOrder SupportedForkdIds *[]ForkIdType }
ProcessorBase is the base struct for all the processors, if reduces the boilerplate implementing the Name, SupportedEvents and SupportedForkIds functions
func (*ProcessorBase[T]) Name ¶
func (g *ProcessorBase[T]) Name() string
Name returns the name of the struct T
func (*ProcessorBase[T]) SupportedEvents ¶
func (p *ProcessorBase[T]) SupportedEvents() []etherman.EventOrder
SupportedEvents returns the supported events in the struct
func (*ProcessorBase[T]) SupportedForkIds ¶
func (p *ProcessorBase[T]) SupportedForkIds() []ForkIdType
SupportedForkIds returns the supported forkIds in the struct or the dafault till incaberry forkId