2021-03-12 18:23:56 +01:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2022-08-16 20:05:56 +02:00
|
|
|
"github.com/pkg/errors"
|
2022-08-16 12:20:13 +00:00
|
|
|
fieldparams "github.com/prysmaticlabs/prysm/v3/config/fieldparams"
|
|
|
|
eth "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
2021-03-12 18:23:56 +01:00
|
|
|
"go.opencensus.io/trace"
|
|
|
|
)
|
|
|
|
|
|
|
|
// HandleKeyReload makes sure the validator keeps operating correctly after a change to the underlying keys.
|
|
|
|
// It is also responsible for logging out information about the new state of keys.
|
2022-01-06 09:33:08 -08:00
|
|
|
func (v *validator) HandleKeyReload(ctx context.Context, newKeys [][fieldparams.BLSPubkeyLength]byte) (anyActive bool, err error) {
|
2021-03-12 18:23:56 +01:00
|
|
|
ctx, span := trace.StartSpan(ctx, "validator.HandleKeyReload")
|
|
|
|
defer span.End()
|
|
|
|
|
|
|
|
statusRequestKeys := make([][]byte, len(newKeys))
|
|
|
|
for i := range newKeys {
|
|
|
|
statusRequestKeys[i] = newKeys[i][:]
|
|
|
|
}
|
|
|
|
resp, err := v.validatorClient.MultipleValidatorStatus(ctx, ð.MultipleValidatorStatusRequest{
|
|
|
|
PublicKeys: statusRequestKeys,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
|
|
|
statuses := make([]*validatorStatus, len(resp.Statuses))
|
|
|
|
for i, s := range resp.Statuses {
|
|
|
|
statuses[i] = &validatorStatus{
|
|
|
|
publicKey: resp.PublicKeys[i],
|
|
|
|
status: s,
|
|
|
|
index: resp.Indices[i],
|
|
|
|
}
|
|
|
|
}
|
2022-08-16 20:05:56 +02:00
|
|
|
vals, err := v.beaconClient.ListValidators(ctx, ð.ListValidatorsRequest{Active: true, PageSize: 0})
|
|
|
|
if err != nil {
|
|
|
|
return false, errors.Wrap(err, "could not get active validator count")
|
|
|
|
}
|
|
|
|
anyActive = v.checkAndLogValidatorStatus(statuses, uint64(vals.TotalSize))
|
2021-03-12 18:23:56 +01:00
|
|
|
if anyActive {
|
|
|
|
logActiveValidatorStatus(statuses)
|
|
|
|
}
|
|
|
|
|
|
|
|
return anyActive, nil
|
|
|
|
}
|