-
Notifications
You must be signed in to change notification settings - Fork 8
/
main.go
130 lines (118 loc) · 3.86 KB
/
main.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/*
Copyright 2020 Adobe. All rights reserved.
This file is licensed to you 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 REPRESENTATIONS
OF ANY KIND, either express or implied. See the License for the specific language
governing permissions and limitations under the License.
*/
package main
import (
"flag"
"io/ioutil"
"log"
"os"
"strings"
"github.com/fasterci/rules_gitops/templating/fasttemplate"
)
type arrayFlags []string
func (i *arrayFlags) String() string {
return ""
}
func (i *arrayFlags) Set(value string) error {
*i = append(*i, value)
return nil
}
var (
stampInfoFile arrayFlags
output, template string
variable, imports arrayFlags
executable bool
startTag, endTag string
)
func init() {
flag.Var(&stampInfoFile, "stamp_info_file", "Paths to info_file and version_file files for stamping. Content of stamp_info_file files will be used to substitute variable values so --variable VAR={BUILD_USER}/value will result in {{VAR}} being expanded to builduser/value")
flag.Var(&variable, "variable", "A variable to expand in the template, in the format NAME=VALUE")
flag.Var(&imports, "imports", "A file to import as another template, in the format NAME=filename")
flag.StringVar(&output, "output", "", "The output file")
flag.StringVar(&template, "template", "", "The input file, mandatory")
flag.BoolVar(&executable, "executable", false, "Whether to adds the executable bit to the output")
flag.StringVar(&startTag, "start_tag", "{{", "Start tag for template placeholders")
flag.StringVar(&endTag, "end_tag", "}}", "End tag for template placeholders")
}
func workspaceStatusDict(filenames []string) map[string]interface{} {
d := map[string]interface{}{}
for _, f := range filenames {
content, err := ioutil.ReadFile(f)
if err != nil {
log.Fatalf("Unable to read %s: %v", f, err)
}
for _, l := range strings.Split(string(content), "\n") {
sv := strings.SplitN(l, " ", 2)
if len(sv) == 2 {
d[sv[0]] = sv[1]
}
}
}
return d
}
func main() {
var err error
flag.Parse()
stamps := workspaceStatusDict(stampInfoFile)
ctx := map[string]interface{}{}
for _, v := range variable {
sv := strings.SplitN(v, "=", 2)
if len(sv) != 2 {
log.Fatalf("variable must be VAR=value, got %s", v)
}
val := fasttemplate.ExecuteString(sv[1], "{", "}", stamps)
ctx[sv[0]] = val
ctx["variables."+sv[0]] = val
}
for _, v := range imports {
sv := strings.SplitN(v, "=", 2)
if len(sv) != 2 {
log.Fatalf("imports must be VAR=filename, got %s", v)
}
imp, err := ioutil.ReadFile(sv[1])
if err != nil {
log.Fatalf("Unable to parse file %s: %v", sv[1], err)
}
val := fasttemplate.ExecuteString(string(imp), startTag, endTag, ctx)
// if err != nil {
// log.Fatalf("Unable to execute template %s: %v", sv[1], err)
// }
ctx["imports."+sv[0]] = fasttemplate.ExecuteString(val, "{", "}", stamps)
}
var tpl []byte
if template != "" {
tpl, err = ioutil.ReadFile(template)
if err != nil {
log.Fatalf("Unable to parse template %s: %v", template, err)
}
} else {
tpl, err = ioutil.ReadAll(os.Stdin)
if err != nil {
log.Fatalf("Unable to parse template from stdin: %v", err)
}
}
outf := os.Stdout
if output != "" {
var perm os.FileMode = 0666
if executable {
perm = 0777
}
outf, err = os.OpenFile(output, os.O_RDWR|os.O_CREATE|os.O_TRUNC, perm)
if err != nil {
log.Fatalf("Unable to create output file %s: %v", output, err)
}
defer outf.Close()
}
_, err = fasttemplate.Execute(string(tpl), startTag, endTag, outf, ctx)
if err != nil {
log.Fatalf("Unable to execute template %s: %v", template, err)
}
}