# frozen_string_literal: true

class AccessRequestsFinder
  attr_accessor :source

  # Arguments:
  #   source - a Group or Project
  def initialize(source)
    @source = source
  end

  def execute(*args)
    execute!(*args)
  rescue Gitlab::Access::AccessDeniedError
    []
  end

  def execute!(current_user)
    raise Gitlab::Access::AccessDeniedError unless can_see_access_requests?(current_user)

    if Feature.enabled?(:project_members_index_by_project_namespace, source)
      source.namespace_requesters
    else
      source.requesters
    end
  end

  private

  def can_see_access_requests?(current_user)
    source && Ability.allowed?(current_user, :admin_member_access_request, source)
  end
end