2014-10-03 15:01:59 -04: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-10-15 19:22:54 -04:00
|
|
|
# Make coding more python3-ish
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
|
|
|
|
2018-07-13 06:27:01 -07:00
|
|
|
from copy import copy, deepcopy
|
|
|
|
|
|
|
|
|
|
|
|
_CONTAINERS = frozenset(('list', 'dict', 'set'))
|
2015-09-02 12:33:42 +03:00
|
|
|
|
2017-06-02 13:14:11 +02:00
|
|
|
|
2014-10-15 19:37:29 -04:00
|
|
|
class Attribute:
|
2014-10-06 17:06:13 -04:00
|
|
|
|
2018-01-05 20:51:44 -06:00
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
isa=None,
|
|
|
|
private=False,
|
|
|
|
default=None,
|
|
|
|
required=False,
|
|
|
|
listof=None,
|
|
|
|
priority=0,
|
|
|
|
class_type=None,
|
|
|
|
always_post_validate=False,
|
|
|
|
inherit=True,
|
|
|
|
alias=None,
|
|
|
|
extend=False,
|
|
|
|
prepend=False,
|
2019-01-24 11:51:52 -05:00
|
|
|
static=False,
|
2018-01-05 20:51:44 -06:00
|
|
|
):
|
|
|
|
|
2016-12-05 14:14:19 -08:00
|
|
|
"""
|
|
|
|
:class:`Attribute` specifies constraints for attributes of objects which
|
|
|
|
derive from playbook data. The attributes of the object are basically
|
|
|
|
a schema for the yaml playbook.
|
2016-12-05 13:09:48 -08:00
|
|
|
|
2016-12-05 14:14:19 -08:00
|
|
|
:kwarg isa: The type of the attribute. Allowable values are a string
|
|
|
|
representation of any yaml basic datatype, python class, or percent.
|
|
|
|
(Enforced at post-validation time).
|
2019-07-16 12:19:01 -07:00
|
|
|
:kwarg private: Not used at runtime. The docs playbook keyword dumper uses it to determine
|
|
|
|
that a keyword should not be documented. mpdehaan had plans to remove attributes marked
|
|
|
|
private from the ds so they would not have been available at all.
|
2016-12-05 14:14:19 -08:00
|
|
|
:kwarg default: Default value if unspecified in the YAML document.
|
|
|
|
:kwarg required: Whether or not the YAML document must contain this field.
|
|
|
|
If the attribute is None when post-validated, an error will be raised.
|
|
|
|
:kwarg listof: If isa is set to "list", this can optionally be set to
|
|
|
|
ensure that all elements in the list are of the given type. Valid
|
|
|
|
values here are the same as those for isa.
|
|
|
|
:kwarg priority: The order in which the fields should be parsed. Generally
|
|
|
|
this does not need to be set, it is for rare situations where another
|
|
|
|
field depends on the fact that another field was parsed first.
|
2016-12-05 14:15:43 -08:00
|
|
|
:kwarg class_type: If isa is set to "class", this can be optionally set to
|
2016-12-05 14:14:19 -08:00
|
|
|
a class (not a string name). The YAML data for this field will be
|
|
|
|
passed to the __init__ method of that class during post validation and
|
|
|
|
the field will be an instance of that class.
|
|
|
|
:kwarg always_post_validate: Controls whether a field should be post
|
2018-07-27 09:15:14 +02:00
|
|
|
validated or not (default: False).
|
2016-12-05 14:14:19 -08:00
|
|
|
:kwarg inherit: A boolean value, which controls whether the object
|
|
|
|
containing this field should attempt to inherit the value from its
|
|
|
|
parent object if the local value is None.
|
2017-11-22 14:35:58 -06:00
|
|
|
:kwarg alias: An alias to use for the attribute name, for situations where
|
|
|
|
the attribute name may conflict with a Python reserved word.
|
2016-12-05 13:09:48 -08:00
|
|
|
"""
|
2014-10-06 17:06:13 -04:00
|
|
|
|
2015-09-02 12:22:18 +03:00
|
|
|
self.isa = isa
|
|
|
|
self.private = private
|
|
|
|
self.default = default
|
|
|
|
self.required = required
|
|
|
|
self.listof = listof
|
|
|
|
self.priority = priority
|
2015-10-23 03:27:09 -04:00
|
|
|
self.class_type = class_type
|
2015-09-02 12:22:18 +03:00
|
|
|
self.always_post_validate = always_post_validate
|
2016-08-24 11:41:05 -05:00
|
|
|
self.inherit = inherit
|
2017-11-22 14:35:58 -06:00
|
|
|
self.alias = alias
|
2018-01-05 20:51:44 -06:00
|
|
|
self.extend = extend
|
|
|
|
self.prepend = prepend
|
2019-01-24 11:51:52 -05:00
|
|
|
self.static = static
|
2015-08-05 13:54:00 -04:00
|
|
|
|
2018-10-12 10:43:09 -05:00
|
|
|
if default is not None and self.isa in _CONTAINERS and not callable(default):
|
|
|
|
raise TypeError('defaults for FieldAttribute may not be mutable, please provide a callable instead')
|
2015-12-09 08:38:53 -08:00
|
|
|
|
2015-09-02 12:33:42 +03:00
|
|
|
def __eq__(self, other):
|
|
|
|
return other.priority == self.priority
|
|
|
|
|
|
|
|
def __ne__(self, other):
|
|
|
|
return other.priority != self.priority
|
|
|
|
|
|
|
|
# NB: higher priority numbers sort first
|
|
|
|
|
|
|
|
def __lt__(self, other):
|
|
|
|
return other.priority < self.priority
|
|
|
|
|
|
|
|
def __gt__(self, other):
|
|
|
|
return other.priority > self.priority
|
|
|
|
|
|
|
|
def __le__(self, other):
|
|
|
|
return other.priority <= self.priority
|
|
|
|
|
|
|
|
def __ge__(self, other):
|
|
|
|
return other.priority >= self.priority
|
|
|
|
|
2014-10-03 15:01:59 -04:00
|
|
|
|
|
|
|
class FieldAttribute(Attribute):
|
|
|
|
pass
|