2023-07-18 10:47:38 +02:00
|
|
|
package execution_client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
2023-08-18 15:43:22 +02:00
|
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/execution"
|
2023-07-18 10:47:38 +02:00
|
|
|
"github.com/ledgerwatch/erigon/cl/cltypes"
|
2023-08-18 15:43:22 +02:00
|
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
|
|
"github.com/ledgerwatch/erigon/turbo/execution/eth1/eth1_chain_reader.go"
|
2023-07-18 10:47:38 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type ExecutionClientDirect struct {
|
2023-08-18 15:43:22 +02:00
|
|
|
chainRW eth1_chain_reader.ChainReaderWriterEth1
|
|
|
|
ctx context.Context
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
|
|
|
|
2023-08-18 15:43:22 +02:00
|
|
|
func NewExecutionClientDirect(ctx context.Context, chainRW eth1_chain_reader.ChainReaderWriterEth1) (*ExecutionClientDirect, error) {
|
2023-07-18 10:47:38 +02:00
|
|
|
return &ExecutionClientDirect{
|
2023-08-18 15:43:22 +02:00
|
|
|
chainRW: chainRW,
|
|
|
|
ctx: ctx,
|
2023-07-18 10:47:38 +02:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2023-08-01 16:01:26 +05:30
|
|
|
func (cc *ExecutionClientDirect) NewPayload(payload *cltypes.Eth1Block, beaconParentRoot *libcommon.Hash) (invalid bool, err error) {
|
2023-07-18 10:47:38 +02:00
|
|
|
if payload == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-23 15:56:35 +01:00
|
|
|
header, err := payload.RlpHeader(beaconParentRoot)
|
2023-08-18 15:43:22 +02:00
|
|
|
if err != nil {
|
|
|
|
return true, err
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
|
|
|
|
2023-08-18 15:43:22 +02:00
|
|
|
body := payload.Body()
|
|
|
|
txs, err := types.DecodeTransactions(body.Transactions)
|
|
|
|
if err != nil {
|
|
|
|
return true, err
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
|
|
|
|
2023-08-18 15:43:22 +02:00
|
|
|
if err := cc.chainRW.InsertBlockAndWait(types.NewBlockFromStorage(payload.BlockHash, header, txs, nil, body.Withdrawals)); err != nil {
|
|
|
|
return false, err
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
2023-08-18 15:43:22 +02:00
|
|
|
|
|
|
|
status, _, err := cc.chainRW.ValidateChain(payload.BlockHash, payload.BlockNumber)
|
2023-07-18 10:47:38 +02:00
|
|
|
if err != nil {
|
2023-08-18 15:43:22 +02:00
|
|
|
return false, err
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
2023-08-18 15:43:22 +02:00
|
|
|
invalid = status == execution.ExecutionStatus_BadBlock
|
2023-07-18 10:47:38 +02:00
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) ForkChoiceUpdate(finalized libcommon.Hash, head libcommon.Hash) error {
|
2023-08-18 15:43:22 +02:00
|
|
|
status, _, err := cc.chainRW.UpdateForkChoice(head, head, finalized)
|
2023-07-18 10:47:38 +02:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("execution Client RPC failed to retrieve ForkChoiceUpdate response, err: %w", err)
|
|
|
|
}
|
2023-08-18 15:43:22 +02:00
|
|
|
if status == execution.ExecutionStatus_InvalidForkchoice {
|
|
|
|
return fmt.Errorf("forkchoice was invalid")
|
|
|
|
}
|
|
|
|
if status == execution.ExecutionStatus_BadBlock {
|
|
|
|
return fmt.Errorf("bad block as forkchoice")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) SupportInsertion() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) InsertBlocks(blks []*types.Block) error {
|
|
|
|
return cc.chainRW.InsertBlocksAndWait(blks)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) InsertBlock(blk *types.Block) error {
|
|
|
|
return cc.chainRW.InsertBlockAndWait(blk)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) IsCanonicalHash(hash libcommon.Hash) (bool, error) {
|
|
|
|
return cc.chainRW.IsCanonicalHash(hash)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) Ready() (bool, error) {
|
|
|
|
return cc.chainRW.Ready()
|
2023-07-18 10:47:38 +02:00
|
|
|
}
|
2023-08-29 02:37:30 +02:00
|
|
|
|
|
|
|
// GetBodiesByRange gets block bodies in given block range
|
|
|
|
func (cc *ExecutionClientDirect) GetBodiesByRange(start, count uint64) ([]*types.RawBody, error) {
|
2023-11-17 13:04:02 +01:00
|
|
|
return cc.chainRW.GetBodiesByRange(start, count)
|
2023-08-29 02:37:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetBodiesByHashes gets block bodies with given hashes
|
|
|
|
func (cc *ExecutionClientDirect) GetBodiesByHashes(hashes []libcommon.Hash) ([]*types.RawBody, error) {
|
2023-11-17 13:04:02 +01:00
|
|
|
return cc.chainRW.GetBodiesByHashes(hashes)
|
2023-08-29 02:37:30 +02:00
|
|
|
}
|
2023-10-16 15:35:26 +02:00
|
|
|
|
|
|
|
func (cc *ExecutionClientDirect) FrozenBlocks() uint64 {
|
|
|
|
return cc.chainRW.FrozenBlocks()
|
|
|
|
}
|