package core
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
|
)
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
func NetInfo() (*ctypes.ResultNetInfo, error) {
|
|
listening := p2pSwitch.IsListening()
|
|
listeners := []string{}
|
|
for _, listener := range p2pSwitch.Listeners() {
|
|
listeners = append(listeners, listener.String())
|
|
}
|
|
peers := []ctypes.Peer{}
|
|
for _, peer := range p2pSwitch.Peers().List() {
|
|
peers = append(peers, ctypes.Peer{
|
|
NodeInfo: *peer.NodeInfo,
|
|
IsOutbound: peer.IsOutbound(),
|
|
ConnectionStatus: peer.Connection().Status(),
|
|
})
|
|
}
|
|
return &ctypes.ResultNetInfo{
|
|
Listening: listening,
|
|
Listeners: listeners,
|
|
Peers: peers,
|
|
}, nil
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Dial given list of seeds if we have no outbound peers
|
|
func DialSeeds(seeds []string) (*ctypes.ResultDialSeeds, error) {
|
|
outbound, _, _ := p2pSwitch.NumPeers()
|
|
if outbound != 0 {
|
|
return nil, fmt.Errorf("Already have some outbound peers")
|
|
}
|
|
// starts go routines to dial each seed after random delays
|
|
p2pSwitch.DialSeeds(seeds)
|
|
return &ctypes.ResultDialSeeds{}, nil
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
func Genesis() (*ctypes.ResultGenesis, error) {
|
|
return &ctypes.ResultGenesis{genDoc}, nil
|
|
}
|