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") // 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") )