neutron/neutron/extensions/trunk_details.py

55 lines
1.7 KiB
Python

# All rights reserved.
#
# 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.
from neutron_lib.api.definitions import trunk_details
from neutron_lib.api import extensions
# NOTE(armax): because of the API machinery, this extension must be on
# its own. This aims at providing subport information for ports that
# are parent in a trunk so that consumers of the Neutron API, like Nova
# can efficiently access trunk information for things like metadata or
# config-drive configuration.
class Trunk_details(extensions.ExtensionDescriptor):
@classmethod
def get_name(cls):
return trunk_details.NAME
@classmethod
def get_alias(cls):
return trunk_details.ALIAS
@classmethod
def get_description(cls):
return trunk_details.DESCRIPTION
@classmethod
def get_updated(cls):
return trunk_details.TIMESTAMP
def get_required_extensions(self):
return trunk_details.REQUIRED_EXTENSIONS or []
def get_optional_extensions(self):
return trunk_details.OPTIONAL_EXTENSIONS or []
def get_extended_resources(self, version):
if version == "2.0":
return trunk_details.RESOURCE_ATTRIBUTE_MAP
else:
return {}