2019-09-18 17:05:24 +00:00
|
|
|
package kv
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-01-14 05:40:20 +00:00
|
|
|
"encoding/binary"
|
2019-09-18 17:05:24 +00:00
|
|
|
|
2019-11-27 05:08:18 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
2020-04-11 19:47:22 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
2020-03-24 20:00:54 +00:00
|
|
|
bolt "go.etcd.io/bbolt"
|
2019-09-18 18:41:47 +00:00
|
|
|
"go.opencensus.io/trace"
|
2019-09-18 17:05:24 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// ArchivedActiveValidatorChanges retrieval by epoch.
|
2019-11-27 05:08:18 +00:00
|
|
|
func (k *Store) ArchivedActiveValidatorChanges(ctx context.Context, epoch uint64) (*pb.ArchivedActiveSetChanges, error) {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.ArchivedActiveValidatorChanges")
|
|
|
|
defer span.End()
|
|
|
|
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-11-27 05:08:18 +00:00
|
|
|
var target *pb.ArchivedActiveSetChanges
|
2019-09-18 18:41:47 +00:00
|
|
|
err := k.db.View(func(tx *bolt.Tx) error {
|
|
|
|
bkt := tx.Bucket(archivedValidatorSetChangesBucket)
|
|
|
|
enc := bkt.Get(buf)
|
|
|
|
if enc == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2019-11-27 05:08:18 +00:00
|
|
|
target = &pb.ArchivedActiveSetChanges{}
|
2019-11-27 06:32:56 +00:00
|
|
|
return decode(enc, target)
|
2019-09-18 18:41:47 +00:00
|
|
|
})
|
|
|
|
return target, err
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SaveArchivedActiveValidatorChanges by epoch.
|
2019-11-27 05:08:18 +00:00
|
|
|
func (k *Store) SaveArchivedActiveValidatorChanges(ctx context.Context, epoch uint64, changes *pb.ArchivedActiveSetChanges) error {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveArchivedActiveValidatorChanges")
|
|
|
|
defer span.End()
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-11-27 06:32:56 +00:00
|
|
|
enc, err := encode(changes)
|
2019-09-18 18:41:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return k.db.Update(func(tx *bolt.Tx) error {
|
|
|
|
bucket := tx.Bucket(archivedValidatorSetChangesBucket)
|
|
|
|
return bucket.Put(buf, enc)
|
|
|
|
})
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ArchivedCommitteeInfo retrieval by epoch.
|
2019-11-27 05:08:18 +00:00
|
|
|
func (k *Store) ArchivedCommitteeInfo(ctx context.Context, epoch uint64) (*pb.ArchivedCommitteeInfo, error) {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.ArchivedCommitteeInfo")
|
|
|
|
defer span.End()
|
|
|
|
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-11-27 05:08:18 +00:00
|
|
|
var target *pb.ArchivedCommitteeInfo
|
2019-09-18 18:41:47 +00:00
|
|
|
err := k.db.View(func(tx *bolt.Tx) error {
|
|
|
|
bkt := tx.Bucket(archivedCommitteeInfoBucket)
|
|
|
|
enc := bkt.Get(buf)
|
|
|
|
if enc == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2019-11-27 05:08:18 +00:00
|
|
|
target = &pb.ArchivedCommitteeInfo{}
|
2019-11-27 06:32:56 +00:00
|
|
|
return decode(enc, target)
|
2019-09-18 18:41:47 +00:00
|
|
|
})
|
|
|
|
return target, err
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SaveArchivedCommitteeInfo by epoch.
|
2019-11-27 05:08:18 +00:00
|
|
|
func (k *Store) SaveArchivedCommitteeInfo(ctx context.Context, epoch uint64, info *pb.ArchivedCommitteeInfo) error {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveArchivedCommitteeInfo")
|
|
|
|
defer span.End()
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-11-27 06:32:56 +00:00
|
|
|
enc, err := encode(info)
|
2019-09-18 18:41:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return k.db.Update(func(tx *bolt.Tx) error {
|
|
|
|
bucket := tx.Bucket(archivedCommitteeInfoBucket)
|
|
|
|
return bucket.Put(buf, enc)
|
|
|
|
})
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ArchivedBalances retrieval by epoch.
|
|
|
|
func (k *Store) ArchivedBalances(ctx context.Context, epoch uint64) ([]uint64, error) {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.ArchivedBalances")
|
|
|
|
defer span.End()
|
|
|
|
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-09-18 18:41:47 +00:00
|
|
|
var target []uint64
|
|
|
|
err := k.db.View(func(tx *bolt.Tx) error {
|
|
|
|
bkt := tx.Bucket(archivedBalancesBucket)
|
|
|
|
enc := bkt.Get(buf)
|
|
|
|
if enc == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2020-01-14 05:40:20 +00:00
|
|
|
target = unmarshalBalances(enc)
|
|
|
|
return nil
|
2019-09-18 18:41:47 +00:00
|
|
|
})
|
|
|
|
return target, err
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SaveArchivedBalances by epoch.
|
|
|
|
func (k *Store) SaveArchivedBalances(ctx context.Context, epoch uint64, balances []uint64) error {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveArchivedBalances")
|
|
|
|
defer span.End()
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2020-01-14 05:40:20 +00:00
|
|
|
enc := marshalBalances(balances)
|
2019-09-18 18:41:47 +00:00
|
|
|
return k.db.Update(func(tx *bolt.Tx) error {
|
|
|
|
bucket := tx.Bucket(archivedBalancesBucket)
|
|
|
|
return bucket.Put(buf, enc)
|
|
|
|
})
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ArchivedValidatorParticipation retrieval by epoch.
|
|
|
|
func (k *Store) ArchivedValidatorParticipation(ctx context.Context, epoch uint64) (*ethpb.ValidatorParticipation, error) {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.ArchivedValidatorParticipation")
|
|
|
|
defer span.End()
|
|
|
|
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-09-18 18:41:47 +00:00
|
|
|
var target *ethpb.ValidatorParticipation
|
|
|
|
err := k.db.View(func(tx *bolt.Tx) error {
|
|
|
|
bkt := tx.Bucket(archivedValidatorParticipationBucket)
|
|
|
|
enc := bkt.Get(buf)
|
|
|
|
if enc == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
target = ðpb.ValidatorParticipation{}
|
2019-11-27 06:32:56 +00:00
|
|
|
return decode(enc, target)
|
2019-09-18 18:41:47 +00:00
|
|
|
})
|
|
|
|
return target, err
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SaveArchivedValidatorParticipation by epoch.
|
|
|
|
func (k *Store) SaveArchivedValidatorParticipation(ctx context.Context, epoch uint64, part *ethpb.ValidatorParticipation) error {
|
2019-09-18 18:41:47 +00:00
|
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveArchivedValidatorParticipation")
|
|
|
|
defer span.End()
|
2020-04-11 19:47:22 +00:00
|
|
|
buf := bytesutil.Uint64ToBytes(epoch)
|
2019-11-27 06:32:56 +00:00
|
|
|
enc, err := encode(part)
|
2019-09-18 18:41:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return k.db.Update(func(tx *bolt.Tx) error {
|
|
|
|
bucket := tx.Bucket(archivedValidatorParticipationBucket)
|
|
|
|
return bucket.Put(buf, enc)
|
|
|
|
})
|
2019-09-18 17:05:24 +00:00
|
|
|
}
|
2020-01-14 05:40:20 +00:00
|
|
|
|
|
|
|
func marshalBalances(bals []uint64) []byte {
|
|
|
|
res := make([]byte, len(bals)*8)
|
|
|
|
offset := 0
|
|
|
|
for i := 0; i < len(bals); i++ {
|
|
|
|
binary.LittleEndian.PutUint64(res[offset:offset+8], bals[i])
|
|
|
|
offset += 8
|
|
|
|
}
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
func unmarshalBalances(bals []byte) []uint64 {
|
|
|
|
numItems := len(bals) / 8
|
|
|
|
res := make([]uint64, numItems)
|
|
|
|
offset := 0
|
|
|
|
for i := 0; i < numItems; i++ {
|
|
|
|
res[i] = binary.LittleEndian.Uint64(bals[offset : offset+8])
|
|
|
|
offset += 8
|
|
|
|
}
|
|
|
|
return res
|
|
|
|
}
|