// 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.v1; import "google/protobuf/descriptor.proto"; import "proto/eth/ext/options.proto"; option csharp_namespace = "Ethereum.Eth.V1"; option go_package = "github.com/prysmaticlabs/prysm/proto/eth/v1"; option java_multiple_files = true; option java_outer_classname = "BeaconNodeProto"; option java_package = "org.ethereum.eth.v1"; option php_namespace = "Ethereum\\Eth\\v1"; message IdentityResponse { Identity data = 1; } message Identity { // The peer id of the node. string peer_id = 1; // The latest ENR of the node. string enr = 2; // All the p2p multiaddresses of the peer, specified as a full multiaddr. repeated string p2p_addresses = 3; // All the discv5 multiaddresses of the peer, specified as a full multiaddr. repeated string discovery_addresses = 4; // Additional metadata that the node would like to provide. Includes extra networking information. Metadata metadata = 5; } message Metadata { // Sequence number starts at 0 used to version the node's metadata. If any other field in the local MetaData changes, // the node MUST increment seq_number by 1. uint64 seq_number = 1; // Attnets is a bitvector representing the node's persistent attestation subnet subscriptions. bytes attnets = 2 [(ethereum.eth.ext.ssz_size) = "8", (ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/go-bitfield.Bitvector64"]; } message PeerRequest { // Peer id of the peer requested. string peer_id = 1; } message PeersRequest { // Requested peer states (available values: disconnected, connecting, connected, disconnecting). repeated ConnectionState state = 1; // Requested peer directions (available values: inbound, outbound). repeated PeerDirection direction = 2; } message PeerResponse { Peer data = 1; Meta meta = 2; message Meta { uint64 count = 1; } } message PeersResponse { repeated Peer data = 1; } message PeerCountResponse { PeerCount data = 1; message PeerCount { // The number of disconnected peers. uint64 disconnected = 1; // The number of connecting peers. uint64 connecting = 2; // The number of connected peers. uint64 connected = 3; // The number of disconnecting peers. uint64 disconnecting = 4; } } // Peer provides details of a peer on the network. message Peer { // The peer id of the peer. string peer_id = 1; // The latest ENR of the peer that's in the record. string enr = 2; // The address of the peer, as a full multiaddr, for example: // /ip4/37.221.192.134/tcp/13000/p2p/16Uiu2HAm8maLMjag1TAUM52zPfmLbVMGFdwUAWgoHu1HDQLR6e17 string last_seen_p2p_address = 3; // The connection state of the peer at the moment of the request. (e.g. Connecting) ConnectionState state = 4; // The direction of the connection (inbound/outbound). PeerDirection direction = 5; } // PeerDirection states the direction of the connection to a peer. enum PeerDirection { INBOUND = 0; OUTBOUND = 1; } // ConnectionState states the current status of the peer. enum ConnectionState { DISCONNECTED = 0; CONNECTING = 1; CONNECTED = 2; DISCONNECTING = 3; } message VersionResponse { Version data = 1; } // Information about the node version. message Version { // A string that uniquely identifies the node and its version. string version = 1; } message SyncingResponse { SyncInfo data = 1; } message SyncInfo { // A uint64 states the latest head slot of the current node. uint64 head_slot = 1 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/prysm/consensus-types/primitives.Slot"]; // A uint64 indicating how many slots are left for the beacon node sync to complete. uint64 sync_distance = 2 [(ethereum.eth.ext.cast_type) = "github.com/prysmaticlabs/prysm/consensus-types/primitives.Slot"]; // A bool indicating whether the node is currently syncing or not. bool is_syncing = 3; // A bool indicating whether the node is currently in optimistic mode. bool is_optimistic = 4; }