mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 13:04:00 -07:00 
			
		
		
		
	[PR #9739/b2e2d2d3 backport][stable-10] keycloak_client: compare desired and before dicts directly in checkmode (#9759)
keycloak_client: compare desired and before dicts directly in checkmode (#9739)
* compare desired and before dicts directly in checkmode
* fix authorizationServicesEnabled being dropped by kc if unset
* only add authorizationsServicesEnabled=false if before_client exists
* add changelog fragment
* Update changelog.
---------
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit b2e2d2d37b)
Co-authored-by: gruenbauer@b1-systems.de <gruenbauer@b1-systems.de>
	
	
This commit is contained in:
		
					parent
					
						
							
								ebb150c3f9
							
						
					
				
			
			
				commit
				
					
						3d418d9ede
					
				
			
		
					 2 changed files with 10 additions and 2 deletions
				
			
		|  | @ -720,7 +720,7 @@ end_state: | |||
| """ | ||||
| 
 | ||||
| from ansible_collections.community.general.plugins.module_utils.identity.keycloak.keycloak import KeycloakAPI, camel, \ | ||||
|     keycloak_argument_spec, get_token, KeycloakError, is_struct_included | ||||
|     keycloak_argument_spec, get_token, KeycloakError | ||||
| from ansible.module_utils.basic import AnsibleModule | ||||
| import copy | ||||
| 
 | ||||
|  | @ -771,6 +771,7 @@ def normalise_cr(clientrep, remove_ids=False): | |||
|         for key, value in clientrep['attributes'].items(): | ||||
|             if isinstance(value, bool): | ||||
|                 clientrep['attributes'][key] = str(value).lower() | ||||
|         clientrep['attributes'].pop('client.secret.creation.time', None) | ||||
|     return clientrep | ||||
| 
 | ||||
| 
 | ||||
|  | @ -965,6 +966,11 @@ def main(): | |||
|     else: | ||||
|         before_client = kc.get_client_by_id(cid, realm=realm) | ||||
| 
 | ||||
|     # kc drops the variable 'authorizationServicesEnabled' if set to false | ||||
|     # to minimize diff/changes we set it to false if not set by kc | ||||
|     if before_client and 'authorizationServicesEnabled' not in before_client: | ||||
|         before_client['authorizationServicesEnabled'] = False | ||||
| 
 | ||||
|     if before_client is None: | ||||
|         before_client = {} | ||||
| 
 | ||||
|  | @ -1036,7 +1042,7 @@ def main(): | |||
|                 if module._diff: | ||||
|                     result['diff'] = dict(before=sanitize_cr(before_norm), | ||||
|                                           after=sanitize_cr(desired_norm)) | ||||
|                 result['changed'] = not is_struct_included(desired_norm, before_norm, CLIENT_META_DATA) | ||||
|                 result['changed'] = desired_norm != before_norm | ||||
| 
 | ||||
|                 module.exit_json(**result) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue