Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

dboptions.go 2.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. // Copyright 2023 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package issues
  4. import (
  5. "code.gitea.io/gitea/models/db"
  6. issues_model "code.gitea.io/gitea/models/issues"
  7. "code.gitea.io/gitea/modules/optional"
  8. )
  9. func ToSearchOptions(keyword string, opts *issues_model.IssuesOptions) *SearchOptions {
  10. searchOpt := &SearchOptions{
  11. Keyword: keyword,
  12. RepoIDs: opts.RepoIDs,
  13. AllPublic: opts.AllPublic,
  14. IsPull: opts.IsPull,
  15. IsClosed: opts.IsClosed,
  16. }
  17. if len(opts.LabelIDs) == 1 && opts.LabelIDs[0] == 0 {
  18. searchOpt.NoLabelOnly = true
  19. } else {
  20. for _, labelID := range opts.LabelIDs {
  21. if labelID > 0 {
  22. searchOpt.IncludedLabelIDs = append(searchOpt.IncludedLabelIDs, labelID)
  23. } else {
  24. searchOpt.ExcludedLabelIDs = append(searchOpt.ExcludedLabelIDs, -labelID)
  25. }
  26. }
  27. // opts.IncludedLabelNames and opts.ExcludedLabelNames are not supported here.
  28. // It's not a TO DO, it's just unnecessary.
  29. }
  30. if len(opts.MilestoneIDs) == 1 && opts.MilestoneIDs[0] == db.NoConditionID {
  31. searchOpt.MilestoneIDs = []int64{0}
  32. } else {
  33. searchOpt.MilestoneIDs = opts.MilestoneIDs
  34. }
  35. // See the comment of issues_model.SearchOptions for the reason why we need to convert
  36. convertID := func(id int64) optional.Option[int64] {
  37. if id > 0 {
  38. return optional.Some(id)
  39. }
  40. if id == db.NoConditionID {
  41. return optional.None[int64]()
  42. }
  43. return nil
  44. }
  45. searchOpt.ProjectID = convertID(opts.ProjectID)
  46. searchOpt.ProjectBoardID = convertID(opts.ProjectBoardID)
  47. searchOpt.PosterID = convertID(opts.PosterID)
  48. searchOpt.AssigneeID = convertID(opts.AssigneeID)
  49. searchOpt.MentionID = convertID(opts.MentionedID)
  50. searchOpt.ReviewedID = convertID(opts.ReviewedID)
  51. searchOpt.ReviewRequestedID = convertID(opts.ReviewRequestedID)
  52. searchOpt.SubscriberID = convertID(opts.SubscriberID)
  53. if opts.UpdatedAfterUnix > 0 {
  54. searchOpt.UpdatedAfterUnix = optional.Some(opts.UpdatedAfterUnix)
  55. }
  56. if opts.UpdatedBeforeUnix > 0 {
  57. searchOpt.UpdatedBeforeUnix = optional.Some(opts.UpdatedBeforeUnix)
  58. }
  59. searchOpt.Paginator = opts.Paginator
  60. switch opts.SortType {
  61. case "", "latest":
  62. searchOpt.SortBy = SortByCreatedDesc
  63. case "oldest":
  64. searchOpt.SortBy = SortByCreatedAsc
  65. case "recentupdate":
  66. searchOpt.SortBy = SortByUpdatedDesc
  67. case "leastupdate":
  68. searchOpt.SortBy = SortByUpdatedAsc
  69. case "mostcomment":
  70. searchOpt.SortBy = SortByCommentsDesc
  71. case "leastcomment":
  72. searchOpt.SortBy = SortByCommentsAsc
  73. case "nearduedate":
  74. searchOpt.SortBy = SortByDeadlineAsc
  75. case "farduedate":
  76. searchOpt.SortBy = SortByDeadlineDesc
  77. case "priority", "priorityrepo", "project-column-sorting":
  78. // Unsupported sort type for search
  79. fallthrough
  80. default:
  81. searchOpt.SortBy = SortByUpdatedDesc
  82. }
  83. return searchOpt
  84. }