Commit 95a03f90 authored by Jonas Waelter's avatar Jonas Waelter

Allow parameter 'external' for normal users

parent aa240c59
...@@ -98,7 +98,7 @@ module API ...@@ -98,7 +98,7 @@ module API
end end
# rubocop: disable CodeReuse/ActiveRecord # rubocop: disable CodeReuse/ActiveRecord
get feature_category: :users do get feature_category: :users do
authenticated_as_admin! if params[:external].present? || (params[:extern_uid].present? && params[:provider].present?) authenticated_as_admin! if params[:extern_uid].present? && params[:provider].present?
unless current_user&.admin? unless current_user&.admin?
params.except!(:created_after, :created_before, :order_by, :sort, :two_factor, :without_projects) params.except!(:created_after, :created_before, :order_by, :sort, :two_factor, :without_projects)
......
...@@ -51,6 +51,12 @@ RSpec.describe UsersFinder do ...@@ -51,6 +51,12 @@ RSpec.describe UsersFinder do
expect(users).to contain_exactly(user, normal_user, external_user, omniauth_user, admin_user) expect(users).to contain_exactly(user, normal_user, external_user, omniauth_user, admin_user)
end end
it 'filters by external users' do
users = described_class.new(user, external: true).execute
expect(users).to contain_exactly(external_user)
end
it 'filters by non external users' do it 'filters by non external users' do
users = described_class.new(user, non_external: true).execute users = described_class.new(user, non_external: true).execute
......
...@@ -320,6 +320,18 @@ RSpec.describe API::Users do ...@@ -320,6 +320,18 @@ RSpec.describe API::Users do
expect(json_response).to all(include('state' => /(blocked|ldap_blocked)/)) expect(json_response).to all(include('state' => /(blocked|ldap_blocked)/))
end end
it "returns an array of external users" do
create(:user)
external_user = create(:user, external: true)
get api("/users?external=true", user)
expect(response).to match_response_schema('public_api/v4/user/basics')
expect(response).to include_pagination_headers
expect(json_response.size).to eq(1)
expect(json_response[0]['id']).to eq(external_user.id)
end
it "returns one user" do it "returns one user" do
get api("/users?username=#{omniauth_user.username}", user) get api("/users?username=#{omniauth_user.username}", user)
......
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