diff --git a/arbos/block_processor.go b/arbos/block_processor.go index ff3baf0f2f..5d0c70f3f1 100644 --- a/arbos/block_processor.go +++ b/arbos/block_processor.go @@ -159,8 +159,32 @@ func ProduceBlock( } hooks := NoopSequencingHooks() + + // Espresso-specific validation + // TODO test: https://github.com/EspressoSystems/espresso-sequencer/issues/772 + if chainConfig.Espresso { + jst := message.Header.BlockJustification + if jst == nil { + return nil, nil, errors.New("batch missing espresso justification") + + } + hotshotHeader := jst.Header + if *lastHotShotCommitment != hotshotHeader.Commit() { + return nil, nil, errors.New("invalid hotshot header") + } + var roots = []*espresso.NmtRoot{&hotshotHeader.TransactionsRoot} + var proofs = []*espresso.NmtProof{&message.Header.BlockJustification.Proof} + // If the validation function below were not mocked, we would need to serialize the transactions + // in the batch here. To avoid the unnecessary overhead, we provide an empty array instead. + var txs []espresso.Bytes + err := espresso.ValidateBatchTransactions(chainConfig.ChainID.Uint64(), roots, proofs, txs) + if err != nil { + return nil, nil, errors.New("failed to validate namespace proof)") + } + } + return ProduceBlockAdvanced( - message.Header, txes, delayedMessagesRead, lastBlockHeader, lastHotShotCommitment, statedb, chainContext, chainConfig, hooks, + message.Header, txes, delayedMessagesRead, lastBlockHeader, statedb, chainContext, chainConfig, hooks, ) } @@ -170,7 +194,6 @@ func ProduceBlockAdvanced( txes types.Transactions, delayedMessagesRead uint64, lastBlockHeader *types.Header, - lastHotShotCommitment *espresso.Commitment, statedb *state.StateDB, chainContext core.ChainContext, chainConfig *params.ChainConfig, @@ -194,29 +217,6 @@ func ProduceBlockAdvanced( l1Timestamp: l1Header.Timestamp, } - // Espresso-specific validation - // TODO test: https://github.com/EspressoSystems/espresso-sequencer/issues/772 - if chainConfig.Espresso { - jst := l1Header.BlockJustification - if jst == nil { - return nil, nil, errors.New("batch missing espresso justification") - - } - hotshotHeader := jst.Header - if *lastHotShotCommitment != hotshotHeader.Commit() { - return nil, nil, errors.New("invalid hotshot header") - } - var roots = []*espresso.NmtRoot{&hotshotHeader.TransactionsRoot} - var proofs = []*espresso.NmtProof{&l1Header.BlockJustification.Proof} - // If the validation function below were not mocked, we would need to serialize the transactions - // in the batch here. To avoid the unnecessary overhead, we provide an empty array instead. - var txs []espresso.Bytes - err := espresso.ValidateBatchTransactions(chainConfig.ChainID.Uint64(), roots, proofs, txs) - if err != nil { - return nil, nil, errors.New("failed to validate namespace proof)") - } - } - header := createNewHeader(lastBlockHeader, l1Info, state, chainConfig) signer := types.MakeSigner(chainConfig, header.Number, header.Time) // Note: blockGasLeft will diverge from the actual gas left during execution in the event of invalid txs, diff --git a/execution/gethexec/executionengine.go b/execution/gethexec/executionengine.go index 2794615df4..8a364debb7 100644 --- a/execution/gethexec/executionengine.go +++ b/execution/gethexec/executionengine.go @@ -288,11 +288,6 @@ func (s *ExecutionEngine) sequenceTransactionsWithBlockMutex(header *arbostypes. } delayedMessagesRead := lastBlockHeader.Nonce.Uint64() - jst := header.BlockJustification - var hotShotHeader espresso.Commitment - if jst != nil { - hotShotHeader = jst.Header.Commit() - } startTime := time.Now() block, receipts, err := arbos.ProduceBlockAdvanced( @@ -300,7 +295,6 @@ func (s *ExecutionEngine) sequenceTransactionsWithBlockMutex(header *arbostypes. txes, delayedMessagesRead, lastBlockHeader, - &hotShotHeader, statedb, s.bc, s.bc.Config(),