preserve delegation info on no_log (#42577)
* preserve delegation info on no_log
fixes #42344
(cherry picked from commit e115e6496f
)
This commit is contained in:
parent
64737fea2d
commit
e8ff717ba8
2 changed files with 13 additions and 0 deletions
2
changelogs/fragments/preserve_delegate_nolog.yml
Normal file
2
changelogs/fragments/preserve_delegate_nolog.yml
Normal file
|
@ -0,0 +1,2 @@
|
|||
bugfixes:
|
||||
- preseve delegation info on nolog https://github.com/ansible/ansible/issues/42344
|
|
@ -12,6 +12,7 @@ from ansible.vars.clean import strip_internal_keys
|
|||
|
||||
_IGNORE = ('failed', 'skipped')
|
||||
_PRESERVE = ('attempts', 'changed', 'retries')
|
||||
_SUB_PRESERVE = {'_ansible_delegated_vars': ('ansible_host', 'ansible_port', 'ansible_user', 'ansible_connection')}
|
||||
|
||||
|
||||
class TaskResult:
|
||||
|
@ -112,9 +113,19 @@ class TaskResult:
|
|||
|
||||
if self._task.no_log or self._result.get('_ansible_no_log', False):
|
||||
x = {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"}
|
||||
|
||||
# preserve full
|
||||
for preserve in _PRESERVE:
|
||||
if preserve in self._result:
|
||||
x[preserve] = self._result[preserve]
|
||||
|
||||
# preserve subset
|
||||
for sub in _SUB_PRESERVE:
|
||||
if sub in self._result:
|
||||
x[sub] = {}
|
||||
for key in _SUB_PRESERVE[sub]:
|
||||
x[sub][key] = self._result[sub][key]
|
||||
|
||||
result._result = x
|
||||
elif self._result:
|
||||
result._result = deepcopy(self._result)
|
||||
|
|
Loading…
Reference in a new issue