Strip no log values from module response keys. Fixes #68400 (#69653)

This commit is contained in:
Matt Martz 2020-05-21 15:17:57 -05:00 committed by GitHub
parent cfd301a586
commit e0f25a2b1f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 2 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- Strip no log values from module response keys (https://github.com/ansible/ansible/issues/68400)

View file

@ -410,8 +410,9 @@ def remove_values(value, no_log_strings):
old_data, new_data = deferred_removals.popleft()
if isinstance(new_data, Mapping):
for old_key, old_elem in old_data.items():
new_key = _remove_values_conditions(old_key, no_log_strings, deferred_removals)
new_elem = _remove_values_conditions(old_elem, no_log_strings, deferred_removals)
new_data[old_key] = new_elem
new_data[new_key] = new_elem
else:
for elem in old_data:
new_elem = _remove_values_conditions(elem, no_log_strings, deferred_removals)

View file

@ -544,6 +544,18 @@
that:
- result.json.json[0] == 'JSON Test Pattern pass1'
- name: Make request that includes password in JSON keys
uri:
url: "https://{{ httpbin_host}}/get?key-password=value-password"
user: admin
password: password
register: sanitize_keys
- name: assert that keys were sanitized
assert:
that:
- sanitize_keys.json.args['key-********'] == 'value-********'
- name: Create a testing file
copy:
content: "content"

View file

@ -105,13 +105,18 @@ class TestRemoveValues(unittest.TestCase):
'three': [
OMIT, 'musketeers', None, {
'ping': OMIT,
'base': [
OMIT: [
OMIT, 'raquets'
]
}
]
}
),
(
{'key-password': 'value-password'},
frozenset(['password']),
{'key-********': 'value-********'},
),
(
'This sentence has an enigma wrapped in a mystery inside of a secret. - mr mystery',
frozenset(['enigma', 'mystery', 'secret']),