peer.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package service
  2. import (
  3. "Gwen/global"
  4. "Gwen/model"
  5. "gorm.io/gorm"
  6. )
  7. type PeerService struct {
  8. }
  9. // FindById 根据id查找
  10. func (ps *PeerService) FindById(id string) *model.Peer {
  11. p := &model.Peer{}
  12. global.DB.Where("id = ?", id).First(p)
  13. return p
  14. }
  15. func (ps *PeerService) FindByUuid(uuid string) *model.Peer {
  16. p := &model.Peer{}
  17. global.DB.Where("uuid = ?", uuid).First(p)
  18. return p
  19. }
  20. func (ps *PeerService) InfoByRowId(id uint) *model.Peer {
  21. p := &model.Peer{}
  22. global.DB.Where("row_id = ?", id).First(p)
  23. return p
  24. }
  25. // FindByUserIdAndUuid 根据用户id和uuid查找peer
  26. func (ps *PeerService) FindByUserIdAndUuid(uuid string,userId uint) *model.Peer {
  27. p := &model.Peer{}
  28. global.DB.Where("uuid = ? and user_id = ?", uuid, userId).First(p)
  29. return p
  30. }
  31. // UuidBindUserId 绑定用户id
  32. func (ps *PeerService) UuidBindUserId(uuid string, userId uint) {
  33. peer := ps.FindByUuid(uuid)
  34. if peer.RowId > 0 {
  35. peer.UserId = userId
  36. ps.Update(peer)
  37. }
  38. }
  39. // UuidUnbindUserId 解绑用户id, 用于用户注销
  40. func (ps *PeerService) UuidUnbindUserId(uuid string, userId uint) {
  41. peer := ps.FindByUserIdAndUuid(uuid, userId)
  42. if peer.RowId > 0 {
  43. global.DB.Model(peer).Update("user_id", 0)
  44. }
  45. }
  46. // ListByUserIds 根据用户id取列表
  47. func (ps *PeerService) ListByUserIds(userIds []uint, page, pageSize uint) (res *model.PeerList) {
  48. res = &model.PeerList{}
  49. res.Page = int64(page)
  50. res.PageSize = int64(pageSize)
  51. tx := global.DB.Model(&model.Peer{})
  52. tx.Where("user_id in (?)", userIds)
  53. tx.Count(&res.Total)
  54. tx.Scopes(Paginate(page, pageSize))
  55. tx.Find(&res.Peers)
  56. return
  57. }
  58. func (ps *PeerService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.PeerList) {
  59. res = &model.PeerList{}
  60. res.Page = int64(page)
  61. res.PageSize = int64(pageSize)
  62. tx := global.DB.Model(&model.Peer{})
  63. if where != nil {
  64. where(tx)
  65. }
  66. tx.Count(&res.Total)
  67. tx.Scopes(Paginate(page, pageSize))
  68. tx.Find(&res.Peers)
  69. return
  70. }
  71. // ListFilterByUserId 根据用户id过滤Peer列表
  72. func (ps *PeerService) ListFilterByUserId(page, pageSize uint, where func(tx *gorm.DB), userId uint) (res *model.PeerList) {
  73. userWhere := func(tx *gorm.DB) {
  74. tx.Where("user_id = ?", userId)
  75. // 如果还有额外的筛选条件,执行它
  76. if where != nil {
  77. where(tx)
  78. }
  79. }
  80. return ps.List(page, pageSize, userWhere)
  81. }
  82. // Create 创建
  83. func (ps *PeerService) Create(u *model.Peer) error {
  84. res := global.DB.Create(u).Error
  85. return res
  86. }
  87. // Delete 删除, 同时也应该删除token
  88. func (ps *PeerService) Delete(u *model.Peer) error {
  89. uuid := u.Uuid
  90. err := global.DB.Delete(u).Error
  91. if err != nil {
  92. return err
  93. }
  94. // 删除token
  95. return AllService.UserService.FlushTokenByUuid(uuid)
  96. }
  97. // GetUuidListByIDs 根据ids获取uuid列表
  98. func (ps *PeerService) GetUuidListByIDs(ids []uint) ([]string, error) {
  99. var uuids []string
  100. err := global.DB.Model(&model.Peer{}).
  101. Where("row_id in (?)", ids).
  102. Pluck("uuid", &uuids).Error
  103. return uuids, err
  104. }
  105. // BatchDelete 批量删除, 同时也应该删除token
  106. func (ps *PeerService) BatchDelete(ids []uint) error {
  107. uuids, err := ps.GetUuidListByIDs(ids)
  108. err = global.DB.Where("row_id in (?)", ids).Delete(&model.Peer{}).Error
  109. if err != nil {
  110. return err
  111. }
  112. // 删除token
  113. return AllService.UserService.FlushTokenByUuids(uuids)
  114. }
  115. // Update 更新
  116. func (ps *PeerService) Update(u *model.Peer) error {
  117. return global.DB.Model(u).Updates(u).Error
  118. }