2015-09-11 19:58:16 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/hashicorp/nomad/api"
|
|
|
|
"github.com/ryanuber/columnize"
|
|
|
|
)
|
|
|
|
|
|
|
|
type AgentMembersCommand struct {
|
2015-09-14 20:13:52 +00:00
|
|
|
Meta
|
2015-09-11 19:58:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *AgentMembersCommand) Help() string {
|
|
|
|
helpText := `
|
|
|
|
Usage: nomad agent-members [options]
|
|
|
|
|
2015-09-13 18:39:49 +00:00
|
|
|
Display a list of the known members and their status.
|
2015-09-11 19:58:16 +00:00
|
|
|
|
2015-09-14 20:13:52 +00:00
|
|
|
General Options:
|
|
|
|
|
|
|
|
` + generalOptionsUsage() + `
|
|
|
|
|
|
|
|
Agent Members Options:
|
2015-09-11 19:58:16 +00:00
|
|
|
|
|
|
|
-detailed
|
|
|
|
Show detailed information about each member. This dumps
|
|
|
|
a raw set of tags which shows more information than the
|
|
|
|
default output format.
|
|
|
|
`
|
|
|
|
return strings.TrimSpace(helpText)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *AgentMembersCommand) Synopsis() string {
|
2015-09-13 18:39:49 +00:00
|
|
|
return "Display a list of known members and their status"
|
2015-09-11 19:58:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *AgentMembersCommand) Run(args []string) int {
|
|
|
|
var detailed bool
|
|
|
|
|
2015-09-14 20:13:52 +00:00
|
|
|
flags := c.Meta.FlagSet("agent-members", FlagSetClient)
|
2015-09-11 19:58:16 +00:00
|
|
|
flags.Usage = func() { c.Ui.Output(c.Help()) }
|
|
|
|
flags.BoolVar(&detailed, "detailed", false, "Show detailed output")
|
|
|
|
|
|
|
|
if err := flags.Parse(args); err != nil {
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check for extra arguments
|
2015-09-14 20:13:52 +00:00
|
|
|
args = flags.Args()
|
|
|
|
if len(args) != 0 {
|
2015-09-11 19:58:16 +00:00
|
|
|
c.Ui.Error(c.Help())
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the HTTP client
|
2015-09-14 20:13:52 +00:00
|
|
|
client, err := c.Meta.Client()
|
2015-09-11 19:58:16 +00:00
|
|
|
if err != nil {
|
2015-09-14 20:13:52 +00:00
|
|
|
c.Ui.Error(fmt.Sprintf("Error initializing client: %s", err))
|
2015-09-11 19:58:16 +00:00
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Query the members
|
|
|
|
mem, err := client.Agent().Members()
|
|
|
|
if err != nil {
|
2015-09-14 20:13:52 +00:00
|
|
|
c.Ui.Error(fmt.Sprintf("Error querying members: %s", err))
|
2015-09-11 19:58:16 +00:00
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Format the list
|
|
|
|
var out []string
|
|
|
|
if detailed {
|
|
|
|
out = detailedOutput(mem)
|
|
|
|
} else {
|
|
|
|
out = standardOutput(mem)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dump the list
|
|
|
|
c.Ui.Output(columnize.SimpleFormat(out))
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func standardOutput(mem []*api.AgentMember) []string {
|
|
|
|
// Format the members list
|
|
|
|
members := make([]string, len(mem)+1)
|
|
|
|
members[0] = "Name|Addr|Port|Status|Proto|Build|DC|Region"
|
|
|
|
for i, member := range mem {
|
2015-09-13 18:39:49 +00:00
|
|
|
members[i+1] = fmt.Sprintf("%s|%s|%d|%s|%d|%s|%s|%s",
|
2015-09-11 19:58:16 +00:00
|
|
|
member.Name,
|
|
|
|
member.Addr,
|
|
|
|
member.Port,
|
|
|
|
member.Status,
|
|
|
|
member.ProtocolCur,
|
|
|
|
member.Tags["build"],
|
|
|
|
member.Tags["dc"],
|
2015-09-13 18:39:49 +00:00
|
|
|
member.Tags["region"])
|
2015-09-11 19:58:16 +00:00
|
|
|
}
|
|
|
|
return members
|
|
|
|
}
|
|
|
|
|
|
|
|
func detailedOutput(mem []*api.AgentMember) []string {
|
|
|
|
// Format the members list
|
|
|
|
members := make([]string, len(mem)+1)
|
|
|
|
members[0] = "Name|Addr|Port|Tags"
|
|
|
|
for i, member := range mem {
|
|
|
|
// Format the tags
|
|
|
|
tagPairs := make([]string, 0, len(member.Tags))
|
|
|
|
for k, v := range member.Tags {
|
|
|
|
tagPairs = append(tagPairs, fmt.Sprintf("%s=%s", k, v))
|
|
|
|
}
|
|
|
|
tags := strings.Join(tagPairs, ",")
|
|
|
|
|
2015-09-13 18:39:49 +00:00
|
|
|
members[i+1] = fmt.Sprintf("%s|%s|%d|%s",
|
2015-09-11 19:58:16 +00:00
|
|
|
member.Name,
|
|
|
|
member.Addr,
|
|
|
|
member.Port,
|
2015-09-13 18:39:49 +00:00
|
|
|
tags)
|
2015-09-11 19:58:16 +00:00
|
|
|
}
|
|
|
|
return members
|
|
|
|
}
|