-
Notifications
You must be signed in to change notification settings - Fork 9
/
setup.go
77 lines (66 loc) · 2.1 KB
/
setup.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
// SPDX-FileCopyrightText: 2021 Comcast Cable Communications Management, LLC
// SPDX-License-Identifier: Apache-2.0
package main
import (
"fmt"
"os"
"runtime"
"github.com/spf13/pflag"
"github.com/spf13/viper"
"github.com/xmidt-org/arrange"
"github.com/xmidt-org/sallust"
"go.uber.org/zap"
)
func setupFlagSet(fs *pflag.FlagSet) {
fs.StringP("file", "f", "", "the configuration file to use. Overrides the search path.")
fs.BoolP("debug", "d", false, "enables debug logging. Overrides configuration.")
fs.BoolP("version", "v", false, "print version and exit")
}
func setup(args []string) (*viper.Viper, *zap.Logger, error) {
l, err := zap.NewDevelopment() // initial value
if err != nil {
return nil, l, fmt.Errorf("failed to create zap logger: %w", err)
}
fs := pflag.NewFlagSet(applicationName, pflag.ContinueOnError)
setupFlagSet(fs)
err = fs.Parse(args)
if err != nil {
return nil, l, fmt.Errorf("failed to create parse args: %w", err)
}
if printVersion, _ := fs.GetBool("version"); printVersion {
printVersionInfo()
}
v := viper.New()
if file, _ := fs.GetString("file"); len(file) > 0 {
v.SetConfigFile(file)
err = v.ReadInConfig()
} else {
v.SetConfigName(applicationName)
v.AddConfigPath(fmt.Sprintf("/etc/%s", applicationName))
v.AddConfigPath(fmt.Sprintf("$HOME/.%s", applicationName))
v.AddConfigPath(".")
err = v.ReadInConfig()
}
if err != nil {
return v, l, fmt.Errorf("failed to read config file: %w", err)
}
if debug, _ := fs.GetBool("debug"); debug {
v.Set("log.level", "DEBUG")
}
var c sallust.Config
err = v.UnmarshalKey("logging", &c, arrange.ComposeDecodeHooks(sallust.DecodeHook))
if err != nil {
return v, l, err
}
l, err = c.Build()
return v, l, err
}
func printVersionInfo() {
fmt.Fprintf(os.Stdout, "%s:\n", applicationName)
fmt.Fprintf(os.Stdout, " version: \t%s\n", Version)
fmt.Fprintf(os.Stdout, " go version: \t%s\n", runtime.Version())
fmt.Fprintf(os.Stdout, " built time: \t%s\n", BuildTime)
fmt.Fprintf(os.Stdout, " git commit: \t%s\n", GitCommit)
fmt.Fprintf(os.Stdout, " os/arch: \t%s/%s\n", runtime.GOOS, runtime.GOARCH)
os.Exit(0)
}