Commit bec88a18 authored by Firdaws Farukh's avatar Firdaws Farukh Committed by Terri Chu

Update list user projects API for admins

parent 31c9e3cb
...@@ -28,6 +28,7 @@ class PersonalProjectsFinder < UnionFinder ...@@ -28,6 +28,7 @@ class PersonalProjectsFinder < UnionFinder
private private
def all_projects(current_user) def all_projects(current_user)
return [@user.personal_projects] if current_user && current_user.can_read_all_resources?
return [projects_with_min_access_level(current_user)] if current_user && min_access_level? return [projects_with_min_access_level(current_user)] if current_user && min_access_level?
projects = [] projects = []
......
...@@ -369,6 +369,9 @@ Keyset pagination supports only `order_by=id`. Other sorting options aren't avai ...@@ -369,6 +369,9 @@ Keyset pagination supports only `order_by=id`. Other sorting options aren't avai
Get a list of visible projects owned by the given user. When accessed without Get a list of visible projects owned by the given user. When accessed without
authentication, only public projects are returned. authentication, only public projects are returned.
NOTE:
Only the projects in the user's (specified in `user_id`) namespace are returned. Projects owned by the user in any group or subgroups are not returned.
This endpoint supports [keyset pagination](index.md#keyset-based-pagination) This endpoint supports [keyset pagination](index.md#keyset-based-pagination)
for selected `order_by` options. for selected `order_by` options.
......
...@@ -3,14 +3,16 @@ ...@@ -3,14 +3,16 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe PersonalProjectsFinder do RSpec.describe PersonalProjectsFinder do
let(:source_user) { create(:user) } let_it_be(:source_user) { create(:user) }
let(:current_user) { create(:user) } let_it_be(:current_user) { create(:user) }
let(:finder) { described_class.new(source_user) } let_it_be(:admin) { create(:admin) }
let(:finder) { described_class.new(source_user) }
let!(:public_project) do let!(:public_project) do
create(:project, :public, namespace: source_user.namespace, updated_at: 1.hour.ago) create(:project, :public, namespace: source_user.namespace, updated_at: 1.hour.ago, path: 'pblc')
end end
let!(:private_project) do let!(:private_project_shared) do
create(:project, :private, namespace: source_user.namespace, updated_at: 3.hours.ago, path: 'mepmep') create(:project, :private, namespace: source_user.namespace, updated_at: 3.hours.ago, path: 'mepmep')
end end
...@@ -18,8 +20,12 @@ RSpec.describe PersonalProjectsFinder do ...@@ -18,8 +20,12 @@ RSpec.describe PersonalProjectsFinder do
create(:project, :internal, namespace: source_user.namespace, updated_at: 2.hours.ago, path: 'C') create(:project, :internal, namespace: source_user.namespace, updated_at: 2.hours.ago, path: 'C')
end end
let!(:private_project_self) do
create(:project, :private, namespace: source_user.namespace, updated_at: 3.hours.ago, path: 'D')
end
before do before do
private_project.add_developer(current_user) private_project_shared.add_developer(current_user)
end end
describe 'without a current user' do describe 'without a current user' do
...@@ -29,18 +35,26 @@ RSpec.describe PersonalProjectsFinder do ...@@ -29,18 +35,26 @@ RSpec.describe PersonalProjectsFinder do
end end
describe 'with a current user' do describe 'with a current user' do
subject { finder.execute(current_user) }
context 'normal user' do context 'normal user' do
it { is_expected.to eq([public_project, internal_project, private_project]) } subject { finder.execute(current_user) }
it { is_expected.to match_array([public_project, internal_project, private_project_shared]) }
end end
context 'external' do context 'external' do
subject { finder.execute(current_user) }
before do before do
current_user.update!(external: true) current_user.update!(external: true)
end end
it { is_expected.to eq([public_project, private_project]) } it { is_expected.to match_array([public_project, private_project_shared]) }
end
context 'and searching with an admin user', :enable_admin_mode do
subject { finder.execute(admin) }
it { is_expected.to match_array([public_project, internal_project, private_project_self, private_project_shared]) }
end end
end end
end end
...@@ -1504,6 +1504,20 @@ RSpec.describe API::Projects do ...@@ -1504,6 +1504,20 @@ RSpec.describe API::Projects do
expect(json_response.map { |project| project['id'] }).to contain_exactly(private_project1.id) expect(json_response.map { |project| project['id'] }).to contain_exactly(private_project1.id)
end end
context 'and using an admin to search', :enable_admin_mode, :aggregate_errors do
it 'returns users projects when authenticated as admin' do
private_project1 = create(:project, :private, name: 'private_project1', creator_id: user4.id, namespace: user4.namespace)
# min_access_level does not make any difference when admins search for a user's projects
get api("/users/#{user4.id}/projects/", admin), params: { min_access_level: 30 }
expect(response).to have_gitlab_http_status(:ok)
expect(response).to include_pagination_headers
expect(json_response).to be_an Array
expect(json_response.map { |project| project['id'] }).to contain_exactly(project4.id, private_project1.id, public_project.id)
end
end
context 'and using the programming language filter' do context 'and using the programming language filter' do
include_context 'with language detection' include_context 'with language detection'
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment