|
|
|
@ -34,11 +34,12 @@ except ImportError:
|
|
|
|
|
|
|
|
|
|
class IncludedFile:
|
|
|
|
|
|
|
|
|
|
def __init__(self, filename, args, task):
|
|
|
|
|
def __init__(self, filename, args, task, is_role=False):
|
|
|
|
|
self._filename = filename
|
|
|
|
|
self._args = args
|
|
|
|
|
self._task = task
|
|
|
|
|
self._hosts = []
|
|
|
|
|
self._is_role = is_role
|
|
|
|
|
|
|
|
|
|
def add_host(self, host):
|
|
|
|
|
if host not in self._hosts:
|
|
|
|
@ -65,7 +66,7 @@ class IncludedFile:
|
|
|
|
|
original_host = res._host
|
|
|
|
|
original_task = res._task
|
|
|
|
|
|
|
|
|
|
if original_task.action in ('include', 'include_tasks'):
|
|
|
|
|
if original_task.action in ('include', 'include_tasks', 'include_role'):
|
|
|
|
|
if original_task.loop:
|
|
|
|
|
if 'results' not in res._result:
|
|
|
|
|
continue
|
|
|
|
@ -75,7 +76,7 @@ class IncludedFile:
|
|
|
|
|
|
|
|
|
|
for include_result in include_results:
|
|
|
|
|
# if the task result was skipped or failed, continue
|
|
|
|
|
if 'skipped' in include_result and include_result['skipped'] or 'failed' in include_result:
|
|
|
|
|
if 'skipped' in include_result and include_result['skipped'] or 'failed' in include_result and include_result['failed']:
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
task_vars = variable_manager.get_vars(play=iterator._play, host=original_host, task=original_task)
|
|
|
|
@ -88,49 +89,52 @@ class IncludedFile:
|
|
|
|
|
if loop_var in include_result:
|
|
|
|
|
task_vars[loop_var] = include_variables[loop_var] = include_result[loop_var]
|
|
|
|
|
|
|
|
|
|
include_file = None
|
|
|
|
|
if original_task:
|
|
|
|
|
if original_task.static:
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
if original_task._parent:
|
|
|
|
|
# handle relative includes by walking up the list of parent include
|
|
|
|
|
# tasks and checking the relative result to see if it exists
|
|
|
|
|
parent_include = original_task._parent
|
|
|
|
|
cumulative_path = None
|
|
|
|
|
while parent_include is not None:
|
|
|
|
|
if not isinstance(parent_include, TaskInclude):
|
|
|
|
|
parent_include = parent_include._parent
|
|
|
|
|
continue
|
|
|
|
|
if isinstance(parent_include, IncludeRole):
|
|
|
|
|
parent_include_dir = parent_include._role_path
|
|
|
|
|
else:
|
|
|
|
|
parent_include_dir = os.path.dirname(templar.template(parent_include.args.get('_raw_params')))
|
|
|
|
|
if cumulative_path is not None and not os.path.isabs(cumulative_path):
|
|
|
|
|
cumulative_path = os.path.join(parent_include_dir, cumulative_path)
|
|
|
|
|
else:
|
|
|
|
|
cumulative_path = parent_include_dir
|
|
|
|
|
if original_task.action in ('include', 'include_tasks'):
|
|
|
|
|
include_file = None
|
|
|
|
|
if original_task:
|
|
|
|
|
if original_task.static:
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
if original_task._parent:
|
|
|
|
|
# handle relative includes by walking up the list of parent include
|
|
|
|
|
# tasks and checking the relative result to see if it exists
|
|
|
|
|
parent_include = original_task._parent
|
|
|
|
|
cumulative_path = None
|
|
|
|
|
while parent_include is not None:
|
|
|
|
|
if not isinstance(parent_include, TaskInclude):
|
|
|
|
|
parent_include = parent_include._parent
|
|
|
|
|
continue
|
|
|
|
|
if isinstance(parent_include, IncludeRole):
|
|
|
|
|
parent_include_dir = parent_include._role_path
|
|
|
|
|
else:
|
|
|
|
|
parent_include_dir = os.path.dirname(templar.template(parent_include.args.get('_raw_params')))
|
|
|
|
|
if cumulative_path is not None and not os.path.isabs(cumulative_path):
|
|
|
|
|
cumulative_path = os.path.join(parent_include_dir, cumulative_path)
|
|
|
|
|
else:
|
|
|
|
|
cumulative_path = parent_include_dir
|
|
|
|
|
include_target = templar.template(include_result['include'])
|
|
|
|
|
if original_task._role:
|
|
|
|
|
new_basedir = os.path.join(original_task._role._role_path, 'tasks', cumulative_path)
|
|
|
|
|
include_file = loader.path_dwim_relative(new_basedir, 'tasks', include_target)
|
|
|
|
|
else:
|
|
|
|
|
include_file = loader.path_dwim_relative(loader.get_basedir(), cumulative_path, include_target)
|
|
|
|
|
|
|
|
|
|
if os.path.exists(include_file):
|
|
|
|
|
break
|
|
|
|
|
else:
|
|
|
|
|
parent_include = parent_include._parent
|
|
|
|
|
|
|
|
|
|
if include_file is None:
|
|
|
|
|
if original_task._role:
|
|
|
|
|
include_target = templar.template(include_result['include'])
|
|
|
|
|
if original_task._role:
|
|
|
|
|
new_basedir = os.path.join(original_task._role._role_path, 'tasks', cumulative_path)
|
|
|
|
|
include_file = loader.path_dwim_relative(new_basedir, 'tasks', include_target)
|
|
|
|
|
else:
|
|
|
|
|
include_file = loader.path_dwim_relative(loader.get_basedir(), cumulative_path, include_target)
|
|
|
|
|
|
|
|
|
|
if os.path.exists(include_file):
|
|
|
|
|
break
|
|
|
|
|
else:
|
|
|
|
|
parent_include = parent_include._parent
|
|
|
|
|
|
|
|
|
|
if include_file is None:
|
|
|
|
|
if original_task._role:
|
|
|
|
|
include_target = templar.template(include_result['include'])
|
|
|
|
|
include_file = loader.path_dwim_relative(original_task._role._role_path, 'tasks', include_target)
|
|
|
|
|
else:
|
|
|
|
|
include_file = loader.path_dwim(include_result['include'])
|
|
|
|
|
|
|
|
|
|
include_file = templar.template(include_file)
|
|
|
|
|
inc_file = IncludedFile(include_file, include_variables, original_task)
|
|
|
|
|
include_file = loader.path_dwim_relative(original_task._role._role_path, 'tasks', include_target)
|
|
|
|
|
else:
|
|
|
|
|
include_file = loader.path_dwim(include_result['include'])
|
|
|
|
|
|
|
|
|
|
include_file = templar.template(include_file)
|
|
|
|
|
inc_file = IncludedFile(include_file, include_variables, original_task)
|
|
|
|
|
else:
|
|
|
|
|
inc_file = IncludedFile("role", include_variables, original_task, is_role=True)
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
pos = included_files.index(inc_file)
|
|
|
|
|