mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-05-22 17:09:08 -07:00
* basic plugin loading working (with many hacks) * task collections working * play/block-level collection module/action working * implement PEP302 loader * implicit package support (no need for __init.py__ in collections) * provides future options for secure loading of content that shouldn't execute inside controller (eg, actively ignore __init__.py on content/module paths) * provide hook for synthetic collection setup (eg ansible.core pseudo-collection for specifying built-in plugins without legacy path, etc) * synthetic package support * ansible.core.plugins mapping works, others don't * synthetic collections working for modules/actions * fix direct-load legacy * change base package name to ansible_collections * note * collection role loading * expand paths from installed content root vars * feature complete? * rename ansible.core to ansible.builtin * and various sanity fixes * sanity tweaks * unittest fixes * less grabby error handler on has_plugin * probably need to replace with a or harden callers * fix win_ping test * disable module test with explicit file extension; might be able to support in some scenarios, but can't see any other tests that verify that behavior... * fix unicode conversion issues on py2 * attempt to keep things working-ish on py2.6 * python2.6 test fun round 2 * rename dirs/configs to "collections" * add wrapper dir for content-adjacent * fix pythoncheck to use localhost * unicode tweaks, native/bytes string prefixing * rename COLLECTION_PATHS to COLLECTIONS_PATHS * switch to pathspec * path handling cleanup * change expensive `all` back to or chain * unused import cleanup * quotes tweak * use wrapped iter/len in Jinja proxy * var name expansion * comment seemingly overcomplicated playbook_paths resolution * drop unnecessary conditional nesting * eliminate extraneous local * zap superfluous validation function * use slice for rolespec NS assembly * misc naming/unicode fixes * collection callback loader asks if valid FQ name instead of just '.' * switch collection role resolution behavior to be internally `text` as much as possible * misc fixmes * to_native in exception constructor * (slightly) detangle tuple accumulation mess in module_utils __init__ walker * more misc fixmes * tighten up action dispatch, add unqualified action test * rename Collection mixin to CollectionSearch * (attempt to) avoid potential confusion/conflict with builtin collections, etc * stale fixmes * tighten up pluginloader collections determination * sanity test fixes * ditch regex escape * clarify comment * update default collections paths config entry * use PATH format instead of list * skip integration tests on Python 2.6 ci_complete
113 lines
4.3 KiB
Python
113 lines
4.3 KiB
Python
# (c) 2014 Michael DeHaan, <michael@ansible.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/>.
|
|
|
|
# Make coding more python3-ish
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
import os
|
|
|
|
from ansible.errors import AnsibleParserError, AnsibleError
|
|
from ansible.module_utils._text import to_native
|
|
from ansible.module_utils.six import string_types
|
|
from ansible.playbook.attribute import FieldAttribute
|
|
from ansible.playbook.base import Base
|
|
from ansible.playbook.collectionsearch import CollectionSearch
|
|
from ansible.playbook.helpers import load_list_of_roles
|
|
from ansible.playbook.role.requirement import RoleRequirement
|
|
|
|
__all__ = ['RoleMetadata']
|
|
|
|
|
|
class RoleMetadata(Base, CollectionSearch):
|
|
'''
|
|
This class wraps the parsing and validation of the optional metadata
|
|
within each Role (meta/main.yml).
|
|
'''
|
|
|
|
_allow_duplicates = FieldAttribute(isa='bool', default=False)
|
|
_dependencies = FieldAttribute(isa='list', default=list)
|
|
_galaxy_info = FieldAttribute(isa='GalaxyInfo')
|
|
|
|
def __init__(self, owner=None):
|
|
self._owner = owner
|
|
super(RoleMetadata, self).__init__()
|
|
|
|
@staticmethod
|
|
def load(data, owner, variable_manager=None, loader=None):
|
|
'''
|
|
Returns a new RoleMetadata object based on the datastructure passed in.
|
|
'''
|
|
|
|
if not isinstance(data, dict):
|
|
raise AnsibleParserError("the 'meta/main.yml' for role %s is not a dictionary" % owner.get_name())
|
|
|
|
m = RoleMetadata(owner=owner).load_data(data, variable_manager=variable_manager, loader=loader)
|
|
return m
|
|
|
|
def _load_dependencies(self, attr, ds):
|
|
'''
|
|
This is a helper loading function for the dependencies list,
|
|
which returns a list of RoleInclude objects
|
|
'''
|
|
|
|
roles = []
|
|
if ds:
|
|
if not isinstance(ds, list):
|
|
raise AnsibleParserError("Expected role dependencies to be a list.", obj=self._ds)
|
|
|
|
for role_def in ds:
|
|
if isinstance(role_def, string_types) or 'role' in role_def or 'name' in role_def:
|
|
roles.append(role_def)
|
|
continue
|
|
try:
|
|
# role_def is new style: { src: 'galaxy.role,version,name', other_vars: "here" }
|
|
def_parsed = RoleRequirement.role_yaml_parse(role_def)
|
|
if def_parsed.get('name'):
|
|
role_def['name'] = def_parsed['name']
|
|
roles.append(role_def)
|
|
except AnsibleError as exc:
|
|
raise AnsibleParserError(to_native(exc), obj=role_def, orig_exc=exc)
|
|
|
|
current_role_path = None
|
|
if self._owner:
|
|
current_role_path = os.path.dirname(self._owner._role_path)
|
|
|
|
try:
|
|
return load_list_of_roles(roles, play=self._owner._play, current_role_path=current_role_path, variable_manager=self._variable_manager,
|
|
loader=self._loader)
|
|
except AssertionError as e:
|
|
raise AnsibleParserError("A malformed list of role dependencies was encountered.", obj=self._ds, orig_exc=e)
|
|
|
|
def _load_galaxy_info(self, attr, ds):
|
|
'''
|
|
This is a helper loading function for the galaxy info entry
|
|
in the metadata, which returns a GalaxyInfo object rather than
|
|
a simple dictionary.
|
|
'''
|
|
|
|
return ds
|
|
|
|
def serialize(self):
|
|
return dict(
|
|
allow_duplicates=self._allow_duplicates,
|
|
dependencies=self._dependencies
|
|
)
|
|
|
|
def deserialize(self, data):
|
|
setattr(self, 'allow_duplicates', data.get('allow_duplicates', False))
|
|
setattr(self, 'dependencies', data.get('dependencies', []))
|