Commit 80306c45 authored by James Edwards-Jones's avatar James Edwards-Jones

Support new Azure SCIM pre-setup check

parent df21f58e
...@@ -27,6 +27,8 @@ class ScimFinder ...@@ -27,6 +27,8 @@ class ScimFinder
if eq_filter_on_extern_uid?(parser) if eq_filter_on_extern_uid?(parser)
by_extern_uid(parser) by_extern_uid(parser)
elsif eq_filter_on_username?(parser)
by_username(parser)
else else
raise UnsupportedFilter raise UnsupportedFilter
end end
...@@ -39,4 +41,13 @@ class ScimFinder ...@@ -39,4 +41,13 @@ class ScimFinder
def by_extern_uid(parser) def by_extern_uid(parser)
Identity.where_group_saml_uid(saml_provider, parser.filter_params[:extern_uid]) Identity.where_group_saml_uid(saml_provider, parser.filter_params[:extern_uid])
end end
def eq_filter_on_username?(parser)
parser.filter_operator == :eq && parser.filter_params[:username].present?
end
def by_username(parser)
user = User.find_by_username(parser.filter_params[:username])
saml_provider.identities.for_user(user)
end
end end
---
title: Support new Azure SCIM pre-setup check
merge_request: 22348
author:
type: fixed
...@@ -37,6 +37,10 @@ describe ScimFinder do ...@@ -37,6 +37,10 @@ describe ScimFinder do
expect(finder.search(filter: "id eq #{identity.extern_uid}").first).to eq identity expect(finder.search(filter: "id eq #{identity.extern_uid}").first).to eq identity
expect(finder.search(filter: "externalId eq #{identity.extern_uid}").first).to eq identity expect(finder.search(filter: "externalId eq #{identity.extern_uid}").first).to eq identity
end end
it 'allows lookup by userName' do
expect(finder.search(filter: "userName eq \"#{identity.user.username}\"").first).to eq identity
end
end end
it 'returns all related identities if there is no filter' do it 'returns all related identities if there is no filter' do
...@@ -50,7 +54,7 @@ describe ScimFinder do ...@@ -50,7 +54,7 @@ describe ScimFinder do
end end
it 'raises an error if the attribute path is unsupported' do it 'raises an error if the attribute path is unsupported' do
expect { finder.search(filter: 'userName eq "name"').count }.to raise_error(ScimFinder::UnsupportedFilter) expect { finder.search(filter: 'displayName eq "name"').count }.to raise_error(ScimFinder::UnsupportedFilter)
end end
end end
end end
......
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