Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

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. ctx, committer, err := db.TxContext()
  22. if err != nil {
  23. return err
  24. }
  25. defer committer.Close()
  26. staring := isStaring(db.GetEngine(ctx), userID, repoID)
  27. if star {
  28. if staring {
  29. return nil
  30. }
  31. if err := db.Insert(ctx, &Star{UID: userID, RepoID: repoID}); err != nil {
  32. return err
  33. }
  34. if _, err := db.Exec(ctx, "UPDATE `repository` SET num_stars = num_stars + 1 WHERE id = ?", repoID); err != nil {
  35. return err
  36. }
  37. if _, err := db.Exec(ctx, "UPDATE `user` SET num_stars = num_stars + 1 WHERE id = ?", userID); err != nil {
  38. return err
  39. }
  40. } else {
  41. if !staring {
  42. return nil
  43. }
  44. if _, err := db.DeleteByBean(ctx, &Star{UID: userID, RepoID: repoID}); err != nil {
  45. return err
  46. }
  47. if _, err := db.Exec(ctx, "UPDATE `repository` SET num_stars = num_stars - 1 WHERE id = ?", repoID); err != nil {
  48. return err
  49. }
  50. if _, err := db.Exec(ctx, "UPDATE `user` SET num_stars = num_stars - 1 WHERE id = ?", userID); err != nil {
  51. return err
  52. }
  53. }
  54. return committer.Commit()
  55. }
  56. // IsStaring checks if user has starred given repository.
  57. func IsStaring(userID, repoID int64) bool {
  58. return isStaring(db.GetEngine(db.DefaultContext), userID, repoID)
  59. }
  60. func isStaring(e db.Engine, userID, repoID int64) bool {
  61. has, _ := e.Get(&Star{UID: userID, RepoID: repoID})
  62. return has
  63. }
  64. // GetStargazers returns the users that starred the repo.
  65. func (repo *Repository) GetStargazers(opts db.ListOptions) ([]*User, error) {
  66. sess := db.GetEngine(db.DefaultContext).Where("star.repo_id = ?", repo.ID).
  67. Join("LEFT", "star", "`user`.id = star.uid")
  68. if opts.Page > 0 {
  69. sess = db.SetSessionPagination(sess, &opts)
  70. users := make([]*User, 0, opts.PageSize)
  71. return users, sess.Find(&users)
  72. }
  73. users := make([]*User, 0, 8)
  74. return users, sess.Find(&users)
  75. }
  76. // GetStarredRepos returns the repos the user starred.
  77. func (u *User) GetStarredRepos(private bool, page, pageSize int, orderBy string) (repos RepositoryList, err error) {
  78. if len(orderBy) == 0 {
  79. orderBy = "updated_unix DESC"
  80. }
  81. sess := db.GetEngine(db.DefaultContext).
  82. Join("INNER", "star", "star.repo_id = repository.id").
  83. Where("star.uid = ?", u.ID).
  84. OrderBy(orderBy)
  85. if !private {
  86. sess = sess.And("is_private = ?", false)
  87. }
  88. if page <= 0 {
  89. page = 1
  90. }
  91. sess.Limit(pageSize, (page-1)*pageSize)
  92. repos = make([]*Repository, 0, pageSize)
  93. if err = sess.Find(&repos); err != nil {
  94. return
  95. }
  96. if err = repos.loadAttributes(db.GetEngine(db.DefaultContext)); err != nil {
  97. return
  98. }
  99. return
  100. }
  101. // GetStarredRepoCount returns the numbers of repo the user starred.
  102. func (u *User) GetStarredRepoCount(private bool) (int64, error) {
  103. sess := db.GetEngine(db.DefaultContext).
  104. Join("INNER", "star", "star.repo_id = repository.id").
  105. Where("star.uid = ?", u.ID)
  106. if !private {
  107. sess = sess.And("is_private = ?", false)
  108. }
  109. return sess.Count(&Repository{})
  110. }