Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

user_follow.go 2.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package models
  5. import (
  6. "code.gitea.io/gitea/modules/timeutil"
  7. )
  8. // Follow represents relations of user and his/her followers.
  9. type Follow struct {
  10. ID int64 `xorm:"pk autoincr"`
  11. UserID int64 `xorm:"UNIQUE(follow)"`
  12. FollowID int64 `xorm:"UNIQUE(follow)"`
  13. CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"`
  14. }
  15. // IsFollowing returns true if user is following followID.
  16. func IsFollowing(userID, followID int64) bool {
  17. has, _ := x.Get(&Follow{UserID: userID, FollowID: followID})
  18. return has
  19. }
  20. // FollowUser marks someone be another's follower.
  21. func FollowUser(userID, followID int64) (err error) {
  22. if userID == followID || IsFollowing(userID, followID) {
  23. return nil
  24. }
  25. sess := x.NewSession()
  26. defer sess.Close()
  27. if err = sess.Begin(); err != nil {
  28. return err
  29. }
  30. if _, err = sess.Insert(&Follow{UserID: userID, FollowID: followID}); err != nil {
  31. return err
  32. }
  33. if _, err = sess.Exec("UPDATE `user` SET num_followers = num_followers + 1 WHERE id = ?", followID); err != nil {
  34. return err
  35. }
  36. if _, err = sess.Exec("UPDATE `user` SET num_following = num_following + 1 WHERE id = ?", userID); err != nil {
  37. return err
  38. }
  39. return sess.Commit()
  40. }
  41. // UnfollowUser unmarks someone as another's follower.
  42. func UnfollowUser(userID, followID int64) (err error) {
  43. if userID == followID || !IsFollowing(userID, followID) {
  44. return nil
  45. }
  46. sess := x.NewSession()
  47. defer sess.Close()
  48. if err = sess.Begin(); err != nil {
  49. return err
  50. }
  51. if _, err = sess.Delete(&Follow{UserID: userID, FollowID: followID}); err != nil {
  52. return err
  53. }
  54. if _, err = sess.Exec("UPDATE `user` SET num_followers = num_followers - 1 WHERE id = ?", followID); err != nil {
  55. return err
  56. }
  57. if _, err = sess.Exec("UPDATE `user` SET num_following = num_following - 1 WHERE id = ?", userID); err != nil {
  58. return err
  59. }
  60. return sess.Commit()
  61. }