prysm-pulse/beacon-chain/db/schema.go

41 lines
1.3 KiB
Go
Raw Normal View History

2018-10-05 17:14:50 +00:00
package db
import (
"github.com/prysmaticlabs/prysm/shared/bytes"
)
// The Schema will define how to store and retrieve data from the db.
// Currently we store blocks by prefixing `block` to their hash and
// using that as the key to store blocks.
// `block` + hash -> block
//
// We store the crystallized state using the crystallized state lookup key, and
// also the genesis block using the genesis lookup key.
// The canonical head is stored using the canonical head lookup key.
2018-09-14 05:07:30 +00:00
// The fields below define the suffix of keys in the db.
var (
attestationBucket = []byte("attestation-bucket")
blockBucket = []byte("block-bucket")
mainChainBucket = []byte("main-chain-bucket")
chainInfoBucket = []byte("chain-info")
blockVoteCacheBucket = []byte("block-vote-cache")
simulatorBucket = []byte("simulator-bucket")
2018-10-17 06:11:24 +00:00
mainChainHeightKey = []byte("chain-height")
aStateLookupKey = []byte("active-state")
cStateLookupKey = []byte("crystallized-state")
simSlotLookupKey = []byte("simulator-slot")
)
// encodeSlotNumber encodes a slot number as big endian uint64.
func encodeSlotNumber(number uint64) []byte {
return bytes.Bytes8(number)
}
// decodeSlotNumber returns a slot number which has been
// encoded as a big endian uint64 in the byte array.
func decodeToSlotNumber(bytearray []byte) uint64 {
return bytes.FromBytes8(bytearray)
}