Skip to content

Commit

Permalink
Refactor report builder interfaces. (#430)
Browse files Browse the repository at this point in the history
  • Loading branch information
winder authored Jan 10, 2025
1 parent 94f1597 commit 1eff813
Show file tree
Hide file tree
Showing 4 changed files with 263 additions and 136 deletions.
6 changes: 3 additions & 3 deletions execute/outcome.go
Original file line number Diff line number Diff line change
Expand Up @@ -182,10 +182,10 @@ func (p *Plugin) getFilterOutcome(
p.msgHasher,
p.reportCodec,
p.estimateProvider,
observation.Nonces,
p.destChain,
uint64(maxReportLength),
p.offchainCfg.BatchGasLimit,
report.WithMaxReportSizeBytes(maxReportLength),
report.WithMaxGas(p.offchainCfg.BatchGasLimit),
report.WithExtraMessageCheck(report.CheckNonces(observation.Nonces)),
)

outcomeReports, selectedReports, err := selectReport(
Expand Down
92 changes: 73 additions & 19 deletions execute/report/builder.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,29 +18,81 @@ type ExecReportBuilder interface {
Build() ([]cciptypes.ExecutePluginReportSingleChain, error)
}

// Option that can be passed to the builder.
type Option func(erb *execReportBuilder)

// WithMaxGas limits how much gas can be used during execution.
func WithMaxGas(maxGas uint64) func(*execReportBuilder) {
return func(erb *execReportBuilder) {
erb.maxGas = maxGas
}
}

// WithMaxReportSizeBytes configures the maximum report size.
func WithMaxReportSizeBytes(maxReportSizeBytes uint64) Option {
return func(erb *execReportBuilder) {
erb.maxReportSizeBytes = maxReportSizeBytes
}
}

// WithMaxMessages configures the number of messages allowed to be in a report.
func WithMaxMessages(maxMessages uint64) Option {
return func(erb *execReportBuilder) {
erb.maxMessages = maxMessages
panic("not implemented")
}
}

// WithExtraMessageCheck adds additional message checks to the default ones.
func WithExtraMessageCheck(check Check) Option {
return func(erb *execReportBuilder) {
erb.checks = append(erb.checks, check)
}
}

func newBuilderInternal(
logger logger.Logger,
hasher cciptypes.MessageHasher,
encoder cciptypes.ExecutePluginCodec,
estimateProvider cciptypes.EstimateProvider,
destChainSelector cciptypes.ChainSelector,
options ...Option,
) *execReportBuilder {
defaultChecks := []Check{
CheckIfPseudoDeleted(),
CheckAlreadyExecuted(),
CheckTokenData(),
CheckTooCostly(),
}

builder := &execReportBuilder{
lggr: logger,
checks: defaultChecks,
encoder: encoder,
hasher: hasher,
estimateProvider: estimateProvider,
destChainSelector: destChainSelector,
}

for _, option := range options {
if option != nil {
option(builder)
}
}

return builder
}

// NewBuilder constructs the report builder.
func NewBuilder(
logger logger.Logger,
hasher cciptypes.MessageHasher,
encoder cciptypes.ExecutePluginCodec,
estimateProvider cciptypes.EstimateProvider,
nonces map[cciptypes.ChainSelector]map[string]uint64,
destChainSelector cciptypes.ChainSelector,
maxReportSizeBytes uint64,
maxGas uint64,
options ...Option,
) ExecReportBuilder {
return &execReportBuilder{
lggr: logger,

encoder: encoder,
hasher: hasher,
estimateProvider: estimateProvider,
sendersNonce: nonces,
expectedNonce: make(map[cciptypes.ChainSelector]map[string]uint64),

destChainSelector: destChainSelector,
maxReportSizeBytes: maxReportSizeBytes,
maxGas: maxGas,
}
return newBuilderInternal(logger, hasher, encoder, estimateProvider, destChainSelector, options...)
}

// validationMetadata contains all metadata needed to accumulate results across multiple reports and messages.
Expand All @@ -63,22 +115,24 @@ type execReportBuilder struct {
encoder cciptypes.ExecutePluginCodec
hasher cciptypes.MessageHasher
estimateProvider cciptypes.EstimateProvider
sendersNonce map[cciptypes.ChainSelector]map[string]uint64

// Config
checks []Check
destChainSelector cciptypes.ChainSelector
maxReportSizeBytes uint64
maxGas uint64
maxMessages uint64

// State
accumulated validationMetadata
// expectedNonce is used to track nonces for multiple messages from the same sender.
expectedNonce map[cciptypes.ChainSelector]map[string]uint64

// Result
execReports []cciptypes.ExecutePluginReportSingleChain
}

// Add an exec report for as many messages as possible in the given commit report.
// The commit report with updated metadata is returned, it reflects which messages
// were selected for the exec report.
func (b *execReportBuilder) Add(
ctx context.Context,
commitReport exectypes.CommitData,
Expand Down
Loading

0 comments on commit 1eff813

Please sign in to comment.