-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
49 lines (40 loc) · 928 Bytes
/
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
package main
import (
"flag"
"io/ioutil"
"log"
"os"
)
var (
infoLogger *log.Logger
warningLogger *log.Logger
errorLogger *log.Logger
cnf *config
)
func init() {
infoLogger = log.New(os.Stderr, "INFO ", log.LstdFlags)
warningLogger = log.New(os.Stderr, "WARNING ", log.LstdFlags)
errorLogger = log.New(os.Stderr, "ERROR ", log.LstdFlags)
}
func main() {
configFile := flag.String("config", "config.yml", "config file")
flag.Parse()
configString := ""
if *configFile != "" {
configBytes, err := ioutil.ReadFile(*configFile)
// error means that the file might not exists, in which case we'll just make it later
if err == nil {
configString = string(configBytes)
}
}
infoLogger.Println("Starting...")
var err error
cnf, err = getConfig(configString, configFile)
if err != nil {
errorLogger.Fatalf("Failed to get config: %v", err)
}
// setup modules
setupWebApi(cnf)
select {
}
}