2023-09-17 11:15:06 +00:00
|
|
|
package persistence
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
"os"
|
2023-12-06 09:48:36 +00:00
|
|
|
"sync"
|
2023-09-17 11:15:06 +00:00
|
|
|
|
|
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
|
|
"github.com/spf13/afero"
|
2023-12-06 09:48:36 +00:00
|
|
|
"go.uber.org/zap/buffer"
|
2023-09-17 11:15:06 +00:00
|
|
|
)
|
|
|
|
|
2023-12-06 09:48:36 +00:00
|
|
|
var bPool = sync.Pool{
|
|
|
|
New: func() interface{} {
|
|
|
|
return &buffer.Buffer{}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2023-09-17 11:15:06 +00:00
|
|
|
type aferoRawBeaconBlockChain struct {
|
|
|
|
fs afero.Fs
|
|
|
|
cfg *clparams.BeaconChainConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewAferoRawBlockSaver(fs afero.Fs, cfg *clparams.BeaconChainConfig) RawBeaconBlockChain {
|
|
|
|
return aferoRawBeaconBlockChain{
|
|
|
|
fs: fs,
|
|
|
|
cfg: cfg,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-06 09:48:36 +00:00
|
|
|
func AferoRawBeaconBlockChainFromOsPath(cfg *clparams.BeaconChainConfig, path string) (RawBeaconBlockChain, afero.Fs) {
|
2023-09-17 11:15:06 +00:00
|
|
|
dataDirFs := afero.NewBasePathFs(afero.NewOsFs(), path)
|
2023-12-06 09:48:36 +00:00
|
|
|
return NewAferoRawBlockSaver(dataDirFs, cfg), dataDirFs
|
2023-09-17 11:15:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (a aferoRawBeaconBlockChain) BlockWriter(ctx context.Context, slot uint64, blockRoot libcommon.Hash) (io.WriteCloser, error) {
|
2023-12-06 09:48:36 +00:00
|
|
|
folderPath, path := rootToPaths(slot, blockRoot, a.cfg)
|
2023-09-17 11:15:06 +00:00
|
|
|
_ = a.fs.MkdirAll(folderPath, 0o755)
|
|
|
|
return a.fs.OpenFile(path, os.O_CREATE|os.O_TRUNC|os.O_RDWR, 0o755)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a aferoRawBeaconBlockChain) BlockReader(ctx context.Context, slot uint64, blockRoot libcommon.Hash) (io.ReadCloser, error) {
|
2023-12-06 09:48:36 +00:00
|
|
|
_, path := rootToPaths(slot, blockRoot, a.cfg)
|
2023-09-17 11:15:06 +00:00
|
|
|
return a.fs.OpenFile(path, os.O_RDONLY, 0o755)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a aferoRawBeaconBlockChain) DeleteBlock(ctx context.Context, slot uint64, blockRoot libcommon.Hash) error {
|
2023-12-06 09:48:36 +00:00
|
|
|
_, path := rootToPaths(slot, blockRoot, a.cfg)
|
2023-09-17 11:15:06 +00:00
|
|
|
return a.fs.Remove(path)
|
|
|
|
}
|