1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Fix keycloak_client_rolemapping role removal and diff (#5619)

* Keycloak: Fix client rolemapping removal

Keycloak's delete_group_rolemapping API wrapper didn't pass data about
the roles to remove to keycloak, resulting in removal of all roles.

Follow the intended behaviour and delete only the roles listed in the
module invocation.

Signed-off-by: Florian Achleitner <flo@fopen.at>

* Keycloak: Fix client_rolemapping diff

The module's diff output wrongly showed the changed roles list as
'after' state. This is obviously wrong for role removal and also
wrong for role addition, if there are other roles assigned.

Use the result of the API query for 'end_state' for 'diff' as well.

Signed-off-by: Florian Achleitner <flo@fopen.at>

* Keycloak: Calculate client_rolemapping proposed state properly

Signed-off-by: Florian Achleitner <flo@fopen.at>

* Add changelog fragment

Signed-off-by: Florian Achleitner <flo@fopen.at>
Co-authored-by: Felix Fontein <felix@fontein.de>
Co-authored-by: Felix Fontein <felix@fontein.de>

* Fix for python2 unit test

Signed-off-by: Florian Achleitner <flo@fopen.at>
Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
fachleitner 2022-12-05 06:23:00 +01:00 committed by GitHub
parent 7ea544a624
commit f0b3bba030
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 5 deletions

View file

@ -0,0 +1,3 @@
bugfixes:
- "keycloak_client_rolemapping - remove only listed mappings with ``state=absent`` (https://github.com/ansible-collections/community.general/pull/5619)."
- "keycloak_client_rolemapping - calculate ``proposed`` and ``after`` return values properly (https://github.com/ansible-collections/community.general/pull/5619)."

View file

@ -608,7 +608,7 @@ class KeycloakAPI(object):
""" """
available_rolemappings_url = URL_CLIENT_GROUP_ROLEMAPPINGS.format(url=self.baseurl, realm=realm, id=gid, client=cid) available_rolemappings_url = URL_CLIENT_GROUP_ROLEMAPPINGS.format(url=self.baseurl, realm=realm, id=gid, client=cid)
try: try:
open_url(available_rolemappings_url, method="DELETE", http_agent=self.http_agent, headers=self.restheaders, open_url(available_rolemappings_url, method="DELETE", http_agent=self.http_agent, headers=self.restheaders, data=json.dumps(role_rep),
validate_certs=self.validate_certs, timeout=self.connection_timeout) validate_certs=self.validate_certs, timeout=self.connection_timeout)
except Exception as e: except Exception as e:
self.module.fail_json(msg="Could not delete available rolemappings for client %s in group %s, realm %s: %s" self.module.fail_json(msg="Could not delete available rolemappings for client %s in group %s, realm %s: %s"

View file

@ -295,7 +295,7 @@ def main():
assigned_roles_before = kc.get_client_group_composite_rolemappings(gid, cid, realm=realm) assigned_roles_before = kc.get_client_group_composite_rolemappings(gid, cid, realm=realm)
result['existing'] = assigned_roles_before result['existing'] = assigned_roles_before
result['proposed'] = roles result['proposed'] = list(assigned_roles_before) if assigned_roles_before else []
update_roles = [] update_roles = []
for role_index, role in enumerate(roles, start=0): for role_index, role in enumerate(roles, start=0):
@ -307,6 +307,7 @@ def main():
'id': role['id'], 'id': role['id'],
'name': role['name'], 'name': role['name'],
}) })
result['proposed'].append(available_role)
# Fetch roles to remove if state absent # Fetch roles to remove if state absent
else: else:
for assigned_role in assigned_roles_before: for assigned_role in assigned_roles_before:
@ -315,13 +316,15 @@ def main():
'id': role['id'], 'id': role['id'],
'name': role['name'], 'name': role['name'],
}) })
if assigned_role in result['proposed']: # Handle double removal
result['proposed'].remove(assigned_role)
if len(update_roles): if len(update_roles):
if state == 'present': if state == 'present':
# Assign roles # Assign roles
result['changed'] = True result['changed'] = True
if module._diff: if module._diff:
result['diff'] = dict(before=assigned_roles_before, after=update_roles) result['diff'] = dict(before=assigned_roles_before, after=result['proposed'])
if module.check_mode: if module.check_mode:
module.exit_json(**result) module.exit_json(**result)
kc.add_group_rolemapping(gid, cid, update_roles, realm=realm) kc.add_group_rolemapping(gid, cid, update_roles, realm=realm)
@ -333,7 +336,7 @@ def main():
# Remove mapping of role # Remove mapping of role
result['changed'] = True result['changed'] = True
if module._diff: if module._diff:
result['diff'] = dict(before=assigned_roles_before, after=update_roles) result['diff'] = dict(before=assigned_roles_before, after=result['proposed'])
if module.check_mode: if module.check_mode:
module.exit_json(**result) module.exit_json(**result)
kc.delete_group_rolemapping(gid, cid, update_roles, realm=realm) kc.delete_group_rolemapping(gid, cid, update_roles, realm=realm)
@ -344,7 +347,7 @@ def main():
# Do nothing # Do nothing
else: else:
result['changed'] = False result['changed'] = False
result['msg'] = 'Nothing to do, roles %s are correctly mapped with group %s.' % (roles, group_name) result['msg'] = 'Nothing to do, roles %s are %s with group %s.' % (roles, 'mapped' if state == 'present' else 'not mapped', group_name)
module.exit_json(**result) module.exit_json(**result)