a6987107bd
In current setup, we rely on executor to perform render operation, however there are many usecases, when we want to have a simple `kustomize build` performed against document entrypoint in phase. Now this will be a default behaviour and if a user would like executor to perform rendering to actually understand what it's doing, he will be able to specify --executor boolean flag. Relates-To: #403 Change-Id: I181830f9814ff48a19ba0a1284e89900187bc7d8
93 lines
2.4 KiB
Go
93 lines
2.4 KiB
Go
/*
|
|
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
|
|
|
|
https://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 phase
|
|
|
|
import (
|
|
"github.com/spf13/cobra"
|
|
|
|
"opendev.org/airship/airshipctl/pkg/config"
|
|
"opendev.org/airship/airshipctl/pkg/phase"
|
|
)
|
|
|
|
const (
|
|
renderExample = `
|
|
# Get all 'initinfra' phase documents containing labels "app=helm" and
|
|
# "service=tiller"
|
|
airshipctl phase render initinfra -l app=helm,service=tiller
|
|
|
|
# Get all documents containing labels "app=helm" and "service=tiller"
|
|
# and kind 'Deployment'
|
|
airshipctl phase render initinfra -l app=helm,service=tiller -k Deployment
|
|
`
|
|
)
|
|
|
|
// NewRenderCommand create a new command for document rendering
|
|
func NewRenderCommand(cfgFactory config.Factory) *cobra.Command {
|
|
filterOptions := &phase.RenderCommand{}
|
|
renderCmd := &cobra.Command{
|
|
Use: "render PHASE_NAME",
|
|
Short: "Render phase documents from model",
|
|
Example: renderExample,
|
|
Args: cobra.ExactArgs(1),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
return filterOptions.RunE(cfgFactory, args[0], cmd.OutOrStdout())
|
|
},
|
|
}
|
|
|
|
addRenderFlags(filterOptions, renderCmd)
|
|
return renderCmd
|
|
}
|
|
|
|
// addRenderFlags adds flags for document render sub-command
|
|
func addRenderFlags(filterOptions *phase.RenderCommand, cmd *cobra.Command) {
|
|
flags := cmd.Flags()
|
|
|
|
flags.StringVarP(
|
|
&filterOptions.Label,
|
|
"label",
|
|
"l",
|
|
"",
|
|
"filter documents by Labels")
|
|
|
|
flags.StringVarP(
|
|
&filterOptions.Annotation,
|
|
"annotation",
|
|
"a",
|
|
"",
|
|
"filter documents by Annotations")
|
|
|
|
flags.StringVarP(
|
|
&filterOptions.APIVersion,
|
|
"apiversion",
|
|
"g",
|
|
"",
|
|
"filter documents by API version")
|
|
|
|
flags.StringVarP(
|
|
&filterOptions.Kind,
|
|
"kind",
|
|
"k",
|
|
"",
|
|
"filter documents by Kinds")
|
|
flags.BoolVarP(
|
|
&filterOptions.Executor,
|
|
"executor",
|
|
"e",
|
|
false,
|
|
"if set to true rendering will be performed by executor "+
|
|
"otherwise phase entrypoint will be rendered by kustomize, if entrypoint is not specified "+
|
|
"error will be returned")
|
|
}
|