mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-09 12:07:47 +00:00
Merge pull request #117901 from ardaguclu/use-getter-allowed-cmds
Use getter function for plugin subcommand resolution
This commit is contained in:
commit
714b165af8
@ -84,10 +84,6 @@ import (
|
|||||||
|
|
||||||
const kubectlCmdHeaders = "KUBECTL_COMMAND_HEADERS"
|
const kubectlCmdHeaders = "KUBECTL_COMMAND_HEADERS"
|
||||||
|
|
||||||
var (
|
|
||||||
allowedCmdsSubcommandPlugin = map[string]struct{}{"create": {}}
|
|
||||||
)
|
|
||||||
|
|
||||||
type KubectlOptions struct {
|
type KubectlOptions struct {
|
||||||
PluginHandler PluginHandler
|
PluginHandler PluginHandler
|
||||||
Arguments []string
|
Arguments []string
|
||||||
@ -146,7 +142,7 @@ func NewDefaultKubectlCommandWithArgs(o KubectlOptions) *cobra.Command {
|
|||||||
if cmdutil.CmdPluginAsSubcommand.IsEnabled() {
|
if cmdutil.CmdPluginAsSubcommand.IsEnabled() {
|
||||||
// Command exists(e.g. kubectl create), but it is not certain that
|
// Command exists(e.g. kubectl create), but it is not certain that
|
||||||
// subcommand also exists (e.g. kubectl create networkpolicy)
|
// subcommand also exists (e.g. kubectl create networkpolicy)
|
||||||
if _, ok := allowedCmdsSubcommandPlugin[foundCmd.Name()]; ok {
|
if IsSubcommandPluginAllowed(foundCmd.Name()) {
|
||||||
var subcommand string
|
var subcommand string
|
||||||
for _, arg := range foundArgs { // first "non-flag" argument as subcommand
|
for _, arg := range foundArgs { // first "non-flag" argument as subcommand
|
||||||
if !strings.HasPrefix(arg, "-") {
|
if !strings.HasPrefix(arg, "-") {
|
||||||
@ -176,6 +172,14 @@ func NewDefaultKubectlCommandWithArgs(o KubectlOptions) *cobra.Command {
|
|||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsSubcommandPluginAllowed returns the given command is allowed
|
||||||
|
// to use plugin as subcommand if the subcommand does not exist as builtin.
|
||||||
|
func IsSubcommandPluginAllowed(foundCmd string) bool {
|
||||||
|
allowedCmds := map[string]struct{}{"create": {}}
|
||||||
|
_, ok := allowedCmds[foundCmd]
|
||||||
|
return ok
|
||||||
|
}
|
||||||
|
|
||||||
// PluginHandler is capable of parsing command line arguments
|
// PluginHandler is capable of parsing command line arguments
|
||||||
// and performing executable filename lookups to search
|
// and performing executable filename lookups to search
|
||||||
// for valid plugin files, and execute found plugins.
|
// for valid plugin files, and execute found plugins.
|
||||||
|
Loading…
Reference in New Issue
Block a user