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.

label.go 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. // Copyright 2019 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 issue
  5. import (
  6. "code.gitea.io/gitea/models"
  7. "code.gitea.io/gitea/modules/log"
  8. "code.gitea.io/gitea/modules/notification"
  9. api "code.gitea.io/gitea/modules/structs"
  10. "code.gitea.io/gitea/modules/webhook"
  11. )
  12. func sendLabelUpdatedWebhook(issue *models.Issue, doer *models.User) {
  13. var err error
  14. if err = issue.LoadRepo(); err != nil {
  15. log.Error("LoadRepo: %v", err)
  16. return
  17. }
  18. if err = issue.LoadPoster(); err != nil {
  19. log.Error("LoadPoster: %v", err)
  20. return
  21. }
  22. mode, _ := models.AccessLevel(issue.Poster, issue.Repo)
  23. if issue.IsPull {
  24. if err = issue.LoadPullRequest(); err != nil {
  25. log.Error("loadPullRequest: %v", err)
  26. return
  27. }
  28. if err = issue.PullRequest.LoadIssue(); err != nil {
  29. log.Error("LoadIssue: %v", err)
  30. return
  31. }
  32. err = webhook.PrepareWebhooks(issue.Repo, models.HookEventPullRequest, &api.PullRequestPayload{
  33. Action: api.HookIssueLabelUpdated,
  34. Index: issue.Index,
  35. PullRequest: issue.PullRequest.APIFormat(),
  36. Repository: issue.Repo.APIFormat(models.AccessModeNone),
  37. Sender: doer.APIFormat(),
  38. })
  39. } else {
  40. err = webhook.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
  41. Action: api.HookIssueLabelUpdated,
  42. Index: issue.Index,
  43. Issue: issue.APIFormat(),
  44. Repository: issue.Repo.APIFormat(mode),
  45. Sender: doer.APIFormat(),
  46. })
  47. }
  48. if err != nil {
  49. log.Error("PrepareWebhooks [is_pull: %v]: %v", issue.IsPull, err)
  50. } else {
  51. go webhook.HookQueue.Add(issue.RepoID)
  52. }
  53. }
  54. // ClearLabels clears all of an issue's labels
  55. func ClearLabels(issue *models.Issue, doer *models.User) (err error) {
  56. if err = issue.ClearLabels(doer); err != nil {
  57. return
  58. }
  59. notification.NotifyIssueClearLabels(doer, issue)
  60. return nil
  61. }
  62. // AddLabel adds a new label to the issue.
  63. func AddLabel(issue *models.Issue, doer *models.User, label *models.Label) error {
  64. if err := models.NewIssueLabel(issue, label, doer); err != nil {
  65. return err
  66. }
  67. sendLabelUpdatedWebhook(issue, doer)
  68. return nil
  69. }
  70. // AddLabels adds a list of new labels to the issue.
  71. func AddLabels(issue *models.Issue, doer *models.User, labels []*models.Label) error {
  72. if err := models.NewIssueLabels(issue, labels, doer); err != nil {
  73. return err
  74. }
  75. sendLabelUpdatedWebhook(issue, doer)
  76. return nil
  77. }
  78. // RemoveLabel removes a label from issue by given ID.
  79. func RemoveLabel(issue *models.Issue, doer *models.User, label *models.Label) error {
  80. if err := issue.LoadRepo(); err != nil {
  81. return err
  82. }
  83. perm, err := models.GetUserRepoPermission(issue.Repo, doer)
  84. if err != nil {
  85. return err
  86. }
  87. if !perm.CanWriteIssuesOrPulls(issue.IsPull) {
  88. return models.ErrLabelNotExist{}
  89. }
  90. if err := models.DeleteIssueLabel(issue, label, doer); err != nil {
  91. return err
  92. }
  93. sendLabelUpdatedWebhook(issue, doer)
  94. return nil
  95. }