package jsonrpc import ( "context" "errors" "fmt" "github.com/ledgerwatch/erigon-lib/gointerfaces/remote" "github.com/ledgerwatch/erigon/p2p" "github.com/ledgerwatch/erigon/turbo/rpchelper" ) // AdminAPI the interface for the admin_* RPC commands. type AdminAPI interface { // NodeInfo returns a collection of metadata known about the host. NodeInfo(ctx context.Context) (*p2p.NodeInfo, error) // Peers returns information about the connected remote nodes. // https://geth.ethereum.org/docs/rpc/ns-admin#admin_peers Peers(ctx context.Context) ([]*p2p.PeerInfo, error) // AddPeer requests connecting to a remote node. AddPeer(ctx context.Context, url string) (bool, error) } // AdminAPIImpl data structure to store things needed for admin_* commands. type AdminAPIImpl struct { ethBackend rpchelper.ApiBackend } // NewAdminAPI returns AdminAPIImpl instance. func NewAdminAPI(eth rpchelper.ApiBackend) *AdminAPIImpl { return &AdminAPIImpl{ ethBackend: eth, } } func (api *AdminAPIImpl) NodeInfo(ctx context.Context) (*p2p.NodeInfo, error) { nodes, err := api.ethBackend.NodeInfo(ctx, 1) if err != nil { return nil, fmt.Errorf("node info request error: %w", err) } if len(nodes) == 0 { return nil, errors.New("empty nodesInfo response") } return &nodes[0], nil } func (api *AdminAPIImpl) Peers(ctx context.Context) ([]*p2p.PeerInfo, error) { return api.ethBackend.Peers(ctx) } func (api *AdminAPIImpl) AddPeer(ctx context.Context, url string) (bool, error) { result, err := api.ethBackend.AddPeer(ctx, &remote.AddPeerRequest{Url: url}) if err != nil { return false, err } if result == nil { return false, errors.New("nil addPeer response") } return result.Success, nil }