1
0

group.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. package cluster
  2. import (
  3. "net/http"
  4. "github.com/0xJacky/Nginx-UI/model"
  5. "github.com/gin-gonic/gin"
  6. "github.com/samber/lo"
  7. "github.com/uozi-tech/cosy"
  8. "gorm.io/gorm"
  9. )
  10. type APIRespEnvGroup struct {
  11. model.EnvGroup
  12. SyncNodes []*model.Environment `json:"sync_nodes,omitempty" gorm:"-"`
  13. }
  14. func GetGroup(c *gin.Context) {
  15. cosy.Core[model.EnvGroup](c).
  16. SetTransformer(func(m *model.EnvGroup) any {
  17. db := cosy.UseDB(c)
  18. var nodes []*model.Environment
  19. if len(m.SyncNodeIds) > 0 {
  20. db.Model(&model.Environment{}).
  21. Where("id IN (?)", m.SyncNodeIds).
  22. Find(&nodes)
  23. }
  24. return &APIRespEnvGroup{
  25. EnvGroup: *m,
  26. SyncNodes: nodes,
  27. }
  28. }).
  29. Get()
  30. }
  31. func GetGroupList(c *gin.Context) {
  32. cosy.Core[model.EnvGroup](c).GormScope(func(tx *gorm.DB) *gorm.DB {
  33. return tx.Order("order_id ASC")
  34. }).
  35. SetScan(func(tx *gorm.DB) any {
  36. var groups []*APIRespEnvGroup
  37. var nodeIDs []uint64
  38. tx.Find(&groups)
  39. for _, group := range groups {
  40. nodeIDs = append(nodeIDs, group.SyncNodeIds...)
  41. }
  42. var nodes []*model.Environment
  43. nodeIDs = lo.Uniq(nodeIDs)
  44. if len(nodeIDs) > 0 {
  45. db := cosy.UseDB(c)
  46. db.Model(&model.Environment{}).
  47. Where("id IN (?)", nodeIDs).
  48. Find(&nodes)
  49. }
  50. nodeMap := lo.SliceToMap(nodes, func(node *model.Environment) (uint64, *model.Environment) {
  51. return node.ID, node
  52. })
  53. for _, group := range groups {
  54. for _, nodeID := range group.SyncNodeIds {
  55. if node, ok := nodeMap[nodeID]; ok {
  56. group.SyncNodes = append(group.SyncNodes, node)
  57. }
  58. }
  59. }
  60. return groups
  61. }).
  62. PagingList()
  63. }
  64. func ReloadNginx(c *gin.Context) {
  65. var json struct {
  66. NodeIDs []uint64 `json:"node_ids" binding:"required"`
  67. }
  68. if !cosy.BindAndValid(c, &json) {
  69. return
  70. }
  71. go syncReload(json.NodeIDs)
  72. c.JSON(http.StatusOK, gin.H{
  73. "message": "ok",
  74. })
  75. }
  76. func RestartNginx(c *gin.Context) {
  77. var json struct {
  78. NodeIDs []uint64 `json:"node_ids" binding:"required"`
  79. }
  80. if !cosy.BindAndValid(c, &json) {
  81. return
  82. }
  83. go syncRestart(json.NodeIDs)
  84. c.JSON(http.StatusOK, gin.H{
  85. "message": "ok",
  86. })
  87. }
  88. func AddGroup(c *gin.Context) {
  89. cosy.Core[model.EnvGroup](c).
  90. SetValidRules(gin.H{
  91. "name": "required",
  92. "sync_node_ids": "omitempty",
  93. "post_sync_action": "omitempty,oneof=" + model.PostSyncActionNone + " " + model.PostSyncActionReloadNginx,
  94. "upstream_test_type": "omitempty,oneof=" + model.UpstreamTestLocal + " " + model.UpstreamTestRemote + " " + model.UpstreamTestMirror,
  95. }).
  96. Create()
  97. }
  98. func ModifyGroup(c *gin.Context) {
  99. cosy.Core[model.EnvGroup](c).
  100. SetValidRules(gin.H{
  101. "name": "required",
  102. "sync_node_ids": "omitempty",
  103. "post_sync_action": "omitempty,oneof=" + model.PostSyncActionNone + " " + model.PostSyncActionReloadNginx,
  104. "upstream_test_type": "omitempty,oneof=" + model.UpstreamTestLocal + " " + model.UpstreamTestRemote + " " + model.UpstreamTestMirror,
  105. }).
  106. Modify()
  107. }
  108. func DeleteGroup(c *gin.Context) {
  109. cosy.Core[model.EnvGroup](c).Destroy()
  110. }
  111. func RecoverGroup(c *gin.Context) {
  112. cosy.Core[model.EnvGroup](c).Recover()
  113. }
  114. func UpdateGroupsOrder(c *gin.Context) {
  115. cosy.Core[model.EnvGroup](c).UpdateOrder()
  116. }