package kv import ( "context" "github.com/boltdb/bolt" "github.com/gogo/protobuf/proto" ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" "github.com/prysmaticlabs/go-ssz" "go.opencensus.io/trace" ) // ProposerSlashing retrieval by slashing root. func (k *Store) ProposerSlashing(ctx context.Context, slashingRoot [32]byte) (*ethpb.ProposerSlashing, error) { ctx, span := trace.StartSpan(ctx, "BeaconDB.ProposerSlashing") defer span.End() var slashing *ethpb.ProposerSlashing err := k.db.View(func(tx *bolt.Tx) error { bkt := tx.Bucket(proposerSlashingsBucket) enc := bkt.Get(slashingRoot[:]) if enc == nil { return nil } slashing = ðpb.ProposerSlashing{} return proto.Unmarshal(enc, slashing) }) return slashing, err } // HasProposerSlashing verifies if a slashing is stored in the db. func (k *Store) HasProposerSlashing(ctx context.Context, slashingRoot [32]byte) bool { ctx, span := trace.StartSpan(ctx, "BeaconDB.HasProposerSlashing") defer span.End() exists := false // #nosec G104. Always returns nil. k.db.View(func(tx *bolt.Tx) error { bkt := tx.Bucket(proposerSlashingsBucket) exists = bkt.Get(slashingRoot[:]) != nil return nil }) return exists } // SaveProposerSlashing to the db by its hash tree root. func (k *Store) SaveProposerSlashing(ctx context.Context, slashing *ethpb.ProposerSlashing) error { ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveProposerSlashing") defer span.End() slashingRoot, err := ssz.HashTreeRoot(slashing) if err != nil { return err } enc, err := proto.Marshal(slashing) if err != nil { return err } return k.db.Update(func(tx *bolt.Tx) error { bucket := tx.Bucket(proposerSlashingsBucket) return bucket.Put(slashingRoot[:], enc) }) } // DeleteProposerSlashing clears a proposer slashing from the db by its hash tree root. func (k *Store) DeleteProposerSlashing(ctx context.Context, slashingRoot [32]byte) error { ctx, span := trace.StartSpan(ctx, "BeaconDB.DeleteProposerSlashing") defer span.End() return k.db.Update(func(tx *bolt.Tx) error { bucket := tx.Bucket(proposerSlashingsBucket) return bucket.Delete(slashingRoot[:]) }) } // AttesterSlashing retrieval by hash tree root. func (k *Store) AttesterSlashing(ctx context.Context, slashingRoot [32]byte) (*ethpb.AttesterSlashing, error) { ctx, span := trace.StartSpan(ctx, "BeaconDB.AttesterSlashing") defer span.End() var slashing *ethpb.AttesterSlashing err := k.db.View(func(tx *bolt.Tx) error { bkt := tx.Bucket(attesterSlashingsBucket) enc := bkt.Get(slashingRoot[:]) if enc == nil { return nil } slashing = ðpb.AttesterSlashing{} return proto.Unmarshal(enc, slashing) }) return slashing, err } // HasAttesterSlashing verifies if a slashing is stored in the db. func (k *Store) HasAttesterSlashing(ctx context.Context, slashingRoot [32]byte) bool { ctx, span := trace.StartSpan(ctx, "BeaconDB.HasAttesterSlashing") defer span.End() exists := false // #nosec G104. Always returns nil. k.db.View(func(tx *bolt.Tx) error { bkt := tx.Bucket(attesterSlashingsBucket) exists = bkt.Get(slashingRoot[:]) != nil return nil }) return exists } // SaveAttesterSlashing to the db by its hash tree root. func (k *Store) SaveAttesterSlashing(ctx context.Context, slashing *ethpb.AttesterSlashing) error { ctx, span := trace.StartSpan(ctx, "BeaconDB.SaveAttesterSlashing") defer span.End() slashingRoot, err := ssz.HashTreeRoot(slashing) if err != nil { return err } enc, err := proto.Marshal(slashing) if err != nil { return err } return k.db.Update(func(tx *bolt.Tx) error { bucket := tx.Bucket(attesterSlashingsBucket) return bucket.Put(slashingRoot[:], enc) }) } // DeleteAttesterSlashing clears an attester slashing from the db by its hash tree root. func (k *Store) DeleteAttesterSlashing(ctx context.Context, slashingRoot [32]byte) error { ctx, span := trace.StartSpan(ctx, "BeaconDB.DeleteAttesterSlashing") defer span.End() return k.db.Update(func(tx *bolt.Tx) error { bucket := tx.Bucket(attesterSlashingsBucket) return bucket.Delete(slashingRoot[:]) }) }