34 lines
817 B
Go
34 lines
817 B
Go
package grpc
|
|
|
|
import (
|
|
"context"
|
|
rpc "go-common/app/service/bbq/recsys/api/grpc/v1"
|
|
"go-common/app/service/bbq/recsys/service"
|
|
"go-common/library/net/rpc/warden"
|
|
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
// New 生成grpc服务
|
|
func New(srv *service.Service) *warden.Server {
|
|
// conf := &warden.ServerConfig{Addr: "0.0.0.0:9009"}
|
|
// s := warden.NewServer(conf)
|
|
s := warden.NewServer(nil)
|
|
rpc.RegisterRecsysServer(s.Server(), srv)
|
|
s.Use(middleware())
|
|
_, err := s.Start()
|
|
if err != nil {
|
|
panic("run server failed!" + err.Error())
|
|
}
|
|
return s
|
|
}
|
|
|
|
// middleware middleware
|
|
func middleware() grpc.UnaryServerInterceptor {
|
|
return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) {
|
|
//call chain
|
|
resp, err = handler(ctx, req)
|
|
return
|
|
}
|
|
}
|