prysm-pulse/proto/prysm/v1alpha1/validator.proto
Raul Jordan a217d71d08
Sync Protobufs Between Hard Fork Branch and Develop (#9362)
Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
2021-08-11 19:14:49 +00:00

716 lines
31 KiB
Protocol Buffer

// Copyright 2020 Prysmatic Labs.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
syntax = "proto3";
package ethereum.eth.v1alpha1;
import "google/api/annotations.proto";
import "google/protobuf/empty.proto";
import "proto/eth/ext/options.proto";
import "proto/prysm/v1alpha1/beacon_block.proto";
import "proto/prysm/v1alpha1/sync_committee.proto";
import "proto/prysm/v1alpha1/attestation.proto";
option csharp_namespace = "Ethereum.Eth.V1";
option go_package = "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1;eth";
option java_multiple_files = true;
option java_outer_classname = "ValidatorProto";
option java_package = "org.ethereum.eth.v1alpha1";
option php_namespace = "Ethereum\\Eth\\v1alpha1";
// Beacon node validator API
//
// The beacon node validator API enables a validator to connect
// and perform its obligations on the Ethereum Beacon Chain.
service BeaconNodeValidator {
// Retrieves validator duties for the requested validators.
//
// The duties consist of:
// Proposer - the validator that creates a beacon chain block.
// Attester — a validator that is part of a committee that needs to sign off on a beacon chain
// block while simultaneously creating a cross link to a recent shard block on a particular shard chain.
// The server returns a list of duties which are the actions should be performed by validators for a given epoch.
// Validator duties should be polled every epoch, but due to chain reorg of >MIN_SEED_LOOKAHEAD could occur,
// the validator duties could chain. For complete safety, it is recommended to poll at every slot to ensure
// validator is fully aware of any sudden chain reorg.
rpc GetDuties(DutiesRequest) returns (DutiesResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/duties"
};
}
// Stream validator duties for the requested validators.
//
// The duties consist of:
// Proposer - the validator that creates a beacon chain block.
// Attester — a validator that is part of a committee that needs to sign off on a beacon chain
rpc StreamDuties(DutiesRequest) returns (stream DutiesResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/duties/stream"
};
}
// DomainData fetches the current BLS signature domain version information from the
// running beacon node's state. This information is used when validators sign
// blocks and attestations appropriately based on their duty.
rpc DomainData(DomainRequest) returns (DomainResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/domain"
};
}
// WaitForChainStart queries the logs of the Validator Deposit Contract on the Ethereum
// proof-of-work chain to verify the beacon chain has started its runtime and
// validators are ready to begin their responsibilities.
//
// If the chain has not yet started, this endpoint starts a server-side stream which updates
// the client when the beacon chain is ready.
rpc WaitForChainStart(google.protobuf.Empty) returns (stream ChainStartResponse) {
option deprecated = true;
option (google.api.http) = {
get: "/eth/v1alpha1/validator/chainstart/stream"
};
}
// WaitForActivation checks if a validator public key exists in the active validator
// registry of the current beacon state. If the validator is NOT yet active, it starts a
// server-side stream which updates the client whenever the validator becomes active in
// the beacon node's state.
//
// The input to this endpoint is a list of validator public keys, and the corresponding
// stream will respond until at least a single corresponding validator to those
// keys is activated.
rpc WaitForActivation(ValidatorActivationRequest) returns (stream ValidatorActivationResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/activation/stream"
};
}
// ValidatorIndex retrieves a validator's index location in the beacon state's
// validator registry looking up whether the validator exists based on its
// public key. This method returns NOT_FOUND if no index is found for the public key
// specified in the request.
rpc ValidatorIndex(ValidatorIndexRequest) returns (ValidatorIndexResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/index"
};
}
// ValidatorStatus returns a validator's status based on the current epoch.
// The request can specify either a validator's public key or validator index.
//
// The status response can be one of the following:
// DEPOSITED - validator's deposit has been recognized by Ethereum 1, not yet recognized by Ethereum.
// PENDING - validator is in Ethereum's activation queue.
// ACTIVE - validator is active.
// EXITING - validator has initiated an an exit request, or has dropped below the ejection balance and is being kicked out.
// EXITED - validator is no longer validating.
// SLASHING - validator has been kicked out due to meeting a slashing condition.
// UNKNOWN_STATUS - validator does not have a known status in the network.
rpc ValidatorStatus(ValidatorStatusRequest) returns (ValidatorStatusResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/status"
};
}
// MultipleValidatorStatus returns a list of validator statuses on the current epoch.
// The request can specify a list of validator public keys.
//
// Returns a list of ValidatorStatusResponses.
rpc MultipleValidatorStatus(MultipleValidatorStatusRequest) returns (MultipleValidatorStatusResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/statuses"
};
}
// Retrieves the latest valid beacon block to be proposed on the beacon chain.
//
// The server returns a new beacon block, without proposer signature, that can be
// proposed on the beacon chain. The block should be filled with all the necessary
// data for proposer to sign.
rpc GetBlock(BlockRequest) returns (BeaconBlock) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/block"
};
}
// Sends the newly signed beacon block to beacon node.
//
// The validator sends the newly signed beacon block to the beacon node so the beacon block can
// be included in the beacon chain. The beacon node is expected to validate and process the
// beacon block into its state.
rpc ProposeBlock(SignedBeaconBlock) returns (ProposeResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/block"
body: "*"
};
}
// Retrieves the latest valid attestation data to be attested on the beacon chain.
//
// The server returns the latest valid data which represents the correct vote
// for the head of the beacon chain.
rpc GetAttestationData(AttestationDataRequest) returns (AttestationData) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/attestation"
};
}
// Sends the newly signed attestation to beacon node.
//
// The validator sends the newly signed attestation to the beacon node for the attestation to
// be included in the beacon chain. The beacon node is expected to validate and publish attestation on
// appropriate committee subnet.
rpc ProposeAttestation(Attestation) returns (AttestResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/attestation"
body: "*"
};
}
// Submit selection proof to the beacon node to aggregate all matching wire attestations with the same data root.
// the beacon node responses with an aggregate and proof object back to validator to sign over.
rpc SubmitAggregateSelectionProof(AggregateSelectionRequest) returns (AggregateSelectionResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/aggregate"
body: "*"
};
}
// Submit a signed aggregate and proof object, the beacon node will broadcast the
// signed aggregated attestation and proof object.
rpc SubmitSignedAggregateSelectionProof(SignedAggregateSubmitRequest) returns (SignedAggregateSubmitResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/aggregate"
body: "*"
};
}
// Propose to leave the list of active validators.
//
// The beacon node is expected to validate the request and make it available for inclusion in
// the next proposed block.
rpc ProposeExit(SignedVoluntaryExit) returns (ProposeExitResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/exit"
body: "*"
};
}
// Subscribe to particular committee ID subnets given validator's duty.
//
// The beacon node is expected to subscribe to the committee ID subnet given by the request. With this,
// beacon node serving attesters can find persistent peers on the subnet to publish attestation,
// and beacon node serving aggregator can join the subnet.
rpc SubscribeCommitteeSubnets(CommitteeSubnetsSubscribeRequest) returns (google.protobuf.Empty) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/subnet/subscribe"
body: "*"
};
}
// Checks the beacon node if another instance of the provided validator keys have been
// attesting/proposing for you.
rpc CheckDoppelGanger(DoppelGangerRequest) returns (DoppelGangerResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/doppelganger"
};
}
// Retrieves the latest valid beacon block to be proposed on the beacon chain.
//
// The server returns a new beacon block, without proposer signature, that can be
// proposed on the beacon chain. The block should be filled with all the necessary
// data for proposer to sign. This block is versioned from Altair onwards.
rpc GetBlockAltair(BlockRequest) returns (BeaconBlockAltair) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/block"
};
}
// Sends the newly signed beacon block to beacon node.
//
// The validator sends the newly signed beacon block to the beacon node so the beacon block can
// be included in the beacon chain. The beacon node is expected to validate and process the
// beacon block into its state. This block is versioned from Altair onwards.
rpc ProposeBlockAltair(SignedBeaconBlockAltair) returns (ProposeResponse) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/block"
body: "*"
};
}
// Retrieves a sync committee message block root to be signed over as part of sync committee duty.
rpc GetSyncMessageBlockRoot(google.protobuf.Empty) returns (SyncMessageBlockRootResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/sync_message_block_root"
};
}
// Submits a sync committee message to be broadcasted over network. This is part of sync committee duty.
rpc SubmitSyncMessage(SyncCommitteeMessage) returns (google.protobuf.Empty) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/sync_message"
body: "*"
};
}
// Retrieves the sync subcommittee index of a given validator.
//
// The server returns the sync subcommittee index given the validator public key,
// if the validator does not exist in the sync committee then an error would be returned.
// The subcommittee index is used for the aggregation of sync committee message.
rpc GetSyncSubcommitteeIndex(SyncSubcommitteeIndexRequest) returns (SyncSubcommitteeIndexResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/sync_subcommittee_index"
};
}
// Retrieve sync committee contribution to the beacon node to aggregate all matching sync committee messages with the same slot and root.
// the beacon node responses with a sync committee contribution object for the validator to sign over.
rpc GetSyncCommitteeContribution(SyncCommitteeContributionRequest) returns (SyncCommitteeContribution) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/contribution_and_proof"
body: "*"
};
}
// Submit a signed sync committee contribution and proof object, the beacon node will broadcast the
// signed contribution and proof object.
rpc SubmitSignedContributionAndProof(SignedContributionAndProof) returns (google.protobuf.Empty) {
option (google.api.http) = {
post: "/eth/v1alpha1/validator/signed_contribution_and_proof"
body: "*"
};
}
// Server-side stream of all signed blocks as they are received by
// the beacon chain node.
rpc StreamBlocksAltair(StreamBlocksRequest) returns (stream StreamBlocksResponse) {
option (google.api.http) = {
get: "/eth/v1alpha1/validator/blocks/stream"
};
}
}
// SyncMessageBlockRootResponse for beacon chain validator to retrieve and
// to sign over the block root as part of sync committee duty to facilitate light client.
message SyncMessageBlockRootResponse {
// The block root of the head block.
bytes root = 1 [(ethereum.eth.ext.ssz_size) = "32"];
}
// SyncSubcommitteeIndexRequest requests sync subcommittee index given the validator public key.
message SyncSubcommitteeIndexRequest {
// The validator's public key.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48"];
// The slot of validator's assignment.
uint64 slot = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
}
message SyncCommitteeContributionRequest {
// Slot for which the aggregation request applies.
uint64 slot = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// 48 byte public key of the validator.
bytes public_key = 2 [(ethereum.eth.ext.ssz_size) = "48", (ethereum.eth.ext.spec_name) = "pubkey"];
// Subnet ID of where this contribution and proof should be broadcast to.
uint64 subnet_id = 3;
}
// SyncSubcommitteeIndexResponse responds index of the sync subcommittee of a given validator.
message SyncSubcommitteeIndexResponse {
// The subcommittee index itself.
// If the total validator count is not sufficient, there could be more than one index.
repeated uint64 indices = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.CommitteeIndex"];
}
message StreamBlocksResponse {
oneof block {
// Representing a phase 0 block.
SignedBeaconBlock phase0_block = 1 ;
// Representing an altair block.
SignedBeaconBlockAltair altair_block = 2;
}
}
message DomainRequest {
// The epoch for which the domain is being requested.
uint64 epoch = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// The bytes domain specified by the validator.
bytes domain = 2;
}
message DomainResponse {
// The signature domain is a byte array used by validators when
// signing data related to block proposals and attestations.
bytes signature_domain = 1;
}
message ValidatorActivationRequest {
// A list of 48 byte validator public keys.
repeated bytes public_keys = 1 [(ethereum.eth.ext.ssz_size) = "?,48"];
}
message ValidatorActivationResponse {
message Status {
// A 48 byte validator public key.
bytes public_key = 1;
// A wrapper representing a validator's status object.
ValidatorStatusResponse status = 2;
// The validators index in the beacon state.
uint64 index = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
}
// A list of validator statuses mapped 1-to-1 with the public keys
// in the request.
repeated Status statuses = 1;
}
message ChainStartResponse {
// A boolean specifying whether or not the chain has started.
bool started = 1;
// The genesis time of the beacon chain.
uint64 genesis_time = 2;
// 32 byte hash tree root of the genesis validator set.
bytes genesis_validators_root = 3 [(ethereum.eth.ext.ssz_size) = "32"];
}
message SyncedResponse {
// A boolean specifying whether or not the beacon node is synced and ready for the validator.
bool synced = 1;
// The genesis time of the beacon chain.
uint64 genesis_time = 2;
}
message ValidatorIndexRequest {
// A 48 byte validator public key.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48"];
}
message ValidatorIndexResponse {
// The validator's index in the beacon chain state's validator registry.
uint64 index = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
}
message ValidatorStatusRequest {
// A 48 byte validator public key.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48"];
}
enum ValidatorStatus {
UNKNOWN_STATUS = 0;
DEPOSITED = 1;
PENDING = 2;
ACTIVE = 3;
EXITING = 4;
SLASHING = 5;
EXITED = 6;
INVALID = 7;
PARTIALLY_DEPOSITED = 8;
}
message ValidatorStatusResponse {
// The corresponding validator status.
ValidatorStatus status = 1;
// The block number of the Ethereum proof-of-work chain
// where the deposit for the validator was included.
uint64 eth1_deposit_block_number = 2;
// The slot in the beacon chain in which the validator's
// deposit was included in a block.
uint64 deposit_inclusion_slot = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// The epoch in the beacon chain in which the validator
// is determined as active.
uint64 activation_epoch = 4 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// The position in the activation queue of pending validators.
uint64 position_in_activation_queue = 5;
}
message MultipleValidatorStatusRequest {
// A list of 48 byte validator public keys.
repeated bytes public_keys = 1 [(ethereum.eth.ext.ssz_size) = "?,48"];
// A list of validator indices.
repeated int64 indices = 2;
}
message MultipleValidatorStatusResponse {
// A list of 48 byte validator public keys.
repeated bytes public_keys = 1 [(ethereum.eth.ext.ssz_size) = "?,48"];
// A list of ValidatorStatusResponses mapped 1-to-1 with the public keys.
repeated ValidatorStatusResponse statuses = 2;
// A list of validator indices.
repeated uint64 indices = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
}
message DutiesRequest {
// Epoch at which validators should perform their duties.
uint64 epoch = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// Array of byte encoded BLS public keys.
repeated bytes public_keys = 2 [(ethereum.eth.ext.ssz_size) = "?,48"];
}
message DutiesResponse {
repeated Duty duties = 1 [deprecated = true];
repeated Duty current_epoch_duties = 2;
repeated Duty next_epoch_duties = 3;
message Duty {
// The committee a validator is assigned to.
repeated uint64 committee = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
// The index into the committee where the validator belongs in.
uint64 committee_index = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.CommitteeIndex"];
// Slot at which a validator must attest.
uint64 attester_slot = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// Slots at which a validator must propose a beacon chain block.
repeated uint64 proposer_slots = 4 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// 48 byte BLS public key for the validator who's assigned to perform a duty.
bytes public_key = 5 [(ethereum.eth.ext.ssz_size) = "48"];
// The current status of the validator assigned to perform the duty.
ValidatorStatus status = 6;
// The index of the validator in the beacon state.
uint64 validator_index = 7 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
// Whether the validator belongs in the sync committee and has to perform sync committee duty.
bool is_sync_committee = 8;
}
}
message BlockRequest {
// Slot for which the block should be proposed.
uint64 slot = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// Validator's 32 byte randao reveal secret of the current epoch.
bytes randao_reveal = 2 [(ethereum.eth.ext.ssz_size) = "48"];
// Validator's 32 byte graffiti message for the new block.
bytes graffiti = 3 [(ethereum.eth.ext.ssz_size) = "32"];
}
message ProposeResponse {
// The block root of the successfully proposed beacon block.
bytes block_root = 1 [(ethereum.eth.ext.ssz_size) = "32"];
}
message ProposeExitResponse {
// The root of the successfully proposed voluntary exit.
bytes exit_root = 1 [(ethereum.eth.ext.ssz_size) = "32"];
}
message AttestationDataRequest {
// Slot for which the attestation should be created.
uint64 slot = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// Committee index the attestation should be created for.
uint64 committee_index = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.CommitteeIndex"];
}
message AttestResponse {
// The root of the attestation data successfully submitted to the beacon node.
bytes attestation_data_root = 1 [(ethereum.eth.ext.ssz_size) = "32"];
}
message AggregateSelectionRequest {
// Slot for which the aggregation request applies.
uint64 slot = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// Committee index of the validator at the given slot.
uint64 committee_index = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.CommitteeIndex"];
// 48 byte public key of the validator.
bytes public_key = 3 [(ethereum.eth.ext.ssz_size) = "48", (ethereum.eth.ext.spec_name) = "pubkey"];
// 96 byte signature of the validator on the slot. This is used as proof that the validator is
// an aggregator for the given slot.
bytes slot_signature = 4 [(ethereum.eth.ext.ssz_size) = "96"];
}
message AggregateSelectionResponse {
// The aggregate and proof message without the signature.
AggregateAttestationAndProof aggregate_and_proof = 1;
}
message SignedAggregateSubmitRequest {
// The signed aggregate and proof message with the signature.
SignedAggregateAttestationAndProof signed_aggregate_and_proof = 1;
}
message SignedAggregateSubmitResponse {
// The 32 byte hash tree root of the aggregated attestation data.
bytes attestation_data_root = 1 [(ethereum.eth.ext.ssz_size) = "32"];
}
message CommitteeSubnetsSubscribeRequest {
// A list of intended slots to subscribe.
repeated uint64 slots = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Slot"];
// A list of intended committee ids to subscribe. It is mapped 1-to-1 with the slots
repeated uint64 committee_ids = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.CommitteeIndex"];
// Whether to subscribe as an aggregator or by default attester.
// It is mapped 1-to-1 with the slots and committee ids.
// Subscribe as an aggregator means to join the subnet.
// Subscribe as an attester means finding persistent peers on the subnet to be able to publish attestations.
repeated bool is_aggregator = 3;
}
// An Ethereum validator.
message Validator {
// 48 byte BLS public key used for the validator's activities.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48", (ethereum.eth.ext.spec_name) = "pubkey"];
// 32 byte hash of the withdrawal destination public key.
bytes withdrawal_credentials = 2 [(ethereum.eth.ext.ssz_size) = "32"];
// The validators current effective balance in gwei.
uint64 effective_balance = 3;
// Whether or not the validator has been slashed.
bool slashed = 4;
// Epoch when the validator became eligible for activation. This field may
// be zero if the validator was present in the Ethereum proof of stake genesis. This
// field is FAR_FUTURE_EPOCH if the validator has not been activated.
uint64 activation_eligibility_epoch = 5 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// Epoch when the validator was activated. This field may be zero if the
// validator was present in the Ethereum proof of stake genesis. This field is
// FAR_FUTURE_EPOCH if the validator has not been activated.
uint64 activation_epoch = 6 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// Epoch when the validator was exited. This field is FAR_FUTURE_EPOCH if
// the validator has not exited.
// FAR_FUTURE_EPOCH is a constant defined by the official Ethereum Beacon Chain specification:
// https://github.com/ethereum/eth2.0-specs/blob/v0.9.2/specs/core/0_beacon-chain.md#constants
uint64 exit_epoch = 7 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// Epoch when the validator is eligible to withdraw their funds. This field
// is FAR_FUTURE_EPOCH if the validator has not exited.
// FAR_FUTURE_EPOCH is a constant defined by the official Ethereum Beacon Chain specification:
// https://github.com/ethereum/eth2.0-specs/blob/v0.9.2/specs/core/0_beacon-chain.md#constants
uint64 withdrawable_epoch = 8 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
}
// ValidatorParticipation stores participation metrics during a given epoch.
message ValidatorParticipation {
// Percentage of validator participation in the given epoch. This field
// contains a value between 0 and 1.
float global_participation_rate = 1 [deprecated = true];
// The total amount of ether, in gwei, that has been used in voting.
uint64 voted_ether = 2 [deprecated = true];
// The total amount of ether, in gwei, that is eligible for voting.
uint64 eligible_ether = 3 [deprecated = true];
// Total staked gwei that was active (i.e. eligible to vote) during the current epoch.
uint64 current_epoch_active_gwei = 4;
// Total staked gwei that had attestations included in a block during the current epoch,
// attestations by the same validator do not increase this figure.
uint64 current_epoch_attesting_gwei = 5;
// Total staked gwei that attested to the majority-elected Casper FFG target epoch during the current epoch.
uint64 current_epoch_target_attesting_gwei = 6;
// Same as current_epoch_active_gwei but for previous epoch.
uint64 previous_epoch_active_gwei = 7;
// Same as current_epoch_attesting_gwei but for previous epoch.
uint64 previous_epoch_attesting_gwei = 8;
// Same as current_epoch_target_attesting_gwei but for previous epoch.
uint64 previous_epoch_target_attesting_gwei = 9;
// Total staked gwei that attested to a head beacon block that is in the canonical chain.
uint64 previous_epoch_head_attesting_gwei = 10;
}
// ValidatorInfo gives information about the state of a validator at a certain epoch.
message ValidatorInfo {
// The validator's 48 byte BLS public key.
bytes public_key = 1;
// The validator's index in the beacon state.
uint64 index = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.ValidatorIndex"];
// The epoch for which the information pertains.
uint64 epoch = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// The validator's current status.
ValidatorStatus status = 4;
// The unix timestamp when the validator enters the next state.
// This could be in the past. Some values depend on chain operation and so will vary from epoch to epoch.
// Specific times for each state are as follows:
// - state == DEPOSITED: time at which Ethereum 1 deposit will be stored on-chain by Ethereum (variable, can be 0).
// - state == PENDING: time at which validator will be activated (variable).
// - state == ACTIVE: no value (next transition depends on user and network actions).
// - state == EXITING: time at which validator will exit.
// - state == SLASHING: time at which validator will exit.
// - state == EXITED: time at which validator funds will be withdrawable.
uint64 transition_timestamp = 5;
// The validator's current balance in GWei.
uint64 balance = 6;
// The validator's current effective balance in GWei.
// Only valid for states ACTIVE, EXITING, SLASHING.
uint64 effective_balance = 7;
}
// DoppelGangerRequest represents the request sent by the validator in order to determine
// if there is any duplicate instance of it running in the network.
message DoppelGangerRequest {
repeated ValidatorRequest validator_requests = 1;
// ValidatorRequest data type which represents a request for each validator.
message ValidatorRequest {
// The validator's 48 byte BLS public key.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48", (ethereum.eth.ext.spec_name) = "pubkey"];
// The validator's last recorded epoch to attest.
uint64 epoch = 3 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/eth2-types.Epoch"];
// The validator's last recorded signed root.
bytes signed_root = 2 [(ethereum.eth.ext.ssz_size) = "32"];
}
}
// DoppelGangerResponse is the response payload sent by the beacon node
// after it has checked for all duplicate keys in the network.
message DoppelGangerResponse {
message ValidatorResponse {
// The validator's 48 byte BLS public key.
bytes public_key = 1 [(ethereum.eth.ext.ssz_size) = "48", (ethereum.eth.ext.spec_name) = "pubkey"];
// Whether a duplicate of the validator exists.
bool duplicate_exists = 2;
}
repeated ValidatorResponse responses = 1;
}
// Request to only return blocks that is verified by the beacon node.
message StreamBlocksRequest {
bool verified_only = 1;
}