mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-09 15:37:56 -05:00
* Add GetAttestationData * Add tests * Add many more tests and refactor * Fix logic * Address PR comments * Address PR comments * Add jsonRestHandler and decouple http logic from rest of the code * Add buildURL tests * Remove handlers_test.go * Improve tests * Implement `ValidatorIndex` of `beaconApiValidatorClient` using Beacon API * Implement getStateValidators * `validatorIndex`: Use `getStateValidators` Co-authored-by: Patrice Vignola <vignola.patrice@gmail.com>
266 lines
12 KiB
Go
266 lines
12 KiB
Go
//go:build use_beacon_api
|
|
// +build use_beacon_api
|
|
|
|
package beacon_api
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
|
"github.com/golang/protobuf/ptypes/empty"
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/v3/encoding/bytesutil"
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
iface "github.com/prysmaticlabs/prysm/v3/validator/client/iface"
|
|
)
|
|
|
|
type beaconApiValidatorClient struct {
|
|
genesisProvider genesisProvider
|
|
jsonRestHandler jsonRestHandler
|
|
fallbackClient iface.ValidatorClient
|
|
}
|
|
|
|
func NewBeaconApiValidatorClient(host string, timeout time.Duration) *beaconApiValidatorClient {
|
|
jsonRestHandler := beaconApiJsonRestHandler{
|
|
httpClient: http.Client{Timeout: timeout},
|
|
host: host,
|
|
}
|
|
|
|
return &beaconApiValidatorClient{
|
|
genesisProvider: beaconApiGenesisProvider{jsonRestHandler: jsonRestHandler},
|
|
jsonRestHandler: jsonRestHandler,
|
|
}
|
|
}
|
|
|
|
func NewBeaconApiValidatorClientWithFallback(url string, timeout time.Duration, fallbackClient iface.ValidatorClient) *beaconApiValidatorClient {
|
|
beaconApiValidatorClient := NewBeaconApiValidatorClient(url, timeout)
|
|
beaconApiValidatorClient.fallbackClient = fallbackClient
|
|
return beaconApiValidatorClient
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetDuties(ctx context.Context, in *ethpb.DutiesRequest) (*ethpb.DutiesResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetDuties(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetDuties is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) CheckDoppelGanger(ctx context.Context, in *ethpb.DoppelGangerRequest) (*ethpb.DoppelGangerResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.CheckDoppelGanger(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.CheckDoppelGanger is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) DomainData(_ context.Context, in *ethpb.DomainRequest) (*ethpb.DomainResponse, error) {
|
|
if len(in.Domain) != 4 {
|
|
return nil, errors.Errorf("invalid domain type: %s", hexutil.Encode(in.Domain))
|
|
}
|
|
|
|
domainType := bytesutil.ToBytes4(in.Domain)
|
|
return c.getDomainData(in.Epoch, domainType)
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetAttestationData(_ context.Context, in *ethpb.AttestationDataRequest) (*ethpb.AttestationData, error) {
|
|
if in == nil {
|
|
return nil, errors.New("GetAttestationData received nil argument `in`")
|
|
}
|
|
|
|
return c.getAttestationData(in.Slot, in.CommitteeIndex)
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetBeaconBlock(ctx context.Context, in *ethpb.BlockRequest) (*ethpb.GenericBeaconBlock, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetBeaconBlock(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetBeaconBlock is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetFeeRecipientByPubKey(ctx context.Context, in *ethpb.FeeRecipientByPubKeyRequest) (*ethpb.FeeRecipientByPubKeyResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetFeeRecipientByPubKey(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetFeeRecipientByPubKey is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetSyncCommitteeContribution(ctx context.Context, in *ethpb.SyncCommitteeContributionRequest) (*ethpb.SyncCommitteeContribution, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetSyncCommitteeContribution(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetSyncCommitteeContribution is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetSyncMessageBlockRoot(ctx context.Context, in *empty.Empty) (*ethpb.SyncMessageBlockRootResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetSyncMessageBlockRoot(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetSyncMessageBlockRoot is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) GetSyncSubcommitteeIndex(ctx context.Context, in *ethpb.SyncSubcommitteeIndexRequest) (*ethpb.SyncSubcommitteeIndexResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.GetSyncSubcommitteeIndex(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.GetSyncSubcommitteeIndex is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) MultipleValidatorStatus(ctx context.Context, in *ethpb.MultipleValidatorStatusRequest) (*ethpb.MultipleValidatorStatusResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.MultipleValidatorStatus(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.MultipleValidatorStatus is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) PrepareBeaconProposer(ctx context.Context, in *ethpb.PrepareBeaconProposerRequest) (*empty.Empty, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.PrepareBeaconProposer(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.PrepareBeaconProposer is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) ProposeAttestation(ctx context.Context, in *ethpb.Attestation) (*ethpb.AttestResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.ProposeAttestation(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.ProposeAttestation is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) ProposeBeaconBlock(ctx context.Context, in *ethpb.GenericSignedBeaconBlock) (*ethpb.ProposeResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.ProposeBeaconBlock(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.ProposeBeaconBlock is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) ProposeExit(ctx context.Context, in *ethpb.SignedVoluntaryExit) (*ethpb.ProposeExitResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.ProposeExit(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.ProposeExit is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) StreamBlocksAltair(ctx context.Context, in *ethpb.StreamBlocksRequest) (ethpb.BeaconNodeValidator_StreamBlocksAltairClient, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.StreamBlocksAltair(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.StreamBlocksAltair is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) StreamDuties(ctx context.Context, in *ethpb.DutiesRequest) (ethpb.BeaconNodeValidator_StreamDutiesClient, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.StreamDuties(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.StreamDuties is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubmitAggregateSelectionProof(ctx context.Context, in *ethpb.AggregateSelectionRequest) (*ethpb.AggregateSelectionResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubmitAggregateSelectionProof(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubmitAggregateSelectionProof is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubmitSignedAggregateSelectionProof(ctx context.Context, in *ethpb.SignedAggregateSubmitRequest) (*ethpb.SignedAggregateSubmitResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubmitSignedAggregateSelectionProof(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubmitSignedAggregateSelectionProof is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubmitSignedContributionAndProof(ctx context.Context, in *ethpb.SignedContributionAndProof) (*empty.Empty, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubmitSignedContributionAndProof(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubmitSignedContributionAndProof is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubmitSyncMessage(ctx context.Context, in *ethpb.SyncCommitteeMessage) (*empty.Empty, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubmitSyncMessage(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubmitSyncMessage is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubmitValidatorRegistrations(ctx context.Context, in *ethpb.SignedValidatorRegistrationsV1) (*empty.Empty, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubmitValidatorRegistrations(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubmitValidatorRegistrations is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) SubscribeCommitteeSubnets(ctx context.Context, in *ethpb.CommitteeSubnetsSubscribeRequest) (*empty.Empty, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.SubscribeCommitteeSubnets(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.SubscribeCommitteeSubnets is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) ValidatorIndex(_ context.Context, in *ethpb.ValidatorIndexRequest) (*ethpb.ValidatorIndexResponse, error) {
|
|
return c.validatorIndex(in)
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) ValidatorStatus(ctx context.Context, in *ethpb.ValidatorStatusRequest) (*ethpb.ValidatorStatusResponse, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.ValidatorStatus(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.ValidatorStatus is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
func (c *beaconApiValidatorClient) WaitForActivation(ctx context.Context, in *ethpb.ValidatorActivationRequest) (ethpb.BeaconNodeValidator_WaitForActivationClient, error) {
|
|
if c.fallbackClient != nil {
|
|
return c.fallbackClient.WaitForActivation(ctx, in)
|
|
}
|
|
|
|
// TODO: Implement me
|
|
panic("beaconApiValidatorClient.WaitForActivation is not implemented. To use a fallback client, create this validator with NewBeaconApiValidatorClientWithFallback instead.")
|
|
}
|
|
|
|
// Deprecated: Do not use.
|
|
func (c *beaconApiValidatorClient) WaitForChainStart(ctx context.Context, _ *empty.Empty) (*ethpb.ChainStartResponse, error) {
|
|
return c.waitForChainStart(ctx)
|
|
}
|