This repository was archived by the owner on Oct 7, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 80
/
Copy pathmanifest-generate.go
109 lines (95 loc) · 3.36 KB
/
manifest-generate.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Copyright 2019 Istio 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 mesh
import (
"fmt"
"os"
"sort"
"strings"
"istio.io/operator/pkg/helm"
"github.com/spf13/cobra"
"istio.io/operator/pkg/manifest"
"istio.io/operator/pkg/name"
)
type manifestGenerateArgs struct {
// inFilename is the path to the input IstioOperator CR.
inFilename string
// outFilename is the path to the generated output directory.
outFilename string
// set is a string with element format "path=value" where path is an IstioOperator path and the value is a
// value to set the node at that path to.
set []string
// force proceeds even if there are validation errors
force bool
}
func addManifestGenerateFlags(cmd *cobra.Command, args *manifestGenerateArgs) {
cmd.PersistentFlags().StringVarP(&args.inFilename, "filename", "f", "", filenameFlagHelpStr)
cmd.PersistentFlags().StringVarP(&args.outFilename, "output", "o", "", "Manifest output directory path")
cmd.PersistentFlags().StringSliceVarP(&args.set, "set", "s", nil, SetFlagHelpStr)
cmd.PersistentFlags().BoolVar(&args.force, "force", false, "Proceed even with validation errors")
}
func manifestGenerateCmd(rootArgs *rootArgs, mgArgs *manifestGenerateArgs) *cobra.Command {
return &cobra.Command{
Use: "generate",
Short: "Generates an Istio install manifest",
Long: "The generate subcommand generates an Istio install manifest and outputs to the console by default.",
Args: func(cmd *cobra.Command, args []string) error {
if len(args) != 0 {
return fmt.Errorf("generate accepts no positional arguments, got %#v", args)
}
return nil
},
RunE: func(cmd *cobra.Command, args []string) error {
l := NewLogger(rootArgs.logToStdErr, cmd.OutOrStdout(), cmd.ErrOrStderr())
return manifestGenerate(rootArgs, mgArgs, l)
}}
}
func manifestGenerate(args *rootArgs, mgArgs *manifestGenerateArgs, l *Logger) error {
if err := configLogs(args.logToStdErr); err != nil {
return fmt.Errorf("could not configure logs: %s", err)
}
overlayFromSet, err := MakeTreeFromSetList(mgArgs.set, mgArgs.force, l)
if err != nil {
return err
}
manifests, _, err := GenManifests(mgArgs.inFilename, overlayFromSet, mgArgs.force, l)
if err != nil {
return err
}
if mgArgs.outFilename == "" {
for _, m := range orderedManifests(manifests) {
l.print(m + "\n")
}
} else {
if err := os.MkdirAll(mgArgs.outFilename, os.ModePerm); err != nil {
return err
}
if err := manifest.RenderToDir(manifests, mgArgs.outFilename, args.dryRun); err != nil {
return err
}
}
return nil
}
func orderedManifests(mm name.ManifestMap) []string {
var keys, out []string
for k := range mm {
keys = append(keys, string(k))
}
sort.Strings(keys)
fmt.Printf("Sorted keys: %s\n\n", strings.Join(keys, "\n"))
for _, k := range keys {
out = append(out, strings.Join(mm[name.ComponentName(k)], helm.YAMLSeparator))
}
return out
}