mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-14 06:48:20 +00:00
47df98a499
log.Warn/Error uses "err" key to log errors in most places. This renames "error" to "err" in some places to adhere to this convention.
52 lines
1.5 KiB
Go
52 lines
1.5 KiB
Go
package services
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces"
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/grpcutil"
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/txpool"
|
|
txpool2 "github.com/ledgerwatch/erigon-lib/txpool"
|
|
"github.com/ledgerwatch/erigon/ethdb/privateapi"
|
|
"github.com/ledgerwatch/log/v3"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/protobuf/types/known/emptypb"
|
|
)
|
|
|
|
type TxPoolService struct {
|
|
txpool.TxpoolClient
|
|
log log.Logger
|
|
version gointerfaces.Version
|
|
}
|
|
|
|
func NewTxPoolService(client txpool.TxpoolClient) *TxPoolService {
|
|
return &TxPoolService{
|
|
TxpoolClient: client,
|
|
version: gointerfaces.VersionFromProto(privateapi.TxPoolAPIVersion),
|
|
log: log.New("remote_service", "tx_pool"),
|
|
}
|
|
}
|
|
|
|
func (s *TxPoolService) EnsureVersionCompatibility() bool {
|
|
Start:
|
|
versionReply, err := s.Version(context.Background(), &emptypb.Empty{}, grpc.WaitForReady(true))
|
|
if err != nil {
|
|
if grpcutil.ErrIs(err, txpool2.ErrPoolDisabled) {
|
|
time.Sleep(3 * time.Second)
|
|
goto Start
|
|
}
|
|
s.log.Error("ensure version", "err", err)
|
|
return false
|
|
}
|
|
if !gointerfaces.EnsureVersion(s.version, versionReply) {
|
|
s.log.Error("incompatible interface versions", "client", s.version.String(),
|
|
"server", fmt.Sprintf("%d.%d.%d", versionReply.Major, versionReply.Minor, versionReply.Patch))
|
|
return false
|
|
}
|
|
s.log.Info("interfaces compatible", "client", s.version.String(),
|
|
"server", fmt.Sprintf("%d.%d.%d", versionReply.Major, versionReply.Minor, versionReply.Patch))
|
|
return true
|
|
}
|