addressBook.go 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. package service
  2. import (
  3. "Gwen/global"
  4. "Gwen/model"
  5. "github.com/google/uuid"
  6. "gorm.io/gorm"
  7. "strings"
  8. )
  9. type AddressBookService struct {
  10. }
  11. func (s *AddressBookService) Info(id string) *model.AddressBook {
  12. p := &model.AddressBook{}
  13. global.DB.Where("id = ?", id).First(p)
  14. return p
  15. }
  16. func (s *AddressBookService) InfoByUserIdAndId(userid uint, id string) *model.AddressBook {
  17. p := &model.AddressBook{}
  18. global.DB.Where("user_id = ? and id = ?", userid, id).First(p)
  19. return p
  20. }
  21. func (s *AddressBookService) InfoByUserIdAndIdAndCid(userid uint, id string, cid uint) *model.AddressBook {
  22. p := &model.AddressBook{}
  23. global.DB.Where("user_id = ? and id = ? and collection_id = ?", userid, id, cid).First(p)
  24. return p
  25. }
  26. func (s *AddressBookService) InfoByRowId(id uint) *model.AddressBook {
  27. p := &model.AddressBook{}
  28. global.DB.Where("row_id = ?", id).First(p)
  29. return p
  30. }
  31. func (s *AddressBookService) ListByUserId(userId, page, pageSize uint) (res *model.AddressBookList) {
  32. res = s.List(page, pageSize, func(tx *gorm.DB) {
  33. tx.Where("user_id = ?", userId)
  34. })
  35. return
  36. }
  37. func (s *AddressBookService) ListByUserIds(userIds []uint, page, pageSize uint) (res *model.AddressBookList) {
  38. res = s.List(page, pageSize, func(tx *gorm.DB) {
  39. tx.Where("user_id in (?)", userIds)
  40. })
  41. return
  42. }
  43. // AddAddressBook
  44. func (s *AddressBookService) AddAddressBook(ab *model.AddressBook) error {
  45. return global.DB.Create(ab).Error
  46. }
  47. // UpdateAddressBook
  48. func (s *AddressBookService) UpdateAddressBook(abs []*model.AddressBook, userId uint) error {
  49. //比较peers和数据库中的数据,如果peers中的数据在数据库中不存在,则添加,如果存在则更新,如果数据库中的数据在peers中不存在,则删除
  50. // 开始事务
  51. tx := global.DB.Begin()
  52. //1. 获取数据库中的数据
  53. var dbABs []*model.AddressBook
  54. tx.Where("user_id = ?", userId).Find(&dbABs)
  55. //2. 比较peers和数据库中的数据
  56. //2.1 获取peers中的id
  57. aBIds := make(map[string]*model.AddressBook)
  58. for _, ab := range abs {
  59. aBIds[ab.Id] = ab
  60. }
  61. //2.2 获取数据库中的id
  62. dbABIds := make(map[string]*model.AddressBook)
  63. for _, dbAb := range dbABs {
  64. dbABIds[dbAb.Id] = dbAb
  65. }
  66. //2.3 比较peers和数据库中的数据
  67. for id, ab := range aBIds {
  68. dbAB, ok := dbABIds[id]
  69. ab.UserId = userId
  70. if !ok {
  71. //添加
  72. if ab.Platform == "" || ab.Username == "" || ab.Hostname == "" {
  73. peer := AllService.PeerService.FindById(ab.Id)
  74. if peer.RowId != 0 {
  75. ab.Platform = AllService.AddressBookService.PlatformFromOs(peer.Os)
  76. ab.Username = peer.Username
  77. ab.Hostname = peer.Hostname
  78. }
  79. }
  80. tx.Create(ab)
  81. } else {
  82. //更新
  83. tx.Model(&model.AddressBook{}).Where("row_id = ?", dbAB.RowId).Updates(ab)
  84. }
  85. }
  86. //2.4 删除
  87. for id, dbAB := range dbABIds {
  88. _, ok := aBIds[id]
  89. if !ok {
  90. tx.Delete(dbAB)
  91. }
  92. }
  93. tx.Commit()
  94. return nil
  95. }
  96. func (s *AddressBookService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.AddressBookList) {
  97. res = &model.AddressBookList{}
  98. res.Page = int64(page)
  99. res.PageSize = int64(pageSize)
  100. tx := global.DB.Model(&model.AddressBook{})
  101. if where != nil {
  102. where(tx)
  103. }
  104. tx.Count(&res.Total)
  105. tx.Scopes(Paginate(page, pageSize))
  106. tx.Find(&res.AddressBooks)
  107. return
  108. }
  109. // Create 创建
  110. func (s *AddressBookService) Create(u *model.AddressBook) error {
  111. res := global.DB.Create(u).Error
  112. return res
  113. }
  114. func (s *AddressBookService) Delete(u *model.AddressBook) error {
  115. return global.DB.Delete(u).Error
  116. }
  117. // Update 更新
  118. func (s *AddressBookService) Update(u *model.AddressBook) error {
  119. return global.DB.Model(u).Updates(u).Error
  120. }
  121. // UpdateAll 更新
  122. func (s *AddressBookService) UpdateAll(u *model.AddressBook) error {
  123. return global.DB.Model(u).Select("*").Omit("created_at").Updates(u).Error
  124. }
  125. // ShareByWebClient 分享
  126. func (s *AddressBookService) ShareByWebClient(m *model.ShareRecord) error {
  127. m.ShareToken = uuid.New().String()
  128. return global.DB.Create(m).Error
  129. }
  130. // SharedPeer
  131. func (s *AddressBookService) SharedPeer(shareToken string) *model.ShareRecord {
  132. m := &model.ShareRecord{}
  133. global.DB.Where("share_token = ?", shareToken).First(m)
  134. return m
  135. }
  136. // PlatformFromOs
  137. func (s *AddressBookService) PlatformFromOs(os string) string {
  138. if strings.Contains(os, "Android") || strings.Contains(os, "android") {
  139. return "Android"
  140. }
  141. if strings.Contains(os, "Windows") || strings.Contains(os, "windows") {
  142. return "Windows"
  143. }
  144. if strings.Contains(os, "Linux") || strings.Contains(os, "linux") {
  145. return "Linux"
  146. }
  147. if strings.Contains(os, "mac") || strings.Contains(os, "Mac") {
  148. return "Mac OS"
  149. }
  150. return ""
  151. }
  152. func (s *AddressBookService) ListByUserIdAndCollectionId(userId, cid, page, pageSize uint) (res *model.AddressBookList) {
  153. res = s.List(page, pageSize, func(tx *gorm.DB) {
  154. tx.Where("user_id = ? and collection_id = ?", userId, cid)
  155. })
  156. return
  157. }
  158. func (s *AddressBookService) ListCollection(page, pageSize uint, where func(tx *gorm.DB)) (res *model.AddressBookCollectionList) {
  159. res = &model.AddressBookCollectionList{}
  160. res.Page = int64(page)
  161. res.PageSize = int64(pageSize)
  162. tx := global.DB.Model(&model.AddressBookCollection{})
  163. if where != nil {
  164. where(tx)
  165. }
  166. tx.Count(&res.Total)
  167. tx.Scopes(Paginate(page, pageSize))
  168. tx.Find(&res.AddressBookCollection)
  169. return
  170. }
  171. func (s *AddressBookService) ListCollectionByIds(ids []uint) (res []*model.AddressBookCollection) {
  172. global.DB.Where("id in ?", ids).Find(&res)
  173. return res
  174. }
  175. func (s *AddressBookService) ListCollectionByUserId(userId uint) (res *model.AddressBookCollectionList) {
  176. res = s.ListCollection(1, 100, func(tx *gorm.DB) {
  177. tx.Where("user_id = ?", userId)
  178. })
  179. return
  180. }
  181. func (s *AddressBookService) CollectionInfoById(id uint) *model.AddressBookCollection {
  182. p := &model.AddressBookCollection{}
  183. global.DB.Where("id = ?", id).First(p)
  184. return p
  185. }
  186. func (s *AddressBookService) CollectionReadRules(user *model.User) (res []*model.AddressBookCollectionRule) {
  187. // personalRules
  188. var personalRules []*model.AddressBookCollectionRule
  189. tx2 := global.DB.Model(&model.AddressBookCollectionRule{})
  190. tx2.Where("type = ? and to_id = ? and rule > 0", model.ShareAddressBookRuleTypePersonal, user.Id).Find(&personalRules)
  191. res = append(res, personalRules...)
  192. //group
  193. var groupRules []*model.AddressBookCollectionRule
  194. tx3 := global.DB.Model(&model.AddressBookCollectionRule{})
  195. tx3.Where("type = ? and to_id = ? and rule > 0", model.ShareAddressBookRuleTypeGroup, user.GroupId).Find(&groupRules)
  196. res = append(res, groupRules...)
  197. return
  198. }
  199. func (s *AddressBookService) UserMaxRule(user *model.User, uid, cid uint) int {
  200. // ismy?
  201. if user.Id == uid {
  202. return model.ShareAddressBookRuleRuleFullControl
  203. }
  204. max := 0
  205. personalRules := &model.AddressBookCollectionRule{}
  206. tx := global.DB.Model(personalRules)
  207. tx.Where("type = ? and collection_id = ? and to_id = ?", model.ShareAddressBookRuleTypePersonal, cid, user.Id).First(&personalRules)
  208. if personalRules.Id != 0 {
  209. max = personalRules.Rule
  210. if max == model.ShareAddressBookRuleRuleFullControl {
  211. return max
  212. }
  213. }
  214. groupRules := &model.AddressBookCollectionRule{}
  215. tx2 := global.DB.Model(groupRules)
  216. tx2.Where("type = ? and collection_id = ? and to_id = ?", model.ShareAddressBookRuleTypeGroup, cid, user.GroupId).First(&groupRules)
  217. if groupRules.Id != 0 {
  218. if groupRules.Rule > max {
  219. max = groupRules.Rule
  220. }
  221. if max == model.ShareAddressBookRuleRuleFullControl {
  222. return max
  223. }
  224. }
  225. return max
  226. }
  227. func (s *AddressBookService) CheckUserReadPrivilege(user *model.User, uid, cid uint) bool {
  228. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleRead
  229. }
  230. func (s *AddressBookService) CheckUserWritePrivilege(user *model.User, uid, cid uint) bool {
  231. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleReadWrite
  232. }
  233. func (s *AddressBookService) CheckUserFullControlPrivilege(user *model.User, uid, cid uint) bool {
  234. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleFullControl
  235. }
  236. func (s *AddressBookService) CreateCollection(t *model.AddressBookCollection) error {
  237. return global.DB.Create(t).Error
  238. }
  239. func (s *AddressBookService) UpdateCollection(t *model.AddressBookCollection) error {
  240. return global.DB.Model(t).Updates(t).Error
  241. }
  242. func (s *AddressBookService) DeleteCollection(t *model.AddressBookCollection) error {
  243. //删除集合下的所有规则、地址簿,再删除集合
  244. tx := global.DB.Begin()
  245. tx.Where("collection_id = ?", t.Id).Delete(&model.AddressBookCollectionRule{})
  246. tx.Where("collection_id = ?", t.Id).Delete(&model.AddressBook{})
  247. tx.Delete(t)
  248. return tx.Commit().Error
  249. }
  250. func (s *AddressBookService) RuleInfoById(u uint) *model.AddressBookCollectionRule {
  251. p := &model.AddressBookCollectionRule{}
  252. global.DB.Where("id = ?", u).First(p)
  253. return p
  254. }
  255. func (s *AddressBookService) RulePersonalInfoByToIdAndCid(toid, cid uint) *model.AddressBookCollectionRule {
  256. p := &model.AddressBookCollectionRule{}
  257. global.DB.Where("type = ? and to_id = ? and collection_id = ?", model.ShareAddressBookRuleTypePersonal, toid, cid).First(p)
  258. return p
  259. }
  260. func (s *AddressBookService) CreateRule(t *model.AddressBookCollectionRule) error {
  261. return global.DB.Create(t).Error
  262. }
  263. func (s *AddressBookService) ListRules(page uint, size uint, f func(tx *gorm.DB)) *model.AddressBookCollectionRuleList {
  264. res := &model.AddressBookCollectionRuleList{}
  265. res.Page = int64(page)
  266. res.PageSize = int64(size)
  267. tx := global.DB.Model(&model.AddressBookCollectionRule{})
  268. if f != nil {
  269. f(tx)
  270. }
  271. tx.Count(&res.Total)
  272. tx.Scopes(Paginate(page, size))
  273. tx.Find(&res.AddressBookCollectionRule)
  274. return res
  275. }
  276. func (s *AddressBookService) UpdateRule(t *model.AddressBookCollectionRule) error {
  277. return global.DB.Model(t).Updates(t).Error
  278. }
  279. func (s *AddressBookService) DeleteRule(t *model.AddressBookCollectionRule) error {
  280. return global.DB.Delete(t).Error
  281. }
  282. // CheckCollectionOwner 检查Collection的所有者
  283. func (s *AddressBookService) CheckCollectionOwner(uid uint, cid uint) bool {
  284. p := s.CollectionInfoById(cid)
  285. return p.UserId == uid
  286. }