X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2FNBI.git;a=blobdiff_plain;f=osm_nbi%2Fvalidation.py;h=fa812bf2214ada724945190052c15ee94f45fd93;hp=4ffd0b785e7357e045caee78855e78f9553d50ac;hb=9750c5ac0f5afdd245ebc25fe5070393b3fbab8d;hpb=b69fb3ca37645088483959976edbfc7fda66df8d diff --git a/osm_nbi/validation.py b/osm_nbi/validation.py index 4ffd0b7..fa812bf 100644 --- a/osm_nbi/validation.py +++ b/osm_nbi/validation.py @@ -35,6 +35,7 @@ vlan_schema = {"type": "integer", "minimum": 1, "maximum": 4095} vlan1000_schema = {"type": "integer", "minimum": 1000, "maximum": 4095} mac_schema = {"type": "string", "pattern": "^[0-9a-fA-F][02468aceACE](:[0-9a-fA-F]{2}){5}$"} # must be unicast: LSB bit of MSB byte ==0 +dpid_Schema = {"type": "string", "pattern": "^[0-9a-fA-F]{2}(:[0-9a-fA-F]{2}){7}$"} # mac_schema={"type":"string", "pattern":"^([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}$"} ip_schema = {"type": "string", "pattern": "^((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$"} @@ -56,6 +57,11 @@ array_edition_schema = { "additionalProperties": False, "minProperties": 1, } +nameshort_list_schema = { + "type": "array", + "minItems": 1, + "items": nameshort_schema, +} ns_instantiate_vdu = { @@ -182,6 +188,8 @@ ns_instantiate = { "$schema": "http://json-schema.org/draft-04/schema#", "type": "object", "properties": { + "lcmOperationType": string_schema, + "nsInstanceId": id_schema, "nsName": name_schema, "nsDescription": {"oneOf": [description_schema, {"type": "null"}]}, "nsdId": id_schema, @@ -252,6 +260,8 @@ ns_action = { # TODO for the moment it is only contemplated the vnfd primitive "$schema": "http://json-schema.org/draft-04/schema#", "type": "object", "properties": { + "lcmOperationType": string_schema, + "nsInstanceId": id_schema, "member_vnf_index": name_schema, "vnf_member_index": name_schema, # TODO for backward compatibility. To remove in future "vdu_id": name_schema, @@ -266,6 +276,8 @@ ns_scale = { # TODO for the moment it is only VDU-scaling "$schema": "http://json-schema.org/draft-04/schema#", "type": "object", "properties": { + "lcmOperationType": string_schema, + "nsInstanceId": id_schema, "scaleType": {"enum": ["SCALE_VNF"]}, "scaleVnfData": { "type": "object", @@ -344,7 +356,7 @@ vim_account_new_schema = { sdn_properties = { "name": name_schema, "description": description_schema, - "dpid": {"type": "string", "pattern": "^[0-9a-fA-F]{2}(:[0-9a-fA-F]{2}){7}$"}, + "dpid": dpid_Schema, "ip": ip_schema, "port": port_schema, "type": {"type": "string", "enum": ["opendaylight", "floodlight", "onos"]}, @@ -404,12 +416,73 @@ sdn_external_port_schema = { "required": ["port"] } -# USERS -user_project_schema = { - "type": "array", - "minItems": 1, - "items": nameshort_schema, +# PDUs +pdu_interface = { + "type": "object", + "properties": { + "name": nameshort_schema, + "mgmt": bool_schema, + "type": {"enum": ["overlay", 'underlay']}, + "ip_address": ip_schema, + # TODO, add user, password, ssh-key + "mac_address": mac_schema, + "vim_network_name": nameshort_schema, # interface is connected to one vim network, or switch port + "vim_network_id": nameshort_schema, + # provide this in case SDN assist must deal with this interface + "switch_dpid": dpid_Schema, + "switch_port": nameshort_schema, + "switch_mac": nameshort_schema, + "switch_vlan": vlan_schema, + }, + "required": ["name", "mgmt", "ip_address"], + "additionalProperties": False +} +pdu_new_schema = { + "title": "pdu creation input schema", + "$schema": "http://json-schema.org/draft-04/schema#", + "type": "object", + "properties": { + "name": nameshort_schema, + "type": nameshort_schema, + "description": description_schema, + "shared": bool_schema, + "vims": nameshort_list_schema, + "vim_accounts": nameshort_list_schema, + "interfaces": { + "type": "array", + "items": {"type": pdu_interface}, + "minItems": 1 + } + }, + "required": ["name", "type", "interfaces"], + "additionalProperties": False } + +pdu_edit_schema = { + "title": "pdu edit input schema", + "$schema": "http://json-schema.org/draft-04/schema#", + "type": "object", + "properties": { + "name": nameshort_schema, + "type": nameshort_schema, + "description": description_schema, + "shared": bool_schema, + "vims": {"oneOff": [array_edition_schema, nameshort_list_schema]}, + "vim_accounts": {"oneOff": [array_edition_schema, nameshort_list_schema]}, + "interfaces": {"oneOff": [ + array_edition_schema, + { + "type": "array", + "items": {"type": pdu_interface}, + "minItems": 1 + } + ]} + }, + "additionalProperties": False, + "minProperties": 1 +} + +# USERS user_new_schema = { "$schema": "http://json-schema.org/draft-04/schema#", "title": "New user schema", @@ -417,7 +490,7 @@ user_new_schema = { "properties": { "username": nameshort_schema, "password": passwd_schema, - "projects": user_project_schema, + "projects": nameshort_list_schema, }, "required": ["username", "password", "projects"], "additionalProperties": False @@ -430,11 +503,13 @@ user_edit_schema = { "password": passwd_schema, "projects": { "oneOff": [ - user_project_schema, + nameshort_list_schema, array_edition_schema ] }, - } + }, + "minProperties": 1, + "additionalProperties": False } # PROJECTS @@ -469,14 +544,16 @@ nbi_new_input_schemas = { "sdns": sdn_new_schema, "ns_instantiate": ns_instantiate, "ns_action": ns_action, - "ns_scale": ns_scale + "ns_scale": ns_scale, + "pdus": pdu_new_schema, } nbi_edit_input_schemas = { "users": user_edit_schema, "projects": project_edit_schema, "vim_accounts": vim_account_edit_schema, - "sdns": sdn_edit_schema + "sdns": sdn_edit_schema, + "pdus": pdu_edit_schema, } @@ -484,19 +561,14 @@ class ValidationError(Exception): pass -def validate_input(indata, item, new=True): +def validate_input(indata, schema_to_use): """ Validates input data against json schema :param indata: user input data. Should be a dictionary - :param item: can be users, projects, vims, sdns, ns_xxxxx - :param new: True if the validation is for creating or False if it is for editing - :return: None if ok, raises ValidationError exception otherwise + :param schema_to_use: jsonschema to test + :return: None if ok, raises ValidationError exception on error """ try: - if new: - schema_to_use = nbi_new_input_schemas.get(item) - else: - schema_to_use = nbi_edit_input_schemas.get(item) if schema_to_use: js_v(indata, schema_to_use) return None