2019-06-21 14:53:50 -04:00
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"github.com/jroimartin/gocui"
|
|
|
|
|
"log"
|
2019-06-21 15:10:06 -04:00
|
|
|
|
"strings"
|
2019-06-21 14:53:50 -04:00
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func FetchPeers(c *client, g *gocui.Gui) {
|
|
|
|
|
for {
|
|
|
|
|
select {
|
|
|
|
|
case <-threadDone:
|
|
|
|
|
return
|
|
|
|
|
default:
|
|
|
|
|
peers, err := c.getPeers()
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Panicln(err)
|
|
|
|
|
}
|
|
|
|
|
WritePeers(g, peers)
|
|
|
|
|
}
|
|
|
|
|
<-time.After(interval * time.Second)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func WritePeers(g *gocui.Gui, peers []Peer) {
|
|
|
|
|
g.Update(func(g *gocui.Gui) error {
|
|
|
|
|
v, err := g.View("main")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
v.Clear()
|
|
|
|
|
maxWidth, _ := g.Size()
|
|
|
|
|
for _, peer := range peers {
|
|
|
|
|
fmt.Fprintf(v, "%s\n", peer.AsTable(maxWidth))
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
})
|
|
|
|
|
}
|
2019-06-21 15:10:06 -04:00
|
|
|
|
|
2019-06-21 16:47:37 -04:00
|
|
|
|
func boolToString(v bool, yes string, no string) string {
|
|
|
|
|
if v {
|
|
|
|
|
return yes
|
|
|
|
|
} else {
|
|
|
|
|
return no
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-21 15:10:06 -04:00
|
|
|
|
func (p Peer) AsTable(maxWidth int) string {
|
|
|
|
|
var id string
|
2019-06-21 16:47:37 -04:00
|
|
|
|
if maxWidth > 160 {
|
2019-06-21 15:10:06 -04:00
|
|
|
|
id = string(p.Id)
|
|
|
|
|
} else {
|
|
|
|
|
id = p.Id.String()
|
|
|
|
|
}
|
2019-06-21 16:47:37 -04:00
|
|
|
|
return fmt.Sprintf("%s| %-15s| %-21s| %-7s| %-8s| %s",
|
|
|
|
|
id, p.Name,
|
|
|
|
|
p.Network.RemoteAddress,
|
|
|
|
|
boolToString(p.Network.Trusted, "trusted", "normal"),
|
|
|
|
|
boolToString(p.Network.Static, "static", "dynamic"),
|
|
|
|
|
strings.Join(p.Caps, ", "))
|
2019-06-21 15:10:06 -04:00
|
|
|
|
}
|