neutron/neutron/extensions/trunk.py

68 lines
2.0 KiB
Python

# Copyright (c) 2016 ZTE Inc.
# 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
from neutron.api import extensions
from neutron.api.v2 import resource_helper
class Trunk(extensions.ExtensionDescriptor):
"""Trunk API extension."""
@classmethod
def get_name(cls):
return trunk.NAME
@classmethod
def get_alias(cls):
return trunk.ALIAS
@classmethod
def get_description(cls):
return trunk.DESCRIPTION
@classmethod
def get_updated(cls):
return trunk.UPDATED_TIMESTAMP
@classmethod
def get_resources(cls):
"""Returns Ext Resources."""
plural_mappings = resource_helper.build_plural_mappings(
{}, trunk.RESOURCE_ATTRIBUTE_MAP)
return resource_helper.build_resource_info(
plural_mappings,
trunk.RESOURCE_ATTRIBUTE_MAP,
trunk.ALIAS,
action_map=trunk.ACTION_MAP,
register_quota=True)
def update_attributes_map(self, attributes, extension_attrs_map=None):
super(Trunk, self).update_attributes_map(
attributes, extension_attrs_map=trunk.RESOURCE_ATTRIBUTE_MAP)
def get_required_extensions(self):
return trunk.REQUIRED_EXTENSIONS or []
def get_optional_extensions(self):
return trunk.OPTIONAL_EXTENSIONS or []
def get_extended_resources(self, version):
if version == "2.0":
return trunk.RESOURCE_ATTRIBUTE_MAP
else:
return {}