c3b1c08a57
Adding shared across tenants and protected from modifictaion resources support. Implemented for clusters, cluster templates, node group templates, data sources, job executions, jobs, job binaries and job binary internals. Changes: * Added validation checks to service.validations.acl * Changed validation schema's to support "is_public" and "is_protected" fields * Added validation of "is_protected" field for update(scale/cancel) and delete methods of corresponding resources * Extended get and list methods outputs with "is_public" resources * Added unit tests for "is_public" and "is_protected" resources Change-Id: I1a3cb14b8de70256e6aa27312dde341e85fc376c Partially-Implements: blueprint shared-protected-resources
112 lines
2.9 KiB
Python
112 lines
2.9 KiB
Python
# Copyright (c) 2015 Mirantis Inc.
|
|
#
|
|
# 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
|
|
|
|
import sahara.service.validations.cluster_template_schema as ct_schema
|
|
|
|
|
|
def _build_node_groups_schema():
|
|
schema = copy.deepcopy(ct_schema.CLUSTER_TEMPLATE_SCHEMA)
|
|
return schema['properties']['node_groups']
|
|
|
|
|
|
def _build_cluster_schema():
|
|
cluster_schema = copy.deepcopy(ct_schema.CLUSTER_TEMPLATE_SCHEMA)
|
|
cluster_schema['properties'].update({
|
|
"is_transient": {
|
|
"type": "boolean"
|
|
},
|
|
"user_keypair_id": {
|
|
"type": "string",
|
|
"format": "valid_keypair_name",
|
|
},
|
|
"cluster_template_id": {
|
|
"type": "string",
|
|
"format": "uuid",
|
|
}})
|
|
return cluster_schema
|
|
|
|
|
|
CLUSTER_SCHEMA = _build_cluster_schema()
|
|
|
|
MULTIPLE_CLUSTER_SCHEMA = copy.deepcopy(CLUSTER_SCHEMA)
|
|
MULTIPLE_CLUSTER_SCHEMA['properties'].update({
|
|
"count": {
|
|
"type": "integer"
|
|
}})
|
|
MULTIPLE_CLUSTER_SCHEMA['required'].append('count')
|
|
|
|
CLUSTER_UPDATE_SCHEMA = {
|
|
"type": "object",
|
|
"properties": {
|
|
"description": {
|
|
"type": ["string", "null"]
|
|
},
|
|
"name": {
|
|
"type": "string",
|
|
"minLength": 1,
|
|
"maxLength": 50,
|
|
"format": "valid_name_hostname",
|
|
},
|
|
"is_public": {
|
|
"type": ["boolean", "null"],
|
|
},
|
|
"is_protected": {
|
|
"type": ["boolean", "null"],
|
|
}
|
|
},
|
|
"additionalProperties": False,
|
|
"required": []
|
|
}
|
|
|
|
CLUSTER_SCALING_SCHEMA = {
|
|
"type": "object",
|
|
"properties": {
|
|
"resize_node_groups": {
|
|
"type": "array",
|
|
"items": {
|
|
"type": "object",
|
|
"properties": {
|
|
"name": {
|
|
"type": "string",
|
|
},
|
|
"count": {
|
|
"type": "integer",
|
|
"minimum": 0,
|
|
},
|
|
},
|
|
"additionalProperties": False,
|
|
"required": [
|
|
"name",
|
|
"count",
|
|
]
|
|
},
|
|
"minItems": 1
|
|
},
|
|
"add_node_groups": _build_node_groups_schema(),
|
|
},
|
|
"additionalProperties": False,
|
|
"anyOf": [
|
|
{
|
|
"required": ["resize_node_groups"]
|
|
},
|
|
{
|
|
"required": ["add_node_groups"]
|
|
}
|
|
]
|
|
|
|
}
|