You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

star.go 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. // Copyright 2016 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/models/db"
  7. "code.gitea.io/gitea/modules/timeutil"
  8. )
  9. // Star represents a starred repo by an user.
  10. type Star struct {
  11. ID int64 `xorm:"pk autoincr"`
  12. UID int64 `xorm:"UNIQUE(s)"`
  13. RepoID int64 `xorm:"UNIQUE(s)"`
  14. CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"`
  15. }
  16. func init() {
  17. db.RegisterModel(new(Star))
  18. }
  19. // StarRepo or unstar repository.
  20. func StarRepo(userID, repoID int64, star bool) error {
  21. sess := db.NewSession(db.DefaultContext)
  22. defer sess.Close()
  23. if err := sess.Begin(); err != nil {
  24. return err
  25. }
  26. if star {
  27. if isStaring(sess, userID, repoID) {
  28. return nil
  29. }
  30. if _, err := sess.Insert(&Star{UID: userID, RepoID: repoID}); err != nil {
  31. return err
  32. }
  33. if _, err := sess.Exec("UPDATE `repository` SET num_stars = num_stars + 1 WHERE id = ?", repoID); err != nil {
  34. return err
  35. }
  36. if _, err := sess.Exec("UPDATE `user` SET num_stars = num_stars + 1 WHERE id = ?", userID); err != nil {
  37. return err
  38. }
  39. } else {
  40. if !isStaring(sess, userID, repoID) {
  41. return nil
  42. }
  43. if _, err := sess.Delete(&Star{UID: userID, RepoID: repoID}); err != nil {
  44. return err
  45. }
  46. if _, err := sess.Exec("UPDATE `repository` SET num_stars = num_stars - 1 WHERE id = ?", repoID); err != nil {
  47. return err
  48. }
  49. if _, err := sess.Exec("UPDATE `user` SET num_stars = num_stars - 1 WHERE id = ?", userID); err != nil {
  50. return err
  51. }
  52. }
  53. return sess.Commit()
  54. }
  55. // IsStaring checks if user has starred given repository.
  56. func IsStaring(userID, repoID int64) bool {
  57. return isStaring(db.GetEngine(db.DefaultContext), userID, repoID)
  58. }
  59. func isStaring(e db.Engine, userID, repoID int64) bool {
  60. has, _ := e.Get(&Star{UID: userID, RepoID: repoID})
  61. return has
  62. }
  63. // GetStargazers returns the users that starred the repo.
  64. func (repo *Repository) GetStargazers(opts db.ListOptions) ([]*User, error) {
  65. sess := db.GetEngine(db.DefaultContext).Where("star.repo_id = ?", repo.ID).
  66. Join("LEFT", "star", "`user`.id = star.uid")
  67. if opts.Page > 0 {
  68. sess = db.SetSessionPagination(sess, &opts)
  69. users := make([]*User, 0, opts.PageSize)
  70. return users, sess.Find(&users)
  71. }
  72. users := make([]*User, 0, 8)
  73. return users, sess.Find(&users)
  74. }
  75. // GetStarredRepos returns the repos the user starred.
  76. func (u *User) GetStarredRepos(private bool, page, pageSize int, orderBy string) (repos RepositoryList, err error) {
  77. if len(orderBy) == 0 {
  78. orderBy = "updated_unix DESC"
  79. }
  80. sess := db.GetEngine(db.DefaultContext).
  81. Join("INNER", "star", "star.repo_id = repository.id").
  82. Where("star.uid = ?", u.ID).
  83. OrderBy(orderBy)
  84. if !private {
  85. sess = sess.And("is_private = ?", false)
  86. }
  87. if page <= 0 {
  88. page = 1
  89. }
  90. sess.Limit(pageSize, (page-1)*pageSize)
  91. repos = make([]*Repository, 0, pageSize)
  92. if err = sess.Find(&repos); err != nil {
  93. return
  94. }
  95. if err = repos.loadAttributes(db.GetEngine(db.DefaultContext)); err != nil {
  96. return
  97. }
  98. return
  99. }
  100. // GetStarredRepoCount returns the numbers of repo the user starred.
  101. func (u *User) GetStarredRepoCount(private bool) (int64, error) {
  102. sess := db.GetEngine(db.DefaultContext).
  103. Join("INNER", "star", "star.repo_id = repository.id").
  104. Where("star.uid = ?", u.ID)
  105. if !private {
  106. sess = sess.And("is_private = ?", false)
  107. }
  108. return sess.Count(&Repository{})
  109. }