mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 04:30:04 +00:00
6738fa3493
* Revert "Optimize Migration for new Attester Protection DB (#8231)" This reverts commitc4ab67832f
. * Revert "Integrate New Slashing Protection DB Methods at Runtime (#8219)" This reverts commit3858068201
. * Revert "DB Migration for Optimal Local Slashing Protection (#8212)" This reverts commitdd3ac6c2ed
.
43 lines
1.8 KiB
Go
43 lines
1.8 KiB
Go
// Package iface defines an interface for the validator database.
|
|
package iface
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/backuputil"
|
|
"github.com/prysmaticlabs/prysm/validator/db/kv"
|
|
)
|
|
|
|
// Ensure the kv store implements the interface.
|
|
var _ = ValidatorDB(&kv.Store{})
|
|
|
|
// ValidatorDB defines the necessary methods for a Prysm validator DB.
|
|
type ValidatorDB interface {
|
|
io.Closer
|
|
backuputil.BackupExporter
|
|
DatabasePath() string
|
|
ClearDB() error
|
|
UpdatePublicKeysBuckets(publicKeys [][48]byte) error
|
|
|
|
// Genesis information related methods.
|
|
GenesisValidatorsRoot(ctx context.Context) ([]byte, error)
|
|
SaveGenesisValidatorsRoot(ctx context.Context, genValRoot []byte) error
|
|
|
|
// Proposer protection related methods.
|
|
HighestSignedProposal(ctx context.Context, publicKey [48]byte) (uint64, error)
|
|
LowestSignedProposal(ctx context.Context, publicKey [48]byte) (uint64, error)
|
|
ProposalHistoryForSlot(ctx context.Context, publicKey [48]byte, slot uint64) ([32]byte, bool, error)
|
|
SaveProposalHistoryForSlot(ctx context.Context, pubKey [48]byte, slot uint64, signingRoot []byte) error
|
|
ProposedPublicKeys(ctx context.Context) ([][48]byte, error)
|
|
|
|
// Attester protection related methods.
|
|
LowestSignedTargetEpoch(ctx context.Context, publicKey [48]byte) (uint64, error)
|
|
LowestSignedSourceEpoch(ctx context.Context, publicKey [48]byte) (uint64, error)
|
|
SaveLowestSignedTargetEpoch(ctx context.Context, publicKey [48]byte, epoch uint64) error
|
|
SaveLowestSignedSourceEpoch(ctx context.Context, publicKey [48]byte, epoch uint64) error
|
|
AttestationHistoryForPubKeyV2(ctx context.Context, publicKey [48]byte) (kv.EncHistoryData, error)
|
|
SaveAttestationHistoryForPubKeyV2(ctx context.Context, publicKey [48]byte, history kv.EncHistoryData) error
|
|
AttestedPublicKeys(ctx context.Context) ([][48]byte, error)
|
|
}
|