BigW Consortium Gitlab

issues_finder.rb 2.16 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
# Finders::Issues class
#
# Used to filter Issues collections by set of params
#
# Arguments:
#   current_user - which user use
#   params:
#     scope: 'created-by-me' or 'assigned-to-me' or 'all'
#     state: 'open' or 'closed' or 'all'
#     group_id: integer
#     project_id: integer
12
#     milestone_title: string
13 14 15 16
#     assignee_id: integer
#     search: string
#     label_name: string
#     sort: string
17
#     my_reaction_emoji: string
18
#
19
class IssuesFinder < IssuableFinder
20 21
  CONFIDENTIAL_ACCESS_LEVEL = Gitlab::Access::REPORTER

22 23 24
  def klass
    Issue
  end
25

26
  def with_confidentiality_access_check
27
    return Issue.all if user_can_see_all_confidential_issues?
28
    return Issue.where('issues.confidential IS NOT TRUE') if user_cannot_see_confidential_issues?
29 30 31 32 33 34 35 36 37 38 39

    Issue.where('
      issues.confidential IS NOT TRUE
      OR (issues.confidential = TRUE
        AND (issues.author_id = :user_id
          OR EXISTS (SELECT TRUE FROM issue_assignees WHERE user_id = :user_id AND issue_id = issues.id)
          OR issues.project_id IN(:project_ids)))',
      user_id: current_user.id,
      project_ids: current_user.authorized_projects(CONFIDENTIAL_ACCESS_LEVEL).select(:id))
  end

40 41 42 43 44 45
  private

  def init_collection
    with_confidentiality_access_check
  end

46
  def user_can_see_all_confidential_issues?
47 48
    return @user_can_see_all_confidential_issues if defined?(@user_can_see_all_confidential_issues)

49 50
    return @user_can_see_all_confidential_issues = false if current_user.blank?
    return @user_can_see_all_confidential_issues = true if current_user.full_private_access?
51

52 53
    @user_can_see_all_confidential_issues =
      project? &&
54 55 56 57
      project &&
      project.team.max_member_access(current_user.id) >= CONFIDENTIAL_ACCESS_LEVEL
  end

58
  def user_cannot_see_confidential_issues?
59 60
    return false if user_can_see_all_confidential_issues?

61
    current_user.blank?
62 63
  end

64 65 66 67 68 69 70 71 72 73 74 75
  def by_assignee(items)
    if assignee
      items.assigned_to(assignee)
    elsif no_assignee?
      items.unassigned
    elsif assignee_id? || assignee_username? # assignee not found
      items.none
    else
      items
    end
  end

76 77 78
  def item_project_ids(items)
    items&.reorder(nil)&.select(:project_id)
  end
79
end