2018-07-13 17:35:08 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"sort"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/hashicorp/vault/api"
|
2018-11-07 01:21:24 +00:00
|
|
|
"github.com/hashicorp/vault/helper/consts"
|
2018-07-13 17:35:08 +00:00
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
"github.com/posener/complete"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ cli.Command = (*PluginListCommand)(nil)
|
|
|
|
var _ cli.CommandAutocomplete = (*PluginListCommand)(nil)
|
|
|
|
|
|
|
|
type PluginListCommand struct {
|
|
|
|
*BaseCommand
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) Synopsis() string {
|
|
|
|
return "Lists available plugins"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) Help() string {
|
|
|
|
helpText := `
|
2018-11-07 01:21:24 +00:00
|
|
|
Usage: vault plugin list [options] [TYPE]
|
2018-07-13 17:35:08 +00:00
|
|
|
|
|
|
|
Lists available plugins registered in the catalog. This does not list whether
|
2018-11-07 01:21:24 +00:00
|
|
|
plugins are in use, but rather just their availability. The last argument of
|
|
|
|
type takes "auth", "database", or "secret".
|
2018-07-13 17:35:08 +00:00
|
|
|
|
|
|
|
List all available plugins in the catalog:
|
|
|
|
|
|
|
|
$ vault plugin list
|
|
|
|
|
2018-11-07 01:21:24 +00:00
|
|
|
List all available database plugins in the catalog:
|
|
|
|
|
|
|
|
$ vault plugin list database
|
|
|
|
|
2018-07-13 17:35:08 +00:00
|
|
|
` + c.Flags().Help()
|
|
|
|
|
|
|
|
return strings.TrimSpace(helpText)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) Flags() *FlagSets {
|
|
|
|
return c.flagSet(FlagSetHTTP | FlagSetOutputFormat)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) AutocompleteArgs() complete.Predictor {
|
|
|
|
return complete.PredictNothing
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) AutocompleteFlags() complete.Flags {
|
|
|
|
return c.Flags().Completions()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *PluginListCommand) Run(args []string) int {
|
|
|
|
f := c.Flags()
|
|
|
|
|
|
|
|
if err := f.Parse(args); err != nil {
|
|
|
|
c.UI.Error(err.Error())
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
args = f.Args()
|
2018-11-07 01:21:24 +00:00
|
|
|
switch {
|
|
|
|
case len(args) > 1:
|
|
|
|
c.UI.Error(fmt.Sprintf("Too many arguments (expected 0 or 1, got %d)", len(args)))
|
2018-07-13 17:35:08 +00:00
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2018-11-07 01:21:24 +00:00
|
|
|
pluginType := consts.PluginTypeUnknown
|
|
|
|
if len(args) > 0 {
|
|
|
|
pluginTypeStr := strings.TrimSpace(args[0])
|
|
|
|
if pluginTypeStr != "" {
|
|
|
|
var err error
|
|
|
|
pluginType, err = consts.ParsePluginType(pluginTypeStr)
|
|
|
|
if err != nil {
|
|
|
|
c.UI.Error(fmt.Sprintf("Error parsing type: %s", err))
|
|
|
|
return 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-13 17:35:08 +00:00
|
|
|
client, err := c.Client()
|
|
|
|
if err != nil {
|
|
|
|
c.UI.Error(err.Error())
|
|
|
|
return 2
|
|
|
|
}
|
|
|
|
|
2018-11-07 01:21:24 +00:00
|
|
|
resp, err := client.Sys().ListPlugins(&api.ListPluginsInput{
|
|
|
|
Type: pluginType,
|
|
|
|
})
|
2018-07-13 17:35:08 +00:00
|
|
|
if err != nil {
|
|
|
|
c.UI.Error(fmt.Sprintf("Error listing available plugins: %s", err))
|
|
|
|
return 2
|
|
|
|
}
|
|
|
|
|
|
|
|
switch Format(c.UI) {
|
|
|
|
case "table":
|
2018-11-07 01:21:24 +00:00
|
|
|
var flattenedNames []string
|
|
|
|
namesAdded := make(map[string]bool)
|
|
|
|
for _, names := range resp.PluginsByType {
|
|
|
|
for _, name := range names {
|
|
|
|
if ok := namesAdded[name]; !ok {
|
|
|
|
flattenedNames = append(flattenedNames, name)
|
|
|
|
namesAdded[name] = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
sort.Strings(flattenedNames)
|
|
|
|
}
|
|
|
|
list := append([]string{"Plugins"}, flattenedNames...)
|
2018-07-13 17:35:08 +00:00
|
|
|
c.UI.Output(tableOutput(list, nil))
|
|
|
|
return 0
|
|
|
|
default:
|
2018-11-07 01:21:24 +00:00
|
|
|
res := make(map[string]interface{})
|
|
|
|
for k, v := range resp.PluginsByType {
|
|
|
|
res[k.String()] = v
|
|
|
|
}
|
|
|
|
return OutputData(c.UI, res)
|
2018-07-13 17:35:08 +00:00
|
|
|
}
|
|
|
|
}
|