99 lines
2.8 KiB
Go
99 lines
2.8 KiB
Go
package grpcserver
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"log"
|
|
"net"
|
|
|
|
"git.coopgo.io/coopgo-platform/carpool-incentives/grpc/proto"
|
|
"git.coopgo.io/coopgo-platform/carpool-incentives/handlers/incentives"
|
|
"github.com/spf13/viper"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/grpc/codes"
|
|
"google.golang.org/grpc/reflection"
|
|
"google.golang.org/grpc/status"
|
|
)
|
|
|
|
type CarpoolIncentivesServerImpl struct {
|
|
IncentivesHandler *incentives.IncentivesHandler
|
|
|
|
proto.UnimplementedCarpoolIncentivesServer
|
|
}
|
|
|
|
func NewCarpoolIncentivesServer(incentivesHandler *incentives.IncentivesHandler) *CarpoolIncentivesServerImpl {
|
|
return &CarpoolIncentivesServerImpl{
|
|
IncentivesHandler: incentivesHandler,
|
|
}
|
|
}
|
|
|
|
func (s CarpoolIncentivesServerImpl) GetAvailableIncentives(ctx context.Context, req *proto.GetAvailableIncentivesRequest) (*proto.GetAvailableIncentivesResponse, error) {
|
|
results := []*proto.Incentive{}
|
|
incentives, err := s.IncentivesHandler.GetAvailableIncentives(req.Userid)
|
|
if err != nil {
|
|
return nil, status.Errorf(codes.Internal, "error in GetAvailableIncentives : ", err)
|
|
}
|
|
|
|
for _, i := range incentives {
|
|
incentive := IncentiveFromStorage(i)
|
|
results = append(results, &incentive)
|
|
}
|
|
|
|
return &proto.GetAvailableIncentivesResponse{
|
|
Incentives: results,
|
|
}, nil
|
|
|
|
}
|
|
func (s CarpoolIncentivesServerImpl) GetInitiatedIncentives(ctx context.Context, req *proto.GetInitiatedIncentivesRequest) (*proto.GetInitiatedIncentivesResponse, error) {
|
|
results := []*proto.Incentive{}
|
|
incentives, err := s.IncentivesHandler.GetInitiatedIncentives(req.Userid)
|
|
if err != nil {
|
|
return nil, status.Errorf(codes.Internal, "error in GetInitiatedIncentives : ", err)
|
|
}
|
|
|
|
for _, i := range incentives {
|
|
incentive := IncentiveFromStorage(i)
|
|
results = append(results, &incentive)
|
|
}
|
|
|
|
return &proto.GetInitiatedIncentivesResponse{
|
|
Incentives: results,
|
|
}, nil
|
|
}
|
|
func (s CarpoolIncentivesServerImpl) SubscribeIncentive(ctx context.Context, req *proto.SubscribeIncentiveRequest) (*proto.SubscribeIncentiveResponse, error) {
|
|
data := req.Data.AsMap()
|
|
|
|
res, err := s.IncentivesHandler.SubscribeIncentive(req.Incentiveid, req.Userid, req.IdentityVerificationIds, data, req.Declined)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &proto.SubscribeIncentiveResponse{
|
|
Subscriptionid: res.ID,
|
|
}, nil
|
|
}
|
|
|
|
func Run(done chan error, cfg *viper.Viper, incentivesHandler *incentives.IncentivesHandler) {
|
|
var (
|
|
dev_env = cfg.GetBool("dev_env")
|
|
address = ":" + cfg.GetString("services.grpc.port")
|
|
)
|
|
//fmt.Println("-> GRPC server on", address)
|
|
|
|
server := grpc.NewServer()
|
|
proto.RegisterCarpoolIncentivesServer(server, NewCarpoolIncentivesServer(incentivesHandler))
|
|
l, err := net.Listen("tcp", address)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
if dev_env {
|
|
reflection.Register(server)
|
|
}
|
|
|
|
if err := server.Serve(l); err != nil {
|
|
fmt.Println("gRPC service ended")
|
|
done <- err
|
|
}
|
|
}
|