2014-11-04 21:16:11 +00:00
|
|
|
# (c) 2012-2014, Michael DeHaan <michael.dehaan@gmail.com>
|
|
|
|
#
|
|
|
|
# This file is part of Ansible
|
|
|
|
#
|
|
|
|
# Ansible is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# Ansible is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2014-11-06 19:14:38 +00:00
|
|
|
|
|
|
|
import os
|
|
|
|
|
2014-11-04 21:16:11 +00:00
|
|
|
from types import NoneType
|
|
|
|
|
2014-11-05 14:00:00 +00:00
|
|
|
from ansible.errors import AnsibleParserError
|
2014-11-06 19:14:38 +00:00
|
|
|
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject
|
2014-11-04 21:16:11 +00:00
|
|
|
|
2014-11-06 19:14:38 +00:00
|
|
|
|
2014-11-14 22:14:08 +00:00
|
|
|
def load_list_of_blocks(ds, parent_block=None, role=None, task_include=None, use_handlers=False, variable_manager=None, loader=None):
|
2014-11-04 21:16:11 +00:00
|
|
|
'''
|
|
|
|
Given a list of mixed task/block data (parsed from YAML),
|
|
|
|
return a list of Block() objects, where implicit blocks
|
|
|
|
are created for each bare Task.
|
|
|
|
'''
|
2015-01-19 22:18:18 +00:00
|
|
|
|
2014-11-04 21:16:11 +00:00
|
|
|
# we import here to prevent a circular dependency with imports
|
|
|
|
from ansible.playbook.block import Block
|
|
|
|
|
|
|
|
assert type(ds) in (list, NoneType)
|
|
|
|
|
|
|
|
block_list = []
|
|
|
|
if ds:
|
|
|
|
for block in ds:
|
2014-11-14 22:14:08 +00:00
|
|
|
b = Block.load(
|
|
|
|
block,
|
|
|
|
parent_block=parent_block,
|
|
|
|
role=role,
|
|
|
|
task_include=task_include,
|
|
|
|
use_handlers=use_handlers,
|
|
|
|
variable_manager=variable_manager,
|
|
|
|
loader=loader
|
|
|
|
)
|
2014-11-04 21:16:11 +00:00
|
|
|
block_list.append(b)
|
|
|
|
|
|
|
|
return block_list
|
|
|
|
|
2014-11-05 14:00:00 +00:00
|
|
|
|
2014-11-14 22:14:08 +00:00
|
|
|
def load_list_of_tasks(ds, block=None, role=None, task_include=None, use_handlers=False, variable_manager=None, loader=None):
|
2014-11-04 21:16:11 +00:00
|
|
|
'''
|
|
|
|
Given a list of task datastructures (parsed from YAML),
|
2014-11-05 14:00:00 +00:00
|
|
|
return a list of Task() or TaskInclude() objects.
|
2014-11-04 21:16:11 +00:00
|
|
|
'''
|
|
|
|
|
|
|
|
# we import here to prevent a circular dependency with imports
|
2014-11-14 22:14:08 +00:00
|
|
|
from ansible.playbook.handler import Handler
|
2014-11-04 21:16:11 +00:00
|
|
|
from ansible.playbook.task import Task
|
2015-02-12 18:11:08 +00:00
|
|
|
#from ansible.playbook.task_include import TaskInclude
|
2014-11-04 21:16:11 +00:00
|
|
|
|
|
|
|
assert type(ds) == list
|
|
|
|
|
|
|
|
task_list = []
|
|
|
|
for task in ds:
|
2014-11-05 14:00:00 +00:00
|
|
|
if not isinstance(task, dict):
|
|
|
|
raise AnsibleParserError("task/handler entries must be dictionaries (got a %s)" % type(task), obj=ds)
|
|
|
|
|
2015-02-12 18:11:08 +00:00
|
|
|
#if 'include' in task:
|
|
|
|
# cur_basedir = None
|
|
|
|
# if isinstance(task, AnsibleBaseYAMLObject) and loader:
|
|
|
|
# pos_info = task.get_position_info()
|
|
|
|
# new_basedir = os.path.dirname(pos_info[0])
|
|
|
|
# cur_basedir = loader.get_basedir()
|
|
|
|
# loader.set_basedir(new_basedir)
|
|
|
|
|
|
|
|
# t = TaskInclude.load(
|
|
|
|
# task,
|
|
|
|
# block=block,
|
|
|
|
# role=role,
|
|
|
|
# task_include=task_include,
|
|
|
|
# use_handlers=use_handlers,
|
|
|
|
# loader=loader
|
|
|
|
# )
|
|
|
|
|
|
|
|
# if cur_basedir and loader:
|
|
|
|
# loader.set_basedir(cur_basedir)
|
|
|
|
#else:
|
|
|
|
if True:
|
2014-11-14 22:14:08 +00:00
|
|
|
if use_handlers:
|
|
|
|
t = Handler.load(task, block=block, role=role, task_include=task_include, variable_manager=variable_manager, loader=loader)
|
|
|
|
else:
|
|
|
|
t = Task.load(task, block=block, role=role, task_include=task_include, variable_manager=variable_manager, loader=loader)
|
2014-11-05 14:00:00 +00:00
|
|
|
|
2014-11-04 21:16:11 +00:00
|
|
|
task_list.append(t)
|
|
|
|
|
|
|
|
return task_list
|
|
|
|
|
2014-11-05 14:00:00 +00:00
|
|
|
|
2015-01-02 13:51:15 +00:00
|
|
|
def load_list_of_roles(ds, current_role_path=None, variable_manager=None, loader=None):
|
2014-11-04 21:16:11 +00:00
|
|
|
'''
|
|
|
|
Loads and returns a list of RoleInclude objects from the datastructure
|
|
|
|
list of role definitions
|
|
|
|
'''
|
|
|
|
|
|
|
|
# we import here to prevent a circular dependency with imports
|
|
|
|
from ansible.playbook.role.include import RoleInclude
|
|
|
|
|
|
|
|
assert isinstance(ds, list)
|
|
|
|
|
|
|
|
roles = []
|
|
|
|
for role_def in ds:
|
2015-01-02 13:51:15 +00:00
|
|
|
i = RoleInclude.load(role_def, current_role_path=current_role_path, variable_manager=variable_manager, loader=loader)
|
2014-11-04 21:16:11 +00:00
|
|
|
roles.append(i)
|
|
|
|
|
|
|
|
return roles
|
|
|
|
|
2014-11-06 19:14:38 +00:00
|
|
|
def compile_block_list(block_list):
|
|
|
|
'''
|
|
|
|
Given a list of blocks, compile them into a flat list of tasks
|
|
|
|
'''
|
|
|
|
|
|
|
|
task_list = []
|
|
|
|
|
|
|
|
for block in block_list:
|
|
|
|
task_list.extend(block.compile())
|
|
|
|
|
|
|
|
return task_list
|
|
|
|
|