-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.go
49 lines (40 loc) · 989 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 runs the backend router*/
package main
import (
log "github.com/sirupsen/logrus"
"github.com/Projeto-USPY/uspy-backend/config"
"github.com/Projeto-USPY/uspy-backend/db"
"github.com/Projeto-USPY/uspy-backend/db/mock"
"github.com/Projeto-USPY/uspy-backend/server"
)
func init() {
log.SetFormatter(&log.TextFormatter{
FullTimestamp: true,
ForceColors: true,
PadLevelText: true,
})
log.SetReportCaller(true)
config.Setup()
if config.Env.IsProd() {
log.SetLevel(log.InfoLevel)
} else {
log.SetLevel(log.DebugLevel)
}
}
func main() {
// connect with database
DB := db.SetupDB()
// setup dummy data for local testing if needed
if config.Env.MockFirestoreData {
if err := mock.SetupMockData(DB); err != nil {
log.Error("error inserting mock data: ", err)
}
}
// setup routes and callbacks
r, err := server.SetupRouter(DB)
if err != nil {
log.Fatal(err)
}
// run web server
_ = r.Run(config.Env.Domain + ":" + config.Env.Port)
}