routers.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package router
  2. import (
  3. "net/http"
  4. "github.com/gin-contrib/pprof"
  5. "github.com/0xJacky/Nginx-UI/api/analytic"
  6. "github.com/0xJacky/Nginx-UI/api/backup"
  7. "github.com/0xJacky/Nginx-UI/api/certificate"
  8. "github.com/0xJacky/Nginx-UI/api/cluster"
  9. "github.com/0xJacky/Nginx-UI/api/config"
  10. "github.com/0xJacky/Nginx-UI/api/crypto"
  11. "github.com/0xJacky/Nginx-UI/api/event"
  12. "github.com/0xJacky/Nginx-UI/api/external_notify"
  13. "github.com/0xJacky/Nginx-UI/api/license"
  14. "github.com/0xJacky/Nginx-UI/api/nginx"
  15. nginxLog "github.com/0xJacky/Nginx-UI/api/nginx_log"
  16. "github.com/0xJacky/Nginx-UI/api/notification"
  17. "github.com/0xJacky/Nginx-UI/api/openai"
  18. "github.com/0xJacky/Nginx-UI/api/pages"
  19. "github.com/0xJacky/Nginx-UI/api/public"
  20. "github.com/0xJacky/Nginx-UI/api/settings"
  21. "github.com/0xJacky/Nginx-UI/api/sites"
  22. "github.com/0xJacky/Nginx-UI/api/streams"
  23. "github.com/0xJacky/Nginx-UI/api/system"
  24. "github.com/0xJacky/Nginx-UI/api/template"
  25. "github.com/0xJacky/Nginx-UI/api/terminal"
  26. "github.com/0xJacky/Nginx-UI/api/upstream"
  27. "github.com/0xJacky/Nginx-UI/api/user"
  28. "github.com/0xJacky/Nginx-UI/internal/middleware"
  29. "github.com/0xJacky/Nginx-UI/mcp"
  30. "github.com/gin-gonic/gin"
  31. "github.com/uozi-tech/cosy"
  32. cSettings "github.com/uozi-tech/cosy/settings"
  33. )
  34. func InitRouter() {
  35. r := cosy.GetEngine()
  36. r.SetTrustedProxies(nil)
  37. // Add CORS middleware to allow all origins
  38. r.Use(middleware.CORS())
  39. initEmbedRoute(r)
  40. pages.InitRouter(r)
  41. r.NoRoute(func(c *gin.Context) {
  42. c.JSON(http.StatusNotFound, gin.H{
  43. "message": "not found",
  44. })
  45. })
  46. mcp.InitRouter(r)
  47. root := r.Group("/api", middleware.IPWhiteList())
  48. {
  49. public.InitRouter(root)
  50. crypto.InitPublicRouter(root)
  51. user.InitAuthRouter(root)
  52. license.InitRouter(root)
  53. system.InitPublicRouter(root)
  54. system.InitSelfCheckRouter(root)
  55. backup.InitRouter(root)
  56. // Authorization required and not websocket request
  57. g := root.Group("/", middleware.AuthRequired(), middleware.Proxy())
  58. {
  59. if cSettings.ServerSettings.RunMode == gin.DebugMode {
  60. pprof.Register(g)
  61. }
  62. user.InitUserRouter(g)
  63. analytic.InitRouter(g)
  64. user.InitManageUserRouter(g)
  65. nginx.InitRouter(g)
  66. sites.InitRouter(g)
  67. streams.InitRouter(g)
  68. config.InitRouter(g)
  69. template.InitRouter(g)
  70. certificate.InitCertificateRouter(g)
  71. certificate.InitDNSCredentialRouter(g)
  72. certificate.InitAcmeUserRouter(g)
  73. system.InitPrivateRouter(g)
  74. settings.InitRouter(g)
  75. openai.InitRouter(g)
  76. cluster.InitRouter(g)
  77. notification.InitRouter(g)
  78. external_notify.InitRouter(g)
  79. backup.InitAutoBackupRouter(g)
  80. }
  81. // Authorization required and websocket request
  82. w := root.Group("/", middleware.AuthRequired(), middleware.ProxyWs())
  83. {
  84. analytic.InitWebSocketRouter(w)
  85. certificate.InitCertificateWebSocketRouter(w)
  86. event.InitRouter(w)
  87. o := w.Group("", middleware.RequireSecureSession())
  88. {
  89. terminal.InitRouter(o)
  90. }
  91. nginxLog.InitRouter(w)
  92. upstream.InitRouter(w)
  93. system.InitWebSocketRouter(w)
  94. nginx.InitWebSocketRouter(w)
  95. cluster.InitWebSocketRouter(w)
  96. }
  97. }
  98. }