Fix the way pull localhosts out of inventory for delegate_to

This patch corrects the way we look in the inventory hosts list for
implicit localhost entries when localhost aliases are used.

Fixes #16568
This commit is contained in:
James Cammarata 2016-07-04 11:05:56 -05:00
parent 1f04130c00
commit 83e4a4048b

View file

@ -489,10 +489,13 @@ class VariableManager:
# try looking it up based on the address field, and finally
# fall back to creating a host on the fly to use for the var lookup
if delegated_host is None:
if delegated_host_name in C.LOCALHOST:
delegated_host = self._inventory.localhost
else:
for h in self._inventory.get_hosts(ignore_limits_and_restrictions=True):
# check if the address matches, or if both the delegated_to host
# and the current host are in the list of localhost aliases
if h.address == delegated_host_name or h.name in C.LOCALHOST and delegated_host_name in C.LOCALHOST:
if h.address == delegated_host_name:
delegated_host = h
break
else: