2021-07-28 02:47:38 +00:00
|
|
|
package privateapi
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
|
2021-09-02 10:04:30 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/grpcutil"
|
2021-09-15 07:22:57 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv/remotedbserver"
|
2021-12-06 12:03:46 +00:00
|
|
|
|
2021-08-08 02:17:08 +00:00
|
|
|
//grpc_prometheus "github.com/grpc-ecosystem/go-grpc-prometheus"
|
2021-07-28 02:47:38 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/remote"
|
2021-09-02 05:55:04 +00:00
|
|
|
txpool_proto "github.com/ledgerwatch/erigon-lib/gointerfaces/txpool"
|
2021-07-29 10:23:23 +00:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
2021-07-28 02:47:38 +00:00
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/credentials"
|
2021-12-06 12:03:46 +00:00
|
|
|
"google.golang.org/grpc/health"
|
|
|
|
"google.golang.org/grpc/health/grpc_health_v1"
|
2021-07-28 02:47:38 +00:00
|
|
|
)
|
|
|
|
|
2021-12-06 12:03:46 +00:00
|
|
|
func StartGrpc(kv *remotedbserver.KvServer, ethBackendSrv *EthBackendServer, txPoolServer txpool_proto.TxpoolServer,
|
|
|
|
miningServer txpool_proto.MiningServer, addr string, rateLimit uint32, creds credentials.TransportCredentials,
|
|
|
|
healthCheck bool) (*grpc.Server, error) {
|
2021-07-28 02:47:38 +00:00
|
|
|
log.Info("Starting private RPC server", "on", addr)
|
|
|
|
lis, err := net.Listen("tcp", addr)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("could not create listener: %w, addr=%s", err, addr)
|
|
|
|
}
|
|
|
|
|
2021-09-02 10:04:30 +00:00
|
|
|
grpcServer := grpcutil.NewServer(rateLimit, creds)
|
2021-07-28 02:47:38 +00:00
|
|
|
remote.RegisterETHBACKENDServer(grpcServer, ethBackendSrv)
|
2021-09-02 05:55:04 +00:00
|
|
|
if txPoolServer != nil {
|
|
|
|
txpool_proto.RegisterTxpoolServer(grpcServer, txPoolServer)
|
|
|
|
}
|
|
|
|
if miningServer != nil {
|
|
|
|
txpool_proto.RegisterMiningServer(grpcServer, miningServer)
|
|
|
|
}
|
2021-07-28 02:47:38 +00:00
|
|
|
remote.RegisterKVServer(grpcServer, kv)
|
2021-12-06 12:03:46 +00:00
|
|
|
var healthServer *health.Server
|
|
|
|
if healthCheck {
|
|
|
|
healthServer = health.NewServer()
|
|
|
|
grpc_health_v1.RegisterHealthServer(grpcServer, healthServer)
|
|
|
|
}
|
2021-07-28 02:47:38 +00:00
|
|
|
go func() {
|
2021-12-06 12:03:46 +00:00
|
|
|
if healthCheck {
|
|
|
|
defer healthServer.Shutdown()
|
|
|
|
}
|
2022-01-04 17:37:36 +00:00
|
|
|
defer ethBackendSrv.StopProposer()
|
2021-07-28 02:47:38 +00:00
|
|
|
if err := grpcServer.Serve(lis); err != nil {
|
|
|
|
log.Error("private RPC server fail", "err", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
return grpcServer, nil
|
|
|
|
}
|