2019-03-07 16:14:57 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/cluster"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/prometheus"
|
|
|
|
"github.com/sirupsen/logrus"
|
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 (
|
|
|
|
port = flag.Int("port", 8000, "The port to server gRPC")
|
|
|
|
metricsPort = flag.Int("metrics-port", 9090, "The port to serve /metrics")
|
|
|
|
privateKey = flag.String("private-key", "", "The private key of funder")
|
2019-04-14 21:53:34 +00:00
|
|
|
rpcPath = flag.String("rpc", "https://goerli.prylabs.net", "RPC address of a running ETH1 node")
|
2019-05-12 20:38:37 +00:00
|
|
|
beaconRPCPath = flag.String("beaconRPC", "localhost:4000", "RPC address of Beacon Node")
|
2019-03-07 16:14:57 +00:00
|
|
|
depositContractAddr = flag.String("deposit-contract", "", "Address of the deposit contract")
|
2020-04-14 20:27:03 +00:00
|
|
|
depositAmount = flag.String("deposit-amount", "", "The amount of wei to deposit into the contract")
|
2019-03-07 16:14:57 +00:00
|
|
|
dbPath = flag.String("db-path", "", "The file path for database storage")
|
|
|
|
disableWatchtower = flag.Bool("disable-watchtower", false, "Disable kubernetes pod watcher. Useful for local testing")
|
|
|
|
verbose = flag.Bool("verbose", false, "Enable debug logging")
|
2020-01-24 19:34:24 +00:00
|
|
|
ensureDeposited = flag.Bool("ensure-deposited", false, "Ensure keys are deposited")
|
|
|
|
allowNewDeposits = flag.Bool("allow-new-deposits", true, "Allow cluster PK manager to send new deposits or generate new keys")
|
2019-03-07 16:14:57 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
if *verbose {
|
|
|
|
logrus.SetLevel(logrus.DebugLevel)
|
|
|
|
}
|
2020-01-24 19:34:24 +00:00
|
|
|
if *ensureDeposited {
|
|
|
|
log.Warn("--ensure-deposited: Ensuring all keys are deposited or deleting them from database!")
|
|
|
|
}
|
|
|
|
if !*allowNewDeposits {
|
|
|
|
log.Warn("Disallowing new deposits")
|
|
|
|
}
|
2019-03-07 16:14:57 +00:00
|
|
|
|
|
|
|
db := newDB(*dbPath)
|
2020-01-24 19:34:24 +00:00
|
|
|
srv := newServer(db, *rpcPath, *depositContractAddr, *privateKey, *depositAmount, *beaconRPCPath)
|
2019-03-07 16:14:57 +00:00
|
|
|
if !*disableWatchtower {
|
|
|
|
wt := newWatchtower(db)
|
|
|
|
go wt.WatchPods()
|
|
|
|
}
|
|
|
|
|
2019-05-12 20:38:37 +00:00
|
|
|
kc := newkeyChecker(db, *beaconRPCPath)
|
|
|
|
go kc.run()
|
|
|
|
|
2019-03-07 16:14:57 +00:00
|
|
|
s := grpc.NewServer()
|
|
|
|
pb.RegisterPrivateKeyServiceServer(s, srv)
|
|
|
|
|
|
|
|
go prometheus.RunSimpleServerOrDie(fmt.Sprintf(":%d", *metricsPort))
|
2019-04-14 21:53:34 +00:00
|
|
|
srv.serveAllocationsHTTPPage()
|
2019-03-07 16:14:57 +00:00
|
|
|
|
|
|
|
lis, err := net.Listen("tcp", fmt.Sprintf(":%d", *port))
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
log.Infof("Listening for gRPC requests on port %d", *port)
|
|
|
|
if err := s.Serve(lis); err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|