2021-08-13 09:12:18 +00:00
|
|
|
// Copyright 2021 Prysmatic Labs.
|
2021-06-02 20:20:11 +00:00
|
|
|
//
|
|
|
|
// 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";
|
|
|
|
|
2021-08-13 09:12:18 +00:00
|
|
|
option csharp_namespace = "Ethereum.Eth.V1";
|
2023-03-17 18:52:56 +00:00
|
|
|
option go_package = "github.com/prysmaticlabs/prysm/v4/proto/eth/v1";
|
2021-06-02 20:20:11 +00:00
|
|
|
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;
|
|
|
|
}
|