-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.go
65 lines (61 loc) · 1.61 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 (
"context"
"go.uber.org/fx"
"go.uber.org/zap"
"strava-app/internal/api"
"strava-app/internal/config"
"strava-app/internal/cronjob"
"strava-app/internal/db"
"strava-app/internal/db/repository"
"strava-app/internal/loggerfx"
"strava-app/server"
)
func main() {
app := fx.New(
fx.Provide(
config.NewConfig,
loggerfx.ProvideLogger,
db.NewDBClient,
server.NewWebServer,
cronjob.NewCronJob,
repository.NewRepo,
api.NewServerAPI),
fx.Invoke(RegisterWebServer),
fx.Invoke(RegisterCronJobServer))
app.Run()
}
func RegisterWebServer(lifeCycle fx.Lifecycle, webServer *server.WebServer, conf *config.Config, logger *zap.Logger) {
lifeCycle.Append(fx.Hook{
OnStart: func(_ context.Context) error {
go func() {
if err := webServer.Start(); err != nil {
logger.Fatal("start server error : ", zap.Error(err))
}
}()
return nil
},
OnStop: func(_ context.Context) error {
logger.Info("stopping server ...")
return webServer.ShutDown()
},
})
logger.Info("web server started on ", zap.String("port", conf.ServicePort))
}
func RegisterCronJobServer(lifeCycle fx.Lifecycle, cronjob *cronjob.CronServer, conf *config.Config, logger *zap.Logger) {
lifeCycle.Append(fx.Hook{
OnStart: func(_ context.Context) error {
go func() {
if err := cronjob.StartJob(); err != nil {
logger.Fatal("start server error : ", zap.Error(err))
}
}()
return nil
},
OnStop: func(_ context.Context) error {
logger.Info("stopping server ...")
return cronjob.StopJob()
},
})
logger.Info("web server started on ", zap.String("port", conf.ServicePort))
}