mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	Fix hash filter for non-ascii strings and Python3
hashlib hashes operate on byte strings. When given a text string on Python3, hashlib backtraces. When given a text string on Python2, hashlib will backtrace if the string contains non-ascii characters. Encode the text string to utf-8 prior to hashing to avoid this problem. Fixes #21452
This commit is contained in:
		
					parent
					
						
							
								e89259dbd0
							
						
					
				
			
			
				commit
				
					
						99fd2328af
					
				
			
		
					 2 changed files with 8 additions and 2 deletions
				
			
		|  | @ -48,7 +48,7 @@ from ansible import errors | ||||||
| from ansible.compat.six import iteritems, string_types, integer_types | from ansible.compat.six import iteritems, string_types, integer_types | ||||||
| from ansible.compat.six.moves import reduce | from ansible.compat.six.moves import reduce | ||||||
| from ansible.compat.six.moves import shlex_quote | from ansible.compat.six.moves import shlex_quote | ||||||
| from ansible.module_utils._text import to_text | from ansible.module_utils._text import to_bytes, to_text | ||||||
| from ansible.parsing.yaml.dumper import AnsibleDumper | from ansible.parsing.yaml.dumper import AnsibleDumper | ||||||
| from ansible.utils.hashing import md5s, checksum_s | from ansible.utils.hashing import md5s, checksum_s | ||||||
| from ansible.utils.unicode import unicode_wrap | from ansible.utils.unicode import unicode_wrap | ||||||
|  | @ -236,7 +236,7 @@ def get_hash(data, hashtype='sha1'): | ||||||
|     except: |     except: | ||||||
|         return None |         return None | ||||||
| 
 | 
 | ||||||
|     h.update(data) |     h.update(to_bytes(data, errors='surrogate_then_strict')) | ||||||
|     return h.hexdigest() |     return h.hexdigest() | ||||||
| 
 | 
 | ||||||
| def get_encrypted_password(password, hashtype='sha512', salt=None): | def get_encrypted_password(password, hashtype='sha512', salt=None): | ||||||
|  |  | ||||||
|  | @ -119,3 +119,9 @@ | ||||||
|   assert: |   assert: | ||||||
|     that: |     that: | ||||||
|       - "users | json_query('[*].hosts[].host') == ['host_a', 'host_b', 'host_c', 'host_d']" |       - "users | json_query('[*].hosts[].host') == ['host_a', 'host_b', 'host_c', 'host_d']" | ||||||
|  | 
 | ||||||
|  | - name: Test hash filter | ||||||
|  |   assert: | ||||||
|  |     that: | ||||||
|  |       - '"{{ "hash" | hash("sha1") }}" == "2346ad27d7568ba9896f1b7da6b5991251debdf2"' | ||||||
|  |       - '"{{ "café" | hash("sha1") }}" == "f424452a9673918c6f09b0cdd35b20be8e6ae7d7"' | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue