2023-06-11 21:50:02 +00:00
|
|
|
package eth2
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2023-08-18 13:43:22 +00:00
|
|
|
|
2023-06-11 21:50:02 +00:00
|
|
|
"github.com/Giulio2002/bls"
|
2023-07-19 22:20:33 +00:00
|
|
|
"github.com/ledgerwatch/erigon/cl/abstract"
|
2023-06-11 21:50:02 +00:00
|
|
|
"github.com/ledgerwatch/erigon/cl/cltypes"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/fork"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/phase1/core/state"
|
|
|
|
)
|
|
|
|
|
2023-07-19 22:20:33 +00:00
|
|
|
func (I *impl) VerifyTransition(s abstract.BeaconState, currentBlock *cltypes.BeaconBlock) error {
|
2023-06-11 21:50:02 +00:00
|
|
|
if !I.FullValidation {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
expectedStateRoot, err := s.HashSSZ()
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("unable to generate state root: %v", err)
|
|
|
|
}
|
|
|
|
if expectedStateRoot != currentBlock.StateRoot {
|
|
|
|
return fmt.Errorf("expected state root differs from received state root")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-07-19 22:20:33 +00:00
|
|
|
func (I *impl) VerifyBlockSignature(s abstract.BeaconState, block *cltypes.SignedBeaconBlock) error {
|
2023-06-11 21:50:02 +00:00
|
|
|
valid, err := verifyBlockSignature(s, block)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error validating block signature: %v", err)
|
|
|
|
}
|
|
|
|
if !valid {
|
|
|
|
return fmt.Errorf("block not valid")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-07-19 22:20:33 +00:00
|
|
|
func verifyBlockSignature(s abstract.BeaconState, block *cltypes.SignedBeaconBlock) (bool, error) {
|
2023-06-11 21:50:02 +00:00
|
|
|
proposer, err := s.ValidatorForValidatorIndex(int(block.Block.ProposerIndex))
|
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
2023-07-19 22:20:33 +00:00
|
|
|
domain, err := s.GetDomain(s.BeaconConfig().DomainBeaconProposer, state.Epoch(s))
|
2023-06-11 21:50:02 +00:00
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
|
|
|
sigRoot, err := fork.ComputeSigningRoot(block.Block, domain)
|
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
|
|
|
pk := proposer.PublicKey()
|
|
|
|
return bls.Verify(block.Signature[:], sigRoot[:], pk[:])
|
|
|
|
}
|