2023-07-15 16:31:15 +00:00
|
|
|
package eth1
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/execution"
|
|
|
|
"github.com/ledgerwatch/erigon/core/rawdb"
|
2023-07-27 23:32:19 +00:00
|
|
|
"github.com/ledgerwatch/erigon/turbo/execution/eth1/eth1_utils"
|
2023-07-15 16:31:15 +00:00
|
|
|
)
|
|
|
|
|
2023-08-11 21:07:36 +00:00
|
|
|
func (e *EthereumExecutionModule) InsertBlocks(ctx context.Context, req *execution.InsertBlocksRequest) (*execution.InsertionResult, error) {
|
2023-07-23 17:10:24 +00:00
|
|
|
if !e.semaphore.TryAcquire(1) {
|
|
|
|
return &execution.InsertionResult{
|
2023-08-01 00:08:15 +00:00
|
|
|
Result: execution.ExecutionStatus_Busy,
|
2023-07-23 17:10:24 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
defer e.semaphore.Release(1)
|
2023-07-20 16:35:02 +00:00
|
|
|
tx, err := e.db.BeginRw(ctx)
|
2023-07-15 16:31:15 +00:00
|
|
|
if err != nil {
|
2023-08-11 21:07:36 +00:00
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertBlocks: could not begin transaction: %s", err)
|
2023-07-15 16:31:15 +00:00
|
|
|
}
|
|
|
|
defer tx.Rollback()
|
2023-09-06 01:48:07 +00:00
|
|
|
e.forkValidator.ClearWithUnwind(e.accumulator, e.stateChangeConsumer)
|
2023-07-30 21:35:55 +00:00
|
|
|
|
2023-08-11 21:07:36 +00:00
|
|
|
for _, block := range req.Blocks {
|
|
|
|
header, err := eth1_utils.HeaderRpcToHeader(block.Header)
|
2023-07-15 16:31:15 +00:00
|
|
|
if err != nil {
|
2023-08-11 21:07:36 +00:00
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertBlocks: cannot convert headers: %s", err)
|
2023-07-15 16:31:15 +00:00
|
|
|
}
|
2023-08-11 21:07:36 +00:00
|
|
|
body := eth1_utils.ConvertRawBlockBodyFromRpc(block.Body)
|
2024-01-09 01:26:26 +00:00
|
|
|
height := header.Number.Uint64()
|
2023-07-23 17:10:24 +00:00
|
|
|
// Parent's total difficulty
|
2024-01-09 01:26:26 +00:00
|
|
|
parentTd, err := rawdb.ReadTd(tx, header.ParentHash, height-1)
|
2023-07-23 17:10:24 +00:00
|
|
|
if err != nil || parentTd == nil {
|
|
|
|
return nil, fmt.Errorf("parent's total difficulty not found with hash %x and height %d: %v", header.ParentHash, header.Number.Uint64()-1, err)
|
|
|
|
}
|
2023-10-05 16:30:19 +00:00
|
|
|
|
2023-07-23 17:10:24 +00:00
|
|
|
// Sum TDs.
|
|
|
|
td := parentTd.Add(parentTd, header.Difficulty)
|
2023-07-15 16:31:15 +00:00
|
|
|
if err := rawdb.WriteHeader(tx, header); err != nil {
|
2024-01-09 01:26:26 +00:00
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertHeaders: writeHeader: %s", err)
|
2023-07-15 16:31:15 +00:00
|
|
|
}
|
2024-01-09 01:26:26 +00:00
|
|
|
if err := rawdb.WriteTd(tx, header.Hash(), height, td); err != nil {
|
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertHeaders: writeTd: %s", err)
|
2023-07-23 17:10:24 +00:00
|
|
|
}
|
2024-01-09 01:26:26 +00:00
|
|
|
if _, err := rawdb.WriteRawBodyIfNotExists(tx, header.Hash(), height, body); err != nil {
|
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertBlocks: writeBody: %s", err)
|
2023-08-11 21:07:36 +00:00
|
|
|
}
|
2023-07-15 16:31:15 +00:00
|
|
|
}
|
|
|
|
if err := tx.Commit(); err != nil {
|
|
|
|
return nil, fmt.Errorf("ethereumExecutionModule.InsertHeaders: could not commit: %s", err)
|
|
|
|
}
|
|
|
|
|
2023-07-23 17:10:24 +00:00
|
|
|
return &execution.InsertionResult{
|
2023-08-01 00:08:15 +00:00
|
|
|
Result: execution.ExecutionStatus_Success,
|
2023-07-23 17:10:24 +00:00
|
|
|
}, tx.Commit()
|
2023-07-15 16:31:15 +00:00
|
|
|
}
|