-
Notifications
You must be signed in to change notification settings - Fork 26
Expand file tree
/
Copy pathserver.go
More file actions
95 lines (68 loc) · 2.27 KB
/
server.go
File metadata and controls
95 lines (68 loc) · 2.27 KB
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
package http
import (
"context"
"errors"
"fmt"
"time"
"github.com/EinStack/glide/pkg/router"
"github.com/gofiber/contrib/otelfiber"
"github.com/gofiber/swagger"
"github.com/EinStack/glide/docs"
_ "github.com/EinStack/glide/docs" // importing docs package to include them into the binary
"github.com/gofiber/contrib/fiberzap/v2"
"github.com/gofiber/fiber/v2"
"github.com/EinStack/glide/pkg/telemetry"
)
type Server struct {
config *ServerConfig
telemetry *telemetry.Telemetry
routerManager *router.Manager
server *fiber.App
}
func NewServer(config *ServerConfig, tel *telemetry.Telemetry, routerManager *router.Manager) (*Server, error) {
srv := config.ToServer()
return &Server{
config: config,
telemetry: tel,
routerManager: routerManager,
server: srv,
}, nil
}
func (srv *Server) Run() error {
// TODO: refactor this when https://github.com/gofiber/contrib/pull/1069 is merged
srv.server.Get("/swagger.json", func(c *fiber.Ctx) error {
return c.Status(fiber.StatusOK).Type("json").Send(docs.SwaggerJSON)
})
srv.server.Use(otelfiber.Middleware())
srv.server.Use(fiberzap.New(fiberzap.Config{
Logger: srv.telemetry.Logger,
}))
v1 := srv.server.Group("/v1")
v1.Get("/swagger/*", swagger.New(swagger.Config{
Title: "Glide API Docs",
URL: "/swagger.json",
}))
v1.Get("/language/", LangRoutersHandler(srv.routerManager))
v1.Post("/language/:router/chat/", LangChatHandler(srv.routerManager))
v1.Use("/language/:router/chatStream", LangStreamRouterValidator(srv.routerManager))
v1.Get("/language/:router/chatStream", LangStreamChatHandler(srv.telemetry, srv.routerManager))
v1.Get("/health/", HealthHandler)
srv.server.Use(NotFoundHandler)
return srv.server.Listen(srv.config.Address())
}
func (srv *Server) Shutdown(ctx context.Context) error {
exitWaitTime := 5 * time.Second
srv.telemetry.Logger.Info(
fmt.Sprintf("Begin graceful shutdown, wait at most %d seconds...", exitWaitTime/time.Second),
)
c, cancel := context.WithTimeout(ctx, exitWaitTime)
defer cancel()
if err := srv.server.ShutdownWithContext(c); err != nil {
if errors.Is(err, context.DeadlineExceeded) {
srv.telemetry.Logger.Info("Server closed forcefully due to shutdown timeout")
return nil
}
return err
}
return nil
}