peer.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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. // Create 创建
  72. func (ps *PeerService) Create(u *model.Peer) error {
  73. res := global.DB.Create(u).Error
  74. return res
  75. }
  76. func (ps *PeerService) Delete(u *model.Peer) error {
  77. return global.DB.Delete(u).Error
  78. }
  79. // BatchDelete
  80. func (ps *PeerService) BatchDelete(ids []uint) error {
  81. return global.DB.Where("row_id in (?)", ids).Delete(&model.Peer{}).Error
  82. }
  83. // Update 更新
  84. func (ps *PeerService) Update(u *model.Peer) error {
  85. return global.DB.Model(u).Updates(u).Error
  86. }