1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Fix ansible_ssh_host after 339c05bb

This commit is contained in:
Daniel Hokka Zakrisson 2012-10-17 22:42:25 +02:00 committed by Michael DeHaan
parent 6ce844167a
commit 37b91c7b81

View file

@ -382,31 +382,24 @@ class Runner(object):
conn = None conn = None
actual_host = host actual_host = host
actual_port = port
try: try:
alternative_host = inject.get('ansible_ssh_host', None)
if alternative_host is not None:
actual_host = alternative_host
delegate_to = inject.get('delegate_to', None) delegate_to = inject.get('delegate_to', None)
# the delegated host may have different SSH port configured, etc # the delegated host may have different SSH port configured, etc
# and we need to transfer those, and only those, variables # and we need to transfer those, and only those, variables
if delegate_to is not None: if delegate_to is not None:
delegate_to = utils.template(self.basedir, delegate_to, inject) delegate_to = utils.template(self.basedir, delegate_to, inject)
delegate_vars = {} actual_host = inject['hostvars'][delegate_to].get('ansible_ssh_host', delegate_to)
try: actual_port = inject['hostvars'][delegate_to].get('ansible_ssh_port', port)
delegate_vars = inject['hostvars'][delegate_to]
for (k,v) in delegate_vars.iteritems():
if k.startswith('ansible_ssh_'):
inject[k] = v
except errors.AnsibleError:
# host not listed in inventory, it's ok
pass
# the host record may just be an alias in case of tunnels
alternative_host = inject.get('ansible_ssh_host', None)
if delegate_to is not None and not alternative_host:
actual_host = delegate_to
# connect # connect
conn = self.connector.connect(actual_host, port) conn = self.connector.connect(actual_host, actual_port)
if delegate_to is not None or alternative_host is not None: if delegate_to is not None or alternative_host is not None:
conn._delegate_for = host conn._delegate_for = host