2021-06-02 15:20:11 -05:00
|
|
|
// 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";
|
|
|
|
|
2021-08-13 12:55:24 +02:00
|
|
|
package ethereum.eth.service;
|
2021-06-02 15:20:11 -05:00
|
|
|
|
|
|
|
import "google/api/annotations.proto";
|
|
|
|
import "google/protobuf/descriptor.proto";
|
|
|
|
import "google/protobuf/empty.proto";
|
|
|
|
|
2021-08-13 11:12:18 +02:00
|
|
|
import "proto/eth/v1/beacon_chain.proto";
|
2021-08-14 18:41:03 +02:00
|
|
|
import "proto/eth/v2/beacon_state.proto";
|
2022-05-13 22:29:18 +02:00
|
|
|
import "proto/eth/v2/ssz.proto";
|
2021-06-02 15:20:11 -05:00
|
|
|
|
2021-08-13 12:55:24 +02:00
|
|
|
option csharp_namespace = "Ethereum.Eth.Service";
|
2023-03-17 11:52:56 -07:00
|
|
|
option go_package = "github.com/prysmaticlabs/prysm/v4/proto/eth/service";
|
2021-06-02 15:20:11 -05:00
|
|
|
option java_multiple_files = true;
|
2021-08-13 19:59:55 +02:00
|
|
|
option java_outer_classname = "BeaconDebugServiceProto";
|
2021-08-13 12:55:24 +02:00
|
|
|
option java_package = "org.ethereum.eth.service";
|
|
|
|
option php_namespace = "Ethereum\\Eth\\Service";
|
2021-06-02 15:20:11 -05:00
|
|
|
|
|
|
|
// Beacon chain debug API
|
|
|
|
//
|
|
|
|
// The beacon chain debug API is a set of endpoints to debug chain and shouldn't be exposed publicly.
|
|
|
|
//
|
2021-08-19 13:00:57 -05:00
|
|
|
// This service is defined in the upstream Ethereum consensus APIs repository (beacon-apis/apis/debug).
|
2021-06-02 15:20:11 -05:00
|
|
|
service BeaconDebug {
|
2021-06-15 17:28:49 +02:00
|
|
|
// GetBeaconStateSSZ returns the SSZ-serialized version of the full BeaconState object for given stateId.
|
2022-06-21 16:29:44 +02:00
|
|
|
//
|
|
|
|
// Spec: https://ethereum.github.io/beacon-APIs/?urls.primaryName=v2.3.0#/Debug/getState
|
2022-05-13 22:29:18 +02:00
|
|
|
rpc GetBeaconStateSSZ(v1.StateRequest) returns (v2.SSZContainer) {
|
2021-06-02 15:20:11 -05:00
|
|
|
option (google.api.http) = {
|
2021-09-21 21:20:57 +02:00
|
|
|
get: "/internal/eth/v1/debug/beacon/states/{state_id}/ssz"
|
2021-06-02 15:20:11 -05:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-08-18 17:50:37 +02:00
|
|
|
// GetBeaconStateV2 returns full BeaconState object for given stateId.
|
2022-06-21 16:29:44 +02:00
|
|
|
//
|
|
|
|
// Spec: https://ethereum.github.io/beacon-APIs/?urls.primaryName=v2.3.0#/Debug/getStateV2
|
2022-08-17 03:35:27 +02:00
|
|
|
rpc GetBeaconStateV2(v2.BeaconStateRequestV2) returns (v2.BeaconStateResponseV2) {
|
2021-08-14 18:41:03 +02:00
|
|
|
option (google.api.http) = {
|
2021-09-21 21:20:57 +02:00
|
|
|
get: "/internal/eth/v2/debug/beacon/states/{state_id}"
|
2021-08-14 18:41:03 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-08-18 17:50:37 +02:00
|
|
|
// GetBeaconStateSSZV2 returns the SSZ-serialized version of the full BeaconState object for given stateId.
|
2022-06-21 16:29:44 +02:00
|
|
|
//
|
|
|
|
// Spec: https://ethereum.github.io/beacon-APIs/?urls.primaryName=v2.3.0#/Debug/getStateV2
|
2022-08-17 03:35:27 +02:00
|
|
|
rpc GetBeaconStateSSZV2(v2.BeaconStateRequestV2) returns (v2.SSZContainer) {
|
2021-08-14 18:41:03 +02:00
|
|
|
option (google.api.http) = {
|
2021-09-21 21:20:57 +02:00
|
|
|
get: "/internal/eth/v2/debug/beacon/states/{state_id}/ssz"
|
2021-08-14 18:41:03 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-03-24 14:08:40 +01:00
|
|
|
// ListForkChoiceHeadsV2 retrieves all possible chain heads (leaves of fork choice tree).
|
2022-06-21 16:29:44 +02:00
|
|
|
//
|
|
|
|
// Spec: https://ethereum.github.io/beacon-APIs/?urls.primaryName=v2.3.0#/Debug/getDebugChainHeadsV2
|
2022-03-24 14:08:40 +01:00
|
|
|
rpc ListForkChoiceHeadsV2(google.protobuf.Empty) returns (v2.ForkChoiceHeadsResponse) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
get: "/internal/eth/v2/debug/beacon/heads"
|
|
|
|
};
|
|
|
|
}
|
2022-08-26 16:54:32 +02:00
|
|
|
|
|
|
|
// GetForkChoice returns a dump fork choice store.
|
|
|
|
//
|
|
|
|
// This function is not a part of the official Beacon APIs.
|
2022-11-28 20:17:53 +01:00
|
|
|
rpc GetForkChoice(google.protobuf.Empty) returns (v1.ForkChoiceDump) {
|
2022-08-26 16:54:32 +02:00
|
|
|
option (google.api.http) = {
|
2023-02-17 10:45:25 -03:00
|
|
|
get: "/internal/eth/v1/debug/fork_choice"
|
2022-08-26 16:54:32 +02:00
|
|
|
};
|
|
|
|
}
|
2023-02-17 10:45:25 -03:00
|
|
|
}
|