mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-17 23:38:46 +00:00
eef35996de
* initialize rpc client * add struct * gaz * add keymap * update proto and add rpc methods * update proto * add method * make changes * add routine * gaz * mockgen * error fix * prom metric * Some improvements * fixes * fix and working cluster pk manager * fix and working cluster pk manager * fix and working cluster pk manager * fix and working cluster pk manager * regen mocks and pb.go * k8s
79 lines
1.7 KiB
Go
79 lines
1.7 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
pbBeacon "github.com/prysmaticlabs/prysm/proto/beacon/rpc/v1"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"go.opencensus.io/plugin/ocgrpc"
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
var keyInterval = 3 * time.Minute
|
|
|
|
type keyChecker struct {
|
|
db *db
|
|
client pbBeacon.ValidatorServiceClient
|
|
}
|
|
|
|
func newkeyChecker(db *db, beaconRPCAddr string) *keyChecker {
|
|
// connect to the beacon node
|
|
dialOpt := grpc.WithInsecure()
|
|
conn, err := grpc.DialContext(context.Background(), beaconRPCAddr, dialOpt, grpc.WithStatsHandler(&ocgrpc.ClientHandler{}))
|
|
if err != nil {
|
|
log.Errorf("Could not dial endpoint: %s, %v", beaconRPCAddr, err)
|
|
}
|
|
valClient := pbBeacon.NewValidatorServiceClient(conn)
|
|
|
|
return &keyChecker{
|
|
db: db,
|
|
client: valClient,
|
|
}
|
|
}
|
|
|
|
func (k *keyChecker) checkKeys() error {
|
|
pubkeys, keyMap, err := k.db.KeyMap()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
log.Debug("Requesting EXITED keys")
|
|
|
|
req := &pbBeacon.ExitedValidatorsRequest{
|
|
PublicKeys: pubkeys,
|
|
}
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), keyInterval)
|
|
defer cancel()
|
|
resp, err := k.client.ExitedValidators(ctx, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
log.WithField(
|
|
"resp_keys", len(resp.PublicKeys),
|
|
).WithField(
|
|
"req_keys", len(req.PublicKeys),
|
|
).Debug("Received EXITED key list")
|
|
|
|
for _, key := range resp.PublicKeys {
|
|
log.WithField("key", fmt.Sprintf("%#x", key)).Debug("Removing EXITED key")
|
|
kMap := keyMap[bytesutil.ToBytes48(key)]
|
|
if err := k.db.RemovePKFromPod(kMap.podName, kMap.privateKey); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (k *keyChecker) run() {
|
|
for {
|
|
if err := k.checkKeys(); err != nil {
|
|
log.WithError(err).Error("Failed to check keys")
|
|
}
|
|
time.Sleep(keyInterval)
|
|
}
|
|
}
|