-
Notifications
You must be signed in to change notification settings - Fork 14
/
grpc.go
36 lines (33 loc) · 1.2 KB
/
grpc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package server
import (
collectionv1 "github.com/adshao/ordinals-indexer/api/collection/v1"
inscriptionv1 "github.com/adshao/ordinals-indexer/api/inscription/v1"
tokenv1 "github.com/adshao/ordinals-indexer/api/token/v1"
"github.com/adshao/ordinals-indexer/internal/conf"
"github.com/adshao/ordinals-indexer/internal/service"
"github.com/go-kratos/kratos/v2/log"
"github.com/go-kratos/kratos/v2/middleware/recovery"
"github.com/go-kratos/kratos/v2/transport/grpc"
)
// NewGRPCServer new a gRPC server.
func NewGRPCServer(c *conf.Server, collection *service.CollectionService, token *service.TokenService, inscription *service.InscriptionService, logger log.Logger) *grpc.Server {
var opts = []grpc.ServerOption{
grpc.Middleware(
recovery.Recovery(),
),
}
if c.Grpc.Network != "" {
opts = append(opts, grpc.Network(c.Grpc.Network))
}
if c.Grpc.Addr != "" {
opts = append(opts, grpc.Address(c.Grpc.Addr))
}
if c.Grpc.Timeout != nil {
opts = append(opts, grpc.Timeout(c.Grpc.Timeout.AsDuration()))
}
srv := grpc.NewServer(opts...)
tokenv1.RegisterTokenServer(srv, token)
collectionv1.RegisterCollectionServer(srv, collection)
inscriptionv1.RegisterInscriptionServer(srv, inscription)
return srv
}