| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 1 | package server |
| 2 | |
| 3 | import ( |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 4 | "fmt" |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 5 | "net" |
| 6 | "os" |
| 7 | |
| iomodo | 5e0dc11 | 2021-03-25 20:49:55 +0400 | [diff] [blame] | 8 | "github.com/giolekva/pcloud/core/kg/api/rpc" |
| iomodo | 3b0b951 | 2021-03-15 00:13:06 +0400 | [diff] [blame] | 9 | "github.com/giolekva/pcloud/core/kg/common" |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 10 | "github.com/giolekva/pcloud/core/kg/log" |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 11 | "github.com/giolekva/pcloud/core/kg/model" |
| iomodo | 3e1576e | 2021-02-23 01:27:56 +0400 | [diff] [blame] | 12 | "github.com/giolekva/pcloud/core/kg/model/proto" |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 13 | "google.golang.org/grpc" |
| 14 | ) |
| 15 | |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 16 | // GRPCServerImpl grpc server implementation |
| 17 | type GRPCServerImpl struct { |
| iomodo | 3b0b951 | 2021-03-15 00:13:06 +0400 | [diff] [blame] | 18 | Log common.LoggerIface |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 19 | srv *grpc.Server |
| 20 | config *model.Config |
| iomodo | 3b0b951 | 2021-03-15 00:13:06 +0400 | [diff] [blame] | 21 | app common.AppIface |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 22 | } |
| 23 | |
| 24 | var _ Server = &GRPCServerImpl{} |
| 25 | |
| 26 | // NewGRPCServer creates new GRPC Server |
| iomodo | 3b0b951 | 2021-03-15 00:13:06 +0400 | [diff] [blame] | 27 | func NewGRPCServer(logger common.LoggerIface, config *model.Config, app common.AppIface) Server { |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 28 | a := &GRPCServerImpl{ |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 29 | Log: logger, |
| 30 | config: config, |
| iomodo | 3e1576e | 2021-02-23 01:27:56 +0400 | [diff] [blame] | 31 | app: app, |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 32 | } |
| 33 | |
| 34 | pwd, _ := os.Getwd() |
| 35 | a.Log.Info("GRPC server current working", log.String("directory", pwd)) |
| 36 | return a |
| 37 | } |
| 38 | |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 39 | // Start method starts a grpc server |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 40 | func (a *GRPCServerImpl) Start() error { |
| 41 | a.Log.Info("Starting GRPC Server...") |
| 42 | |
| iomodo | c0479a6 | 2021-02-22 20:08:36 +0400 | [diff] [blame] | 43 | lis, err := net.Listen("tcp", fmt.Sprintf(":%d", a.config.GRPC.Port)) |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 44 | if err != nil { |
| iomodo | c0479a6 | 2021-02-22 20:08:36 +0400 | [diff] [blame] | 45 | a.Log.Error("Failed to listen: %v", log.Err(err)) |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 46 | return err |
| 47 | } |
| 48 | |
| 49 | a.srv = grpc.NewServer() |
| iomodo | 3e1576e | 2021-02-23 01:27:56 +0400 | [diff] [blame] | 50 | userService := rpc.NewService(a.app) |
| 51 | proto.RegisterUserServiceServer(a.srv, userService) |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 52 | |
| iomodo | c0479a6 | 2021-02-22 20:08:36 +0400 | [diff] [blame] | 53 | a.Log.Info("GRPC Server is listening on", log.Int("port", a.config.GRPC.Port)) |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 54 | if err := a.srv.Serve(lis); err != nil { |
| iomodo | c0479a6 | 2021-02-22 20:08:36 +0400 | [diff] [blame] | 55 | a.Log.Error("Failed to serve rpc: %v", log.Err(err)) |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 56 | return err |
| 57 | } |
| 58 | return nil |
| 59 | } |
| 60 | |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 61 | // Shutdown method shuts grpc server down |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 62 | func (a *GRPCServerImpl) Shutdown() error { |
| 63 | a.Log.Info("Stopping GRPC Server...") |
| 64 | a.srv.GracefulStop() |
| iomodo | b892d07 | 2021-02-22 00:23:16 +0400 | [diff] [blame] | 65 | a.Log.Info("GRPC Server stopped") |
| iomodo | db170e1 | 2021-02-21 23:06:20 +0400 | [diff] [blame] | 66 | return nil |
| 67 | } |