2019-11-12 17:01:27 +00:00
|
|
|
package node
|
2019-07-23 02:19:55 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2019-11-30 05:36:02 +00:00
|
|
|
"fmt"
|
2019-07-23 02:19:55 +00:00
|
|
|
"sort"
|
|
|
|
|
|
|
|
ptypes "github.com/gogo/protobuf/types"
|
2019-11-30 05:36:02 +00:00
|
|
|
"github.com/libp2p/go-libp2p-core/network"
|
2019-11-27 05:08:18 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
2019-09-16 20:45:03 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/blockchain"
|
2019-07-23 02:19:55 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/db"
|
2019-11-30 05:36:02 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p"
|
2019-08-21 20:58:38 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/sync"
|
2019-11-30 05:36:02 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/sync/peerstatus"
|
2019-07-23 02:19:55 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/version"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/codes"
|
|
|
|
"google.golang.org/grpc/status"
|
|
|
|
)
|
|
|
|
|
2019-11-12 17:01:27 +00:00
|
|
|
// Server defines a server implementation of the gRPC Node service,
|
2019-07-23 02:19:55 +00:00
|
|
|
// providing RPC endpoints for verifying a beacon node's sync status, genesis and
|
|
|
|
// version information, and services the node implements and runs.
|
2019-11-12 17:01:27 +00:00
|
|
|
type Server struct {
|
|
|
|
SyncChecker sync.Checker
|
|
|
|
Server *grpc.Server
|
|
|
|
BeaconDB db.Database
|
2019-11-30 05:36:02 +00:00
|
|
|
PeersFetcher p2p.PeersProvider
|
2019-11-12 17:01:27 +00:00
|
|
|
GenesisTimeFetcher blockchain.GenesisTimeFetcher
|
2019-07-23 02:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetSyncStatus checks the current network sync status of the node.
|
2019-11-12 17:01:27 +00:00
|
|
|
func (ns *Server) GetSyncStatus(ctx context.Context, _ *ptypes.Empty) (*ethpb.SyncStatus, error) {
|
2019-07-23 02:19:55 +00:00
|
|
|
return ðpb.SyncStatus{
|
2019-11-12 17:01:27 +00:00
|
|
|
Syncing: ns.SyncChecker.Syncing(),
|
2019-07-23 02:19:55 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetGenesis fetches genesis chain information of Ethereum 2.0.
|
2019-11-12 17:01:27 +00:00
|
|
|
func (ns *Server) GetGenesis(ctx context.Context, _ *ptypes.Empty) (*ethpb.Genesis, error) {
|
|
|
|
contractAddr, err := ns.BeaconDB.DepositContractAddress(ctx)
|
2019-09-16 20:45:03 +00:00
|
|
|
if err != nil {
|
2019-11-13 21:03:12 +00:00
|
|
|
return nil, status.Errorf(codes.Internal, "Could not retrieve contract address from db: %v", err)
|
2019-09-16 20:45:03 +00:00
|
|
|
}
|
2019-11-12 17:01:27 +00:00
|
|
|
genesisTime := ns.GenesisTimeFetcher.GenesisTime()
|
2019-09-16 20:45:03 +00:00
|
|
|
gt, err := ptypes.TimestampProto(genesisTime)
|
|
|
|
if err != nil {
|
2019-11-13 21:03:12 +00:00
|
|
|
return nil, status.Errorf(codes.Internal, "Could not convert genesis time to proto: %v", err)
|
2019-09-16 20:45:03 +00:00
|
|
|
}
|
|
|
|
return ðpb.Genesis{
|
|
|
|
GenesisTime: gt,
|
|
|
|
DepositContractAddress: contractAddr,
|
|
|
|
}, nil
|
2019-07-23 02:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetVersion checks the version information of the beacon node.
|
2019-11-12 17:01:27 +00:00
|
|
|
func (ns *Server) GetVersion(ctx context.Context, _ *ptypes.Empty) (*ethpb.Version, error) {
|
2019-07-23 02:19:55 +00:00
|
|
|
return ðpb.Version{
|
|
|
|
Version: version.GetVersion(),
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListImplementedServices lists the services implemented and enabled by this node.
|
|
|
|
//
|
|
|
|
// Any service not present in this list may return UNIMPLEMENTED or
|
|
|
|
// PERMISSION_DENIED. The server may also support fetching services by grpc
|
|
|
|
// reflection.
|
2019-11-12 17:01:27 +00:00
|
|
|
func (ns *Server) ListImplementedServices(ctx context.Context, _ *ptypes.Empty) (*ethpb.ImplementedServices, error) {
|
|
|
|
serviceInfo := ns.Server.GetServiceInfo()
|
2019-07-23 02:19:55 +00:00
|
|
|
serviceNames := make([]string, 0, len(serviceInfo))
|
|
|
|
for svc := range serviceInfo {
|
|
|
|
serviceNames = append(serviceNames, svc)
|
|
|
|
}
|
|
|
|
sort.Strings(serviceNames)
|
|
|
|
return ðpb.ImplementedServices{
|
|
|
|
Services: serviceNames,
|
|
|
|
}, nil
|
|
|
|
}
|
2019-11-29 16:44:51 +00:00
|
|
|
|
2019-11-30 05:36:02 +00:00
|
|
|
// ListPeers lists the peers connected to this node.
|
2019-11-29 16:44:51 +00:00
|
|
|
func (ns *Server) ListPeers(ctx context.Context, _ *ptypes.Empty) (*ethpb.Peers, error) {
|
2019-11-30 05:36:02 +00:00
|
|
|
peers := make([]*ethpb.Peer, 0)
|
|
|
|
for _, peer := range ns.PeersFetcher.Peers() {
|
|
|
|
peerStatus := peerstatus.Get(peer.AddrInfo.ID)
|
|
|
|
if peerStatus != nil {
|
|
|
|
address := fmt.Sprintf("%s/p2p/%s", peer.AddrInfo.Addrs[0].String(), peer.AddrInfo.ID.Pretty())
|
|
|
|
direction := ethpb.PeerDirection_UNKNOWN
|
|
|
|
switch peer.Direction {
|
|
|
|
case network.DirInbound:
|
|
|
|
direction = ethpb.PeerDirection_INBOUND
|
|
|
|
case network.DirOutbound:
|
|
|
|
direction = ethpb.PeerDirection_OUTBOUND
|
|
|
|
}
|
|
|
|
peers = append(peers, ðpb.Peer{
|
|
|
|
Address: address,
|
|
|
|
Direction: direction,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ðpb.Peers{
|
|
|
|
Peers: peers,
|
|
|
|
}, nil
|
2019-11-29 16:44:51 +00:00
|
|
|
}
|