sub.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. package sub
  2. import (
  3. "context"
  4. "crypto/tls"
  5. "io"
  6. "net"
  7. "net/http"
  8. "strconv"
  9. "strings"
  10. "x-ui/config"
  11. "x-ui/logger"
  12. "x-ui/util/common"
  13. "x-ui/web/network"
  14. "x-ui/web/service"
  15. "github.com/gin-gonic/gin"
  16. )
  17. type Server struct {
  18. httpServer *http.Server
  19. listener net.Listener
  20. sub *SUBController
  21. settingService service.SettingService
  22. ctx context.Context
  23. cancel context.CancelFunc
  24. }
  25. func NewServer() *Server {
  26. ctx, cancel := context.WithCancel(context.Background())
  27. return &Server{
  28. ctx: ctx,
  29. cancel: cancel,
  30. }
  31. }
  32. func (s *Server) initRouter() (*gin.Engine, error) {
  33. if config.IsDebug() {
  34. gin.SetMode(gin.DebugMode)
  35. } else {
  36. gin.DefaultWriter = io.Discard
  37. gin.DefaultErrorWriter = io.Discard
  38. gin.SetMode(gin.ReleaseMode)
  39. }
  40. engine := gin.Default()
  41. subPath, err := s.settingService.GetSubPath()
  42. if err != nil {
  43. return nil, err
  44. }
  45. subDomain, err := s.settingService.GetSubDomain()
  46. if err != nil {
  47. return nil, err
  48. }
  49. if subDomain != "" {
  50. validateDomain := func(c *gin.Context) {
  51. host := strings.Split(c.Request.Host, ":")[0]
  52. if host != subDomain {
  53. c.AbortWithStatus(http.StatusForbidden)
  54. return
  55. }
  56. c.Next()
  57. }
  58. engine.Use(validateDomain)
  59. }
  60. g := engine.Group(subPath)
  61. s.sub = NewSUBController(g)
  62. return engine, nil
  63. }
  64. func (s *Server) Start() (err error) {
  65. //This is an anonymous function, no function name
  66. defer func() {
  67. if err != nil {
  68. s.Stop()
  69. }
  70. }()
  71. subEnable, err := s.settingService.GetSubEnable()
  72. if err != nil {
  73. return err
  74. }
  75. if !subEnable {
  76. return nil
  77. }
  78. engine, err := s.initRouter()
  79. if err != nil {
  80. return err
  81. }
  82. certFile, err := s.settingService.GetSubCertFile()
  83. if err != nil {
  84. return err
  85. }
  86. keyFile, err := s.settingService.GetSubKeyFile()
  87. if err != nil {
  88. return err
  89. }
  90. listen, err := s.settingService.GetSubListen()
  91. if err != nil {
  92. return err
  93. }
  94. port, err := s.settingService.GetSubPort()
  95. if err != nil {
  96. return err
  97. }
  98. listenAddr := net.JoinHostPort(listen, strconv.Itoa(port))
  99. listener, err := net.Listen("tcp", listenAddr)
  100. if err != nil {
  101. return err
  102. }
  103. if certFile != "" || keyFile != "" {
  104. cert, err := tls.LoadX509KeyPair(certFile, keyFile)
  105. if err != nil {
  106. listener.Close()
  107. return err
  108. }
  109. c := &tls.Config{
  110. Certificates: []tls.Certificate{cert},
  111. }
  112. listener = network.NewAutoHttpsListener(listener)
  113. listener = tls.NewListener(listener, c)
  114. }
  115. if certFile != "" || keyFile != "" {
  116. logger.Info("Sub server run https on", listener.Addr())
  117. } else {
  118. logger.Info("Sub server run http on", listener.Addr())
  119. }
  120. s.listener = listener
  121. s.httpServer = &http.Server{
  122. Handler: engine,
  123. }
  124. go func() {
  125. s.httpServer.Serve(listener)
  126. }()
  127. return nil
  128. }
  129. func (s *Server) Stop() error {
  130. s.cancel()
  131. var err1 error
  132. var err2 error
  133. if s.httpServer != nil {
  134. err1 = s.httpServer.Shutdown(s.ctx)
  135. }
  136. if s.listener != nil {
  137. err2 = s.listener.Close()
  138. }
  139. return common.Combine(err1, err2)
  140. }
  141. func (s *Server) GetCtx() context.Context {
  142. return s.ctx
  143. }