2023-10-05 04:27:37 +02:00
|
|
|
package silkworm
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2023-12-12 16:05:56 +07:00
|
|
|
"math/big"
|
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
"github.com/erigontech/silkworm-go"
|
2023-10-05 04:27:37 +02:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus"
|
|
|
|
)
|
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
type Silkworm = silkworm_go.Silkworm
|
|
|
|
type SentrySettings = silkworm_go.SentrySettings
|
|
|
|
type MappedHeaderSnapshot = silkworm_go.MappedHeaderSnapshot
|
|
|
|
type MappedBodySnapshot = silkworm_go.MappedBodySnapshot
|
|
|
|
type MappedTxnSnapshot = silkworm_go.MappedTxnSnapshot
|
|
|
|
type MappedChainSnapshot = silkworm_go.MappedChainSnapshot
|
2023-11-02 02:35:13 +01:00
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
var New = silkworm_go.New
|
|
|
|
var NewMemoryMappedRegion = silkworm_go.NewMemoryMappedRegion
|
|
|
|
var NewMappedHeaderSnapshot = silkworm_go.NewMappedHeaderSnapshot
|
|
|
|
var NewMappedBodySnapshot = silkworm_go.NewMappedBodySnapshot
|
|
|
|
var NewMappedTxnSnapshot = silkworm_go.NewMappedTxnSnapshot
|
2023-11-02 02:35:13 +01:00
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
var ErrInterrupted = silkworm_go.ErrInterrupted
|
2023-10-18 01:37:16 +02:00
|
|
|
|
2023-11-02 02:35:13 +01:00
|
|
|
type RpcDaemonService struct {
|
|
|
|
silkworm *Silkworm
|
|
|
|
db kv.RoDB
|
|
|
|
}
|
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
func NewRpcDaemonService(s *Silkworm, db kv.RoDB) RpcDaemonService {
|
2023-11-02 02:35:13 +01:00
|
|
|
return RpcDaemonService{
|
|
|
|
silkworm: s,
|
|
|
|
db: db,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (service RpcDaemonService) Start() error {
|
2023-11-30 12:45:02 +01:00
|
|
|
return service.silkworm.StartRpcDaemon(service.db.CHandle())
|
2023-11-02 02:35:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (service RpcDaemonService) Stop() error {
|
|
|
|
return service.silkworm.StopRpcDaemon()
|
|
|
|
}
|
|
|
|
|
|
|
|
type SentryService struct {
|
2023-11-30 12:45:02 +01:00
|
|
|
silkworm *silkworm_go.Silkworm
|
|
|
|
settings silkworm_go.SentrySettings
|
2023-11-02 02:35:13 +01:00
|
|
|
}
|
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
func NewSentryService(s *Silkworm, settings silkworm_go.SentrySettings) SentryService {
|
2023-11-02 02:35:13 +01:00
|
|
|
return SentryService{
|
|
|
|
silkworm: s,
|
|
|
|
settings: settings,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (service SentryService) Start() error {
|
|
|
|
return service.silkworm.SentryStart(service.settings)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (service SentryService) Stop() error {
|
|
|
|
return service.silkworm.SentryStop()
|
|
|
|
}
|
|
|
|
|
2023-11-30 12:45:02 +01:00
|
|
|
func ExecuteBlocks(s *Silkworm, txn kv.Tx, chainID *big.Int, startBlock uint64, maxBlock uint64, batchSize uint64, writeChangeSets, writeReceipts, writeCallTraces bool) (uint64, error) {
|
|
|
|
lastExecutedBlock, err := s.ExecuteBlocks(txn.CHandle(), chainID, startBlock, maxBlock, batchSize, writeChangeSets, writeReceipts, writeCallTraces)
|
|
|
|
if (err != nil) && errors.Is(err, silkworm_go.ErrInvalidBlock) {
|
2023-10-05 04:27:37 +02:00
|
|
|
return lastExecutedBlock, consensus.ErrInvalidBlock
|
|
|
|
}
|
2023-11-30 12:45:02 +01:00
|
|
|
return lastExecutedBlock, err
|
2023-10-05 04:27:37 +02:00
|
|
|
}
|
2023-12-12 16:05:56 +07:00
|
|
|
|
|
|
|
type CanAddSnapshotsToSilkwarm interface {
|
|
|
|
AddSnapshotsToSilkworm(*Silkworm) error
|
|
|
|
}
|