prysm-pulse/proto/beacon/rpc/v1/services.proto
Preston Van Loon 956721fe43 Simplified validator workflow 2 - updateAssignments (#1371)
* Add attestation p2p messages

* first pass refactor

* lint

* viz fix

* comment unused const for now

* Add opentracing spans

* PR feedback

* added updateAssignments implementation

* update proto

* handle error in runner

* only do updates on epoch start

* gazelle

* goimports
2019-01-25 11:26:03 +08:00

135 lines
3.8 KiB
Protocol Buffer

syntax = "proto3";
package ethereum.beacon.rpc.v1;
import "proto/beacon/p2p/v1/types.proto";
import "google/protobuf/empty.proto";
import "google/protobuf/timestamp.proto";
service BeaconService {
// CanonicalHead can be called on demand to fetch the current, head block of a
// beacon node.
rpc CanonicalHead(google.protobuf.Empty) returns (ethereum.beacon.p2p.v1.BeaconBlock);
// LatestAttestation streams the latest aggregated attestation to connected
// validator clients.
rpc LatestAttestation(google.protobuf.Empty) returns (stream ethereum.beacon.p2p.v1.Attestation);
// CurrentAssignmentsAndGenesisTime is called by a validator client upon first connecting
// to a beacon node in order to determine the current validator assignments
// and genesis timestamp of the protocol.
rpc CurrentAssignmentsAndGenesisTime(ValidatorAssignmentRequest) returns (CurrentAssignmentsResponse);
// ValidatorAssignments streams validator assignments to clients
// for a subset of public keys in the active validator set.
rpc ValidatorAssignments(ValidatorAssignmentRequest) returns(stream ValidatorAssignmentResponse);
}
service AttesterService {
rpc AttestHead(AttestRequest) returns (AttestResponse);
}
service ProposerService {
rpc ProposeBlock(ethereum.beacon.p2p.v1.BeaconBlock) returns (ProposeResponse);
rpc LatestPOWChainBlockHash(google.protobuf.Empty) returns (POWChainResponse);
rpc ComputeStateRoot(ethereum.beacon.p2p.v1.BeaconBlock) returns (StateRootResponse);
rpc ProposerIndex(ProposerIndexRequest) returns (IndexResponse);
}
service ValidatorService {
// These endpoints can be called on demand in the future
// by some web3 API for users to conveniently know their assignment.
rpc ValidatorShardID(PublicKey) returns (ShardIDResponse);
rpc ValidatorIndex(PublicKey) returns (IndexResponse);
rpc ValidatorSlotAndResponsibility(PublicKey) returns (SlotResponsibilityResponse);
rpc ValidatorEpochAssignments(ValidatorEpochAssignmentsRequest) returns (ValidatorEpochAssignmentsResponse);
}
message ProposeRequest {
bytes parent_hash = 1;
uint64 slot_number = 2;
bytes randao_reveal_hash32 = 3;
bytes attestation_bitmask = 4;
repeated uint32 attestation_aggregate_sig = 5;
google.protobuf.Timestamp timestamp = 6;
}
message ProposeResponse {
bytes block_hash = 1;
}
message POWChainResponse {
bytes block_hash = 1;
}
message ProposerIndexRequest {
uint64 slot_number = 1;
}
message StateRootResponse {
bytes state_root = 1;
}
message AttestRequest {
ethereum.beacon.p2p.v1.Attestation attestation = 1;
}
message AttestResponse {
bytes attestation_hash = 1;
}
// Request assignment updates for either all validators or a subset of validators
// defined by their public keys.
message ValidatorAssignmentRequest {
bool all_validators = 1;
repeated PublicKey public_keys = 2;
}
message ValidatorAssignmentResponse {
repeated Assignment assignments = 1;
}
enum ValidatorRole {
UNKNOWN = 0;
ATTESTER = 1;
PROPOSER = 2;
}
// Assignment defines a validator's assignment responsibilities.
message Assignment {
PublicKey public_key = 1;
uint64 shard_id = 2;
ValidatorRole role = 3;
uint64 assigned_slot = 4;
}
message PublicKey {
bytes public_key = 1;
}
message SlotResponsibilityResponse {
uint64 slot = 1;
ValidatorRole role = 2;
}
message IndexResponse {
uint32 index = 1;
}
message ShardIDResponse {
uint64 shard_id = 1;
}
message CurrentAssignmentsResponse {
repeated Assignment assignments = 1;
google.protobuf.Timestamp genesis_timestamp = 2;
}
message ValidatorEpochAssignmentsRequest {
uint64 epoch_start = 1;
PublicKey public_key = 2;
}
message ValidatorEpochAssignmentsResponse {
uint64 epoch_start = 1;
repeated Assignment assignments = 2;
}