# Copyright 2015 Cisco Systems, 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. """ This module contains all the base classes for the Meta. """ import re import logging log = logging.getLogger('ucs') class WriteXmlOption(object): """Class used as enum.""" ALL = 0 ALL_CONFIG = 1 DIRTY = 2 class UcsVersion(object): """ This class handles the operations related to the UcsVersions. It provides the functionality to compare Ucs version objects. Attributes: * version (str): version string """ def __init__(self, version): if version is None: return None self.__version = version match_pattern = re.compile("^(?P[1-9][0-9]{0,2})\." "(?P(([0-9])|([1-9][0-9]{0,1})))\(" "(?P(([0-9])|([1-9][0-9]{0,2})))\." "(?P(([0-9])|([1-9][0-9]{0,4})))\)$") match_obj = re.match(match_pattern, version) if match_obj: self.__major = match_obj.group("major") self.__minor = match_obj.group("minor") self.__mr = match_obj.group("mr") self.__patch = match_obj.group("patch") return match_pattern = re.compile("^(?P[1-9][0-9]{0,2})\." "(?P(([0-9])|([1-9][0-9]{0,1})))\(" "(?P(([0-9])|([1-9][0-9]{0,2})))" "(?P[a-z])\)$") match_obj = re.match(match_pattern, version) if match_obj: self.__major = match_obj.group("major") self.__minor = match_obj.group("minor") self.__mr = match_obj.group("mr") self.__patch = match_obj.group("patch") return match_pattern = re.compile("^(?P[1-9][0-9]{0,2})\." "(?P(([0-9])|([1-9][0-9]{0,1})))\(" "(?P(([0-9])|([1-9][0-9]{0,2})))\)$") match_obj = re.match(match_pattern, version) if match_obj: self.__major = match_obj.group("major") self.__minor = match_obj.group("minor") self.__mr = match_obj.group("mr") return @property def major(self): """Getter Method of UcsVersion Class""" return self.__major @property def minor(self): """Getter Method of UcsVersion Class""" return self.__minor @property def mr(self): """Getter Method of UcsVersion Class""" return self.__mr @property def patch(self): """Getter Method of UcsVersion Class""" return self.__patch @property def version(self): """Getter Method of UcsVersion Class""" return self.__version def compare_to(self, version): """Method to compare UcsVersion.""" if version is None or not isinstance(version, UcsVersion): return 1 if self.__major != version.major: return ord(self.__major) - ord(version.major) if self.__minor != version.minor: return ord(self.__minor) - ord(version.minor) if self.__mr != version.mr: return ord(self.__mr) - ord(version.mr) return ord(self.__patch) - ord(version.patch) def __gt__(self, version): return self.compare_to(version) > 0 def __lt__(self, version): return self.compare_to(version) < 0 def __ge__(self, version): return self.compare_to(version) >= 0 def __le__(self, version): return self.compare_to(version) <= 0 def __eq__(self, version): return self.compare_to(version) == 0 def __str__(self): return self.__version class MoPropertyRestriction(object): """ This class handles the restriction information of the properties of managed object. """ def __init__(self, min_length=None, max_length=None, pattern=None, value_set=None, range_val=None): self.__min_length = min_length self.__max_length = max_length self.__pattern = pattern self.__range_val = range_val self.__value_set = value_set self.__range_roc = None self.__value_set_roc = None @property def min_length(self): """Getter Method of MoPropertyRestriction Class""" return self.__min_length @property def max_length(self): """Getter Method of MoPropertyRestriction Class""" return self.__max_length @property def pattern(self): """Getter Method of MoPropertyRestriction Class""" return self.__pattern @property def range_val(self): """Getter Method of MoPropertyRestriction Class""" return self.__range_val @property def value_set(self): """Getter Method of MoPropertyRestriction Class""" return self.__value_set @property def range_roc(self): """Getter Method of MoPropertyRestriction Class""" return self.__range_roc @property def value_set_roc(self): """Getter Method of MoPropertyRestriction Class""" return self.__value_set_roc class MoPropertyMeta(object): """ This class handles the meta information of the properties of managed Object. """ NAMING = 0 CREATE_ONLY = 1 READ_ONLY = 2 READ_WRITE = 3 INTERNAL = 4 def __init__(self, name, xml_attribute, field_type, version, access, mask, min_length, max_length, pattern, value_set, range_val): self.__name = name self.__xml_attribute = xml_attribute self.__field_type = field_type self.__version = version self.__access = access self.__mask = mask self.__restriction = MoPropertyRestriction(min_length, max_length, pattern, value_set, range_val) @property def name(self): """Getter Method of MoPropertyMeta Class""" return self.__name @property def xml_attribute(self): """Getter Method of MoPropertyMeta Class""" return self.__xml_attribute @property def field_type(self): """Getter Method of MoPropertyMeta Class""" return self.__field_type @property def version(self): """Getter Method of MoPropertyMeta Class""" return self.__version @property def access(self): """Getter Method of MoPropertyMeta Class""" return self.__access @property def mask(self): """Getter Method of MoPropertyMeta Class""" return self.__mask @property def restriction(self): """Getter Method of MoPropertyMeta Class""" return self.__restriction def validate_property_value(self, input_value): """validate property value of mo.""" error_msg = None if input_value is None: log.debug("<%s> Value should not be None" % self.name) return False if self.__restriction.min_length: if len(input_value) >= self.__restriction.min_length: return True else: error_msg = (str(self.name) + " minimum character should be " + str(self.__restriction.min_length)) if self.__restriction.max_length: if len(input_value) <= self.__restriction.max_length: return True else: error_msg = (str(self.name) + " maximum character should be " + str(self.__restriction.max_length)) if self.__restriction.range_val and str(input_value).isdigit() \ and len(self.__restriction.range_val) > 0: fits_in_range = False value = int(input_value) for rest_range in self.__restriction.range_val: match = re.match( r"""^(?P[0-9]{1,})\-(?P[0-9]{1,})$""", rest_range, 0) if match: min_ = int(match.group("min")) max_ = int(match.group("max")) else: continue if min_ <= value and max_ >= value: fits_in_range = True break if fits_in_range: return True else: error_msg = ("Value " + str(value) + " does not fit the range" + str(self.__restriction.range_val)) if self.__restriction.pattern and self.__restriction.value_set: pattern = "^" + str(self.__restriction.pattern) + "%s%s$" % ( '|' if self.__restriction.value_set else '', '|'.join(['('+x+')' for x in self.__restriction.value_set])) match = re.match(pattern, input_value, 0) if match: return True else: error_msg = (str(self.name) + " should adhere to regex " + str(pattern)) elif self.__restriction.pattern: pattern = "^" + self.__restriction.pattern + "$" match = re.match(pattern, input_value, 0) if match: return True else: error_msg = (str(self.name) + " should adhere to regex " + str(pattern)) elif self.__restriction.value_set \ and len(self.__restriction.value_set) > 0: if input_value in self.__restriction.value_set: return True else: error_msg = (str(self.name) + " valid values are " + str(self.__restriction.value_set)) if error_msg is not None: log.debug(error_msg) return False return True def __str__(self): """ Method to return string representation. """ access_dict = {0: "NAMING", 1: "CREATE_ONLY", 2: "READ_ONLY", 3: "READ_WRITE", 4: "INTERNAL"} ts = 8 out_str = "\n" out_str += "Property".ljust(ts * 4) + str(self.name) + "\n" out_str += ("-" * len("Property")).ljust(ts * 4) + "-" * len( self.name) + "\n" out_str += str("xml_attribute").ljust(ts * 4) + ':' + str( self.xml_attribute) + "\n" out_str += str("field_type").ljust(ts * 4) + ':' + str( self.field_type) + "\n" out_str += str("min_version").ljust(ts * 4) + ':' + str( self.version) + "\n" out_str += str("access").ljust(ts * 4) + ':' + str( access_dict[self.access]) + "\n" out_str += str("min_length").ljust(ts * 4) + ':' + str( self.restriction.min_length) + "\n" out_str += str("max_length").ljust(ts * 4) + ':' + str( self.restriction.max_length) + "\n" out_str += str("pattern").ljust(ts * 4) + ':' + str( self.restriction.pattern) + "\n" out_str += str("value_set").ljust(ts * 4) + ':' + str( self.restriction.value_set) + "\n" out_str += str("range_val").ljust(ts * 4) + ':' + str( self.restriction.range_val) return out_str class MoMeta(object): """ This class handles the meta information of the managed Object. """ ACCESS_TYPE_IO = "InputOutput" ACCESS_TYPE_OUTPUTONLY = "OutputOnly" def __init__(self, name, xml_attribute, rn, version, inp_out, mask, field_names, access, parents, children, verbs): self.__name = name self.__xml_attribute = xml_attribute self.__rn = rn self.__version = version self.__inp_out = inp_out self.__mask = mask self.__field_names = field_names self.__access = access self.__children = children self.__parents = parents self.__verbs = verbs @property def name(self): """Getter Method of MoMeta Class""" return self.__name @property def xml_attribute(self): """Getter Method of MoMeta Class""" return self.__xml_attribute @property def rn(self): """Getter Method of MoMeta Class""" return self.__rn @property def version(self): """Getter Method of MoMeta Class""" return self.__version @property def inp_out(self): """Getter Method of MoMeta Class""" return self.__inp_out @property def mask(self): """Getter Method of MoMeta Class""" return self.__mask @property def field_names(self): """Getter Method of MoMeta Class""" return self.__field_names @property def access(self): """Getter Method of MoMeta Class""" return self.__access @property def children(self): """Getter Method of MoMeta Class""" return self.__children @property def parents(self): """Getter Method of MoMeta Class""" return self.__parents @property def verbs(self): """Getter Method of MoMeta Class""" return self.__verbs class MethodPropertyMeta(object): """ This class handles the meta information of the properties of external method Object. """ def __init__(self, name, xml_attribute, field_type, version, inp_out, is_complex_type): self.__name = name self.__xml_attribute = xml_attribute self.__field_type = field_type self.__version = version self.__inp_out = inp_out self.__is_complex_type = is_complex_type @property def name(self): """Getter Method of MethodPropertyMeta Class""" return self.name @property def xml_attribute(self): """Getter Method of MethodPropertyMeta Class""" return self.__xml_attribute @property def field_type(self): """Getter Method of MethodPropertyMeta Class""" return self.__field_type @property def version(self): """Getter Method of MethodPropertyMeta Class""" return self.__version @property def inp_out(self): """Getter Method of MethodPropertyMeta Class""" return self.__inp_out @property def is_complex_type(self): """Getter Method of MethodPropertyMeta Class""" return self.__is_complex_type class MethodMeta(object): """ This class handles the meta information of the meta property of external method Object. """ def __init__(self, name, xml_attribute, version): self.__name = name self.__xml_attribute = xml_attribute self.__version = version @property def name(self): """Getter Method of MethodMeta Class""" return self.__name @property def xml_attribute(self): """Getter Method of MethodMeta Class""" return self.__xml_attribute @property def version(self): """Getter Method of MethodMeta Class""" return self.__version