2022-10-09 13:41:15 +02:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-10-22 17:38:29 +01:00
|
|
|
"fmt"
|
2022-10-09 13:41:15 +02:00
|
|
|
"net"
|
|
|
|
"time"
|
|
|
|
|
2022-11-15 20:39:18 +01:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
2022-10-29 21:51:32 +02:00
|
|
|
"github.com/ledgerwatch/erigon/cl/rpc/consensusrpc"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/sentinel/sentinel"
|
2022-10-09 13:41:15 +02:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
"google.golang.org/grpc"
|
2022-11-11 23:22:47 +01:00
|
|
|
"google.golang.org/grpc/credentials"
|
2022-10-09 17:49:27 +02:00
|
|
|
"google.golang.org/grpc/credentials/insecure"
|
2022-10-09 13:41:15 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type ServerConfig struct {
|
|
|
|
Network string
|
|
|
|
Addr string
|
|
|
|
}
|
|
|
|
|
2022-11-15 20:39:18 +01:00
|
|
|
func StartSentinelService(cfg *sentinel.SentinelConfig, db kv.RoDB, srvCfg *ServerConfig, creds credentials.TransportCredentials) (consensusrpc.SentinelClient, error) {
|
2022-10-09 13:41:15 +02:00
|
|
|
ctx := context.Background()
|
2022-11-15 20:39:18 +01:00
|
|
|
sent, err := sentinel.New(context.Background(), cfg, db)
|
2022-10-09 13:41:15 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if err := sent.Start(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
gossip_topics := []sentinel.GossipTopic{
|
|
|
|
sentinel.BeaconBlockSsz,
|
2022-10-23 14:22:33 -04:00
|
|
|
sentinel.BeaconAggregateAndProofSsz,
|
2022-10-24 11:52:49 -04:00
|
|
|
sentinel.VoluntaryExitSsz,
|
|
|
|
sentinel.ProposerSlashingSsz,
|
|
|
|
sentinel.AttesterSlashingSsz,
|
2022-10-09 13:41:15 +02:00
|
|
|
sentinel.LightClientFinalityUpdateSsz,
|
|
|
|
sentinel.LightClientOptimisticUpdateSsz,
|
|
|
|
}
|
|
|
|
for _, v := range gossip_topics {
|
|
|
|
// now lets separately connect to the gossip topics. this joins the room
|
|
|
|
subscriber, err := sent.SubscribeGossip(v)
|
|
|
|
if err != nil {
|
2022-11-24 21:29:51 +07:00
|
|
|
log.Error("[Sentinel] failed to start sentinel", "err", err)
|
2022-10-09 13:41:15 +02:00
|
|
|
}
|
2022-10-16 18:54:12 +01:00
|
|
|
// actually start the subscription, aka listening and sending packets to the sentinel recv channel
|
2022-10-09 13:41:15 +02:00
|
|
|
err = subscriber.Listen()
|
|
|
|
if err != nil {
|
2022-11-24 21:29:51 +07:00
|
|
|
log.Error("[Sentinel] failed to start sentinel", "err", err)
|
2022-10-09 13:41:15 +02:00
|
|
|
}
|
|
|
|
}
|
2022-11-24 21:29:51 +07:00
|
|
|
log.Info("[Sentinel] Sentinel started", "enr", sent.String())
|
2022-10-09 13:41:15 +02:00
|
|
|
|
|
|
|
server := NewSentinelServer(ctx, sent)
|
2022-11-11 23:22:47 +01:00
|
|
|
if creds == nil {
|
|
|
|
creds = insecure.NewCredentials()
|
|
|
|
}
|
|
|
|
|
|
|
|
go StartServe(server, srvCfg, creds)
|
2022-10-22 17:38:29 +01:00
|
|
|
timeOutTimer := time.NewTimer(5 * time.Second)
|
|
|
|
WaitingLoop:
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-timeOutTimer.C:
|
|
|
|
return nil, fmt.Errorf("[Server] timeout beginning server")
|
|
|
|
default:
|
2022-10-29 21:51:32 +02:00
|
|
|
if _, err := server.GetPeers(ctx, &consensusrpc.EmptyRequest{}); err == nil {
|
2022-10-22 17:38:29 +01:00
|
|
|
break WaitingLoop
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-11-11 23:22:47 +01:00
|
|
|
|
|
|
|
conn, err := grpc.DialContext(ctx, srvCfg.Addr, grpc.WithTransportCredentials(creds))
|
2022-10-09 13:41:15 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2022-10-29 21:51:32 +02:00
|
|
|
return consensusrpc.NewSentinelClient(conn), nil
|
2022-10-09 13:41:15 +02:00
|
|
|
}
|
|
|
|
|
2022-11-11 23:22:47 +01:00
|
|
|
func StartServe(server *SentinelServer, srvCfg *ServerConfig, creds credentials.TransportCredentials) {
|
2022-10-09 13:41:15 +02:00
|
|
|
lis, err := net.Listen(srvCfg.Network, srvCfg.Addr)
|
|
|
|
if err != nil {
|
|
|
|
log.Warn("[Sentinel] could not serve service", "reason", err)
|
|
|
|
}
|
|
|
|
// Create a gRPC server
|
2022-11-11 23:22:47 +01:00
|
|
|
gRPCserver := grpc.NewServer(grpc.Creds(creds))
|
2022-10-09 13:41:15 +02:00
|
|
|
go server.ListenToGossip()
|
|
|
|
// Regiser our server as a gRPC server
|
2022-10-29 21:51:32 +02:00
|
|
|
consensusrpc.RegisterSentinelServer(gRPCserver, server)
|
2022-10-09 13:41:15 +02:00
|
|
|
if err := gRPCserver.Serve(lis); err != nil {
|
|
|
|
log.Warn("[Sentinel] could not serve service", "reason", err)
|
|
|
|
}
|
|
|
|
}
|