peer.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. func (ps *PeerService) Delete(u *model.Peer) error {
  88. return global.DB.Delete(u).Error
  89. }
  90. // BatchDelete
  91. func (ps *PeerService) BatchDelete(ids []uint) error {
  92. return global.DB.Where("row_id in (?)", ids).Delete(&model.Peer{}).Error
  93. }
  94. // Update 更新
  95. func (ps *PeerService) Update(u *model.Peer) error {
  96. return global.DB.Model(u).Updates(u).Error
  97. }