Allows delegate_to to use inventory host/port info.

This commit is contained in:
Michael DeHaan 2012-10-16 20:57:37 -04:00
parent ac16efe289
commit 339c05bb88
3 changed files with 23 additions and 5 deletions

View file

@ -286,7 +286,7 @@ class Inventory(object):
host = self.get_host(hostname)
if host is None:
raise Exception("host not found: %s" % hostname)
raise errors.AnsibleError("host not found: %s" % hostname)
return host.get_variables()
def add_group(self, group):

View file

@ -384,14 +384,32 @@ class Runner(object):
actual_host = host
try:
delegate_to = inject.get('delegate_to', None)
alternative_host = inject.get('ansible_ssh_host', None)
# the delegated host may have different SSH port configured, etc
# and we need to transfer those, and only those, variables
if delegate_to is not None:
delegate_vars = {}
try:
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
elif alternative_host is not None:
actual_host = alternative_host
# connect
conn = self.connector.connect(actual_host, port)
if delegate_to is not None or alternative_host is not None:
conn._delegate_for = host
except errors.AnsibleConnectionFailed, e:
result = dict(failed=True, msg="FAILED: %s" % str(e))
return ReturnData(host=host, comm_ok=False, result=result)

View file

@ -53,7 +53,7 @@ class Connection(object):
user = self.runner.remote_user
vvv("ESTABLISH CONNECTION FOR USER: %s" % user, host=self.host)
vvv("ESTABLISH CONNECTION FOR USER: %s on PORT %s TO %s" % (user, self.port, self.host), host=self.host)
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())