mirror of https://github.com/docker/cli.git
Annotate "stack" commands to be "swarm" and "kubernetes"
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
f2529443a0
commit
93c36eb228
|
@ -9,11 +9,15 @@ import (
|
||||||
// NewStackCommand returns a cobra command for `stack` subcommands
|
// NewStackCommand returns a cobra command for `stack` subcommands
|
||||||
func NewStackCommand(dockerCli command.Cli) *cobra.Command {
|
func NewStackCommand(dockerCli command.Cli) *cobra.Command {
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "stack",
|
Use: "stack",
|
||||||
Short: "Manage Docker stacks",
|
Short: "Manage Docker stacks",
|
||||||
Args: cli.NoArgs,
|
Args: cli.NoArgs,
|
||||||
RunE: command.ShowHelp(dockerCli.Err()),
|
RunE: command.ShowHelp(dockerCli.Err()),
|
||||||
Annotations: map[string]string{"version": "1.25"},
|
Annotations: map[string]string{
|
||||||
|
"kubernetes": "",
|
||||||
|
"swarm": "",
|
||||||
|
"version": "1.25",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
cmd.AddCommand(
|
cmd.AddCommand(
|
||||||
newDeployCommand(dockerCli),
|
newDeployCommand(dockerCli),
|
||||||
|
@ -37,6 +41,10 @@ func NewTopLevelDeployCommand(dockerCli command.Cli) *cobra.Command {
|
||||||
cmd := newDeployCommand(dockerCli)
|
cmd := newDeployCommand(dockerCli)
|
||||||
// Remove the aliases at the top level
|
// Remove the aliases at the top level
|
||||||
cmd.Aliases = []string{}
|
cmd.Aliases = []string{}
|
||||||
cmd.Annotations = map[string]string{"experimental": "", "version": "1.25"}
|
cmd.Annotations = map[string]string{
|
||||||
|
"experimental": "",
|
||||||
|
"swarm": "",
|
||||||
|
"version": "1.25",
|
||||||
|
}
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
|
@ -277,10 +277,12 @@ func areFlagsSupported(cmd *cobra.Command, details versionDetails) error {
|
||||||
if _, ok := f.Annotations["experimentalCLI"]; ok && !hasExperimentalCLI {
|
if _, ok := f.Annotations["experimentalCLI"]; ok && !hasExperimentalCLI {
|
||||||
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported when experimental cli features are enabled", f.Name))
|
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported when experimental cli features are enabled", f.Name))
|
||||||
}
|
}
|
||||||
if _, ok := f.Annotations["kubernetes"]; ok && !hasKubernetes {
|
_, isKubernetesAnnotated := f.Annotations["kubernetes"]
|
||||||
|
_, isSwarmAnnotated := f.Annotations["swarm"]
|
||||||
|
if isKubernetesAnnotated && !isSwarmAnnotated && !hasKubernetes {
|
||||||
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported on a Docker cli with kubernetes features enabled", f.Name))
|
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported on a Docker cli with kubernetes features enabled", f.Name))
|
||||||
}
|
}
|
||||||
if _, ok := f.Annotations["swarm"]; ok && hasKubernetes {
|
if isSwarmAnnotated && !isKubernetesAnnotated && hasKubernetes {
|
||||||
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported on a Docker cli with swarm features enabled", f.Name))
|
errs = append(errs, fmt.Sprintf("\"--%s\" is only supported on a Docker cli with swarm features enabled", f.Name))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -309,10 +311,13 @@ func areSubcommandsSupported(cmd *cobra.Command, details versionDetails) error {
|
||||||
if _, ok := curr.Annotations["experimentalCLI"]; ok && !hasExperimentalCLI {
|
if _, ok := curr.Annotations["experimentalCLI"]; ok && !hasExperimentalCLI {
|
||||||
return fmt.Errorf("%s is only supported when experimental cli features are enabled", cmd.CommandPath())
|
return fmt.Errorf("%s is only supported when experimental cli features are enabled", cmd.CommandPath())
|
||||||
}
|
}
|
||||||
if _, ok := curr.Annotations["kubernetes"]; ok && !hasKubernetes {
|
_, isKubernetesAnnotated := curr.Annotations["kubernetes"]
|
||||||
|
_, isSwarmAnnotated := curr.Annotations["swarm"]
|
||||||
|
|
||||||
|
if isKubernetesAnnotated && !isSwarmAnnotated && !hasKubernetes {
|
||||||
return fmt.Errorf("%s is only supported on a Docker cli with kubernetes features enabled", cmd.CommandPath())
|
return fmt.Errorf("%s is only supported on a Docker cli with kubernetes features enabled", cmd.CommandPath())
|
||||||
}
|
}
|
||||||
if _, ok := curr.Annotations["swarm"]; ok && hasKubernetes {
|
if isSwarmAnnotated && !isKubernetesAnnotated && hasKubernetes {
|
||||||
return fmt.Errorf("%s is only supported on a Docker cli with swarm features enabled", cmd.CommandPath())
|
return fmt.Errorf("%s is only supported on a Docker cli with swarm features enabled", cmd.CommandPath())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue