2020-07-02 17:50:05 +00:00
|
|
|
package client
|
2020-01-02 17:04:07 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-02-08 18:24:03 +00:00
|
|
|
"strconv"
|
2022-06-27 23:01:24 +00:00
|
|
|
"sync/atomic"
|
2020-01-02 17:04:07 +00:00
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
"github.com/pkg/errors"
|
2024-02-15 05:46:47 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/primitives"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/encoding/bytesutil"
|
|
|
|
ethpb "github.com/prysmaticlabs/prysm/v5/proto/prysm/v1alpha1"
|
2020-01-02 17:04:07 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
var log = logrus.WithField("prefix", "client")
|
2021-01-11 20:03:28 +00:00
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
type submittedAttData struct {
|
|
|
|
beaconBlockRoot []byte
|
|
|
|
source *ethpb.Checkpoint
|
|
|
|
target *ethpb.Checkpoint
|
2020-01-02 17:04:07 +00:00
|
|
|
}
|
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
type submittedAtt struct {
|
|
|
|
data submittedAttData
|
|
|
|
pubkeys [][]byte
|
|
|
|
committees []primitives.CommitteeIndex
|
|
|
|
}
|
|
|
|
|
|
|
|
// submittedAttKey is defined as a concatenation of:
|
|
|
|
// - AttestationData.BeaconBlockRoot
|
|
|
|
// - AttestationData.Source.HashTreeRoot()
|
|
|
|
// - AttestationData.Target.HashTreeRoot()
|
|
|
|
type submittedAttKey [96]byte
|
|
|
|
|
|
|
|
func (k submittedAttKey) FromAttData(data *ethpb.AttestationData) error {
|
|
|
|
sourceRoot, err := data.Source.HashTreeRoot()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
targetRoot, err := data.Target.HashTreeRoot()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
copy(k[0:], data.BeaconBlockRoot)
|
|
|
|
copy(k[32:], sourceRoot[:])
|
|
|
|
copy(k[64:], targetRoot[:])
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// saveSubmittedAtt saves the submitted attestation data along with the attester's pubkey.
|
|
|
|
// The purpose of this is to display combined attesting logs for all keys managed by the validator client.
|
|
|
|
func (v *validator) saveSubmittedAtt(data *ethpb.AttestationData, pubkey []byte, isAggregate bool) error {
|
|
|
|
v.attLogsLock.Lock()
|
|
|
|
defer v.attLogsLock.Unlock()
|
|
|
|
|
|
|
|
key := submittedAttKey{}
|
|
|
|
if err := key.FromAttData(data); err != nil {
|
|
|
|
return errors.Wrapf(err, "could not create submitted attestation key")
|
|
|
|
}
|
|
|
|
d := submittedAttData{
|
|
|
|
beaconBlockRoot: data.BeaconBlockRoot,
|
|
|
|
source: data.Source,
|
|
|
|
target: data.Target,
|
|
|
|
}
|
|
|
|
|
|
|
|
var submittedAtts map[submittedAttKey]*submittedAtt
|
|
|
|
if isAggregate {
|
|
|
|
submittedAtts = v.submittedAggregates
|
|
|
|
} else {
|
|
|
|
submittedAtts = v.submittedAtts
|
|
|
|
}
|
|
|
|
|
|
|
|
if submittedAtts[key] == nil {
|
|
|
|
submittedAtts[key] = &submittedAtt{
|
|
|
|
d,
|
|
|
|
[][]byte{},
|
|
|
|
[]primitives.CommitteeIndex{},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
submittedAtts[key] = &submittedAtt{
|
|
|
|
d,
|
|
|
|
append(submittedAtts[key].pubkeys, pubkey),
|
|
|
|
append(submittedAtts[key].committees, data.CommitteeIndex),
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// LogSubmittedAtts logs info about submitted attestations.
|
|
|
|
func (v *validator) LogSubmittedAtts(slot primitives.Slot) {
|
2020-01-02 17:04:07 +00:00
|
|
|
v.attLogsLock.Lock()
|
|
|
|
defer v.attLogsLock.Unlock()
|
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
for _, attLog := range v.submittedAtts {
|
|
|
|
pubkeys := make([]string, len(attLog.pubkeys))
|
|
|
|
for i, p := range attLog.pubkeys {
|
|
|
|
pubkeys[i] = fmt.Sprintf("%#x", bytesutil.Trunc(p))
|
|
|
|
}
|
|
|
|
committees := make([]string, len(attLog.committees))
|
|
|
|
for i, c := range attLog.committees {
|
|
|
|
committees[i] = strconv.FormatUint(uint64(c), 10)
|
|
|
|
}
|
2020-01-02 17:04:07 +00:00
|
|
|
log.WithFields(logrus.Fields{
|
2024-02-08 18:24:03 +00:00
|
|
|
"slot": slot,
|
|
|
|
"committeeIndices": committees,
|
|
|
|
"pubkeys": pubkeys,
|
|
|
|
"blockRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.beaconBlockRoot)),
|
|
|
|
"sourceEpoch": attLog.data.source.Epoch,
|
|
|
|
"sourceRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.source.Root)),
|
|
|
|
"targetEpoch": attLog.data.target.Epoch,
|
|
|
|
"targetRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.target.Root)),
|
2020-01-02 23:45:48 +00:00
|
|
|
}).Info("Submitted new attestations")
|
2020-01-02 17:04:07 +00:00
|
|
|
}
|
2024-02-08 18:24:03 +00:00
|
|
|
for _, attLog := range v.submittedAggregates {
|
|
|
|
pubkeys := make([]string, len(attLog.pubkeys))
|
|
|
|
for i, p := range attLog.pubkeys {
|
|
|
|
pubkeys[i] = fmt.Sprintf("%#x", bytesutil.Trunc(p))
|
|
|
|
}
|
|
|
|
committees := make([]string, len(attLog.committees))
|
|
|
|
for i, c := range attLog.committees {
|
|
|
|
committees[i] = strconv.FormatUint(uint64(c), 10)
|
|
|
|
}
|
|
|
|
log.WithFields(logrus.Fields{
|
|
|
|
"slot": slot,
|
|
|
|
"committeeIndices": committees,
|
|
|
|
"pubkeys": pubkeys,
|
|
|
|
"blockRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.beaconBlockRoot)),
|
|
|
|
"sourceEpoch": attLog.data.source.Epoch,
|
|
|
|
"sourceRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.source.Root)),
|
|
|
|
"targetEpoch": attLog.data.target.Epoch,
|
|
|
|
"targetRoot": fmt.Sprintf("%#x", bytesutil.Trunc(attLog.data.target.Root)),
|
|
|
|
}).Info("Submitted new aggregate attestations")
|
|
|
|
}
|
2020-01-02 17:04:07 +00:00
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
v.submittedAtts = make(map[submittedAttKey]*submittedAtt)
|
|
|
|
v.submittedAggregates = make(map[submittedAttKey]*submittedAtt)
|
2020-01-02 17:04:07 +00:00
|
|
|
}
|
2020-12-10 18:56:18 +00:00
|
|
|
|
2024-02-08 18:24:03 +00:00
|
|
|
// LogSubmittedSyncCommitteeMessages logs info about submitted sync committee messages.
|
|
|
|
func (v *validator) LogSubmittedSyncCommitteeMessages() {
|
2024-02-26 17:57:26 +00:00
|
|
|
if v.syncCommitteeStats.totalMessagesSubmitted > 0 {
|
|
|
|
log.WithField("messages", v.syncCommitteeStats.totalMessagesSubmitted).Debug("Submitted sync committee messages successfully to beacon node")
|
|
|
|
// Reset the amount.
|
|
|
|
atomic.StoreUint64(&v.syncCommitteeStats.totalMessagesSubmitted, 0)
|
|
|
|
}
|
2022-06-27 23:01:24 +00:00
|
|
|
}
|