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
|
|
|
|
|
|
|
def load_list_of_blocks(ds, parent_block=None, role=None, task_include=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.
|
|
|
|
'''
|
|
|
|
|
|
|
|
# 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-06 19:14:38 +00:00
|
|
|
b = Block.load(block, parent_block=parent_block, role=role, task_include=task_include, 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
|
|
|
|
|
|
|
def load_list_of_tasks(ds, block=None, role=None, task_include=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
|
|
|
|
from ansible.playbook.task import Task
|
2014-11-05 14:00:00 +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)
|
|
|
|
|
|
|
|
if 'include' in task:
|
2014-11-06 19:14:38 +00:00
|
|
|
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)
|
|
|
|
|
2014-11-05 14:00:00 +00:00
|
|
|
t = TaskInclude.load(task, block=block, role=role, task_include=task_include, loader=loader)
|
2014-11-06 19:14:38 +00:00
|
|
|
|
|
|
|
if cur_basedir and loader:
|
|
|
|
loader.set_basedir(cur_basedir)
|
2014-11-05 14:00:00 +00:00
|
|
|
else:
|
|
|
|
t = Task.load(task, block=block, role=role, task_include=task_include, loader=loader)
|
|
|
|
|
2014-11-04 21:16:11 +00:00
|
|
|
task_list.append(t)
|
|
|
|
|
|
|
|
return task_list
|
|
|
|
|
2014-11-05 14:00:00 +00:00
|
|
|
|
2014-11-04 21:16:11 +00:00
|
|
|
def load_list_of_roles(ds, loader=None):
|
|
|
|
'''
|
|
|
|
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:
|
|
|
|
i = RoleInclude.load(role_def, loader=loader)
|
|
|
|
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
|
|
|
|
|