2022-05-26 03:31:06 +00:00
|
|
|
package services
|
2021-11-14 04:08:52 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2023-06-15 06:11:51 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/chain"
|
2023-05-23 07:49:17 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/common"
|
2021-11-14 04:08:52 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
|
|
|
"github.com/ledgerwatch/erigon/core/types"
|
2023-05-26 10:12:33 +00:00
|
|
|
"github.com/ledgerwatch/erigon/eth/ethconfig"
|
2021-12-14 10:13:17 +00:00
|
|
|
"github.com/ledgerwatch/erigon/rlp"
|
2023-06-15 06:11:51 +00:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
2021-11-14 04:08:52 +00:00
|
|
|
)
|
|
|
|
|
2022-05-26 03:31:06 +00:00
|
|
|
type All struct {
|
|
|
|
BlockReader FullBlockReader
|
|
|
|
}
|
|
|
|
|
2021-11-14 04:08:52 +00:00
|
|
|
type BlockReader interface {
|
2023-05-23 07:49:17 +00:00
|
|
|
BlockByNumber(ctx context.Context, db kv.Tx, number uint64) (*types.Block, error)
|
|
|
|
BlockByHash(ctx context.Context, db kv.Tx, hash common.Hash) (*types.Block, error)
|
|
|
|
CurrentBlock(db kv.Tx) (*types.Block, error)
|
2023-06-03 10:26:20 +00:00
|
|
|
BlockWithSenders(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (block *types.Block, senders []common.Address, err error)
|
2021-11-14 04:08:52 +00:00
|
|
|
}
|
2021-11-29 03:43:19 +00:00
|
|
|
|
2021-12-05 02:03:08 +00:00
|
|
|
type HeaderReader interface {
|
2023-06-03 10:26:20 +00:00
|
|
|
Header(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (*types.Header, error)
|
|
|
|
HeaderByNumber(ctx context.Context, tx kv.Getter, blockNum uint64) (*types.Header, error)
|
2023-05-23 07:49:17 +00:00
|
|
|
HeaderByHash(ctx context.Context, tx kv.Getter, hash common.Hash) (*types.Header, error)
|
2023-06-05 05:36:24 +00:00
|
|
|
ReadAncestor(db kv.Getter, hash common.Hash, number, ancestor uint64, maxNonCanonical *uint64) (common.Hash, uint64)
|
2023-06-15 06:11:51 +00:00
|
|
|
|
|
|
|
//TODO: change it to `iter`
|
|
|
|
HeadersRange(ctx context.Context, walker func(header *types.Header) error) error
|
2022-01-07 13:52:38 +00:00
|
|
|
}
|
|
|
|
|
2023-08-18 16:10:35 +00:00
|
|
|
type BorEventReader interface {
|
|
|
|
EventLookup(ctx context.Context, tx kv.Getter, txnHash common.Hash) (uint64, bool, error)
|
|
|
|
EventsByBlock(ctx context.Context, tx kv.Tx, hash common.Hash, blockNum uint64) ([]rlp.RawValue, error)
|
|
|
|
}
|
|
|
|
|
2023-11-04 10:59:07 +00:00
|
|
|
type BorSpanReader interface {
|
|
|
|
Span(ctx context.Context, tx kv.Getter, spanNum uint64) ([]byte, error)
|
|
|
|
}
|
|
|
|
|
2022-01-07 13:52:38 +00:00
|
|
|
type CanonicalReader interface {
|
2023-06-03 10:26:20 +00:00
|
|
|
CanonicalHash(ctx context.Context, tx kv.Getter, blockNum uint64) (common.Hash, error)
|
2023-06-05 05:36:24 +00:00
|
|
|
BadHeaderNumber(ctx context.Context, tx kv.Getter, hash common.Hash) (blockHeight *uint64, err error)
|
2021-12-05 02:03:08 +00:00
|
|
|
}
|
|
|
|
|
2021-12-14 10:13:17 +00:00
|
|
|
type BodyReader interface {
|
2023-06-03 10:26:20 +00:00
|
|
|
BodyWithTransactions(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (body *types.Body, err error)
|
|
|
|
BodyRlp(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (bodyRlp rlp.RawValue, err error)
|
|
|
|
Body(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (body *types.Body, txAmount uint32, err error)
|
|
|
|
HasSenders(ctx context.Context, tx kv.Getter, hash common.Hash, blockNum uint64) (bool, error)
|
2022-01-07 13:52:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type TxnReader interface {
|
2023-05-23 07:49:17 +00:00
|
|
|
TxnLookup(ctx context.Context, tx kv.Getter, txnHash common.Hash) (uint64, bool, error)
|
2022-06-12 11:44:01 +00:00
|
|
|
TxnByIdxInBlock(ctx context.Context, tx kv.Getter, blockNum uint64, i int) (txn types.Transaction, err error)
|
2023-05-23 07:49:17 +00:00
|
|
|
RawTransactions(ctx context.Context, tx kv.Getter, fromBlock, toBlock uint64) (txs [][]byte, err error)
|
2022-01-07 13:52:38 +00:00
|
|
|
}
|
|
|
|
type HeaderAndCanonicalReader interface {
|
|
|
|
HeaderReader
|
|
|
|
CanonicalReader
|
|
|
|
}
|
|
|
|
|
|
|
|
type BlockAndTxnReader interface {
|
|
|
|
BlockReader
|
|
|
|
//HeaderReader
|
|
|
|
TxnReader
|
2021-12-14 10:13:17 +00:00
|
|
|
}
|
|
|
|
|
2021-11-29 03:43:19 +00:00
|
|
|
type FullBlockReader interface {
|
|
|
|
BlockReader
|
2021-12-14 10:13:17 +00:00
|
|
|
BodyReader
|
2021-12-05 02:03:08 +00:00
|
|
|
HeaderReader
|
2023-08-18 16:10:35 +00:00
|
|
|
BorEventReader
|
2023-11-04 10:59:07 +00:00
|
|
|
BorSpanReader
|
2022-01-07 13:52:38 +00:00
|
|
|
TxnReader
|
|
|
|
CanonicalReader
|
2023-05-26 10:12:33 +00:00
|
|
|
|
2023-06-15 06:11:51 +00:00
|
|
|
FrozenBlocks() uint64
|
2023-08-18 16:10:35 +00:00
|
|
|
FrozenBorBlocks() uint64
|
2023-06-15 06:11:51 +00:00
|
|
|
FrozenFiles() (list []string)
|
|
|
|
FreezingCfg() ethconfig.BlocksFreezing
|
|
|
|
CanPruneTo(currentBlockInDB uint64) (canPruneBlocksTo uint64)
|
|
|
|
|
2023-05-26 10:12:33 +00:00
|
|
|
Snapshots() BlockSnapshots
|
2023-08-18 16:10:35 +00:00
|
|
|
BorSnapshots() BlockSnapshots
|
2023-05-26 10:12:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type BlockSnapshots interface {
|
2023-06-15 06:11:51 +00:00
|
|
|
ReopenFolder() error
|
|
|
|
SegmentsMax() uint64
|
|
|
|
ScanDir() (map[string]struct{}, []*Range, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// BlockRetire - freezing blocks: moving old data from DB to snapshot files
|
|
|
|
type BlockRetire interface {
|
2023-08-18 16:10:35 +00:00
|
|
|
PruneAncientBlocks(tx kv.RwTx, limit int, includeBor bool) error
|
2023-11-01 16:22:35 +00:00
|
|
|
RetireBlocksInBackground(ctx context.Context, maxBlockNumInDB uint64, includeBor bool, lvl log.Lvl, seedNewSnapshots func(downloadRequest []DownloadRequest) error, onDelete func(l []string) error)
|
2023-06-15 06:11:51 +00:00
|
|
|
HasNewFrozenFiles() bool
|
|
|
|
BuildMissedIndicesIfNeed(ctx context.Context, logPrefix string, notifier DBEventNotifier, cc *chain.Config) error
|
2021-11-29 03:43:19 +00:00
|
|
|
}
|
2023-05-22 08:49:21 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
type HeaderWriter interface {
|
|
|
|
WriteHeader(tx kv.RwTx, header *types.Header) error
|
|
|
|
WriteHeaderRaw(tx kv.StatelessRwTx, number uint64, hash libcommon.Hash, headerRlp []byte, skipIndexing bool) error
|
|
|
|
WriteCanonicalHash(tx kv.RwTx, hash libcommon.Hash, number uint64) error
|
|
|
|
WriteTd(db kv.Putter, hash libcommon.Hash, number uint64, td *big.Int) error
|
|
|
|
// [from,to)
|
|
|
|
FillHeaderNumberIndex(logPrefix string, tx kv.RwTx, tmpDir string, from, to uint64, ctx context.Context, logger log.Logger) error
|
|
|
|
}
|
|
|
|
type BlockWriter interface {
|
|
|
|
HeaderWriter
|
|
|
|
WriteRawBodyIfNotExists(tx kv.RwTx, hash libcommon.Hash, number uint64, body *types.RawBody) (ok bool, lastTxnNum uint64, err error)
|
|
|
|
WriteBody(tx kv.RwTx, hash libcommon.Hash, number uint64, body *types.Body) error
|
|
|
|
}
|
|
|
|
*/
|
2023-06-15 06:11:51 +00:00
|
|
|
|
|
|
|
type DBEventNotifier interface {
|
|
|
|
OnNewSnapshot()
|
|
|
|
}
|
|
|
|
|
|
|
|
type DownloadRequest struct {
|
|
|
|
Ranges *Range
|
|
|
|
Path string
|
|
|
|
TorrentHash string
|
2023-08-18 16:10:35 +00:00
|
|
|
Bor bool
|
2023-06-15 06:11:51 +00:00
|
|
|
}
|
|
|
|
|
2023-08-18 16:10:35 +00:00
|
|
|
func NewDownloadRequest(ranges *Range, path string, torrentHash string, bor bool) DownloadRequest {
|
|
|
|
return DownloadRequest{Ranges: ranges, Path: path, TorrentHash: torrentHash, Bor: bor}
|
2023-06-15 06:11:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type Range struct {
|
|
|
|
From, To uint64
|
|
|
|
}
|