-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathmain.go
119 lines (100 loc) · 2.99 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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
package main
import (
"fmt"
"net/http"
"os"
"github.com/RedHatInsights/quickstarts/config"
"github.com/RedHatInsights/quickstarts/pkg/database"
"github.com/RedHatInsights/quickstarts/pkg/logger"
"github.com/RedHatInsights/quickstarts/pkg/routes"
"github.com/go-chi/chi/v5"
"github.com/go-chi/chi/v5/middleware"
"github.com/joho/godotenv"
_ "github.com/joho/godotenv/autoload"
"github.com/prometheus/client_golang/prometheus/promhttp"
"github.com/redhatinsights/platform-go-middlewares/request_id"
"github.com/sirupsen/logrus"
)
func initDependecies() {
database.Init()
}
func probe(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.WriteHeader(http.StatusOK)
w.Write([]byte("OK"))
}
func specHandler(w http.ResponseWriter, r *http.Request) {
root := "./spec"
fs := http.FileServer(http.Dir(root))
if _, err := os.Stat(root + r.RequestURI); os.IsNotExist(err) {
http.StripPrefix(r.RequestURI, fs).ServeHTTP(w, r)
} else {
fs.ServeHTTP(w, r)
}
}
func main() {
godotenv.Load()
config.Init()
cfg := config.Get()
initDependecies()
setupGlobalLogger(cfg)
logrus.WithFields(logrus.Fields{
"ServerAddr": cfg.ServerAddr,
})
r := chi.NewRouter()
mr := chi.NewRouter()
routerLogger := logrus.New()
r.Use(
request_id.ConfiguredRequestID("x-rh-insights-request-id"),
middleware.RealIP,
middleware.Recoverer,
middleware.RequestLogger(logger.NewLogger(cfg, routerLogger)),
)
root := "./spec/"
fs := http.FileServer(http.Dir(root))
r.With(routes.PrometheusMiddleware).Route("/api/quickstarts/v1", func(sub chi.Router) {
sub.Route("/quickstarts", routes.MakeQuickstartsRouter)
sub.Route("/progress", routes.MakeQuickstartsProgressRouter)
sub.Route("/helptopics", routes.MakeHelpTopicsRouter)
sub.Route("/favorites", routes.MakeFavoriteQuickstartsRouter)
sub.Handle("/spec/*", http.StripPrefix("/api/quickstarts/v1/spec", fs))
})
mr.Get("/", probe)
mr.Handle("/metrics", promhttp.Handler())
r.Get("/test", probe)
server := http.Server{
Addr: cfg.ServerAddr,
Handler: r,
}
metricsServer := http.Server{
Addr: fmt.Sprintf(":%d", cfg.MetricsPort),
Handler: mr,
}
go func() {
if err := metricsServer.ListenAndServe(); err != nil && err != http.ErrServerClosed {
logrus.Fatal("Metrics server stopped")
}
}()
logrus.Infoln("Starting http server")
if err := server.ListenAndServe(); err != nil && err != http.ErrServerClosed {
logrus.Fatal("Api server has stopped")
}
// <-done
// logrus.Info("Gracefully stopping server")
// ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
// defer func() {
// // extra handling here
// cancel()
// }()
// if err := server.Shutdown(ctx); err != nil {
// logrus.Fatal("Server shutdown failed:%+v", err)
// }
// logrus.Info("Server stypped properly")
}
func setupGlobalLogger(opts *config.QuickstartsConfig) {
logLevel, err := logrus.ParseLevel(opts.LogLevel)
if err != nil {
logLevel = logrus.ErrorLevel
}
logrus.SetLevel(logLevel)
}