/
local.go
69 lines (60 loc) · 1.36 KB
/
local.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
package cmd
import (
"fmt"
"github.com/GoodwayGroup/gwsm/env"
"github.com/clok/kemba"
"github.com/jedib0t/go-pretty/v6/table"
"github.com/urfave/cli/v2"
"os"
"sort"
"strings"
)
// Print the resulting environment for a set of local ConfigMap and Summon secrets.yml file.
func ViewLocalEnv(c *cli.Context) error {
groupedValues, err := env.GetGroupedLocalEnv(c)
if err != nil {
return err
}
for group, values := range groupedValues {
t := table.NewWriter()
t.SetOutputMirror(os.Stdout)
t.SetStyle(table.StyleLight)
if group == "local" {
t.SetTitle("From ConfigMap")
} else {
l := kemba.PickColor(group)
t.SetTitle(fmt.Sprintf("From secret: %s", l.Sprintf(group)))
}
t.AppendHeader(table.Row{"Key", "Value"})
keys := make([]string, 0, len(values))
for k := range values {
keys = append(keys, k)
}
sort.Strings(keys)
for _, key := range keys {
var value string
if strings.HasSuffix(key, c.String("secret-suffix")) {
l := kemba.PickColor(values[key])
value = l.Sprint(values[key])
key = l.Sprint(key)
} else {
value = values[key]
}
t.AppendRow([]interface{}{
key,
value,
})
}
t.Render()
fmt.Println("")
}
return nil
}
func ViewAnsibleEncryptedEnv(c *cli.Context) error {
dataStr, err := env.GetEnvFromAnsibleVault(c)
if err != nil {
return err
}
fmt.Println(dataStr)
return nil
}