Implement completion for "kops get"

This commit is contained in:
John Gardiner Myers 2021-07-13 20:42:07 -07:00
parent 14d58a4e87
commit c312c19dcb
14 changed files with 50 additions and 79 deletions

View File

@ -39,9 +39,6 @@ var (
Display one or many resources.` + validResources))
getExample = templates.Examples(i18n.T(`
# Get all clusters in a state store
kops get clusters
# Get a cluster and its instance groups
kops get k8s-cluster.example.com
@ -50,19 +47,14 @@ var (
# Save a cluster and its instancegroups' desired configuration to YAML file
kops get k8s-cluster.example.com -o yaml > cluster-desired-config.yaml
# Get a secret
kops get secrets kube -oplaintext
# Get the admin password for a cluster
kops get secrets admin -oplaintext`))
`))
getShort = i18n.T(`Get one or many resources.`)
)
type GetOptions struct {
output string
clusterName string
ClusterName string
Output string
}
const (
@ -73,7 +65,7 @@ const (
func NewCmdGet(f *util.Factory, out io.Writer) *cobra.Command {
options := &GetOptions{
output: OutputTable,
Output: OutputTable,
}
cmd := &cobra.Command{
@ -82,29 +74,17 @@ func NewCmdGet(f *util.Factory, out io.Writer) *cobra.Command {
Short: getShort,
Long: getLong,
Example: getExample,
Run: func(cmd *cobra.Command, args []string) {
ctx := context.TODO()
if len(args) != 0 {
options.clusterName = args[0]
}
if rootCommand.clusterName != "" {
if len(args) != 0 {
exitWithError(fmt.Errorf("cannot mix --name for cluster with positional arguments"))
}
options.clusterName = rootCommand.clusterName
}
err := RunGet(ctx, &rootCommand, os.Stdout, options)
if err != nil {
exitWithError(err)
}
Args: rootCommand.clusterNameArgs(&options.ClusterName),
ValidArgsFunction: commandutils.CompleteClusterName(&rootCommand, true),
RunE: func(cmd *cobra.Command, args []string) error {
return RunGet(context.TODO(), &rootCommand, out, options)
},
}
cmd.PersistentFlags().StringVarP(&options.output, "output", "o", options.output, "output format. One of: table, yaml, json")
cmd.PersistentFlags().StringVarP(&options.Output, "output", "o", options.Output, "output format. One of: table, yaml, json")
cmd.RegisterFlagCompletionFunc("output", func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
return []string{"table", "json", "yaml"}, cobra.ShellCompDirectiveNoFileComp
})
// create subcommands
cmd.AddCommand(NewCmdGetAssets(f, out, options))
@ -124,7 +104,7 @@ func RunGet(ctx context.Context, f commandutils.Factory, out io.Writer, options
return err
}
cluster, err := client.GetCluster(ctx, options.clusterName)
cluster, err := client.GetCluster(ctx, options.ClusterName)
if err != nil {
return err
}
@ -148,14 +128,14 @@ func RunGet(ctx context.Context, f commandutils.Factory, out io.Writer, options
}
var obj []runtime.Object
if options.output != OutputTable {
if options.Output != OutputTable {
obj = append(obj, cluster)
for _, group := range instancegroups {
obj = append(obj, group)
}
}
switch options.output {
switch options.Output {
case OutputYaml:
if err := fullOutputYAML(out, obj...); err != nil {
return fmt.Errorf("error writing cluster yaml to stdout: %v", err)
@ -170,19 +150,19 @@ func RunGet(ctx context.Context, f commandutils.Factory, out io.Writer, options
return nil
case OutputTable:
fmt.Fprintf(os.Stdout, "Cluster\n")
fmt.Fprintf(out, "Cluster\n")
err = clusterOutputTable([]*api.Cluster{cluster}, out)
if err != nil {
return err
}
fmt.Fprintf(os.Stdout, "\nInstance Groups\n")
fmt.Fprintf(out, "\nInstance Groups\n")
err = igOutputTable(cluster, instancegroups, out)
if err != nil {
return err
}
default:
return fmt.Errorf("Unknown output format: %q", options.output)
return fmt.Errorf("Unknown output format: %q", options.Output)
}
return nil

View File

@ -99,7 +99,7 @@ func NewCmdGetAssets(f *util.Factory, out io.Writer, getOptions *GetOptions) *co
func RunGetAssets(ctx context.Context, f *util.Factory, out io.Writer, options *GetAssetsOptions) error {
clusterName := rootCommand.ClusterName(true)
options.clusterName = clusterName
options.ClusterName = clusterName
if clusterName == "" {
return fmt.Errorf("--name is required")
}
@ -150,7 +150,7 @@ func RunGetAssets(ctx context.Context, f *util.Factory, out io.Writer, options *
}
}
switch options.output {
switch options.Output {
case OutputTable:
if err = imageOutputTable(result.Images, out); err != nil {
return err
@ -173,7 +173,7 @@ func RunGetAssets(ctx context.Context, f *util.Factory, out io.Writer, options *
return fmt.Errorf("error writing to output: %v", err)
}
default:
return fmt.Errorf("unsupported output format: %q", options.output)
return fmt.Errorf("unsupported output format: %q", options.Output)
}
return nil

View File

@ -168,13 +168,13 @@ func RunGetClusters(ctx context.Context, f commandutils.Factory, out io.Writer,
}
var obj []runtime.Object
if options.output != OutputTable {
if options.Output != OutputTable {
for _, c := range clusters {
obj = append(obj, c)
}
}
switch options.output {
switch options.Output {
case OutputTable:
return clusterOutputTable(clusters, out)
case OutputYaml:
@ -182,7 +182,7 @@ func RunGetClusters(ctx context.Context, f commandutils.Factory, out io.Writer,
case OutputJSON:
return fullOutputJSON(out, obj...)
default:
return fmt.Errorf("Unknown output format: %q", options.output)
return fmt.Errorf("Unknown output format: %q", options.Output)
}
}

View File

@ -116,13 +116,13 @@ func RunGetInstanceGroups(ctx context.Context, options *GetInstanceGroupsOptions
}
var obj []runtime.Object
if options.output != OutputTable {
if options.Output != OutputTable {
for _, c := range instancegroups {
obj = append(obj, c)
}
}
switch options.output {
switch options.Output {
case OutputTable:
return igOutputTable(cluster, instancegroups, out)
case OutputYaml:
@ -130,7 +130,7 @@ func RunGetInstanceGroups(ctx context.Context, options *GetInstanceGroupsOptions
case OutputJSON:
return fullOutputJSON(out, obj...)
default:
return fmt.Errorf("Unknown output format: %q", options.output)
return fmt.Errorf("Unknown output format: %q", options.Output)
}
}

View File

@ -84,18 +84,18 @@ func RunGetInstances(ctx context.Context, f *util.Factory, out io.Writer, option
}
clusterName := rootCommand.ClusterName(true)
options.clusterName = clusterName
options.ClusterName = clusterName
if clusterName == "" {
return fmt.Errorf("--name is required")
}
cluster, err := clientset.GetCluster(ctx, options.clusterName)
cluster, err := clientset.GetCluster(ctx, options.ClusterName)
if err != nil {
return err
}
if cluster == nil {
return fmt.Errorf("cluster not found %q", options.clusterName)
return fmt.Errorf("cluster not found %q", options.ClusterName)
}
cloud, err := cloudup.BuildCloud(cluster)
@ -137,11 +137,11 @@ func RunGetInstances(ctx context.Context, f *util.Factory, out io.Writer, option
cg.AdjustNeedUpdate()
}
switch options.output {
switch options.Output {
case OutputTable:
return instanceOutputTable(cloudInstances, out)
default:
return fmt.Errorf("unsupported output format: %q", options.output)
return fmt.Errorf("unsupported output format: %q", options.Output)
}
}

View File

@ -144,7 +144,7 @@ func RunGetKeypairs(ctx context.Context, out io.Writer, options *GetKeypairsOpti
if len(items) == 0 {
return fmt.Errorf("no keypairs found")
}
switch options.output {
switch options.Output {
case OutputTable:
t := &tables.Table{}
@ -191,7 +191,7 @@ func RunGetKeypairs(ctx context.Context, out io.Writer, options *GetKeypairsOpti
return fmt.Errorf("json output format is not (currently) supported for keypairs")
default:
return fmt.Errorf("Unknown output format: %q", options.output)
return fmt.Errorf("Unknown output format: %q", options.Output)
}
}

View File

@ -193,7 +193,7 @@ func RunGetSecrets(ctx context.Context, options *GetSecretsOptions, args []strin
if len(items) == 0 {
return fmt.Errorf("No secrets found")
}
switch options.output {
switch options.Output {
case OutputTable:
@ -239,6 +239,6 @@ func RunGetSecrets(ctx context.Context, options *GetSecretsOptions, args []strin
return nil
default:
return fmt.Errorf("Unknown output format: %q", options.output)
return fmt.Errorf("Unknown output format: %q", options.Output)
}
}

9
docs/cli/kops_get.md generated
View File

@ -20,9 +20,6 @@ kops get [flags]
### Examples
```
# Get all clusters in a state store
kops get clusters
# Get a cluster and its instance groups
kops get k8s-cluster.example.com
@ -31,12 +28,6 @@ kops get [flags]
# Save a cluster and its instancegroups' desired configuration to YAML file
kops get k8s-cluster.example.com -o yaml > cluster-desired-config.yaml
# Get a secret
kops get secrets kube -oplaintext
# Get the admin password for a cluster
kops get secrets admin -oplaintext
```
### Options