-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.go
117 lines (105 loc) · 2.54 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
package main
import (
"fmt"
"os"
"sorsops/vault-env/v2/models"
"sorsops/vault-env/v2/secrets"
"github.com/urfave/cli/v2"
log "github.com/sirupsen/logrus"
)
var semverVersion string = "0.0.0"
func main() {
var input string
var collection string
var output string
var vaultAddress string
var defaultToken string
var format string
var verbose bool = false
log.SetLevel(log.FatalLevel)
app := &cli.App{
Name: "vault-env",
EnableBashCompletion: true,
Usage: "used to retrieve Hashicorp vault secrets in a gitlab pipeline",
Flags: []cli.Flag{
&cli.StringFlag{
Name: "input",
Value: ".vault-env.yml",
Usage: "the input file to parse.",
Destination: &input,
},
&cli.StringFlag{
Name: "token",
EnvVars: []string{"VAULT_TOKEN"},
Usage: "the default vault token to use when no login requested",
Destination: &defaultToken,
},
&cli.StringFlag{
Name: "collection",
Value: "default",
Usage: "the collection of secrets to pull",
Destination: &collection,
},
&cli.StringFlag{
Name: "output",
Value: "",
Usage: "the default file output",
Destination: &output,
},
&cli.StringFlag{
Name: "vaultAddr",
EnvVars: []string{"VAULT_ADDR"},
Usage: "the address of the vault instance",
Destination: &vaultAddress,
},
&cli.StringFlag{
Name: "format",
Value: string(models.NIX),
Usage: "the output format to use. Use `WINDOWS` if you want to output in .bat compatible format",
Destination: &format,
},
&cli.BoolFlag{
Name: "verbose",
Value: false,
Usage: "sets the output to be verbose",
Destination: &verbose,
},
},
Commands: []*cli.Command{
{
Name: "version",
Usage: "retrieves version information",
Flags: []cli.Flag{},
Action: func(c *cli.Context) error {
fmt.Println(semverVersion)
return nil
},
},
},
Action: func(c *cli.Context) error {
if verbose {
log.SetLevel(log.TraceLevel)
}
err := secrets.RetrieveSecrets(&models.SecretCtx{
VaultAddress: vaultAddress,
InputFile: input,
Collection: collection,
DefaultToken: defaultToken,
Output: output,
Format: format,
})
if err != nil {
return err
}
return nil
},
}
err := app.Run(os.Args)
if err != nil {
log.Println("A fatal error has occurred")
log.Println(err)
os.Exit(1)
} else {
os.Exit(0)
}
}