95 lines
2.1 KiB
Go
95 lines
2.1 KiB
Go
|
// Copyright (c) HashiCorp, Inc.
|
||
|
// SPDX-License-Identifier: MPL-2.0
|
||
|
|
||
|
package command
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"strings"
|
||
|
"time"
|
||
|
|
||
|
"github.com/mitchellh/cli"
|
||
|
"github.com/posener/complete"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
_ cli.Command = (*OperatorMembersCommand)(nil)
|
||
|
_ cli.CommandAutocomplete = (*OperatorMembersCommand)(nil)
|
||
|
)
|
||
|
|
||
|
type OperatorMembersCommand struct {
|
||
|
*BaseCommand
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) Synopsis() string {
|
||
|
return "Returns the list of nodes in the cluster"
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) Help() string {
|
||
|
helpText := `
|
||
|
Usage: vault operator members
|
||
|
|
||
|
Provides the details of all the nodes in the cluster.
|
||
|
|
||
|
$ vault operator members
|
||
|
|
||
|
` + c.Flags().Help()
|
||
|
|
||
|
return strings.TrimSpace(helpText)
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) Flags() *FlagSets {
|
||
|
set := c.flagSet(FlagSetHTTP | FlagSetOutputFormat)
|
||
|
|
||
|
return set
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) AutocompleteArgs() complete.Predictor {
|
||
|
return complete.PredictAnything
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) AutocompleteFlags() complete.Flags {
|
||
|
return c.Flags().Completions()
|
||
|
}
|
||
|
|
||
|
func (c *OperatorMembersCommand) Run(args []string) int {
|
||
|
f := c.Flags()
|
||
|
|
||
|
if err := f.Parse(args); err != nil {
|
||
|
c.UI.Error(err.Error())
|
||
|
return 1
|
||
|
}
|
||
|
|
||
|
client, err := c.Client()
|
||
|
if err != nil {
|
||
|
c.UI.Error(err.Error())
|
||
|
return 2
|
||
|
}
|
||
|
|
||
|
resp, err := client.Sys().HAStatus()
|
||
|
if err != nil {
|
||
|
c.UI.Error(err.Error())
|
||
|
return 2
|
||
|
}
|
||
|
|
||
|
switch Format(c.UI) {
|
||
|
case "table":
|
||
|
out := make([]string, 0)
|
||
|
cols := []string{"Host Name", "API Address", "Cluster Address", "Active Node", "Version", "Upgrade Version", "Redundancy Zone", "Last Echo"}
|
||
|
out = append(out, strings.Join(cols, " | "))
|
||
|
for _, node := range resp.Nodes {
|
||
|
cols := []string{node.Hostname, node.APIAddress, node.ClusterAddress, fmt.Sprintf("%t", node.ActiveNode), node.Version, node.UpgradeVersion, node.RedundancyZone}
|
||
|
if node.LastEcho != nil {
|
||
|
cols = append(cols, node.LastEcho.Format(time.RFC3339))
|
||
|
} else {
|
||
|
cols = append(cols, "")
|
||
|
}
|
||
|
out = append(out, strings.Join(cols, " | "))
|
||
|
}
|
||
|
c.UI.Output(tableOutput(out, nil))
|
||
|
return 0
|
||
|
default:
|
||
|
return OutputData(c.UI, resp)
|
||
|
}
|
||
|
}
|