2019-01-12 04:58:27 +00:00
/ *
Copyright 2018 The Kubernetes Authors .
Licensed under the Apache License , Version 2.0 ( the "License" ) ;
you may not use this file except in compliance with the License .
You may obtain a copy of the License at
http : //www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing , software
distributed under the License is distributed on an "AS IS" BASIS ,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND , either express or implied .
See the License for the specific language governing permissions and
limitations under the License .
* /
package genericclioptions
import (
"github.com/spf13/cobra"
2019-04-07 17:07:55 +00:00
"k8s.io/cli-runtime/pkg/printers"
2019-01-12 04:58:27 +00:00
)
// KubeTemplatePrintFlags composes print flags that provide both a JSONPath and a go-template printer.
// This is necessary if dealing with cases that require support both both printers, since both sets of flags
// require overlapping flags.
type KubeTemplatePrintFlags struct {
GoTemplatePrintFlags * GoTemplatePrintFlags
JSONPathPrintFlags * JSONPathPrintFlags
AllowMissingKeys * bool
TemplateArgument * string
}
2021-03-18 22:40:29 +00:00
// AllowedFormats returns slice of string of allowed GoTemplete and JSONPathPrint printing formats
2019-01-12 04:58:27 +00:00
func ( f * KubeTemplatePrintFlags ) AllowedFormats ( ) [ ] string {
if f == nil {
return [ ] string { }
}
return append ( f . GoTemplatePrintFlags . AllowedFormats ( ) , f . JSONPathPrintFlags . AllowedFormats ( ) ... )
}
2021-03-18 22:40:29 +00:00
// ToPrinter receives an outputFormat and returns a printer capable of
// handling --template printing.
// Returns false if the specified outputFormat does not match a supported format.
// Supported Format types can be found in pkg/printers/printers.go
2019-01-12 04:58:27 +00:00
func ( f * KubeTemplatePrintFlags ) ToPrinter ( outputFormat string ) ( printers . ResourcePrinter , error ) {
if f == nil {
return nil , NoCompatiblePrinterError { }
}
if p , err := f . JSONPathPrintFlags . ToPrinter ( outputFormat ) ; ! IsNoCompatiblePrinterError ( err ) {
return p , err
}
return f . GoTemplatePrintFlags . ToPrinter ( outputFormat )
}
// AddFlags receives a *cobra.Command reference and binds
// flags related to template printing to it
func ( f * KubeTemplatePrintFlags ) AddFlags ( c * cobra . Command ) {
if f == nil {
return
}
if f . TemplateArgument != nil {
c . Flags ( ) . StringVar ( f . TemplateArgument , "template" , * f . TemplateArgument , "Template string or path to template file to use when -o=go-template, -o=go-template-file. The template format is golang templates [http://golang.org/pkg/text/template/#pkg-overview]." )
c . MarkFlagFilename ( "template" )
}
if f . AllowMissingKeys != nil {
c . Flags ( ) . BoolVar ( f . AllowMissingKeys , "allow-missing-template-keys" , * f . AllowMissingKeys , "If true, ignore any errors in templates when a field or map key is missing in the template. Only applies to golang and jsonpath output formats." )
}
}
// NewKubeTemplatePrintFlags returns flags associated with
// --template printing, with default values set.
func NewKubeTemplatePrintFlags ( ) * KubeTemplatePrintFlags {
allowMissingKeysPtr := true
templateArgPtr := ""
return & KubeTemplatePrintFlags {
GoTemplatePrintFlags : & GoTemplatePrintFlags {
TemplateArgument : & templateArgPtr ,
AllowMissingKeys : & allowMissingKeysPtr ,
} ,
JSONPathPrintFlags : & JSONPathPrintFlags {
TemplateArgument : & templateArgPtr ,
AllowMissingKeys : & allowMissingKeysPtr ,
} ,
TemplateArgument : & templateArgPtr ,
AllowMissingKeys : & allowMissingKeysPtr ,
}
}