2016-05-18 00:54:32 -04:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
|
2017-01-12 15:47:55 -05:00
|
|
|
"github.com/tendermint/abci/types"
|
2017-04-21 18:25:13 -04:00
|
|
|
cmn "github.com/tendermint/tmlibs/common"
|
2016-05-18 00:54:32 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
type GRPCServer struct {
|
2017-01-23 20:26:17 -08:00
|
|
|
cmn.BaseService
|
2016-05-18 00:54:32 -04:00
|
|
|
|
|
|
|
proto string
|
|
|
|
addr string
|
|
|
|
listener net.Listener
|
2016-08-10 18:29:46 -04:00
|
|
|
server *grpc.Server
|
2016-05-18 00:54:32 -04:00
|
|
|
|
2017-01-12 15:47:55 -05:00
|
|
|
app types.ABCIApplicationServer
|
2016-05-18 00:54:32 -04:00
|
|
|
}
|
|
|
|
|
2017-05-13 10:01:16 +02:00
|
|
|
// NewGRPCServer returns a new gRPC ABCI server
|
2017-05-15 12:51:24 -04:00
|
|
|
func NewGRPCServer(protoAddr string, app types.ABCIApplicationServer) cmn.Service {
|
2016-05-18 00:54:32 -04:00
|
|
|
parts := strings.SplitN(protoAddr, "://", 2)
|
|
|
|
proto, addr := parts[0], parts[1]
|
|
|
|
s := &GRPCServer{
|
|
|
|
proto: proto,
|
|
|
|
addr: addr,
|
|
|
|
listener: nil,
|
|
|
|
app: app,
|
|
|
|
}
|
2017-01-23 20:26:17 -08:00
|
|
|
s.BaseService = *cmn.NewBaseService(nil, "ABCIServer", s)
|
2017-05-15 12:51:24 -04:00
|
|
|
return s
|
2016-05-18 00:54:32 -04:00
|
|
|
}
|
|
|
|
|
2017-05-13 10:01:16 +02:00
|
|
|
// OnStart starts the gRPC service
|
2016-05-18 00:54:32 -04:00
|
|
|
func (s *GRPCServer) OnStart() error {
|
2017-09-21 15:32:06 -04:00
|
|
|
if err := s.BaseService.OnStart(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2016-05-18 00:54:32 -04:00
|
|
|
ln, err := net.Listen(s.proto, s.addr)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
s.listener = ln
|
2016-08-10 18:29:46 -04:00
|
|
|
s.server = grpc.NewServer()
|
2017-01-12 15:47:55 -05:00
|
|
|
types.RegisterABCIApplicationServer(s.server, s.app)
|
2016-08-10 18:29:46 -04:00
|
|
|
go s.server.Serve(s.listener)
|
2016-05-18 00:54:32 -04:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2017-05-13 10:01:16 +02:00
|
|
|
// OnStop stops the gRPC server
|
2016-05-18 00:54:32 -04:00
|
|
|
func (s *GRPCServer) OnStop() {
|
2016-10-28 12:06:40 -07:00
|
|
|
s.BaseService.OnStop()
|
2016-08-10 18:29:46 -04:00
|
|
|
s.server.Stop()
|
2016-05-18 00:54:32 -04:00
|
|
|
}
|