124 lines
4.7 KiB
Go
124 lines
4.7 KiB
Go
package karmadactl
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/spf13/cobra"
|
|
"k8s.io/cli-runtime/pkg/genericclioptions"
|
|
"k8s.io/cli-runtime/pkg/resource"
|
|
kubectldescribe "k8s.io/kubectl/pkg/cmd/describe"
|
|
cmdutil "k8s.io/kubectl/pkg/cmd/util"
|
|
"k8s.io/kubectl/pkg/describe"
|
|
"k8s.io/kubectl/pkg/util/templates"
|
|
|
|
"github.com/karmada-io/karmada/pkg/karmadactl/options"
|
|
"github.com/karmada-io/karmada/pkg/karmadactl/util"
|
|
)
|
|
|
|
var (
|
|
describeLong = templates.LongDesc(`
|
|
Show details of a specific resource or group of resources in a member cluster.
|
|
|
|
Print a detailed description of the selected resources, including related
|
|
resources such as events or controllers. You may select a single object by name,
|
|
all objects of that type, provide a name prefix, or label selector. For example:
|
|
|
|
$ %[1]s describe TYPE NAME_PREFIX
|
|
|
|
will first check for an exact match on TYPE and NAME_PREFIX. If no such
|
|
resource exists, it will output details for every resource that has a name
|
|
prefixed with NAME_PREFIX.`)
|
|
|
|
describeExample = templates.Examples(`
|
|
# Describe a pod in cluster(member1)
|
|
%[1]s describe pods/nginx -C=member1
|
|
|
|
# Describe all pods in cluster(member1)
|
|
%[1]s describe pods -C=member1
|
|
|
|
# Describe a pod identified by type and name in "pod.json" in cluster(member1)
|
|
%[1]s describe -f pod.json -C=member1
|
|
|
|
# Describe pods by label name=myLabel in cluster(member1)
|
|
%[1]s describe po -l name=myLabel -C=member1
|
|
|
|
# Describe all pods managed by the 'frontend' replication controller in cluster(member1)
|
|
# (rc-created pods get the name of the rc as a prefix in the pod name)
|
|
%[1]s describe pods frontend -C=member1`)
|
|
)
|
|
|
|
// NewCmdDescribe new describe command.
|
|
func NewCmdDescribe(f util.Factory, parentCommand string, streams genericclioptions.IOStreams) *cobra.Command {
|
|
o := &DescribeOptions{
|
|
KubectlDescribeOptions: &kubectldescribe.DescribeOptions{
|
|
FilenameOptions: &resource.FilenameOptions{},
|
|
DescriberSettings: &describe.DescriberSettings{
|
|
ShowEvents: true,
|
|
ChunkSize: cmdutil.DefaultChunkSize,
|
|
},
|
|
CmdParent: parentCommand,
|
|
IOStreams: streams,
|
|
},
|
|
}
|
|
|
|
cmd := &cobra.Command{
|
|
Use: "describe (-f FILENAME | TYPE [NAME_PREFIX | -l label] | TYPE/NAME) (-C CLUSTER)",
|
|
Short: "Show details of a specific resource or group of resources in a cluster",
|
|
Long: fmt.Sprintf(describeLong, parentCommand),
|
|
SilenceUsage: true,
|
|
DisableFlagsInUseLine: true,
|
|
Example: fmt.Sprintf(describeExample, parentCommand),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
if err := o.Complete(f, cmd, args); err != nil {
|
|
return err
|
|
}
|
|
if err := o.Run(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
},
|
|
Annotations: map[string]string{
|
|
util.TagCommandGroup: util.GroupClusterTroubleshootingAndDebugging,
|
|
},
|
|
}
|
|
|
|
flags := cmd.Flags()
|
|
|
|
options.AddKubeConfigFlags(flags)
|
|
flags.StringVarP(options.DefaultConfigFlags.Namespace, "namespace", "n", *options.DefaultConfigFlags.Namespace, "If present, the namespace scope for this CLI request")
|
|
usage := "containing the resource to describe"
|
|
cmdutil.AddFilenameOptionFlags(cmd, o.KubectlDescribeOptions.FilenameOptions, usage)
|
|
flags.StringVarP(&o.KubectlDescribeOptions.Selector, "selector", "l", o.KubectlDescribeOptions.Selector, "Selector (label query) to filter on, supports '=', '==', and '!='.(e.g. -l key1=value1,key2=value2)")
|
|
flags.BoolVarP(&o.KubectlDescribeOptions.AllNamespaces, "all-namespaces", "A", o.KubectlDescribeOptions.AllNamespaces, "If present, list the requested object(s) across all namespaces. Namespace in current context is ignored even if specified with --namespace.")
|
|
flags.BoolVar(&o.KubectlDescribeOptions.DescriberSettings.ShowEvents, "show-events", o.KubectlDescribeOptions.DescriberSettings.ShowEvents, "If true, display events related to the described object.")
|
|
cmdutil.AddChunkSizeFlag(cmd, &o.KubectlDescribeOptions.DescriberSettings.ChunkSize)
|
|
flags.StringVarP(&o.Cluster, "cluster", "C", "", "Specify a member cluster")
|
|
|
|
return cmd
|
|
}
|
|
|
|
// DescribeOptions contains the input to the describe command.
|
|
type DescribeOptions struct {
|
|
// flags specific to describe
|
|
KubectlDescribeOptions *kubectldescribe.DescribeOptions
|
|
Cluster string
|
|
}
|
|
|
|
// Complete ensures that options are valid and marshals them if necessary
|
|
func (o *DescribeOptions) Complete(f util.Factory, cmd *cobra.Command, args []string) error {
|
|
if len(o.Cluster) == 0 {
|
|
return fmt.Errorf("must specify a cluster")
|
|
}
|
|
|
|
memberFactory, err := f.FactoryForMemberCluster(o.Cluster)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return o.KubectlDescribeOptions.Complete(memberFactory, cmd, args)
|
|
}
|
|
|
|
// Run describe information of resources
|
|
func (o *DescribeOptions) Run() error {
|
|
return o.KubectlDescribeOptions.Run()
|
|
}
|