mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-10 11:41:21 +00:00
60 lines
1.3 KiB
Go
60 lines
1.3 KiB
Go
|
package rpcclient
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/rpc/v1"
|
||
|
"github.com/sirupsen/logrus"
|
||
|
"google.golang.org/grpc"
|
||
|
)
|
||
|
|
||
|
var log = logrus.WithField("prefix", "rpc-client")
|
||
|
|
||
|
// Service for an RPCClient to a Beacon Node.
|
||
|
type Service struct {
|
||
|
ctx context.Context
|
||
|
cancel context.CancelFunc
|
||
|
conn *grpc.ClientConn
|
||
|
endpoint string
|
||
|
}
|
||
|
|
||
|
// Config for the RPCClient service.
|
||
|
type Config struct {
|
||
|
Endpoint string
|
||
|
}
|
||
|
|
||
|
// NewRPCClient sets up a new beacon node RPC client connection.
|
||
|
func NewRPCClient(ctx context.Context, cfg *Config) *Service {
|
||
|
ctx, cancel := context.WithCancel(ctx)
|
||
|
return &Service{
|
||
|
ctx: ctx,
|
||
|
cancel: cancel,
|
||
|
endpoint: cfg.Endpoint,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Start the grpc connection.
|
||
|
func (s *Service) Start() {
|
||
|
log.Info("Starting service")
|
||
|
conn, err := grpc.Dial(s.endpoint, grpc.WithInsecure())
|
||
|
if err != nil {
|
||
|
log.Errorf("Could not connect to beacon node via RPC endpoint: %s: %v", s.endpoint, err)
|
||
|
return
|
||
|
}
|
||
|
s.conn = conn
|
||
|
}
|
||
|
|
||
|
// Stop the dialed connection.
|
||
|
func (s *Service) Stop() error {
|
||
|
log.Info("Stopping service")
|
||
|
if s.conn != nil {
|
||
|
return s.conn.Close()
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
// BeaconServiceClient return the proto RPC interface.
|
||
|
func (s *Service) BeaconServiceClient() pb.BeaconServiceClient {
|
||
|
return pb.NewBeaconServiceClient(s.conn)
|
||
|
}
|