X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2FNBI.git;a=blobdiff_plain;f=osm_nbi%2Fvalidation.py;h=b6ef64c1d8aca6e81e83d43c019fbb44c48f2b02;hp=81b288dab362f0c8cff3ecea815fbf4d5184b47e;hb=refs%2Fchanges%2F35%2F7735%2F1;hpb=5c01e193a17fcf730406e39fe7d019e1dee5c64d diff --git a/osm_nbi/validation.py b/osm_nbi/validation.py index 81b288d..b6ef64c 100644 --- a/osm_nbi/validation.py +++ b/osm_nbi/validation.py @@ -16,6 +16,7 @@ from jsonschema import validate as js_v, exceptions as js_e from http import HTTPStatus from copy import deepcopy +from uuid import UUID # To test for valid UUID __author__ = "Alfonso Tierno " __version__ = "0.1" @@ -380,7 +381,7 @@ vim_account_new_schema = { "description": description_schema, "vim": name_schema, "datacenter": name_schema, - "vim_type": {"enum": ["openstack", "openvim", "vmware", "opennebula", "aws"]}, + "vim_type": {"enum": ["openstack", "openvim", "vmware", "opennebula", "aws", "azure", "fos"]}, "vim_url": description_schema, # "vim_url_admin": description_schema, # "vim_tenant": name_schema, @@ -420,7 +421,7 @@ wim_account_new_schema = { "name": name_schema, "description": description_schema, "wim": name_schema, - "wim_type": {"enum": ["tapi", "onos", "odl", "dynpac"]}, + "wim_type": {"enum": ["tapi", "onos", "odl", "dynpac", "fake"]}, "wim_url": description_schema, "user": shortname_schema, "password": passwd_schema, @@ -565,16 +566,35 @@ pdu_edit_schema = { } # USERS -project_role_mapping = { - "title": "", +project_role_mappings = { + "title": "list pf projects/roles", "$schema": "http://json-schema.org/draft-04/schema#", - "type": "object", - "properties": { - "project": shortname_schema, - "role": shortname_schema + "type": "array", + "items": { + "type": "object", + "properties": { + "project": shortname_schema, + "role": shortname_schema + }, + "required": ["project", "role"], + "additionalProperties": False }, - "required": ["project", "role"], - "additionalProperties": False + "minItems": 1 +} +project_role_mappings_optional = { + "title": "list of projects/roles or projects only", + "$schema": "http://json-schema.org/draft-04/schema#", + "type": "array", + "items": { + "type": "object", + "properties": { + "project": shortname_schema, + "role": shortname_schema + }, + "required": ["project"], + "additionalProperties": False + }, + "minItems": 1 } user_new_schema = { "$schema": "http://json-schema.org/draft-04/schema#", @@ -584,11 +604,7 @@ user_new_schema = { "username": shortname_schema, "password": passwd_schema, "projects": nameshort_list_schema, - "project_role_mappings": { - "type": "array", - "items": project_role_mapping, - "minItems": 1 - }, + "project_role_mappings": project_role_mappings, }, "required": ["username", "password"], "additionalProperties": False @@ -599,17 +615,16 @@ user_edit_schema = { "type": "object", "properties": { "password": passwd_schema, + "username": shortname_schema, # To allow User Name modification "projects": { "oneOf": [ nameshort_list_schema, array_edition_schema ] }, - "project_role_mappings": { - "type": "array", - "items": project_role_mapping, - "minItems": 1 - }, + "project_role_mappings": project_role_mappings, + "add_project_role_mappings": project_role_mappings, + "remove_project_role_mappings": project_role_mappings_optional, }, "minProperties": 1, "additionalProperties": False @@ -633,6 +648,7 @@ project_edit_schema = { "type": "object", "properties": { "admin": bool_schema, + "name": shortname_schema, # To allow Project Name modification }, "additionalProperties": False, "minProperties": 1 @@ -645,7 +661,13 @@ roles_new_schema = { "type": "object", "properties": { "name": shortname_schema, - "definition": object_schema, + "permissions": { + "type": "object", + "patternProperties": { + ".": bool_schema, + }, + # "minProperties": 1, + } }, "required": ["name"], "additionalProperties": False @@ -655,11 +677,17 @@ roles_edit_schema = { "title": "Roles edit schema for administrators", "type": "object", "properties": { - "_id": id_schema, "name": shortname_schema, - "definition": object_schema, + "permissions": { + "type": "object", + "patternProperties": { + ".": { + "oneOf": [bool_schema, null_schema] + } + }, + # "minProperties": 1, + } }, - "required": ["_id", "name", "definition"], "additionalProperties": False, "minProperties": 1 } @@ -701,7 +729,7 @@ nsi_vld_instantiate = { "vim-network-id": {"OneOf": [string_schema, object_schema]}, "ip-profile": object_schema, }, - "required": ["name"], + "required": ["name"], "additionalProperties": False } @@ -711,7 +739,7 @@ nsi_instantiate = { "type": "object", "properties": { "lcmOperationType": string_schema, - "nsiInstanceId": id_schema, + "netsliceInstanceId": id_schema, "nsiName": name_schema, "nsiDescription": {"oneOf": [description_schema, null_schema]}, "nstId": string_schema, @@ -739,7 +767,7 @@ nsi_action = { } nsi_terminate = { - + } @@ -768,3 +796,16 @@ def validate_input(indata, schema_to_use): raise ValidationError("Format error {} '{}' ".format(error_pos, e.message)) except js_e.SchemaError: raise ValidationError("Bad json schema {}".format(schema_to_use), http_code=HTTPStatus.INTERNAL_SERVER_ERROR) + + +def is_valid_uuid(x): + """ + Test for a valid UUID + :param x: string to test + :return: True if x is a valid uuid, False otherwise + """ + try: + if UUID(x): + return True + except (TypeError, ValueError): + return False