mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 02:31:19 +00:00
5a66807989
* First take at updating everything to v5 * Patch gRPC gateway to use prysm v5 Fix patch * Update go ssz --------- Co-authored-by: Preston Van Loon <pvanloon@offchainlabs.com>
122 lines
3.7 KiB
Go
122 lines
3.7 KiB
Go
package beacon_api
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"encoding/json"
|
|
"fmt"
|
|
neturl "net/url"
|
|
"regexp"
|
|
"strconv"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/v5/api/server/structs"
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/primitives"
|
|
|
|
ethpb "github.com/prysmaticlabs/prysm/v5/proto/prysm/v1alpha1"
|
|
)
|
|
|
|
var beaconAPITogRPCValidatorStatus = map[string]ethpb.ValidatorStatus{
|
|
"pending_initialized": ethpb.ValidatorStatus_DEPOSITED,
|
|
"pending_queued": ethpb.ValidatorStatus_PENDING,
|
|
"active_ongoing": ethpb.ValidatorStatus_ACTIVE,
|
|
"active_exiting": ethpb.ValidatorStatus_EXITING,
|
|
"active_slashed": ethpb.ValidatorStatus_SLASHING,
|
|
"exited_unslashed": ethpb.ValidatorStatus_EXITED,
|
|
"exited_slashed": ethpb.ValidatorStatus_EXITED,
|
|
"withdrawal_possible": ethpb.ValidatorStatus_EXITED,
|
|
"withdrawal_done": ethpb.ValidatorStatus_EXITED,
|
|
}
|
|
|
|
func validRoot(root string) bool {
|
|
matchesRegex, err := regexp.MatchString("^0x[a-fA-F0-9]{64}$", root)
|
|
if err != nil {
|
|
return false
|
|
}
|
|
return matchesRegex
|
|
}
|
|
|
|
func uint64ToString[T uint64 | primitives.Slot | primitives.ValidatorIndex | primitives.CommitteeIndex | primitives.Epoch](val T) string {
|
|
return strconv.FormatUint(uint64(val), 10)
|
|
}
|
|
|
|
func buildURL(path string, queryParams ...neturl.Values) string {
|
|
if len(queryParams) == 0 {
|
|
return path
|
|
}
|
|
|
|
return fmt.Sprintf("%s?%s", path, queryParams[0].Encode())
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) getFork(ctx context.Context) (*structs.GetStateForkResponse, error) {
|
|
const endpoint = "/eth/v1/beacon/states/head/fork"
|
|
|
|
stateForkResponseJson := &structs.GetStateForkResponse{}
|
|
|
|
if err := c.jsonRestHandler.Get(ctx, endpoint, stateForkResponseJson); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return stateForkResponseJson, nil
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) getHeaders(ctx context.Context) (*structs.GetBlockHeadersResponse, error) {
|
|
const endpoint = "/eth/v1/beacon/headers"
|
|
|
|
blockHeadersResponseJson := &structs.GetBlockHeadersResponse{}
|
|
|
|
if err := c.jsonRestHandler.Get(ctx, endpoint, blockHeadersResponseJson); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return blockHeadersResponseJson, nil
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) getLiveness(ctx context.Context, epoch primitives.Epoch, validatorIndexes []string) (*structs.GetLivenessResponse, error) {
|
|
const endpoint = "/eth/v1/validator/liveness/"
|
|
url := endpoint + strconv.FormatUint(uint64(epoch), 10)
|
|
|
|
livenessResponseJson := &structs.GetLivenessResponse{}
|
|
|
|
marshalledJsonValidatorIndexes, err := json.Marshal(validatorIndexes)
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "failed to marshal validator indexes")
|
|
}
|
|
|
|
if err = c.jsonRestHandler.Post(ctx, url, nil, bytes.NewBuffer(marshalledJsonValidatorIndexes), livenessResponseJson); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return livenessResponseJson, nil
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) getSyncing(ctx context.Context) (*structs.SyncStatusResponse, error) {
|
|
const endpoint = "/eth/v1/node/syncing"
|
|
|
|
syncingResponseJson := &structs.SyncStatusResponse{}
|
|
|
|
if err := c.jsonRestHandler.Get(ctx, endpoint, syncingResponseJson); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return syncingResponseJson, nil
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) isSyncing(ctx context.Context) (bool, error) {
|
|
response, err := c.getSyncing(ctx)
|
|
if err != nil || response == nil || response.Data == nil {
|
|
return true, errors.Wrapf(err, "failed to get syncing status")
|
|
}
|
|
|
|
return response.Data.IsSyncing, err
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) isOptimistic(ctx context.Context) (bool, error) {
|
|
response, err := c.getSyncing(ctx)
|
|
if err != nil || response == nil || response.Data == nil {
|
|
return true, errors.Wrapf(err, "failed to get syncing status")
|
|
}
|
|
|
|
return response.Data.IsOptimistic, err
|
|
}
|