list.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package sites
  2. import (
  3. "net/http"
  4. "os"
  5. "path/filepath"
  6. "strings"
  7. "github.com/0xJacky/Nginx-UI/internal/config"
  8. "github.com/0xJacky/Nginx-UI/internal/nginx"
  9. "github.com/0xJacky/Nginx-UI/internal/site"
  10. "github.com/0xJacky/Nginx-UI/model"
  11. "github.com/0xJacky/Nginx-UI/query"
  12. "github.com/gin-gonic/gin"
  13. "github.com/samber/lo"
  14. "github.com/spf13/cast"
  15. "github.com/uozi-tech/cosy"
  16. )
  17. func GetSiteList(c *gin.Context) {
  18. name := c.Query("name")
  19. status := c.Query("status")
  20. orderBy := c.Query("sort_by")
  21. sort := c.DefaultQuery("order", "desc")
  22. queryEnvGroupId := cast.ToUint64(c.Query("env_group_id"))
  23. configFiles, err := os.ReadDir(nginx.GetConfPath("sites-available"))
  24. if err != nil {
  25. cosy.ErrHandler(c, cosy.WrapErrorWithParams(site.ErrReadDirFailed, err.Error()))
  26. return
  27. }
  28. enabledConfig, err := os.ReadDir(nginx.GetConfPath("sites-enabled"))
  29. if err != nil {
  30. cosy.ErrHandler(c, cosy.WrapErrorWithParams(site.ErrReadDirFailed, err.Error()))
  31. return
  32. }
  33. s := query.Site
  34. sTx := s.Preload(s.EnvGroup)
  35. if queryEnvGroupId != 0 {
  36. sTx.Where(s.EnvGroupID.Eq(queryEnvGroupId))
  37. }
  38. sites, err := sTx.Find()
  39. if err != nil {
  40. cosy.ErrHandler(c, err)
  41. return
  42. }
  43. sitesMap := lo.SliceToMap(sites, func(item *model.Site) (string, *model.Site) {
  44. return filepath.Base(item.Path), item
  45. })
  46. configStatusMap := make(map[string]config.ConfigStatus)
  47. for _, site := range configFiles {
  48. configStatusMap[site.Name()] = config.StatusDisabled
  49. }
  50. // Check for enabled sites and maintenance mode sites
  51. for _, enabledSite := range enabledConfig {
  52. name := enabledSite.Name()
  53. // Check if this is a maintenance mode configuration
  54. if strings.HasSuffix(name, site.MaintenanceSuffix) {
  55. // Extract the original site name by removing maintenance suffix
  56. originalName := strings.TrimSuffix(name, site.MaintenanceSuffix)
  57. configStatusMap[originalName] = config.StatusMaintenance
  58. } else {
  59. configStatusMap[name] = config.StatusEnabled
  60. }
  61. }
  62. var configs []config.Config
  63. for i := range configFiles {
  64. file := configFiles[i]
  65. fileInfo, _ := file.Info()
  66. if file.IsDir() {
  67. continue
  68. }
  69. // name filter
  70. if name != "" && !strings.Contains(file.Name(), name) {
  71. continue
  72. }
  73. // status filter
  74. if status != "" && configStatusMap[file.Name()] != config.ConfigStatus(status) {
  75. continue
  76. }
  77. var (
  78. envGroupId uint64
  79. envGroup *model.EnvGroup
  80. )
  81. if site, ok := sitesMap[file.Name()]; ok {
  82. envGroupId = site.EnvGroupID
  83. envGroup = site.EnvGroup
  84. }
  85. // env group filter
  86. if queryEnvGroupId != 0 && envGroupId != queryEnvGroupId {
  87. continue
  88. }
  89. indexedSite := site.GetIndexedSite(file.Name())
  90. configs = append(configs, config.Config{
  91. Name: file.Name(),
  92. ModifiedAt: fileInfo.ModTime(),
  93. Size: fileInfo.Size(),
  94. IsDir: fileInfo.IsDir(),
  95. Status: configStatusMap[file.Name()],
  96. EnvGroupID: envGroupId,
  97. EnvGroup: envGroup,
  98. Urls: indexedSite.Urls,
  99. })
  100. }
  101. configs = config.Sort(orderBy, sort, configs)
  102. c.JSON(http.StatusOK, gin.H{
  103. "data": configs,
  104. })
  105. }