From 7254b22bf44af3114f13e6fed08e78bf00ec7dfb Mon Sep 17 00:00:00 2001 From: Andrew Hamilton Date: Wed, 22 Jul 2015 17:12:00 -0700 Subject: [PATCH] Fixing delegate_to when using a variable --- lib/ansible/executor/task_executor.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/lib/ansible/executor/task_executor.py b/lib/ansible/executor/task_executor.py index a2f75a42285..53962ae56c3 100644 --- a/lib/ansible/executor/task_executor.py +++ b/lib/ansible/executor/task_executor.py @@ -455,19 +455,19 @@ class TaskExecutor: # get the vars for the delegate by its name try: this_info = variables['hostvars'][self._task.delegate_to] + + # get the real ssh_address for the delegate and allow ansible_ssh_host to be templated + #self._play_context.remote_user = self._compute_delegate_user(self.delegate_to, delegate['inject']) + self._play_context.remote_addr = this_info.get('ansible_ssh_host', self._task.delegate_to) + self._play_context.port = this_info.get('ansible_ssh_port', self._play_context.port) + self._play_context.password = this_info.get('ansible_ssh_pass', self._play_context.password) + self._play_context.private_key_file = this_info.get('ansible_ssh_private_key_file', self._play_context.private_key_file) + self._play_context.connection = this_info.get('ansible_connection', C.DEFAULT_TRANSPORT) + self._play_context.become_pass = this_info.get('ansible_sudo_pass', self._play_context.become_pass) except: # make sure the inject is empty for non-inventory hosts this_info = {} - # get the real ssh_address for the delegate and allow ansible_ssh_host to be templated - #self._play_context.remote_user = self._compute_delegate_user(self.delegate_to, delegate['inject']) - self._play_context.remote_addr = this_info.get('ansible_ssh_host', self._task.delegate_to) - self._play_context.port = this_info.get('ansible_ssh_port', self._play_context.port) - self._play_context.password = this_info.get('ansible_ssh_pass', self._play_context.password) - self._play_context.private_key_file = this_info.get('ansible_ssh_private_key_file', self._play_context.private_key_file) - self._play_context.connection = this_info.get('ansible_connection', C.DEFAULT_TRANSPORT) - self._play_context.become_pass = this_info.get('ansible_sudo_pass', self._play_context.become_pass) - if self._play_context.remote_addr in ('127.0.0.1', 'localhost'): self._play_context.connection = 'local'