2019-03-07 16:14:57 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/cluster"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/keystore"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
2019-06-13 14:53:42 +00:00
|
|
|
_ "go.uber.org/automaxprocs"
|
2019-03-07 16:14:57 +00:00
|
|
|
"google.golang.org/grpc"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
serverAddr = flag.String("server", "", "The address of the gRPC server")
|
|
|
|
podName = flag.String("pod-name", "", "The name of the pod running this tool")
|
|
|
|
keystoreDir = flag.String("keystore-dir", "", "The directory to generate keystore with received validator key")
|
|
|
|
password = flag.String("keystore-password", "", "The password to unlock the new keystore")
|
2019-04-14 21:53:34 +00:00
|
|
|
numKeys = flag.Uint64("keys", 1, "The number of keys to request")
|
2019-03-07 16:14:57 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
fmt.Printf("Starting client to fetch private key for pod %s\n", *podName)
|
|
|
|
|
|
|
|
store := keystore.NewKeystore(*keystoreDir)
|
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
conn, err := grpc.DialContext(ctx, *serverAddr, grpc.WithInsecure())
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
client := pb.NewPrivateKeyServiceClient(conn)
|
|
|
|
|
2019-04-14 21:53:34 +00:00
|
|
|
resp, err := client.Request(ctx, &pb.PrivateKeyRequest{
|
|
|
|
PodName: *podName,
|
|
|
|
NumberOfKeys: *numKeys,
|
|
|
|
})
|
2019-03-07 16:14:57 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2019-04-14 21:53:34 +00:00
|
|
|
for i, privateKey := range resp.PrivateKeys.PrivateKeys {
|
|
|
|
pk, err := bls.SecretKeyFromBytes(privateKey)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-03-07 16:14:57 +00:00
|
|
|
|
2019-04-14 21:53:34 +00:00
|
|
|
k := &keystore.Key{
|
|
|
|
PublicKey: pk.PublicKey(),
|
|
|
|
SecretKey: pk,
|
|
|
|
}
|
2019-03-07 16:14:57 +00:00
|
|
|
|
2019-04-14 21:53:34 +00:00
|
|
|
validatorKeyFile := *keystoreDir + params.BeaconConfig().ValidatorPrivkeyFileName + "-" + fmt.Sprintf("%d", i)
|
|
|
|
if err := store.StoreKey(validatorKeyFile, k, *password); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-03-07 16:14:57 +00:00
|
|
|
|
2019-04-14 21:53:34 +00:00
|
|
|
fmt.Printf("New key written to %s\n", validatorKeyFile)
|
|
|
|
}
|
2019-03-07 16:14:57 +00:00
|
|
|
}
|