mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-17 23:38:46 +00:00
f0fcebccc4
* Get started on cleaning up slashing protection * Merge branch 'master' of github.com:prysmaticlabs/prysm into cleanup-protection * Move protection functions to own files * Lint * Merge branch 'master' of github.com:prysmaticlabs/prysm into cleanup-protection * Begin adding test for proposal protection * Merge branch 'master' of github.com:prysmaticlabs/prysm into cleanup-protection * Fix build * Fix tests * Fix tst * Fix tests * Fix proposal tests * Merge branch 'master' into cleanup-protection * Merge branch 'master' into cleanup-protection * Merge branch 'master' into cleanup-protection * Merge branch 'master' of github.com:prysmaticlabs/prysm into cleanup-protection * Reorder protections * Change lock * Fix test * Merge branch 'master' into cleanup-protection * Merge branch 'master' into cleanup-protection * Merge branch 'master' into cleanup-protection * Change log * Merge branch 'cleanup-protection' of github.com:prysmaticlabs/prysm into cleanup-protection * Merge branch 'master' into cleanup-protection
67 lines
2.5 KiB
Go
67 lines
2.5 KiB
Go
package slashingprotection
|
|
|
|
import (
|
|
"context"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
log "github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// CheckBlockSafety this function is part of slashing protection for block proposals it performs
|
|
// validation without db update. To be used before the block is signed.
|
|
func (s *Service) CheckBlockSafety(ctx context.Context, blockHeader *ethpb.BeaconBlockHeader) bool {
|
|
slashable, err := s.slasherClient.IsSlashableBlockNoUpdate(ctx, blockHeader)
|
|
if err != nil {
|
|
log.Warnf("External slashing block protection returned an error: %v", err)
|
|
return true
|
|
}
|
|
if slashable != nil && slashable.Slashable {
|
|
log.Warn("External slashing proposal protection found the block to be slashable")
|
|
}
|
|
return !slashable.Slashable
|
|
}
|
|
|
|
// CommitBlock this function is part of slashing protection for block proposals it performs
|
|
// validation and db update. To be used after the block is proposed.
|
|
func (s *Service) CommitBlock(ctx context.Context, blockHeader *ethpb.SignedBeaconBlockHeader) bool {
|
|
ps, err := s.slasherClient.IsSlashableBlock(ctx, blockHeader)
|
|
if err != nil {
|
|
log.Warnf("External slashing block protection returned an error: %v", err)
|
|
return true
|
|
}
|
|
if ps != nil && ps.ProposerSlashing != nil {
|
|
log.Warn("External slashing proposal protection found the block to be slashable")
|
|
return false
|
|
}
|
|
return true
|
|
}
|
|
|
|
// CheckAttestationSafety implements the slashing protection for attestations without db update.
|
|
// To be used before signing.
|
|
func (s *Service) CheckAttestationSafety(ctx context.Context, attestation *ethpb.IndexedAttestation) bool {
|
|
slashable, err := s.slasherClient.IsSlashableAttestationNoUpdate(ctx, attestation)
|
|
if err != nil {
|
|
log.Warnf("External slashing attestation protection returned an error: %v", err)
|
|
return true
|
|
}
|
|
if slashable.Slashable {
|
|
log.Warn("External slashing attestation protection found the attestation to be slashable")
|
|
}
|
|
return !slashable.Slashable
|
|
}
|
|
|
|
// CommitAttestation implements the slashing protection for attestations it performs
|
|
// validation and db update. To be used after the attestation is proposed.
|
|
func (s *Service) CommitAttestation(ctx context.Context, attestation *ethpb.IndexedAttestation) bool {
|
|
as, err := s.slasherClient.IsSlashableAttestation(ctx, attestation)
|
|
if err != nil {
|
|
log.Warnf("External slashing attestation protection returned an error: %v", err)
|
|
return true
|
|
}
|
|
if as != nil && as.AttesterSlashing != nil {
|
|
log.Warnf("External slashing attestation protection found the attestation to be slashable: %v", as)
|
|
return false
|
|
}
|
|
return true
|
|
}
|