2020-07-02 17:50:05 +00:00
|
|
|
package client
|
2020-01-02 17:04:07 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2020-12-10 18:56:18 +00:00
|
|
|
"time"
|
2020-01-02 17:04:07 +00:00
|
|
|
|
2021-02-22 23:20:57 +00:00
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
2021-09-21 19:59:25 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/config/params"
|
2021-09-23 15:23:37 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/encoding/bytesutil"
|
2021-07-21 21:34:07 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
2021-09-15 00:09:04 +00:00
|
|
|
prysmTime "github.com/prysmaticlabs/prysm/time"
|
2021-10-01 20:17:57 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/time/slots"
|
2020-01-02 17:04:07 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
2021-01-11 20:03:28 +00:00
|
|
|
var log = logrus.WithField("prefix", "validator")
|
|
|
|
|
2020-01-02 17:04:07 +00:00
|
|
|
type attSubmitted struct {
|
2020-01-02 23:45:48 +00:00
|
|
|
data *ethpb.AttestationData
|
2021-02-23 00:14:50 +00:00
|
|
|
attesterIndices []types.ValidatorIndex
|
|
|
|
aggregatorIndices []types.ValidatorIndex
|
2020-01-02 17:04:07 +00:00
|
|
|
}
|
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// LogAttestationsSubmitted logs info about submitted attestations.
|
2020-01-02 17:04:07 +00:00
|
|
|
func (v *validator) LogAttestationsSubmitted() {
|
|
|
|
v.attLogsLock.Lock()
|
|
|
|
defer v.attLogsLock.Unlock()
|
|
|
|
|
|
|
|
for _, attLog := range v.attLogs {
|
|
|
|
log.WithFields(logrus.Fields{
|
2020-01-02 23:45:48 +00:00
|
|
|
"Slot": attLog.data.Slot,
|
|
|
|
"CommitteeIndex": attLog.data.CommitteeIndex,
|
|
|
|
"BeaconBlockRoot": 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)),
|
|
|
|
"AttesterIndices": attLog.attesterIndices,
|
|
|
|
"AggregatorIndices": attLog.aggregatorIndices,
|
|
|
|
}).Info("Submitted new attestations")
|
2020-01-02 17:04:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
v.attLogs = make(map[[32]byte]*attSubmitted)
|
|
|
|
}
|
2020-12-10 18:56:18 +00:00
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// LogNextDutyTimeLeft logs the next duty info.
|
2021-02-16 07:45:34 +00:00
|
|
|
func (v *validator) LogNextDutyTimeLeft(slot types.Slot) error {
|
2020-12-18 21:12:57 +00:00
|
|
|
if !v.logDutyCountDown {
|
|
|
|
return nil
|
|
|
|
}
|
2021-01-04 17:28:00 +00:00
|
|
|
if v.duties == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2020-12-18 21:12:57 +00:00
|
|
|
|
2021-02-16 07:45:34 +00:00
|
|
|
var nextDutySlot types.Slot
|
|
|
|
attestingCounts := make(map[types.Slot]uint64)
|
|
|
|
proposingCounts := make(map[types.Slot]uint64)
|
2020-12-10 18:56:18 +00:00
|
|
|
for _, duty := range v.duties.CurrentEpochDuties {
|
2021-01-07 10:22:38 +00:00
|
|
|
attestingCounts[duty.AttesterSlot]++
|
|
|
|
|
2020-12-10 18:56:18 +00:00
|
|
|
if duty.AttesterSlot > slot && (nextDutySlot > duty.AttesterSlot || nextDutySlot == 0) {
|
|
|
|
nextDutySlot = duty.AttesterSlot
|
|
|
|
}
|
|
|
|
for _, proposerSlot := range duty.ProposerSlots {
|
2021-01-07 10:22:38 +00:00
|
|
|
proposingCounts[proposerSlot]++
|
|
|
|
|
2020-12-10 18:56:18 +00:00
|
|
|
if proposerSlot > slot && (nextDutySlot > proposerSlot || nextDutySlot == 0) {
|
|
|
|
nextDutySlot = proposerSlot
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if nextDutySlot == 0 {
|
|
|
|
log.WithField("slotInEpoch", slot%params.BeaconConfig().SlotsPerEpoch).Info("No duty until next epoch")
|
|
|
|
} else {
|
2021-10-01 20:17:57 +00:00
|
|
|
nextDutyTime, err := slots.ToTime(v.genesisTime, nextDutySlot)
|
2020-12-10 18:56:18 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-09-15 00:09:04 +00:00
|
|
|
timeLeft := time.Duration(nextDutyTime.Unix() - prysmTime.Now().Unix()).Nanoseconds()
|
2020-12-10 18:56:18 +00:00
|
|
|
// There is not much value to log if time left is less than one slot.
|
|
|
|
if uint64(timeLeft) >= params.BeaconConfig().SecondsPerSlot {
|
|
|
|
log.WithFields(
|
|
|
|
logrus.Fields{
|
|
|
|
"currentSlot": slot,
|
|
|
|
"dutySlot": nextDutySlot,
|
2021-01-07 10:22:38 +00:00
|
|
|
"attesting": attestingCounts[nextDutySlot],
|
|
|
|
"proposing": proposingCounts[nextDutySlot],
|
2020-12-10 18:56:18 +00:00
|
|
|
"slotInEpoch": slot % params.BeaconConfig().SlotsPerEpoch,
|
|
|
|
"secondsLeft": timeLeft,
|
|
|
|
}).Info("Next duty")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|