tcpforwarding.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. package repository
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. v1 "github.com/go-nunu/nunu-layout-advanced/api/v1"
  7. "github.com/go-nunu/nunu-layout-advanced/internal/model"
  8. "go.mongodb.org/mongo-driver/bson"
  9. "go.mongodb.org/mongo-driver/bson/primitive"
  10. "go.mongodb.org/mongo-driver/mongo"
  11. "time"
  12. )
  13. type TcpforwardingRepository interface {
  14. GetTcpforwarding(ctx context.Context, id int64) (*model.Tcpforwarding, error)
  15. AddTcpforwarding(ctx context.Context, req *model.Tcpforwarding) (int, error)
  16. EditTcpforwarding(ctx context.Context, req *model.Tcpforwarding) error
  17. DeleteTcpforwarding(ctx context.Context, id int64) error
  18. GetTcpforwardingWafTcpIdById(ctx context.Context, id int) (int, error)
  19. GetTcpForwardingPortCountByHostId(ctx context.Context, hostId int) (int64, error)
  20. GetTcpForwardingAllIdsByID(ctx context.Context, hostId int) ([]int, error)
  21. AddTcpforwardingIps(ctx context.Context,req model.TcpForwardingRule) (primitive.ObjectID, error)
  22. EditTcpforwardingIps(ctx context.Context, req model.TcpForwardingRule) error
  23. GetTcpForwardingIpsByID(ctx context.Context, tcpId int) (*model.TcpForwardingRule, error)
  24. DeleteTcpForwardingIpsById(ctx context.Context, tcpId int) error
  25. // 获取IP数量等于1的IP
  26. GetIpCountByIp(ctx context.Context,ips []string) ([]v1.IpCountResult, error)
  27. // 获取端口数量
  28. GetPortCount(ctx context.Context,hostId int64, port string) (int64, error)
  29. }
  30. func NewTcpforwardingRepository(
  31. repository *Repository,
  32. ) TcpforwardingRepository {
  33. return &tcpforwardingRepository{
  34. Repository: repository,
  35. }
  36. }
  37. type tcpforwardingRepository struct {
  38. *Repository
  39. }
  40. func (r *tcpforwardingRepository) GetTcpforwarding(ctx context.Context, id int64) (*model.Tcpforwarding, error) {
  41. var tcpforwarding model.Tcpforwarding
  42. if err := r.db.Where("id = ?", id).First(&tcpforwarding).Error; err != nil {
  43. return nil, err
  44. }
  45. return &tcpforwarding, nil
  46. }
  47. func (r *tcpforwardingRepository) AddTcpforwarding(ctx context.Context, req *model.Tcpforwarding) (int, error) {
  48. if err := r.db.Create(req).Error; err != nil {
  49. return 0, err
  50. }
  51. return req.Id, nil
  52. }
  53. func (r *tcpforwardingRepository) EditTcpforwarding(ctx context.Context, req *model.Tcpforwarding) error {
  54. data := map[string]interface{}{
  55. "proxy" : req.Proxy,
  56. }
  57. if err := r.db.Updates(req).Updates(data).Error; err != nil {
  58. return err
  59. }
  60. return nil
  61. }
  62. func (r *tcpforwardingRepository) DeleteTcpforwarding(ctx context.Context, id int64) error {
  63. if err := r.db.Where("id = ?", id).Delete(&model.Tcpforwarding{}).Error; err != nil {
  64. return err
  65. }
  66. return nil
  67. }
  68. func (r *tcpforwardingRepository) GetTcpforwardingWafTcpIdById(ctx context.Context, id int) (int, error) {
  69. var WafTcpId int
  70. if err := r.db.Model(&model.Tcpforwarding{}).Where("id = ?", id).Select("waf_tcp_id").Find(&WafTcpId).Error; err != nil {
  71. return 0, err
  72. }
  73. return WafTcpId, nil
  74. }
  75. func (r *tcpforwardingRepository) GetTcpForwardingPortCountByHostId(ctx context.Context, hostId int) (int64, error) {
  76. var count int64
  77. if err := r.db.Model(&model.Tcpforwarding{}).Where("host_id = ?", hostId).Count(&count).Error; err != nil {
  78. return 0, err
  79. }
  80. return count, nil
  81. }
  82. func (r *tcpforwardingRepository) GetTcpForwardingAllIdsByID(ctx context.Context, hostId int) ([]int, error) {
  83. var res []int
  84. if err := r.db.WithContext(ctx).Model(&model.Tcpforwarding{}).Where("host_id = ?", hostId).Select("id").Find(&res).Error; err != nil {
  85. return nil, err
  86. }
  87. return res, nil
  88. }
  89. //mongodb 插入
  90. func (r *tcpforwardingRepository) AddTcpforwardingIps(ctx context.Context,req model.TcpForwardingRule) (primitive.ObjectID, error) {
  91. collection := r.mongoDB.Collection("tcp_forwarding_rules")
  92. req.CreatedAt = time.Now()
  93. result, err := collection.InsertOne(ctx, req)
  94. if err != nil {
  95. return primitive.NilObjectID, fmt.Errorf("插入MongoDB失败: %w", err)
  96. }
  97. // 返回插入文档的ID
  98. return result.InsertedID.(primitive.ObjectID), nil
  99. }
  100. func (r *tcpforwardingRepository) EditTcpforwardingIps(ctx context.Context, req model.TcpForwardingRule) error {
  101. collection := r.mongoDB.Collection("tcp_forwarding_rules")
  102. updateData := bson.M{}
  103. if req.Uid != 0 {
  104. updateData["uid"] = req.Uid
  105. }
  106. if req.HostId != 0 {
  107. updateData["host_id"] = req.HostId
  108. }
  109. if req.TcpId != 0 {
  110. updateData["tcp_id"] = req.TcpId
  111. }
  112. if len(req.BackendList) > 0 {
  113. updateData["backend_list"] = req.BackendList
  114. }
  115. updateData["cdn_origin_ids"] = req.CdnOriginIds
  116. // 始终更新更新时间
  117. updateData["updated_at"] = time.Now()
  118. // 如果没有任何字段需要更新,则直接返回
  119. if len(updateData) == 0 {
  120. return nil
  121. }
  122. // 执行更新
  123. update := bson.M{"$set": updateData}
  124. err := collection.UpdateOne(ctx, bson.M{"tcp_id": req.TcpId}, update)
  125. if err != nil {
  126. if errors.Is(err, mongo.ErrNoDocuments) {
  127. return fmt.Errorf("记录不存在")
  128. }
  129. return fmt.Errorf("更新MongoDB文档失败: %w", err)
  130. }
  131. return nil
  132. }
  133. func (r *tcpforwardingRepository) GetTcpForwardingIpsByID(ctx context.Context, tcpId int) (*model.TcpForwardingRule, error) {
  134. collection := r.mongoDB.Collection("tcp_forwarding_rules")
  135. var res model.TcpForwardingRule
  136. err := collection.Find(ctx, bson.M{"tcp_id": tcpId}).One(&res)
  137. if err != nil {
  138. if errors.Is(err, mongo.ErrNoDocuments) {
  139. return nil, fmt.Errorf("记录不存在")
  140. }
  141. return nil, fmt.Errorf("查询MongoDB失败: %w", err)
  142. }
  143. return &res, nil
  144. }
  145. func (r *tcpforwardingRepository) DeleteTcpForwardingIpsById(ctx context.Context, tcpId int) error {
  146. collection := r.mongoDB.Collection("tcp_forwarding_rules")
  147. err := collection.Remove(ctx, bson.M{"tcp_id": tcpId})
  148. if err != nil {
  149. if errors.Is(err, mongo.ErrNoDocuments) {
  150. return fmt.Errorf("记录不存在")
  151. }
  152. return fmt.Errorf("删除MongoDB文档失败: %w", err)
  153. }
  154. return nil
  155. }
  156. // 获取IP数量等于1的IP
  157. func (r *tcpforwardingRepository) GetIpCountByIp(ctx context.Context,ips []string) ([]v1.IpCountResult, error) {
  158. if len(ips) == 0 {
  159. return []v1.IpCountResult{}, nil
  160. }
  161. pipeline := []bson.M{
  162. {
  163. "$match": bson.M{
  164. "ip": bson.M{"$in": ips},
  165. },
  166. },
  167. {
  168. "$group": bson.M{
  169. "_id": "$ip",
  170. "count": bson.M{"$sum": 1},
  171. },
  172. },
  173. {
  174. "$project": bson.M{
  175. "_id": 0, // 不输出默认的_id
  176. "ip": "$_id", // 将分组的_id字段重命名为ip
  177. "count": 1, // 保留count字段
  178. },
  179. },
  180. }
  181. var results []v1.IpCountResult
  182. // 使用 qmgo 执行聚合查询
  183. err := r.mongoDB.Collection("tcp_forwarding_rules").Aggregate(ctx, pipeline).All(&results)
  184. if err != nil {
  185. return nil, err
  186. }
  187. return results, nil
  188. }
  189. func (r *tcpforwardingRepository) GetPortCount(ctx context.Context,hostId int64, port string) (int64, error) {
  190. var count int64
  191. if err := r.db.WithContext(ctx).Model(&model.Tcpforwarding{}).Where("host_id = ? AND port = ?", hostId, port).Count(&count).Error; err != nil {
  192. return 0, err
  193. }
  194. return count, nil
  195. }