gin.go 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package server
  2. import (
  3. "time"
  4. "github.com/gin-gonic/gin"
  5. "github.com/sirupsen/logrus"
  6. )
  7. type ServiceHandler interface {
  8. SetupRoutes(r *gin.Engine)
  9. Close() error
  10. }
  11. type Server struct {
  12. router *gin.Engine
  13. logger *logrus.Logger
  14. config *Config
  15. handlers []*ServiceHandler
  16. }
  17. func NewGinServer(logger *logrus.Logger, config *Config) (*Server, error) {
  18. if logger == nil {
  19. return nil, NewError("initialize", ErrInvalidConfig, "logger is required")
  20. }
  21. // Set Gin mode to release
  22. gin.SetMode(gin.ReleaseMode)
  23. // Initialize router
  24. router := gin.New()
  25. server := &Server{
  26. router: router,
  27. logger: logger,
  28. config: config,
  29. }
  30. // Add middleware in specific order
  31. router.Use(server.recoveryMiddleware())
  32. router.Use(server.requestIDMiddleware())
  33. router.Use(server.loggerMiddleware())
  34. router.Use(server.corsMiddleware())
  35. router.Use(server.errorHandlerMiddleware())
  36. return server, nil
  37. }
  38. func (s *Server) Router() *gin.Engine {
  39. return s.router
  40. }
  41. func (s *Server) Run() error {
  42. if err := s.router.Run(); err != nil {
  43. return NewError("run", ErrServerStartFailed, err.Error())
  44. }
  45. return nil
  46. }
  47. func (s *Server) Close() error {
  48. return nil
  49. }
  50. func (s *Server) SetupRoutes() {
  51. if len(s.handlers) == 0 {
  52. s.logger.Warn("no handlers registered")
  53. return
  54. }
  55. for _, h := range s.handlers {
  56. if h == nil {
  57. s.logger.Error("nil handler found")
  58. continue
  59. }
  60. (*h).SetupRoutes(s.router)
  61. }
  62. }
  63. // AddHealthCheck adds a basic health check endpoint
  64. func (s *Server) AddHealthCheck() {
  65. s.router.GET("/health", func(c *gin.Context) {
  66. c.JSON(200, gin.H{
  67. "status": "ok",
  68. "time": time.Now().UTC(),
  69. })
  70. })
  71. }