From 9adbcfdea8f2b1ba652062a8437cd8897384feac Mon Sep 17 00:00:00 2001 From: Patrick Schork <354473+pschork@users.noreply.github.com> Date: Mon, 15 Jul 2024 16:58:27 -0700 Subject: [PATCH] Call NodeInfo endpoint if port check was successful --- .../dataapi/queried_operators_handlers.go | 27 ++++++++++++++----- 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/disperser/dataapi/queried_operators_handlers.go b/disperser/dataapi/queried_operators_handlers.go index 842173901a..e328ae0265 100644 --- a/disperser/dataapi/queried_operators_handlers.go +++ b/disperser/dataapi/queried_operators_handlers.go @@ -11,7 +11,8 @@ import ( "github.com/Layr-Labs/eigenda/core" "github.com/Layr-Labs/eigensdk-go/logging" "github.com/gammazero/workerpool" - "google.golang.org/grpc/health/grpc_health_v1" + "google.golang.org/grpc" + "google.golang.org/grpc/credentials/insecure" ) type OperatorOnlineStatus struct { @@ -182,6 +183,10 @@ func (s *server) probeOperatorPorts(ctx context.Context, operatorId string) (*Op dispersalSocket := operatorSocket.GetDispersalSocket() dispersalOnline := checkIsOperatorOnline(dispersalSocket, 3, s.logger) + if dispersalOnline == true { + getNodeInfo(dispersalSocket, operatorId, s.logger) + } + // Create the metadata regardless of online status portCheckResponse := &OperatorPortCheckResponse{ OperatorId: operatorId, @@ -199,12 +204,22 @@ func (s *server) probeOperatorPorts(ctx context.Context, operatorId string) (*Op } // query operator host info endpoint if available -func (s *Server) checkNodeInfo(socket string, operatorId string, timeoutSecs int, logger logging.Logger) (*node.NodeInfoReply, error) { - var client node.NodeInfoRequest - - client = grpc_health_v1.NewHealthClient(s.disperserConn) +func getNodeInfo(socket string, operatorId string, logger logging.Logger) { + conn, err := grpc.Dial(socket, grpc.WithTransportCredentials(insecure.NewCredentials())) + if err != nil { + logger.Error("Failed to dial operator", err) + return + } + defer conn.Close() + client := node.NewDispersalClient(conn) + reply, err := client.NodeInfo(context.Background(), &node.NodeInfoRequest{}) + if err != nil { + logger.Error("Failed to call node info api", err) + return + } - return client.Check(ctx, &node.NodeInfoReply{}) + logger.Info(operatorId, reply.Semver, reply.Arch, reply.Os, reply.NumCpu, reply.MemBytes) + return } // method to check if operator is online via socket dial