Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

issue_user.go 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. "context"
  7. "fmt"
  8. "code.gitea.io/gitea/models/db"
  9. repo_model "code.gitea.io/gitea/models/repo"
  10. )
  11. // IssueUser represents an issue-user relation.
  12. type IssueUser struct {
  13. ID int64 `xorm:"pk autoincr"`
  14. UID int64 `xorm:"INDEX"` // User ID.
  15. IssueID int64
  16. IsRead bool
  17. IsMentioned bool
  18. }
  19. func init() {
  20. db.RegisterModel(new(IssueUser))
  21. }
  22. func newIssueUsers(ctx context.Context, repo *repo_model.Repository, issue *Issue) error {
  23. assignees, err := getRepoAssignees(ctx, repo)
  24. if err != nil {
  25. return fmt.Errorf("getAssignees: %v", err)
  26. }
  27. // Poster can be anyone, append later if not one of assignees.
  28. isPosterAssignee := false
  29. // Leave a seat for poster itself to append later, but if poster is one of assignee
  30. // and just waste 1 unit is cheaper than re-allocate memory once.
  31. issueUsers := make([]*IssueUser, 0, len(assignees)+1)
  32. for _, assignee := range assignees {
  33. issueUsers = append(issueUsers, &IssueUser{
  34. IssueID: issue.ID,
  35. UID: assignee.ID,
  36. })
  37. isPosterAssignee = isPosterAssignee || assignee.ID == issue.PosterID
  38. }
  39. if !isPosterAssignee {
  40. issueUsers = append(issueUsers, &IssueUser{
  41. IssueID: issue.ID,
  42. UID: issue.PosterID,
  43. })
  44. }
  45. return db.Insert(ctx, issueUsers)
  46. }
  47. // UpdateIssueUserByRead updates issue-user relation for reading.
  48. func UpdateIssueUserByRead(uid, issueID int64) error {
  49. _, err := db.GetEngine(db.DefaultContext).Exec("UPDATE `issue_user` SET is_read=? WHERE uid=? AND issue_id=?", true, uid, issueID)
  50. return err
  51. }
  52. // UpdateIssueUsersByMentions updates issue-user pairs by mentioning.
  53. func UpdateIssueUsersByMentions(ctx context.Context, issueID int64, uids []int64) error {
  54. for _, uid := range uids {
  55. iu := &IssueUser{
  56. UID: uid,
  57. IssueID: issueID,
  58. }
  59. has, err := db.GetEngine(ctx).Get(iu)
  60. if err != nil {
  61. return err
  62. }
  63. iu.IsMentioned = true
  64. if has {
  65. _, err = db.GetEngine(ctx).ID(iu.ID).Cols("is_mentioned").Update(iu)
  66. } else {
  67. _, err = db.GetEngine(ctx).Insert(iu)
  68. }
  69. if err != nil {
  70. return err
  71. }
  72. }
  73. return nil
  74. }