/
main.go
65 lines (53 loc) · 1.5 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
package main
import (
"flag"
"fmt"
"os"
"github.com/sethjback/gobl/auth"
"github.com/sethjback/gobl/config"
"github.com/sethjback/gobl/coordinator/apihandler"
"github.com/sethjback/gobl/coordinator/manager"
"github.com/sethjback/gobl/gobldb/leveldb"
"github.com/sethjback/gobl/httpapi"
"github.com/sethjback/gobl/model"
"github.com/sethjback/gobl/util/log"
"github.com/sethjback/gobl/version"
)
func main() {
var cPath, admin string
flag.StringVar(&cPath, "config", "", "Path to the config file")
flag.StringVar(&admin, "admin", "", "Set the admin password")
flag.Parse()
conf, err := config.Parse(cPath)
if err != nil {
fmt.Println("Error parsing config file:", err)
os.Exit(1)
}
log.Init(conf.Log)
log.Infof("main", "coordinator starting. Version: %s", version.Version.String())
log.Debug("main", "config:", *conf)
if admin != "" {
gDb, err := leveldb.New(conf.DB)
if err != nil {
log.Fatalf("main", "Error creating admin user: %v", err)
}
p, err := auth.PasswordHash([]byte(admin))
if err != nil {
log.Fatalf("main", "Error creating admin user: %v", err)
}
err = gDb.SaveUser(model.User{Email: "admin", Password: string(p)})
if err != nil {
log.Fatalf("main", "Error creating admin user: %v", err)
}
gDb.Close()
}
err = manager.Init(conf)
if err != nil {
log.Fatalf("main", "Error initializing manager: %v", err)
}
httpAPI := httpapi.New(apihandler.Routes)
httpAPI.Start(conf.Server, func() {
log.Infof("main", "shutting down")
manager.Shutdown()
})
}