Skip to content
Snippets Groups Projects
Commit 020d5da0 authored by Alex Clemmer's avatar Alex Clemmer
Browse files

Remove kubectl and Jsonnet flags from commands that don't use them

parent 3d5b174a
No related branches found
No related tags found
No related merge requests found
......@@ -27,6 +27,8 @@ const (
func init() {
RootCmd.AddCommand(deleteCmd)
addJsonnetFlagsToCmd(deleteCmd)
addKubectlFlagsToCmd(deleteCmd)
addEnvCmdFlags(deleteCmd)
deleteCmd.PersistentFlags().Int64(flagGracePeriod, -1, "Number of seconds given to resources to terminate gracefully. A negative value is ignored")
}
......
......@@ -24,6 +24,8 @@ import (
const flagDiffStrategy = "diff-strategy"
func init() {
addJsonnetFlagsToCmd(diffCmd)
addKubectlFlagsToCmd(diffCmd)
addEnvCmdFlags(diffCmd)
diffCmd.PersistentFlags().String(flagDiffStrategy, "all", "Diff strategy, all or subset.")
RootCmd.AddCommand(diffCmd)
......
......@@ -63,27 +63,10 @@ var clientConfig clientcmd.ClientConfig
func init() {
RootCmd.PersistentFlags().CountP(flagVerbose, "v", "Increase verbosity. May be given multiple times.")
RootCmd.PersistentFlags().StringP(flagJpath, "J", "", "Additional jsonnet library search path")
RootCmd.PersistentFlags().StringSliceP(flagExtVar, "V", nil, "Values of external variables")
RootCmd.PersistentFlags().StringSlice(flagExtVarFile, nil, "Read external variable from a file")
RootCmd.PersistentFlags().StringSliceP(flagTlaVar, "A", nil, "Values of top level arguments")
RootCmd.PersistentFlags().StringSlice(flagTlaVarFile, nil, "Read top level argument from a file")
RootCmd.PersistentFlags().String(flagResolver, "noop", "Change implementation of resolveImage native function. One of: noop, registry")
RootCmd.PersistentFlags().String(flagResolvFail, "warn", "Action when resolveImage fails. One of ignore,warn,error")
// The "usual" clientcmd/kubectl flags
loadingRules := clientcmd.NewDefaultClientConfigLoadingRules()
loadingRules.DefaultClientConfig = &clientcmd.DefaultClientConfig
overrides := clientcmd.ConfigOverrides{}
kflags := clientcmd.RecommendedConfigOverrideFlags("")
RootCmd.PersistentFlags().StringVar(&loadingRules.ExplicitPath, "kubeconfig", "", "Path to a kube config. Only required if out-of-cluster")
clientcmd.BindOverrideFlags(&overrides, RootCmd.PersistentFlags(), kflags)
clientConfig = clientcmd.NewInteractiveDeferredLoadingClientConfig(loadingRules, &overrides, os.Stdin)
RootCmd.PersistentFlags().Set("logtostderr", "true")
}
// RootCmd is the root of cobra subcommand tree
// RootCmd is the root of all commands that expand Jsonnet code or talk to
// the API server
var RootCmd = &cobra.Command{
Use: "kubecfg",
Short: "Synchronise Kubernetes resources with config files",
......@@ -108,6 +91,29 @@ var RootCmd = &cobra.Command{
},
}
func addJsonnetFlagsToCmd(cmd *cobra.Command) {
cmd.PersistentFlags().StringP(flagJpath, "J", "", "Additional jsonnet library search path")
cmd.PersistentFlags().StringSliceP(flagExtVar, "V", nil, "Values of external variables")
cmd.PersistentFlags().StringSlice(flagExtVarFile, nil, "Read external variable from a file")
cmd.PersistentFlags().StringSliceP(flagTlaVar, "A", nil, "Values of top level arguments")
cmd.PersistentFlags().StringSlice(flagTlaVarFile, nil, "Read top level argument from a file")
cmd.PersistentFlags().String(flagResolver, "noop", "Change implementation of resolveImage native function. One of: noop, registry")
cmd.PersistentFlags().String(flagResolvFail, "warn", "Action when resolveImage fails. One of ignore,warn,error")
}
func addKubectlFlagsToCmd(cmd *cobra.Command) {
// The "usual" clientcmd/kubectl flags
loadingRules := clientcmd.NewDefaultClientConfigLoadingRules()
loadingRules.DefaultClientConfig = &clientcmd.DefaultClientConfig
overrides := clientcmd.ConfigOverrides{}
kflags := clientcmd.RecommendedConfigOverrideFlags("")
cmd.PersistentFlags().StringVar(&loadingRules.ExplicitPath, "kubeconfig", "", "Path to a kube config. Only required if out-of-cluster")
clientcmd.BindOverrideFlags(&overrides, cmd.PersistentFlags(), kflags)
clientConfig = clientcmd.NewInteractiveDeferredLoadingClientConfig(loadingRules, &overrides, os.Stdin)
cmd.PersistentFlags().Set("logtostderr", "true")
}
func logLevel(verbosity int) log.Level {
switch verbosity {
case 0:
......
......@@ -27,6 +27,8 @@ const (
func init() {
RootCmd.AddCommand(showCmd)
addJsonnetFlagsToCmd(showCmd)
addKubectlFlagsToCmd(showCmd)
addEnvCmdFlags(showCmd)
showCmd.PersistentFlags().StringP(flagFormat, "o", "yaml", "Output format. Supported values are: json, yaml")
}
......
......@@ -49,6 +49,8 @@ const (
func init() {
RootCmd.AddCommand(updateCmd)
addJsonnetFlagsToCmd(updateCmd)
addKubectlFlagsToCmd(updateCmd)
addEnvCmdFlags(updateCmd)
updateCmd.PersistentFlags().Bool(flagCreate, true, "Create missing resources")
updateCmd.PersistentFlags().Bool(flagSkipGc, false, "Don't perform garbage collection, even with --"+flagGcTag)
......@@ -57,9 +59,8 @@ func init() {
}
var updateCmd = &cobra.Command{
Use: "update [<env>|-f <file-or-dir>]",
Short: `Update (or optionally create) Kubernetes resources on the cluster using the
local configuration. Accepts JSON, YAML, or Jsonnet.`,
Use: "update [<env>|-f <file-or-dir>]",
Short: `Update (or optionally create) Kubernetes resources on the cluster using the local configuration. Accepts JSON, YAML, or Jsonnet.`,
RunE: func(cmd *cobra.Command, args []string) error {
flags := cmd.Flags()
var err error
......
......@@ -23,6 +23,8 @@ import (
func init() {
RootCmd.AddCommand(validateCmd)
addJsonnetFlagsToCmd(validateCmd)
addKubectlFlagsToCmd(validateCmd)
addEnvCmdFlags(validateCmd)
}
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment