2019-07-23 02:19:55 +00:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"sort"
|
|
|
|
|
|
|
|
ptypes "github.com/gogo/protobuf/types"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/db"
|
2019-08-21 20:58:38 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/sync"
|
2019-07-23 02:19:55 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/version"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/codes"
|
|
|
|
"google.golang.org/grpc/status"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NodeServer defines a server implementation of the gRPC Node service,
|
|
|
|
// providing RPC endpoints for verifying a beacon node's sync status, genesis and
|
|
|
|
// version information, and services the node implements and runs.
|
|
|
|
type NodeServer struct {
|
|
|
|
syncChecker sync.Checker
|
|
|
|
server *grpc.Server
|
2019-08-21 16:04:00 +00:00
|
|
|
beaconDB db.Database
|
2019-07-23 02:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetSyncStatus checks the current network sync status of the node.
|
|
|
|
func (ns *NodeServer) GetSyncStatus(ctx context.Context, _ *ptypes.Empty) (*ethpb.SyncStatus, error) {
|
|
|
|
return ðpb.SyncStatus{
|
|
|
|
Syncing: ns.syncChecker.Syncing(),
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetGenesis fetches genesis chain information of Ethereum 2.0.
|
|
|
|
func (ns *NodeServer) GetGenesis(ctx context.Context, _ *ptypes.Empty) (*ethpb.Genesis, error) {
|
2019-08-23 01:39:06 +00:00
|
|
|
// TODO(3045): Use the getter from the blockchain service.
|
|
|
|
return nil, status.Error(codes.Unimplemented, "not implemented")
|
2019-07-23 02:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetVersion checks the version information of the beacon node.
|
|
|
|
func (ns *NodeServer) GetVersion(ctx context.Context, _ *ptypes.Empty) (*ethpb.Version, error) {
|
|
|
|
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.
|
|
|
|
func (ns *NodeServer) ListImplementedServices(ctx context.Context, _ *ptypes.Empty) (*ethpb.ImplementedServices, error) {
|
|
|
|
serviceInfo := ns.server.GetServiceInfo()
|
|
|
|
serviceNames := make([]string, 0, len(serviceInfo))
|
|
|
|
for svc := range serviceInfo {
|
|
|
|
serviceNames = append(serviceNames, svc)
|
|
|
|
}
|
|
|
|
sort.Strings(serviceNames)
|
|
|
|
return ðpb.ImplementedServices{
|
|
|
|
Services: serviceNames,
|
|
|
|
}, nil
|
|
|
|
}
|