mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Merge pull request #12765 from bcoca/lookup_inventory_hostname
implemented inventory_hostname lookup in v2
This commit is contained in:
commit
6d87bd405d
3 changed files with 44 additions and 22 deletions
|
@ -159,7 +159,7 @@ class Inventory(object):
|
||||||
or applied subsets
|
or applied subsets
|
||||||
"""
|
"""
|
||||||
|
|
||||||
patterns = self._split_pattern(pattern)
|
patterns = Inventory.split_host_pattern(pattern)
|
||||||
hosts = self._evaluate_patterns(patterns)
|
hosts = self._evaluate_patterns(patterns)
|
||||||
|
|
||||||
# mainly useful for hostvars[host] access
|
# mainly useful for hostvars[host] access
|
||||||
|
@ -175,7 +175,8 @@ class Inventory(object):
|
||||||
|
|
||||||
return hosts
|
return hosts
|
||||||
|
|
||||||
def _split_pattern(self, pattern):
|
@classmethod
|
||||||
|
def split_host_pattern(cls, pattern):
|
||||||
"""
|
"""
|
||||||
Takes a string containing host patterns separated by commas (or a list
|
Takes a string containing host patterns separated by commas (or a list
|
||||||
thereof) and returns a list of single patterns (which may not contain
|
thereof) and returns a list of single patterns (which may not contain
|
||||||
|
@ -188,7 +189,7 @@ class Inventory(object):
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if isinstance(pattern, list):
|
if isinstance(pattern, list):
|
||||||
return list(itertools.chain(*map(self._split_pattern, pattern)))
|
return list(itertools.chain(*map(cls.split_host_pattern, pattern)))
|
||||||
|
|
||||||
if ';' in pattern:
|
if ';' in pattern:
|
||||||
display.deprecated("Use ',' instead of ';' to separate host patterns")
|
display.deprecated("Use ',' instead of ';' to separate host patterns")
|
||||||
|
@ -226,11 +227,8 @@ class Inventory(object):
|
||||||
|
|
||||||
return [p.strip() for p in patterns]
|
return [p.strip() for p in patterns]
|
||||||
|
|
||||||
def _evaluate_patterns(self, patterns):
|
@classmethod
|
||||||
"""
|
def order_patterns(cls, patterns):
|
||||||
Takes a list of patterns and returns a list of matching host names,
|
|
||||||
taking into account any negative and intersection patterns.
|
|
||||||
"""
|
|
||||||
|
|
||||||
# Host specifiers should be sorted to ensure consistent behavior
|
# Host specifiers should be sorted to ensure consistent behavior
|
||||||
pattern_regular = []
|
pattern_regular = []
|
||||||
|
@ -251,8 +249,15 @@ class Inventory(object):
|
||||||
|
|
||||||
# when applying the host selectors, run those without the "&" or "!"
|
# when applying the host selectors, run those without the "&" or "!"
|
||||||
# first, then the &s, then the !s.
|
# first, then the &s, then the !s.
|
||||||
patterns = pattern_regular + pattern_intersection + pattern_exclude
|
return pattern_regular + pattern_intersection + pattern_exclude
|
||||||
|
|
||||||
|
def _evaluate_patterns(self, patterns):
|
||||||
|
"""
|
||||||
|
Takes a list of patterns and returns a list of matching host names,
|
||||||
|
taking into account any negative and intersection patterns.
|
||||||
|
"""
|
||||||
|
|
||||||
|
patterns = Inventory.order_patterns(patterns)
|
||||||
hosts = []
|
hosts = []
|
||||||
|
|
||||||
for p in patterns:
|
for p in patterns:
|
||||||
|
@ -575,7 +580,7 @@ class Inventory(object):
|
||||||
if subset_pattern is None:
|
if subset_pattern is None:
|
||||||
self._subset = None
|
self._subset = None
|
||||||
else:
|
else:
|
||||||
subset_patterns = self._split_pattern(subset_pattern)
|
subset_patterns = Inventory.split_host_pattern(subset_pattern)
|
||||||
results = []
|
results = []
|
||||||
# allow Unix style @filename data
|
# allow Unix style @filename data
|
||||||
for x in subset_patterns:
|
for x in subset_patterns:
|
||||||
|
|
|
@ -21,18 +21,35 @@ __metaclass__ = type
|
||||||
|
|
||||||
from ansible.errors import *
|
from ansible.errors import *
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
from ansible.inventory import Inventory
|
||||||
|
|
||||||
class LookupModule(LookupBase):
|
class LookupModule(LookupBase):
|
||||||
|
|
||||||
def run(self, terms, inject=None, **kwargs):
|
def get_hosts(self, variables, pattern):
|
||||||
### FIXME: Is this needed now that listify is run on all lookup plugin terms?
|
#print(variables)
|
||||||
if not isinstance(terms, list):
|
#print(variables['groups'])
|
||||||
raise AnsibleError("with_inventory_hostnames expects a list")
|
hosts = []
|
||||||
|
if pattern in variables['groups']:
|
||||||
|
hosts = variables['groups'][pattern]
|
||||||
|
elif pattern in variables['groups']['all']:
|
||||||
|
hosts = [pattern]
|
||||||
|
return hosts
|
||||||
|
|
||||||
# FIXME: the inventory is no longer available this way, so we may have
|
def run(self, terms, variables=None, **kwargs):
|
||||||
# to dump the host list into the list of variables and read it back
|
|
||||||
# in here (or the inventory sources, so we can recreate the list
|
|
||||||
# of hosts)
|
|
||||||
#return self._flatten(inventory.Inventory(self.host_list).list_hosts(terms))
|
|
||||||
return terms
|
|
||||||
|
|
||||||
|
host_list = []
|
||||||
|
|
||||||
|
for term in terms:
|
||||||
|
patterns = Inventory.order_patterns(Inventory.split_host_pattern(term))
|
||||||
|
|
||||||
|
for p in patterns:
|
||||||
|
that = self.get_hosts(variables, p)
|
||||||
|
if p.startswith("!"):
|
||||||
|
host_list = [ h for h in host_list if h not in that]
|
||||||
|
elif p.startswith("&"):
|
||||||
|
host_list = [ h for h in host_list if h in that ]
|
||||||
|
else:
|
||||||
|
host_list.extend(that)
|
||||||
|
|
||||||
|
# return unique list
|
||||||
|
return list(set(host_list))
|
||||||
|
|
|
@ -92,10 +92,10 @@ class TestInventory(unittest.TestCase):
|
||||||
|
|
||||||
for p in self.patterns:
|
for p in self.patterns:
|
||||||
r = self.patterns[p]
|
r = self.patterns[p]
|
||||||
self.assertEqual(r, self.i._split_pattern(p))
|
self.assertEqual(r, self.i.split_host_pattern(p))
|
||||||
|
|
||||||
for p, r in self.pattern_lists:
|
for p, r in self.pattern_lists:
|
||||||
self.assertEqual(r, self.i._split_pattern(p))
|
self.assertEqual(r, self.i.split_host_pattern(p))
|
||||||
|
|
||||||
def test_ranges(self):
|
def test_ranges(self):
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue