namespace.go 3.2 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 APIRespNamespace struct {
  11. model.Namespace
  12. SyncNodes []*model.Node `json:"sync_nodes,omitempty" gorm:"-"`
  13. }
  14. func GetNamespace(c *gin.Context) {
  15. cosy.Core[model.Namespace](c).
  16. SetTransformer(func(m *model.Namespace) any {
  17. db := cosy.UseDB(c)
  18. var nodes []*model.Node
  19. if len(m.SyncNodeIds) > 0 {
  20. db.Model(&model.Node{}).
  21. Where("id IN (?)", m.SyncNodeIds).
  22. Find(&nodes)
  23. }
  24. return &APIRespNamespace{
  25. Namespace: *m,
  26. SyncNodes: nodes,
  27. }
  28. }).
  29. Get()
  30. }
  31. func GetNamespaceList(c *gin.Context) {
  32. cosy.Core[model.Namespace](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 namespaces []*APIRespNamespace
  37. var nodeIDs []uint64
  38. tx.Find(&namespaces)
  39. for _, namespace := range namespaces {
  40. nodeIDs = append(nodeIDs, namespace.SyncNodeIds...)
  41. }
  42. var nodes []*model.Node
  43. nodeIDs = lo.Uniq(nodeIDs)
  44. if len(nodeIDs) > 0 {
  45. db := cosy.UseDB(c)
  46. db.Model(&model.Node{}).
  47. Where("id IN (?)", nodeIDs).
  48. Find(&nodes)
  49. }
  50. nodeMap := lo.SliceToMap(nodes, func(node *model.Node) (uint64, *model.Node) {
  51. return node.ID, node
  52. })
  53. for _, namespace := range namespaces {
  54. for _, nodeID := range namespace.SyncNodeIds {
  55. if node, ok := nodeMap[nodeID]; ok {
  56. namespace.SyncNodes = append(namespace.SyncNodes, node)
  57. }
  58. }
  59. }
  60. return namespaces
  61. }).
  62. PagingList()
  63. }
  64. func AddNamespace(c *gin.Context) {
  65. cosy.Core[model.Namespace](c).
  66. SetValidRules(gin.H{
  67. "name": "required",
  68. "sync_node_ids": "omitempty",
  69. "post_sync_action": "omitempty,oneof=" + model.PostSyncActionNone + " " + model.PostSyncActionReloadNginx,
  70. "upstream_test_type": "omitempty,oneof=" + model.UpstreamTestLocal + " " + model.UpstreamTestRemote + " " + model.UpstreamTestMirror,
  71. }).
  72. Create()
  73. }
  74. func ModifyNamespace(c *gin.Context) {
  75. cosy.Core[model.Namespace](c).
  76. SetValidRules(gin.H{
  77. "name": "required",
  78. "sync_node_ids": "omitempty",
  79. "post_sync_action": "omitempty,oneof=" + model.PostSyncActionNone + " " + model.PostSyncActionReloadNginx,
  80. "upstream_test_type": "omitempty,oneof=" + model.UpstreamTestLocal + " " + model.UpstreamTestRemote + " " + model.UpstreamTestMirror,
  81. }).
  82. Modify()
  83. }
  84. func DeleteNamespace(c *gin.Context) {
  85. cosy.Core[model.Namespace](c).Destroy()
  86. }
  87. func RecoverNamespace(c *gin.Context) {
  88. cosy.Core[model.Namespace](c).Recover()
  89. }
  90. func UpdateNamespacesOrder(c *gin.Context) {
  91. cosy.Core[model.Namespace](c).UpdateOrder()
  92. }
  93. func ReloadNginx(c *gin.Context) {
  94. var json struct {
  95. NodeIDs []uint64 `json:"node_ids" binding:"required"`
  96. }
  97. if !cosy.BindAndValid(c, &json) {
  98. return
  99. }
  100. go syncReload(json.NodeIDs)
  101. c.JSON(http.StatusOK, gin.H{
  102. "message": "ok",
  103. })
  104. }
  105. func RestartNginx(c *gin.Context) {
  106. var json struct {
  107. NodeIDs []uint64 `json:"node_ids" binding:"required"`
  108. }
  109. if !cosy.BindAndValid(c, &json) {
  110. return
  111. }
  112. go syncRestart(json.NodeIDs)
  113. c.JSON(http.StatusOK, gin.H{
  114. "message": "ok",
  115. })
  116. }