mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
* keycloak: fix creating a user federation w/ idempotent id
Creating a user federation while specifying an id (that doesn't exist
yet) will fail with a 404. This commits fix this behavior.
* keycloak: fix user federation mapper duplication
This commit fixes a bug where mappers are duplicated instead of
configured when creating a user federation.
When creating a user federation, some mappers are autogenerated by
keycloak. This commit lets the keycloak_user_federation module recompute
mappers final values after the user federation is created so that the
module can try to merge them by their name.
* add missing fragment for pr #4212
(cherry picked from commit c1485b885d
)
Co-authored-by: Jules Lamur <jlamur@users.noreply.github.com>
This commit is contained in:
parent
c0008e976f
commit
c4a53243d5
3 changed files with 27 additions and 8 deletions
|
@ -0,0 +1,8 @@
|
||||||
|
---
|
||||||
|
bugfixes:
|
||||||
|
- keycloak_user_federation - creating a user federation while specifying an
|
||||||
|
ID (that does not exist yet) no longer fail with a 404 Not Found
|
||||||
|
(https://github.com/ansible-collections/community.general/pull/4212).
|
||||||
|
- keycloak_user_federation - mappers auto-created by keycloak are matched and
|
||||||
|
merged by their name and no longer create duplicated entries
|
||||||
|
(https://github.com/ansible-collections/community.general/pull/4212).
|
|
@ -845,7 +845,7 @@ def main():
|
||||||
before_comp = {}
|
before_comp = {}
|
||||||
|
|
||||||
# if user federation exists, get associated mappers
|
# if user federation exists, get associated mappers
|
||||||
if cid is not None:
|
if cid is not None and before_comp:
|
||||||
before_comp['mappers'] = sorted(kc.get_components(urlencode(dict(parent=cid)), realm), key=lambda x: x.get('name'))
|
before_comp['mappers'] = sorted(kc.get_components(urlencode(dict(parent=cid)), realm), key=lambda x: x.get('name'))
|
||||||
|
|
||||||
# Build a proposed changeset from parameters given to this module
|
# Build a proposed changeset from parameters given to this module
|
||||||
|
@ -921,12 +921,23 @@ def main():
|
||||||
after_comp = kc.create_component(desired_comp, realm)
|
after_comp = kc.create_component(desired_comp, realm)
|
||||||
|
|
||||||
for mapper in updated_mappers:
|
for mapper in updated_mappers:
|
||||||
if mapper.get('id') is not None:
|
found = kc.get_components(urlencode(dict(parent=cid, name=mapper['name'])), realm)
|
||||||
kc.update_component(mapper, realm)
|
if len(found) > 1:
|
||||||
|
module.fail_json(msg='Found multiple mappers with name `{name}`. Cannot continue.'.format(name=mapper['name']))
|
||||||
|
if len(found) == 1:
|
||||||
|
old_mapper = found[0]
|
||||||
else:
|
else:
|
||||||
if mapper.get('parentId') is None:
|
old_mapper = {}
|
||||||
mapper['parentId'] = after_comp['id']
|
|
||||||
mapper = kc.create_component(mapper, realm)
|
new_mapper = old_mapper.copy()
|
||||||
|
new_mapper.update(mapper)
|
||||||
|
|
||||||
|
if new_mapper.get('id') is not None:
|
||||||
|
kc.update_component(new_mapper, realm)
|
||||||
|
else:
|
||||||
|
if new_mapper.get('parentId') is None:
|
||||||
|
new_mapper['parentId'] = after_comp['id']
|
||||||
|
mapper = kc.create_component(new_mapper, realm)
|
||||||
|
|
||||||
after_comp['mappers'] = updated_mappers
|
after_comp['mappers'] = updated_mappers
|
||||||
result['end_state'] = sanitize(after_comp)
|
result['end_state'] = sanitize(after_comp)
|
||||||
|
|
|
@ -342,7 +342,7 @@ class TestKeycloakUserFederation(ModuleTestCase):
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
return_value_components_get = [
|
return_value_components_get = [
|
||||||
[]
|
[], []
|
||||||
]
|
]
|
||||||
return_value_component_create = [
|
return_value_component_create = [
|
||||||
{
|
{
|
||||||
|
@ -457,7 +457,7 @@ class TestKeycloakUserFederation(ModuleTestCase):
|
||||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||||
self.module.main()
|
self.module.main()
|
||||||
|
|
||||||
self.assertEqual(len(mock_get_components.mock_calls), 1)
|
self.assertEqual(len(mock_get_components.mock_calls), 2)
|
||||||
self.assertEqual(len(mock_get_component.mock_calls), 0)
|
self.assertEqual(len(mock_get_component.mock_calls), 0)
|
||||||
self.assertEqual(len(mock_create_component.mock_calls), 2)
|
self.assertEqual(len(mock_create_component.mock_calls), 2)
|
||||||
self.assertEqual(len(mock_update_component.mock_calls), 0)
|
self.assertEqual(len(mock_update_component.mock_calls), 0)
|
||||||
|
|
Loading…
Reference in a new issue