2021-07-28 18:05:07 +00:00
|
|
|
// Copyright 2021 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 "proto/eth/ext/options.proto";
|
|
|
|
import "proto/prysm/v1alpha1/beacon_block.proto";
|
|
|
|
|
|
|
|
import "google/api/annotations.proto";
|
|
|
|
|
|
|
|
option csharp_namespace = "Ethereum.Eth.V1alpha1";
|
|
|
|
option go_package = "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1;eth";
|
|
|
|
option java_multiple_files = true;
|
|
|
|
option java_outer_classname = "SlasherProto";
|
|
|
|
option java_package = "org.ethereum.eth.v1alpha1";
|
|
|
|
option php_namespace = "Ethereum\\Eth\\v1alpha1";
|
|
|
|
|
|
|
|
// Slasher service API
|
|
|
|
//
|
|
|
|
// Slasher service provides an interface for checking if attestations or blocks
|
|
|
|
// are slashable.
|
|
|
|
service Slasher {
|
|
|
|
// Returns any found attester slashings for an input indexed attestation.
|
|
|
|
rpc IsSlashableAttestation(ethereum.eth.v1alpha1.IndexedAttestation)
|
|
|
|
returns (AttesterSlashingResponse) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
post : "/eth/v1alpha1/slasher/attestations/slashable",
|
|
|
|
body : "*"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns any found proposer slashings for an input signed block header.
|
|
|
|
rpc IsSlashableBlock(ethereum.eth.v1alpha1.SignedBeaconBlockHeader)
|
|
|
|
returns (ProposerSlashingResponse) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
get : "/eth/v1alpha1/slasher/blocks/slashable"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the highest source and target attestation for validator indices
|
|
|
|
// that have been observed by slasher.
|
|
|
|
rpc HighestAttestations(HighestAttestationRequest)
|
|
|
|
returns (HighestAttestationResponse) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
get : "/eth/v1alpha1/slasher/attestations/highest"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
message AttesterSlashingResponse {
|
|
|
|
repeated ethereum.eth.v1alpha1.AttesterSlashing attester_slashings = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message ProposerSlashingResponse {
|
|
|
|
repeated ethereum.eth.v1alpha1.ProposerSlashing proposer_slashings = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message HighestAttestationRequest { repeated uint64 validator_indices = 1; }
|
|
|
|
|
|
|
|
message HighestAttestationResponse {
|
|
|
|
repeated HighestAttestation attestations = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message HighestAttestation {
|
|
|
|
uint64 validator_index = 1;
|
|
|
|
uint64 highest_source_epoch = 2
|
|
|
|
[ (ethereum.eth.ext.cast_type) =
|
2022-04-29 14:32:11 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/consensus-types/primitives.Epoch" ];
|
2021-07-28 18:05:07 +00:00
|
|
|
uint64 highest_target_epoch = 3
|
|
|
|
[ (ethereum.eth.ext.cast_type) =
|
2022-04-29 14:32:11 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/consensus-types/primitives.Epoch" ];
|
2021-07-28 18:05:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ProposalHistory defines the structure for recording a validator's historical
|
|
|
|
// proposals. Using a bitlist to represent the epochs and an uint64 to mark the
|
|
|
|
// latest marked epoch of the bitlist, we can easily store which epochs a
|
|
|
|
// validator has proposed a block for while pruning the older data.
|
|
|
|
message ProposalHistory {
|
|
|
|
bytes epoch_bits = 1 [
|
|
|
|
(ethereum.eth.ext.cast_type) =
|
|
|
|
"github.com/prysmaticlabs/go-bitfield.Bitlist",
|
|
|
|
deprecated = true
|
|
|
|
];
|
|
|
|
uint64 latest_epoch_written = 2 [
|
2022-04-29 14:32:11 +00:00
|
|
|
(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/prysm/consensus-types/primitives.Epoch",
|
2021-07-28 18:05:07 +00:00
|
|
|
deprecated = true
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
message Slashable { bool slashable = 1 [ deprecated = true ]; }
|
|
|
|
|
|
|
|
// AttestationHistory defines the structure for recording a validator's
|
|
|
|
// historical attestation. Using a map[uint64]uint64 to map its target epoch to
|
|
|
|
// its source epoch, in order to detect if a vote being created is not a double
|
|
|
|
// vote and surrounded by, or surrounding any other votes. Using an uint64 to
|
|
|
|
// mark the latest written epoch, we can safely perform a rolling prune whenever
|
|
|
|
// the history is updated.
|
|
|
|
message AttestationHistory {
|
|
|
|
map<uint64, uint64> target_to_source = 1 [ deprecated = true ];
|
|
|
|
uint64 latest_epoch_written = 2 [
|
2022-04-29 14:32:11 +00:00
|
|
|
(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/prysm/consensus-types/primitives.Epoch",
|
2021-07-28 18:05:07 +00:00
|
|
|
deprecated = true
|
|
|
|
];
|
|
|
|
}
|