addressBook.go 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  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. // UpdateByMap 更新
  122. func (s *AddressBookService) UpdateByMap(u *model.AddressBook, data map[string]interface{}) error {
  123. return global.DB.Model(u).Updates(data).Error
  124. }
  125. // UpdateAll 更新
  126. func (s *AddressBookService) UpdateAll(u *model.AddressBook) error {
  127. return global.DB.Model(u).Select("*").Omit("created_at").Updates(u).Error
  128. }
  129. // ShareByWebClient 分享
  130. func (s *AddressBookService) ShareByWebClient(m *model.ShareRecord) error {
  131. m.ShareToken = uuid.New().String()
  132. return global.DB.Create(m).Error
  133. }
  134. // SharedPeer
  135. func (s *AddressBookService) SharedPeer(shareToken string) *model.ShareRecord {
  136. m := &model.ShareRecord{}
  137. global.DB.Where("share_token = ?", shareToken).First(m)
  138. return m
  139. }
  140. // PlatformFromOs
  141. func (s *AddressBookService) PlatformFromOs(os string) string {
  142. if strings.Contains(os, "Android") || strings.Contains(os, "android") {
  143. return "Android"
  144. }
  145. if strings.Contains(os, "Windows") || strings.Contains(os, "windows") {
  146. return "Windows"
  147. }
  148. if strings.Contains(os, "Linux") || strings.Contains(os, "linux") {
  149. return "Linux"
  150. }
  151. if strings.Contains(os, "mac") || strings.Contains(os, "Mac") {
  152. return "Mac OS"
  153. }
  154. return ""
  155. }
  156. func (s *AddressBookService) ListByUserIdAndCollectionId(userId, cid, page, pageSize uint) (res *model.AddressBookList) {
  157. res = s.List(page, pageSize, func(tx *gorm.DB) {
  158. tx.Where("user_id = ? and collection_id = ?", userId, cid)
  159. })
  160. return
  161. }
  162. func (s *AddressBookService) ListCollection(page, pageSize uint, where func(tx *gorm.DB)) (res *model.AddressBookCollectionList) {
  163. res = &model.AddressBookCollectionList{}
  164. res.Page = int64(page)
  165. res.PageSize = int64(pageSize)
  166. tx := global.DB.Model(&model.AddressBookCollection{})
  167. if where != nil {
  168. where(tx)
  169. }
  170. tx.Count(&res.Total)
  171. tx.Scopes(Paginate(page, pageSize))
  172. tx.Find(&res.AddressBookCollection)
  173. return
  174. }
  175. func (s *AddressBookService) ListCollectionByIds(ids []uint) (res []*model.AddressBookCollection) {
  176. global.DB.Where("id in ?", ids).Find(&res)
  177. return res
  178. }
  179. func (s *AddressBookService) ListCollectionByUserId(userId uint) (res *model.AddressBookCollectionList) {
  180. res = s.ListCollection(1, 100, func(tx *gorm.DB) {
  181. tx.Where("user_id = ?", userId)
  182. })
  183. return
  184. }
  185. func (s *AddressBookService) CollectionInfoById(id uint) *model.AddressBookCollection {
  186. p := &model.AddressBookCollection{}
  187. global.DB.Where("id = ?", id).First(p)
  188. return p
  189. }
  190. func (s *AddressBookService) CollectionReadRules(user *model.User) (res []*model.AddressBookCollectionRule) {
  191. // personalRules
  192. var personalRules []*model.AddressBookCollectionRule
  193. tx2 := global.DB.Model(&model.AddressBookCollectionRule{})
  194. tx2.Where("type = ? and to_id = ? and rule > 0", model.ShareAddressBookRuleTypePersonal, user.Id).Find(&personalRules)
  195. res = append(res, personalRules...)
  196. //group
  197. var groupRules []*model.AddressBookCollectionRule
  198. tx3 := global.DB.Model(&model.AddressBookCollectionRule{})
  199. tx3.Where("type = ? and to_id = ? and rule > 0", model.ShareAddressBookRuleTypeGroup, user.GroupId).Find(&groupRules)
  200. res = append(res, groupRules...)
  201. return
  202. }
  203. func (s *AddressBookService) UserMaxRule(user *model.User, uid, cid uint) int {
  204. // ismy?
  205. if user.Id == uid {
  206. return model.ShareAddressBookRuleRuleFullControl
  207. }
  208. max := 0
  209. personalRules := &model.AddressBookCollectionRule{}
  210. tx := global.DB.Model(personalRules)
  211. tx.Where("type = ? and collection_id = ? and to_id = ?", model.ShareAddressBookRuleTypePersonal, cid, user.Id).First(&personalRules)
  212. if personalRules.Id != 0 {
  213. max = personalRules.Rule
  214. if max == model.ShareAddressBookRuleRuleFullControl {
  215. return max
  216. }
  217. }
  218. groupRules := &model.AddressBookCollectionRule{}
  219. tx2 := global.DB.Model(groupRules)
  220. tx2.Where("type = ? and collection_id = ? and to_id = ?", model.ShareAddressBookRuleTypeGroup, cid, user.GroupId).First(&groupRules)
  221. if groupRules.Id != 0 {
  222. if groupRules.Rule > max {
  223. max = groupRules.Rule
  224. }
  225. if max == model.ShareAddressBookRuleRuleFullControl {
  226. return max
  227. }
  228. }
  229. return max
  230. }
  231. func (s *AddressBookService) CheckUserReadPrivilege(user *model.User, uid, cid uint) bool {
  232. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleRead
  233. }
  234. func (s *AddressBookService) CheckUserWritePrivilege(user *model.User, uid, cid uint) bool {
  235. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleReadWrite
  236. }
  237. func (s *AddressBookService) CheckUserFullControlPrivilege(user *model.User, uid, cid uint) bool {
  238. return s.UserMaxRule(user, uid, cid) >= model.ShareAddressBookRuleRuleFullControl
  239. }
  240. func (s *AddressBookService) CreateCollection(t *model.AddressBookCollection) error {
  241. return global.DB.Create(t).Error
  242. }
  243. func (s *AddressBookService) UpdateCollection(t *model.AddressBookCollection) error {
  244. return global.DB.Model(t).Updates(t).Error
  245. }
  246. func (s *AddressBookService) DeleteCollection(t *model.AddressBookCollection) error {
  247. //删除集合下的所有规则、地址簿,再删除集合
  248. tx := global.DB.Begin()
  249. tx.Where("collection_id = ?", t.Id).Delete(&model.AddressBookCollectionRule{})
  250. tx.Where("collection_id = ?", t.Id).Delete(&model.AddressBook{})
  251. tx.Delete(t)
  252. return tx.Commit().Error
  253. }
  254. func (s *AddressBookService) RuleInfoById(u uint) *model.AddressBookCollectionRule {
  255. p := &model.AddressBookCollectionRule{}
  256. global.DB.Where("id = ?", u).First(p)
  257. return p
  258. }
  259. func (s *AddressBookService) RulePersonalInfoByToIdAndCid(toid, cid uint) *model.AddressBookCollectionRule {
  260. p := &model.AddressBookCollectionRule{}
  261. global.DB.Where("type = ? and to_id = ? and collection_id = ?", model.ShareAddressBookRuleTypePersonal, toid, cid).First(p)
  262. return p
  263. }
  264. func (s *AddressBookService) CreateRule(t *model.AddressBookCollectionRule) error {
  265. return global.DB.Create(t).Error
  266. }
  267. func (s *AddressBookService) ListRules(page uint, size uint, f func(tx *gorm.DB)) *model.AddressBookCollectionRuleList {
  268. res := &model.AddressBookCollectionRuleList{}
  269. res.Page = int64(page)
  270. res.PageSize = int64(size)
  271. tx := global.DB.Model(&model.AddressBookCollectionRule{})
  272. if f != nil {
  273. f(tx)
  274. }
  275. tx.Count(&res.Total)
  276. tx.Scopes(Paginate(page, size))
  277. tx.Find(&res.AddressBookCollectionRule)
  278. return res
  279. }
  280. func (s *AddressBookService) UpdateRule(t *model.AddressBookCollectionRule) error {
  281. return global.DB.Model(t).Updates(t).Error
  282. }
  283. func (s *AddressBookService) DeleteRule(t *model.AddressBookCollectionRule) error {
  284. return global.DB.Delete(t).Error
  285. }
  286. // CheckCollectionOwner 检查Collection的所有者
  287. func (s *AddressBookService) CheckCollectionOwner(uid uint, cid uint) bool {
  288. p := s.CollectionInfoById(cid)
  289. return p.UserId == uid
  290. }