123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- # -*- coding: utf-8 -*-
- from lodel.leapi.datahandlers.base_classes import Reference, MultipleRef, SingleRef, FieldValidationError
-
- from lodel import logger
-
- class Link(SingleRef):
- pass
-
-
- ##@brief Child class of MultipleRef where references are represented in the form of a python list
- class List(MultipleRef):
-
- ##@brief instanciates a list reference
- # @param allowed_classes list | None : list of allowed em classes if None no restriction
- # @param internal bool
- # @param kwargs
- def __init__(self, max_length = None, **kwargs):
- super().__init__(**kwargs)
-
- ##@brief Check value
- # @param value *
- # @return tuple(value, exception)
- def _check_data_value(self, value):
- if isinstance(value, list) or isinstance(value, str):
- val, expt = super()._check_data_value(value)
- else:
- return None, FieldValidationError("List or string expected for a list field")
- #if not isinstance(expt, Exception):
- # val = list(val)
-
- return val, expt
-
- def construct_data(self, emcomponent, fname, datas, cur_value):
- if cur_value == 'None' or cur_value is None or cur_value == '':
- return None
- emcomponent_fields = emcomponent.fields()
- data_handler = None
- if fname in emcomponent_fields:
- data_handler = emcomponent_fields[fname]
- u_fname = emcomponent.uid_fieldname()
- uidtype = emcomponent.field(u_fname[0]) if isinstance(u_fname, list) else emcomponent.field(u_fname)
-
- if isinstance(cur_value, str):
- value = cur_value.split(',')
- l_value = [uidtype.cast_type(uid) for uid in value]
- elif isinstance(cur_value, list):
- l_value = list()
- for value in cur_value:
- if isinstance(value,uidtype):
- l_value.append(value)
- else:
- raise ValueError("The items must be of the same type, string or %s" % (ecomponent.__name__))
- else:
- l_value = None
-
- if l_value is not None:
- br_class = self.back_reference()[0]
- for br_id in l_value:
- query_filters = list()
- query_filters.append((br_class.uid_fieldname()[0], '=', br_id))
- br_obj = br_class.get(query_filters)
- if len(br_obj) == 0:
- raise ValueError("Not existing instance of class %s in back_reference" % br_class.__name__)
- br_list = br_obj.data(self.back_reference()[1])
- if br_id not in br_list:
- br_list.append(br_id)
- br_obj.set_data(self.back_reference()[1], br_list)
- br_obj.update()
- return l_value
-
- ##@brief Child class of MultipleRef where references are represented in the form of a python set
- class Set(MultipleRef):
-
- ##@brief instanciates a set reference
- # @param allowed_classes list | None : list of allowed em classes if None no restriction
- # @param internal bool : if False, the field is not internal
- # @param kwargs : Other named arguments
- def __init__(self, **kwargs):
- super().__init__(**kwargs)
-
- ##@brief Check value
- # @param value *
- # @return tuple(value, exception)
- def _check_data_value(self, value):
- if isinstance(value, set) or isinstance(value, str):
- val, expt = super()._check_data_value(value)
- else:
- return None, FieldValidationError("Set or string expected for a set field")
- return val, expt
-
- def construct_data(self, emcomponent, fname, datas, cur_value):
- if cur_value == 'None' or cur_value is None or cur_value == '':
- return None
- emcomponent_fields = emcomponent.fields()
- data_handler = None
- if fname in emcomponent_fields:
- data_handler = emcomponent_fields[fname]
- u_fname = emcomponent.uid_fieldname()
- uidtype = emcomponent.field(u_fname[0]) if isinstance(u_fname, list) else emcomponent.field(u_fname)
- if isinstance(cur_value, str):
- value = cur_value.split(',')
- l_value = [uidtype.cast_type(uid) for uid in value]
- logger.debug("Valeur avec uidtype : %d" % l_value)
- #l_value = [int(uid) for uid in value]
- return list(l_value)
- elif isinstance(cur_value, set):
- l_value = list()
-
- for value in cur_value:
- if isinstance(value,uidtype):
- l_value.append(value)
- else:
- raise ValueError("The items must be of the same type, string or %s" % (ecomponent.__name__))
- return l_value
- logger.debug(l_value)
- else:
- return None
-
-
- ##@brief Child class of MultipleRef where references are represented in the form of a python dict
- class Map(MultipleRef):
-
- ##@brief instanciates a dict reference
- # @param allowed_classes list | None : list of allowed em classes if None no restriction
- # @param internal bool : if False, the field is not internal
- # @param kwargs : Other named arguments
- def __init__(self, **kwargs):
- super().__init__(**kwargs)
-
- ##@brief Check value
- # @param value *
- # @return tuple(value, exception)
- def _check_data_value(self, value):
- val, expt = super()._check_data_value(value)
- if not isinstance(value, dict):
- return None, FieldValidationError("Values for dict fields should be dict")
- return (
- None if isinstance(expt, Exception) else value,
- expt)
-
- ##@brief This Reference class is designed to handler hierarchy with some constraint
- class Hierarch(MultipleRef):
-
- directly_editable = False
- ##@brief Instanciate a data handler handling hierarchical relation with constraints
- # @param back_reference tuple : Here it is mandatory to have a back ref (like a parent field)
- # @param max_depth int | None : limit of depth
- # @param max_childs int | Nine : maximum number of childs by nodes
- def __init__(self, back_reference, max_depth = None, max_childs = None, **kwargs):
- super().__init__( back_reference = back_reference,
- max_depth = max_depth,
- max_childs = max_childs,
- **kwargs)
-
- def _check_data_value(self, value):
- if isinstance(value, list) or isinstance(value, str):
- val, expt = super()._check_data_value(value)
- else:
- return None, FieldValidationError("Set or string expected for a set field")
- return val, expt
-
- def construct_data(self, emcomponent, fname, datas, cur_value):
- if cur_value == 'None' or cur_value is None or cur_value == '':
- return None
- emcomponent_fields = emcomponent.fields()
- data_handler = None
- if fname in emcomponent_fields:
- data_handler = emcomponent_fields[fname]
- u_fname = emcomponent.uid_fieldname()
- uidtype = emcomponent.field(u_fname[0]) if isinstance(u_fname, list) else emcomponent.field(u_fname)
- if isinstance(cur_value, str):
- value = cur_value.split(',')
- l_value = [uidtype.cast_type(uid) for uid in value]
- return list(l_value)
- elif isinstance(cur_value, list):
- l_value = list()
- for value in cur_value:
- if isinstance(value,uidtype):
- l_value.append(value)
- else:
- raise ValueError("The items must be of the same type, string or %s" % (ecomponent.__name__))
- return l_value
- else:
- return None
|