nova/nova/api/openstack/compute/schemas/flavor_manage.py

102 lines
3.8 KiB
Python

# Copyright 2014 NEC Corporation. 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.
import copy
from nova.api.validation import parameter_types
from nova.db import api as db
create = {
'type': 'object',
'properties': {
'flavor': {
'type': 'object',
'properties': {
# in nova/flavors.py, name with all white spaces is forbidden.
'name': parameter_types.name,
# forbid leading/trailing whitespaces
'id': {
'type': ['string', 'number', 'null'],
'minLength': 1, 'maxLength': 255,
'pattern': '^(?! )[a-zA-Z0-9. _-]+(?<! )$'
},
'ram': parameter_types.flavor_param_positive,
'vcpus': parameter_types.flavor_param_positive,
'disk': parameter_types.flavor_param_non_negative,
'OS-FLV-EXT-DATA:ephemeral':
parameter_types.flavor_param_non_negative,
'swap': parameter_types.flavor_param_non_negative,
# positive ( > 0) float
'rxtx_factor': {
'type': ['number', 'string'],
'pattern': '^[0-9]+(\.[0-9]+)?$',
'minimum': 0, 'exclusiveMinimum': True,
'maximum': db.SQL_SP_FLOAT_MAX
},
'os-flavor-access:is_public': parameter_types.boolean,
},
# TODO(oomichi): 'id' should be required with v2.1+microversions.
# On v2.0 API, nova-api generates a flavor-id automatically if
# specifying null as 'id' or not specifying 'id'. Ideally a client
# should specify null as 'id' for requesting auto-generated id
# exactly. However, this strict limitation causes a backwards
# incompatible issue on v2.1. So now here relaxes the requirement
# of 'id'.
'required': ['name', 'ram', 'vcpus', 'disk'],
'additionalProperties': False,
},
},
'required': ['flavor'],
'additionalProperties': False,
}
create_v20 = copy.deepcopy(create)
create_v20['properties']['flavor']['properties']['name'] = (parameter_types.
name_with_leading_trailing_spaces)
# 2.55 adds an optional description field with a max length of 65535 since the
# backing database column is a TEXT column which is 64KiB.
flavor_description = {
'type': ['string', 'null'], 'minLength': 0, 'maxLength': 65535,
'pattern': parameter_types.valid_description_regex,
}
create_v2_55 = copy.deepcopy(create)
create_v2_55['properties']['flavor']['properties']['description'] = (
flavor_description)
update_v2_55 = {
'type': 'object',
'properties': {
'flavor': {
'type': 'object',
'properties': {
'description': flavor_description
},
# Since the only property that can be specified on update is the
# description field, it is required. If we allow updating other
# flavor attributes in a later microversion, we should reconsider
# what is required.
'required': ['description'],
'additionalProperties': False,
},
},
'required': ['flavor'],
'additionalProperties': False,
}