erigon-pulse/cmd/erigon-cl/forkchoice/on_attester_slashing.go
Giulio rebuffo 515aedda7b
Added Caplin Phase 1 (#7290)
* Introduces full beacon validation
* Removes light client
* NOTE: slow on purpose, I want everything to be BLS verified for now.
2023-04-17 18:06:50 +00:00

49 lines
1.5 KiB
Go

package forkchoice
import (
"fmt"
"github.com/ledgerwatch/erigon/cl/cltypes"
"github.com/ledgerwatch/erigon/cl/utils"
)
func (f *ForkChoiceStore) OnAttesterSlashing(attesterSlashing *cltypes.AttesterSlashing) error {
f.mu.Lock()
defer f.mu.Unlock()
// Check if these attestation is even slashable.
attestation1 := attesterSlashing.Attestation_1
attestation2 := attesterSlashing.Attestation_2
if !cltypes.IsSlashableAttestationData(attestation1.Data, attestation2.Data) {
return fmt.Errorf("attestation data is not slashable")
}
// Retrieve justified state
state, err := f.forkGraph.GetStateCopy(f.justifiedCheckpoint.Root)
if err != nil {
return err
}
if state == nil {
return fmt.Errorf("justified checkpoint state not accessible")
}
// Verify validity of slashings
valid, err := state.IsValidIndexedAttestation(attestation1)
if err != nil {
return fmt.Errorf("error calculating indexed attestation 1 validity: %v", err)
}
if !valid {
return fmt.Errorf("invalid indexed attestation 1")
}
valid, err = state.IsValidIndexedAttestation(attestation2)
if err != nil {
return fmt.Errorf("error calculating indexed attestation 2 validity: %v", err)
}
if !valid {
return fmt.Errorf("invalid indexed attestation 2")
}
for _, index := range utils.IntersectionOfSortedSets(attestation1.AttestingIndices, attestation2.AttestingIndices) {
f.equivocatingIndicies[index] = struct{}{}
}
// add attestation indicies to equivocating indicies.
return nil
}