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

108 lines
2.6 KiB
Go
Raw Normal View History

2018-10-05 17:14:50 +00:00
package db
import (
"context"
2018-10-17 06:11:24 +00:00
"fmt"
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
"github.com/boltdb/bolt"
2018-10-05 17:14:50 +00:00
"github.com/gogo/protobuf/proto"
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
"github.com/prysmaticlabs/prysm/shared/hashutil"
"go.opencensus.io/trace"
2018-10-05 17:14:50 +00:00
)
// SaveAttestation puts the attestation record into the beacon chain db.
func (db *BeaconDB) SaveAttestation(ctx context.Context, attestation *pb.Attestation) error {
ctx, span := trace.StartSpan(ctx, "beaconDB.SaveAttestation")
defer span.End()
encodedState, err := proto.Marshal(attestation)
2018-10-05 17:14:50 +00:00
if err != nil {
return err
}
hash := hashutil.Hash(encodedState)
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
return db.update(func(tx *bolt.Tx) error {
a := tx.Bucket(attestationBucket)
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
return a.Put(hash[:], encodedState)
})
2018-10-05 17:14:50 +00:00
}
// DeleteAttestation deletes the attestation record into the beacon chain db.
func (db *BeaconDB) DeleteAttestation(attestation *pb.Attestation) error {
hash, err := hashutil.HashProto(attestation)
if err != nil {
return err
}
return db.update(func(tx *bolt.Tx) error {
a := tx.Bucket(attestationBucket)
return a.Delete(hash[:])
})
}
// Attestation retrieves an attestation record from the db using its hash.
func (db *BeaconDB) Attestation(hash [32]byte) (*pb.Attestation, error) {
var attestation *pb.Attestation
2018-10-17 06:11:24 +00:00
err := db.view(func(tx *bolt.Tx) error {
a := tx.Bucket(attestationBucket)
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
enc := a.Get(hash[:])
if enc == nil {
return nil
2018-10-05 17:14:50 +00:00
}
2018-10-17 06:11:24 +00:00
var err error
attestation, err = createAttestation(enc)
return err
})
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
return attestation, err
2018-10-05 17:14:50 +00:00
}
// Attestations retrieves all the attestation records from the db.
// These are the attestations that have not been seen on the beacon chain.
func (db *BeaconDB) Attestations() ([]*pb.Attestation, error) {
var attestations []*pb.Attestation
err := db.view(func(tx *bolt.Tx) error {
a := tx.Bucket(attestationBucket)
if err := a.ForEach(func(k, v []byte) error {
attestation, err := createAttestation(v)
if err != nil {
return err
}
attestations = append(attestations, attestation)
return nil
}); err != nil {
return err
}
return nil
})
return attestations, err
}
2018-10-17 06:11:24 +00:00
// HasAttestation checks if the attestation exists.
func (db *BeaconDB) HasAttestation(hash [32]byte) bool {
exists := false
// #nosec G104
2018-10-17 06:11:24 +00:00
db.view(func(tx *bolt.Tx) error {
a := tx.Bucket(attestationBucket)
2018-10-05 17:14:50 +00:00
2018-10-17 06:11:24 +00:00
exists = a.Get(hash[:]) != nil
return nil
})
return exists
2018-10-05 17:14:50 +00:00
}
func createAttestation(enc []byte) (*pb.Attestation, error) {
protoAttestation := &pb.Attestation{}
if err := proto.Unmarshal(enc, protoAttestation); err != nil {
2018-10-17 06:11:24 +00:00
return nil, fmt.Errorf("failed to unmarshal encoding: %v", err)
2018-10-05 17:14:50 +00:00
}
return protoAttestation, nil
2018-10-05 17:14:50 +00:00
}