mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-14 22:33:34 +00:00
Use getter function for plugin subcommand resolution
Plugin subcommand resolution is relatively less used than the builtin subcommands. That's why, instead always initializing a hash map on memory, it would be better to use a getter function only serves as needed. In addition to that this function will be exported that external libraries can use it.
This commit is contained in:
parent
af1bf43067
commit
4634073d0b
@ -84,10 +84,6 @@ import (
|
||||
|
||||
const kubectlCmdHeaders = "KUBECTL_COMMAND_HEADERS"
|
||||
|
||||
var (
|
||||
allowedCmdsSubcommandPlugin = map[string]struct{}{"create": {}}
|
||||
)
|
||||
|
||||
type KubectlOptions struct {
|
||||
PluginHandler PluginHandler
|
||||
Arguments []string
|
||||
@ -146,7 +142,7 @@ func NewDefaultKubectlCommandWithArgs(o KubectlOptions) *cobra.Command {
|
||||
if cmdutil.CmdPluginAsSubcommand.IsEnabled() {
|
||||
// Command exists(e.g. kubectl create), but it is not certain that
|
||||
// subcommand also exists (e.g. kubectl create networkpolicy)
|
||||
if _, ok := allowedCmdsSubcommandPlugin[foundCmd.Name()]; ok {
|
||||
if _, ok := GetAllowedCmdsAsSubcommandPlugins()[foundCmd.Name()]; ok {
|
||||
var subcommand string
|
||||
for _, arg := range foundArgs { // first "non-flag" argument as subcommand
|
||||
if !strings.HasPrefix(arg, "-") {
|
||||
@ -176,6 +172,13 @@ func NewDefaultKubectlCommandWithArgs(o KubectlOptions) *cobra.Command {
|
||||
return cmd
|
||||
}
|
||||
|
||||
// GetAllowedCmdsAsSubcommandPlugins returns the list of builtin commands
|
||||
// that plugins are allowed to be used as subcommands only if the passed subcommand
|
||||
// does not exist as builtin.
|
||||
func GetAllowedCmdsAsSubcommandPlugins() map[string]struct{} {
|
||||
return map[string]struct{}{"create": {}}
|
||||
}
|
||||
|
||||
// PluginHandler is capable of parsing command line arguments
|
||||
// and performing executable filename lookups to search
|
||||
// for valid plugin files, and execute found plugins.
|
||||
|
Loading…
Reference in New Issue
Block a user