This file is indexed.

/usr/share/doc/python-neutron-lib-doc/html/_sources/contributor/api_attributes.rst.txt is in python-neutron-lib-doc 1.13.0-0ubuntu1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
..
      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.


      Convention for heading levels in Neutron devref:
      =======  Heading 0 (reserved for the title in a document)
      -------  Heading 1
      ~~~~~~~  Heading 2
      +++++++  Heading 3
      '''''''  Heading 4
      (Avoid deeper levels because they do not render well.)


API Attributes
==============

Neutron's resource attributes are defined in dictionaries
in ``api/definitions``.

The map containing all installed resources (for core and active extensions)
is in ``api/attributes.py``.


Attribute map structure
-----------------------

Example attribute definitions for ``dns_name``:

.. code-block:: python

        'dns_name': {
            'allow_post': True,
            'allow_put': True,
            'default': '',
            'convert_to': convert_to_lowercase,
            'validate': {'type:dns_name': FQDN_MAX_LEN},
            'is_visible': True
        },


The ``validate`` item specifies rules for `validating <api_validators.html>`_
the attribute.

The ``convert_to`` item specifies rules for `converting <api_converters.html>`_
the attribute.

Example attribute definitions for ``gateway_ip``:

.. code-block:: python

        'gateway_ip': {
            'allow_post': True,
            'allow_put': True,
            'default': constants.ATTR_NOT_SPECIFIED,
            'validate': {'type:ip_address_or_none': None},
            'is_visible': True
        }

Note: a default of ``ATTR_NOT_SPECIFIED`` indicates that an attribute is not
required, but will be generated by the plugin if it is not specified.
Particularly, a value of ``ATTR_NOT_SPECIFIED`` is different from an
attribute that has been specified with a value of ``None``.  For example,
if ``gateway_ip`` is omitted in a request to create a subnet, the plugin
will receive ``ATTR_NOT_SPECIFIED`` and the default gateway IP will be
generated.  However, if ``gateway_ip`` is specified as ``None``, this means
that the subnet does not have a gateway IP.

The following are the defined keys for attribute maps:

======================  ======
``default``             default value of the attribute (if missing, the attribute becomes mandatory)
``allow_post``          the attribute can be used on ``POST`` requests
``allow_put``           the attribute can be used on ``PUT`` requests
``validate``            specifies rules for validating data in the attribute
``convert_to``          transformation to apply to the value before it is returned
``convert_list_to``     if the value is a list, apply this transformation to the value before it is returned
``is_visible``          the attribute is returned in ``GET`` responses
``required_by_policy``  the attribute is required by the policy engine and should therefore be filled by the API layer even if not present in request body
``enforce_policy``      the attribute is actively part of the policy enforcing mechanism, ie: there might be rules which refer to this attribute
``primary_key``         Mark the attribute as a unique key.
======================  ======