command/ls/members/members.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package members
import (
"bytes"
"flag"
"fmt"
"os"
"strings"
"text/tabwriter"
"git.j3s.sh/cascade/api"
)
const usage = `cascade ls members [options]
this command lists the members of the cascade serf
cluster.
options:
-api
address of the api to target (default = 127.0.0.1:8500)
-l | -details
show more details (default = nil)
`
type Flags struct {
apiAddr string
details bool
}
var membersFlags Flags
func Run(args []string) {
flags := flag.NewFlagSet("agent", flag.ContinueOnError)
flags.Usage = func() { fmt.Printf(usage) }
flags.StringVar(&membersFlags.apiAddr, "api", "", "")
flags.BoolVar(&membersFlags.details, "l", false, "")
flags.BoolVar(&membersFlags.details, "details", false, "")
flags.Parse(args)
cfg := api.DefaultNonPooledConfig()
client, err := api.NewClient(cfg)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
members, err := client.Agent().Members()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
var b bytes.Buffer
tw := tabwriter.NewWriter(&b, 0, 2, 2, ' ', 0)
if membersFlags.details {
fmt.Fprintf(tw, "node\taddr\tstatus\ttags\n")
}
for _, m := range members {
if membersFlags.details {
fmt.Fprintf(tw, "%s\t%s:%d\t%s\t%v\n", m.Name, m.Addr, m.Port, m.StatusPretty(), printTags(m.Tags))
}
if !membersFlags.details {
fmt.Fprintf(tw, "%s\n", m.Name)
}
}
if err := tw.Flush(); err != nil {
fmt.Printf("error flushing tabwriter: %s", err)
os.Exit(1)
}
fmt.Print(b.String())
}
func printTags(tags map[string]string) string {
var results []string
for k, v := range tags {
results = append(results, fmt.Sprintf("%s=%s", k, v))
}
return strings.Join(results, ",")
}