mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-25 04:47:18 +00:00
36e3a9f82a
* generate archive proto * archived committee info * archive methods added to iface definition * impl * update iface * proto comments * implement first method * committee info * save committee info * participation checked in * fully implemented * tests * test defs * db impls done
40 lines
2.1 KiB
Go
40 lines
2.1 KiB
Go
package kv
|
|
|
|
// The schema will define how to store and retrieve data from the db.
|
|
// we can prefix or suffix certain values such as `block` with attributes
|
|
// for prefix-wide scans across the underlying BoltDB buckets when filtering data.
|
|
// For example, we might store attestations as shard + attestation_root -> attestation, making
|
|
// it easy to scan for keys that have a certain shard number as a prefix and return those
|
|
// corresponding attestations.
|
|
var (
|
|
attestationsBucket = []byte("attestations")
|
|
blocksBucket = []byte("blocks")
|
|
validatorsBucket = []byte("validators")
|
|
stateBucket = []byte("state")
|
|
proposerSlashingsBucket = []byte("proposer-slashings")
|
|
attesterSlashingsBucket = []byte("attester-slashings")
|
|
voluntaryExitsBucket = []byte("voluntary-exits")
|
|
chainMetadataBucket = []byte("chain-metadata")
|
|
checkpointBucket = []byte("check-point")
|
|
archivedValidatorSetChangesBucket = []byte("archived-active-changes")
|
|
archivedCommitteeInfoBucket = []byte("archived-committee-info")
|
|
archivedBalancesBucket = []byte("archived-balances")
|
|
archivedValidatorParticipationBucket = []byte("archived-validator-participation")
|
|
archivedActiveIndicesBucket = []byte("archived-active-indices")
|
|
|
|
// Key indices buckets.
|
|
blockParentRootIndicesBucket = []byte("block-parent-root-indices")
|
|
blockSlotIndicesBucket = []byte("block-slot-indices")
|
|
attestationParentRootIndicesBucket = []byte("attestation-parent-root-indices")
|
|
attestationShardIndicesBucket = []byte("attestation-shard-indices")
|
|
attestationStartEpochIndicesBucket = []byte("attestation-start-epoch-indices")
|
|
attestationEndEpochIndicesBucket = []byte("attestation-end-epoch-indices")
|
|
|
|
// Specific item keys.
|
|
headBlockRootKey = []byte("head-root")
|
|
genesisBlockRootKey = []byte("genesis-root")
|
|
depositContractAddressKey = []byte("deposit-contract")
|
|
justifiedCheckpointKey = []byte("justified-checkpoint")
|
|
finalizedCheckpointKey = []byte("finalized-checkpoint")
|
|
)
|