def procList(context, main, add, filterinfo, session, params, curValue, startsWith, firstRecord, recordCount): print 'Get data of selector from Celesta Python procedure.' print 'User %s' % context.userId print 'main "%s".' % main print 'add "%s".' % add print 'filterinfo "%s".' % filterinfo print 'session "%s".' % session print 'params "%s".' % params print 'curValue "%s".' % curValue print 'startsWith "%s".' % startsWith print 'firstRecord "%s".' % firstRecord print 'recordCount "%s".' % recordCount recordList = ArrayList() for i in range(3): rec = DataRecord() rec.setId("item" + str(i)) rec.setName("Item " + str(i)) recordList.add(rec) # context.warning('dd2'); # context.message('dd1', u'Заголовок4', u"solutions/default/resources/group_icon_default.png"); # context.error('dd4', u'Заголовок4', u"solutions/default/resources/group_icon_default.png"); # recordList = ArrayList() return ResultSelectorData(recordList, 0)
def tablesList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): u'''Функция list для селектора выбора таблиц. ''' tables = TablesCursor(context) recordList = ArrayList() paramsXML = minidom.parseString(params) if paramsXML.getElementsByTagName('grainid')[0].childNodes: grainid = paramsXML.getElementsByTagName( 'grainid')[0].childNodes[0].data tables.setRange('grainid', grainid) tables.setFilter( 'tablename', "@%s'%s'%%" % ("%" * (not startswith), curvalue.replace("'", "''"))) tables.orderBy('tablename') tables.limit(firstrecord, recordcount) if tables.tryFindSet(): while True: rec = DataRecord() rec.setId(tables.tablename) rec.setName(tables.tablename) recordList.add(rec) if not tables.nextInSet(): break return ResultSelectorData(recordList, 0)
def customPermissionsTypesList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): u'''Функция list для селектора выбора ролей. ''' customPermissionsTypes = customPermsTypesCursor(context) customPermissionsTypes.setFilter( 'name', """@%s'%s'%%""" % ("%" * (not startswith), curvalue.replace("'", "''"))) customPermissionsTypes.orderBy('name') customPermissionsTypes.limit(firstrecord, recordcount) recordList = ArrayList() for customPermissionsTypes in customPermissionsTypes.iterate(): rec = DataRecord() rec.setId(unicode(customPermissionsTypes.name)) rec.setName(customPermissionsTypes.name) recordList.add(rec) return ResultSelectorData(recordList, 0)
def grainsList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): u'''Функция list для селектора выбора гранул. ''' grains = GrainsCursor(context) grains.setFilter( 'id', "@%s'%s'%%" % ("%" * (not startswith), curvalue.replace("'", "''"))) grains.orderBy('id') grains.limit(firstrecord, recordcount) recordList = ArrayList() if grains.tryFindSet(): while True: rec = DataRecord() rec.setId(unicode(grains.id)) rec.setName(grains.id) recordList.add(rec) if not grains.nextInSet(): break return ResultSelectorData(recordList, 0)
def rolesList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): u'''Функция list для селектора выбора ролей. ''' roles = RolesCursor(context) roles.setFilter( 'id', """!'editor'&!'reader'&@%s'%s'%%""" % ("%" * (not startswith), curvalue.replace("'", "''"))) roles.orderBy('id') roles.limit(firstrecord, recordcount) recordList = ArrayList() if roles.tryFindSet(): while True: rec = DataRecord() rec.setId(unicode(roles.id)) rec.setName(roles.id) recordList.add(rec) if not roles.nextInSet(): break return ResultSelectorData(recordList, 0)
def rolesList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue="", startswith=False, firstrecord=0, recordcount=None): u'''Функция list селектора типа элемента. ''' # raise Exception(curvalue) recordList = ArrayList() roles = RolesCursor(context) roles.setFilter( 'description', "@%s'%s'%%" % ("%" * (not startswith), curvalue.replace("'", "''"))) roles.orderBy('id') roles.limit(firstrecord, recordcount) if roles.tryFindSet(): while True: rec = DataRecord() rec.setId(roles.id) rec.setName( '%s - %s' % (roles.id, roles.description if roles.description else '')) recordList.add(rec) if not roles.nextInSet(): break return ResultSelectorData(recordList, 0)
def employeesList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue="", startswith=False, firstrecord=0, recordcount=None): u'''Функция list селектора типа элемента. ''' settings = Settings() # raise Exception(curvalue) recordList = ArrayList() employeesGrain = settings.getEmployeesParam("employeesGrain") employeesTable = settings.getEmployeesParam("employeesTable") employeesId = settings.getEmployeesParam("employeesId") employeesName = settings.getEmployeesParam("employeesName") employeesCursor = tableCursorImport(employeesGrain, employeesTable) employees = employeesCursor(context) employees.setFilter( employeesName, "@%s'%s'%%" % ("%" * (not startswith), curvalue.replace("'", "''"))) employees.orderBy(employeesName) employees.limit(firstrecord, recordcount) for employees in employees.iterate(): rec = DataRecord() rec.setId(getattr(employees, employeesId)) rec.setName(getattr(employees, employeesName)) recordList.add(rec) return ResultSelectorData(recordList, 0)
def itemsListAndCount(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): """Функция для получения списка элементов в пределе одного фильтра типа itemset""" all_fields, current = (x['filter'] for x in json.loads(XMLJSONConverter.xmlToJson(params))['schema']['filter']) add = repair_add(add) grain, table = context.getData()[add][0]["@tableName"].split('.') field_name = current["@id"] for necessary_field in context.getData()[add]: if field_name == necessary_field['@id']: current_field = necessary_field break selector_path = current_field['@selector_data'] # if bound_status != 'bound': if selector_path: selector_path = selector_path.split('.') selector_module, selector_function_name = '.'.join(selector_path[:-1]), selector_path[-1] selector_module = import_module(selector_module) selector = getattr(selector_module, selector_function_name) return selector(context, main, add, filterinfo, session, params, curvalue, startswith, firstrecord, recordcount) cursor_instance = tableCursorImport(grain, table) cursor = cursor_instance(context) # Булевый флаг для определения, является ли поле числовым is_quotes = current_field['@type'] != 'float' curvalue = curvalue.strip() cursor.orderBy(field_name) recordList = ArrayList() # набираем список значений i = 0 # if curvalue: # cursor.setRange(field_name, curvalue) while cursor.tryFirst() and i < (firstrecord + recordcount): current_name = getattr(cursor, field_name) if is_quotes: current_name = current_name.replace("'", "''") if (i >= firstrecord and not curvalue) or (i > firstrecord and curvalue): rec = DataRecord() rec.setId("rec%i" % i) rec.setName( unicode(current_name.replace('""', '"').replace("''", "'")) if is_quotes else unicode(current_name)) recordList.add(rec) # Определение формы выведения в setFilter для разных типов значений current_filter = ">%s" % ("'%s'" % current_name if is_quotes else int(current_name)) if curvalue: current_filter = """%s&@%s'%s'%%""" % (current_filter, "%" * (not startswith), curvalue.replace("'", "''")) # filtered_function(all_fields, add, cursor) cursor.setFilter(field_name, current_filter) i += 1 return ResultSelectorData(recordList, i)
def filtersList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): """Функция для получения списка доступных фильтров по полю @key""" add = repair_add(add) recordList = ArrayList() for filter_dict in context.getData()[add]: if filter_dict['@key'] == 'unview': rec = DataRecord() rec.setId(filter_dict['@id']) rec.setName(filter_dict['@label']) rec.addParameter('type', filter_dict['@type']) rec.addParameter('randint', str(clock())) rec.addParameter('face', filter_dict['@face']) rec.addParameter('bound', filter_dict['@bound']) rec.addParameter('selector_data', filter_dict['@selector_data']) rec.addParameter('boolInput', filter_dict['@boolInput']) recordList.add(rec) return ResultSelectorData(recordList, 0)
def usersList(context, main=None, add=None, filterinfo=None, session=None, params=None, curvalue=None, startswith=None, firstrecord=None, recordcount=None): u'''Функция list селектора типа элемента. ''' settings=Settings() recordList = ArrayList() #raise Exception(startswith, curvalue) if settings.isUseAuthServer() and settings.loginIsSubject(): sessionId=json.loads(session)["sessioncontext"]["sessionid"] server=SecurityParamsFactory.getAuthServerUrl() users_xml=getUsersFromAuthServer(server, sessionId) for user in users_xml.getElementsByTagName("user"): if startswith and string.find(user.getAttribute("name"), curvalue)==0 or \ not startswith and string.find(user.getAttribute("name"), curvalue)>0: rec = DataRecord() rec.setId(user.getAttribute("SID")) rec.setName(user.getAttribute("login")) recordList.add(rec) else: subject = subjectsCursor(context) subject.setFilter('name', "@%s'%s'%%" % ("%"*(not startswith), curvalue.replace("'","''"))) subject.orderBy('name') subject.limit(firstrecord, recordcount) for subject in subject.iterate(): rec = DataRecord() rec.setId(subject.sid) if subject.name is not None or subject.name!='': rec.setName(subject.name) else: rec.setName(u'[Имя не назначено!]') recordList.add(rec) return ResultSelectorData(recordList, 0)