mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-05 10:32:19 +00:00
33d8c08c1c
This is the initial merge for polygon milestones it implements an rpc call used by heimdall but does not directly impact any chain processing
103 lines
2.5 KiB
Go
103 lines
2.5 KiB
Go
package heimdallgrpc
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"math/big"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor/heimdall/milestone"
|
|
|
|
proto "github.com/maticnetwork/polyproto/heimdall"
|
|
protoutils "github.com/maticnetwork/polyproto/utils"
|
|
)
|
|
|
|
func (h *HeimdallGRPCClient) FetchMilestoneCount(ctx context.Context) (int64, error) {
|
|
h.logger.Info("Fetching milestone count")
|
|
|
|
res, err := h.client.FetchMilestoneCount(ctx, nil)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
h.logger.Info("Fetched milestone count")
|
|
|
|
return res.Result.Count, nil
|
|
}
|
|
|
|
func (h *HeimdallGRPCClient) FetchMilestone(ctx context.Context) (*milestone.Milestone, error) {
|
|
h.logger.Info("Fetching milestone")
|
|
|
|
res, err := h.client.FetchMilestone(ctx, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
h.logger.Info("Fetched milestone")
|
|
|
|
milestone := &milestone.Milestone{
|
|
StartBlock: new(big.Int).SetUint64(res.Result.StartBlock),
|
|
EndBlock: new(big.Int).SetUint64(res.Result.EndBlock),
|
|
Hash: protoutils.ConvertH256ToHash(res.Result.RootHash),
|
|
Proposer: protoutils.ConvertH160toAddress(res.Result.Proposer),
|
|
BorChainID: res.Result.BorChainID,
|
|
Timestamp: uint64(res.Result.Timestamp.GetSeconds()),
|
|
}
|
|
|
|
return milestone, nil
|
|
}
|
|
|
|
func (h *HeimdallGRPCClient) FetchLastNoAckMilestone(ctx context.Context) (string, error) {
|
|
h.logger.Info("Fetching latest no ack milestone Id")
|
|
|
|
res, err := h.client.FetchLastNoAckMilestone(ctx, nil)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
h.logger.Info("Fetched last no-ack milestone")
|
|
|
|
return res.Result.Result, nil
|
|
}
|
|
|
|
func (h *HeimdallGRPCClient) FetchNoAckMilestone(ctx context.Context, milestoneID string) error {
|
|
req := &proto.FetchMilestoneNoAckRequest{
|
|
MilestoneID: milestoneID,
|
|
}
|
|
|
|
h.logger.Info("Fetching no ack milestone", "milestoneID", milestoneID)
|
|
|
|
res, err := h.client.FetchNoAckMilestone(ctx, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if !res.Result.Result {
|
|
return fmt.Errorf("Not in rejected list: milestoneID %q", milestoneID)
|
|
}
|
|
|
|
h.logger.Info("Fetched no ack milestone", "milestoneID", milestoneID)
|
|
|
|
return nil
|
|
}
|
|
|
|
func (h *HeimdallGRPCClient) FetchMilestoneID(ctx context.Context, milestoneID string) error {
|
|
req := &proto.FetchMilestoneIDRequest{
|
|
MilestoneID: milestoneID,
|
|
}
|
|
|
|
h.logger.Info("Fetching milestone id", "milestoneID", milestoneID)
|
|
|
|
res, err := h.client.FetchMilestoneID(ctx, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if !res.Result.Result {
|
|
return fmt.Errorf("This milestoneID %q does not exist", milestoneID)
|
|
}
|
|
|
|
h.logger.Info("Fetched milestone id", "milestoneID", milestoneID)
|
|
|
|
return nil
|
|
}
|