2023-01-31 08:30:57 +00:00
|
|
|
package heimdallgrpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
grpc_retry "github.com/grpc-ecosystem/go-grpc-middleware/retry"
|
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
proto "github.com/maticnetwork/polyproto/heimdall"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/codes"
|
|
|
|
"google.golang.org/grpc/credentials/insecure"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
stateFetchLimit = 50
|
|
|
|
)
|
|
|
|
|
|
|
|
type HeimdallGRPCClient struct {
|
|
|
|
conn *grpc.ClientConn
|
|
|
|
client proto.HeimdallClient
|
2023-07-18 08:47:04 +00:00
|
|
|
logger log.Logger
|
2023-01-31 08:30:57 +00:00
|
|
|
}
|
|
|
|
|
2023-07-18 08:47:04 +00:00
|
|
|
func NewHeimdallGRPCClient(address string, logger log.Logger) *HeimdallGRPCClient {
|
2023-01-31 08:30:57 +00:00
|
|
|
opts := []grpc_retry.CallOption{
|
|
|
|
grpc_retry.WithMax(10000),
|
|
|
|
grpc_retry.WithBackoff(grpc_retry.BackoffLinear(5 * time.Second)),
|
|
|
|
grpc_retry.WithCodes(codes.Internal, codes.Unavailable, codes.Aborted, codes.NotFound),
|
|
|
|
}
|
|
|
|
|
|
|
|
conn, err := grpc.Dial(address,
|
|
|
|
grpc.WithStreamInterceptor(grpc_retry.StreamClientInterceptor(opts...)),
|
|
|
|
grpc.WithUnaryInterceptor(grpc_retry.UnaryClientInterceptor(opts...)),
|
|
|
|
grpc.WithTransportCredentials(insecure.NewCredentials()),
|
|
|
|
)
|
|
|
|
if err != nil {
|
2023-07-18 08:47:04 +00:00
|
|
|
logger.Crit("Failed to connect to Heimdall gRPC", "error", err)
|
2023-01-31 08:30:57 +00:00
|
|
|
}
|
|
|
|
|
2023-07-18 08:47:04 +00:00
|
|
|
logger.Info("Connected to Heimdall gRPC server", "address", address)
|
2023-01-31 08:30:57 +00:00
|
|
|
|
|
|
|
return &HeimdallGRPCClient{
|
|
|
|
conn: conn,
|
|
|
|
client: proto.NewHeimdallClient(conn),
|
2023-07-18 08:47:04 +00:00
|
|
|
logger: logger,
|
2023-01-31 08:30:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *HeimdallGRPCClient) Close() {
|
2023-07-18 08:47:04 +00:00
|
|
|
h.logger.Debug("Shutdown detected, Closing Heimdall gRPC client")
|
2023-01-31 08:30:57 +00:00
|
|
|
h.conn.Close()
|
|
|
|
}
|