-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
executable file
·48 lines (39 loc) · 1.2 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
package main
import (
// External
log "github.com/sirupsen/logrus"
// Internal
api "github.com/iakrevetkho/robin/internal/api"
apiresources "github.com/iakrevetkho/robin/internal/api/resources"
auth_google "github.com/iakrevetkho/robin/internal/auth/google"
"github.com/iakrevetkho/robin/internal/config"
"github.com/iakrevetkho/robin/internal/helpers"
)
func main() {
helpers.InitLog()
// Load app configuration
config, err := config.LoadConfig("config.yml")
if err != nil {
log.Fatalf("Couldn't load app config. %v", err)
}
log.SetLevel(config.LogLevel)
log.WithField("config", config).Infof("Loaded config")
// Init auth providers
googleAuthProvider, err := auth_google.New(config)
if err != nil {
log.Fatalf("Couldn't init google auth provider. %v", err)
}
// Create api controller data
controllerData := apiresources.ControllerData{
GoogleAuthProvider: googleAuthProvider,
}
// Init API controller
apiController, err := api.Init(controllerData, config)
if err != nil {
log.Fatalf("Couldn't init API controller. %v", err)
}
defer apiController.Close()
// Wait any terminate signal
signal := helpers.WaitTermSignals()
log.Infof("Exit. Catched signal '%s'", signal.String())
}