/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records * @param Tinebase_Model_Filter_FilterGroup $_filter * @param Tinebase_Model_Pagination $_pagination * * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL, $_pagination = NULL) { $result = parent::_multipleRecordsToJson($_records, $_filter, $_pagination); // get groups + types (departments) and merge data $groupIds = $_records->group_id; $groups = Tinebase_Group::getInstance()->getMultiple(array_unique(array_values($groupIds))); $knownTypes = Tinebase_Department::getInstance()->search(new Tinebase_Model_DepartmentFilter()); foreach ($result as &$course) { $groupIdx = $groups->getIndexById($course['group_id']); if ($groupIdx !== FALSE) { $group = $groups[$groupIdx]->toArray(); unset($group['id']); $course = array_merge($group, $course); } else { if (Tinebase_Core::isLogLevel(Zend_Log::NOTICE)) { Tinebase_Core::getLogger()->notice(__METHOD__ . '::' . __LINE__ . ' Group with ID ' . $course['group_id'] . ' does not exist.'); } } $typeIdx = $knownTypes->getIndexById($course['type']); if ($typeIdx !== FALSE) { //if (Tinebase_Core::isLogLevel(Zend_Log::DEBUG)) Tinebase_Core::getLogger()->debug(__METHOD__ . '::' . __LINE__ . ' ' . print_r($knownTypes[$typeIdx]->toArray(), true)); $course['type'] = $knownTypes[$typeIdx]->toArray(); } else { if (Tinebase_Core::isLogLevel(Zend_Log::NOTICE)) { Tinebase_Core::getLogger()->notice(__METHOD__ . '::' . __LINE__ . ' Department with ID ' . $course['type'] . ' does not exist.'); } $course['type'] = array('id' => $course['type'], 'name' => $course['type']); } } return $result; }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup $_filter * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL) { if (count($_records) == 0) { return array(); } switch ($_records->getRecordClassName()) { case 'Tinebase_Model_Preference': $accountFilterArray = $_filter->getFilter('account')->toArray(); $adminMode = $accountFilterArray['value']['accountId'] == 0 && $accountFilterArray['value']['accountType'] == Tinebase_Acl_Rights::ACCOUNT_TYPE_ANYONE; foreach ($_records as $record) { if (!isset($app) || $record->application_id != $app->getId()) { $app = Tinebase_Application::getInstance()->getApplicationById($record->application_id); } $preference = Tinebase_Core::getPreference($app->name, TRUE); $preference->resolveOptions($record); if ($record->type == Tinebase_Model_Preference::TYPE_DEFAULT || !$adminMode && $record->type == Tinebase_Model_Preference::TYPE_ADMIN) { $record->value = Tinebase_Model_Preference::DEFAULT_VALUE; } } break; } $result = parent::_multipleRecordsToJson($_records, $_filter); return $result; }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup * @param Tinebase_Model_Pagination $_pagination * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL, $_pagination = NULL) { $result = parent::_multipleRecordsToJson($_records, $_filter, $_pagination); foreach ($result as &$contact) { $contact['jpegphoto'] = $this->_getImageLink($contact); } return $result; }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup $_filter * @param Tinebase_Model_Pagination $_pagination * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL, $_pagination = null) { switch ($_records->getRecordClassName()) { case 'Sipgate_Model_Connection': Sipgate_Controller_Line::getInstance()->resolveMultipleLines($_records); $this->_resolveMultipleContacts($_records); break; case 'Sipgate_Model_Line': Sipgate_Controller_Account::getInstance()->resolveMultipleAccounts($_records); Tinebase_User::getInstance()->resolveMultipleUsers($_records, $this->_resolveUserFields['Sipgate_Model_Line']); break; } return parent::_multipleRecordsToJson($_records); }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup $_filter * @param Tinebase_Model_Pagination $_pagination needed for sorting * @return array data * * @todo perhaps we need to resolveContainerTagsUsers() before mergeAndRemoveNonMatchingRecurrences(), but i'm not sure about that * @todo use Calendar_Convert_Event_Json */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL, $_pagination = NULL) { if ($_records->getRecordClassName() == 'Calendar_Model_Event') { if (is_null($_filter)) { throw new Tinebase_Exception_InvalidArgument('Required argument $_filter is missing'); } Tinebase_Notes::getInstance()->getMultipleNotesOfRecords($_records); Calendar_Model_Attender::resolveAttendee($_records->attendee, TRUE, $_records); Calendar_Convert_Event_Json::resolveOrganizer($_records); Calendar_Convert_Event_Json::resolveRrule($_records); Calendar_Controller_Event::getInstance()->getAlarms($_records); Calendar_Model_Rrule::mergeAndRemoveNonMatchingRecurrences($_records, $_filter); $_records->sortByPagination($_pagination); $eventsData = parent::_multipleRecordsToJson($_records); foreach ($eventsData as $eventData) { if (!array_key_exists(Tinebase_Model_Grants::GRANT_READ, $eventData) || !$eventData[Tinebase_Model_Grants::GRANT_READ]) { $eventData['notes'] = array(); $eventData['tags'] = array(); } } return $eventsData; } return parent::_multipleRecordsToJson($_records); }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup $_filter * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL) { switch ($_records->getRecordClassName()) { case 'Tinebase_Model_AccessLog': // TODO use _resolveUserFields and remove this foreach ($_records as $record) { if (!empty($record->account_id)) { try { $record->account_id = Admin_Controller_User::getInstance()->get($record->account_id)->toArray(); } catch (Tinebase_Exception_NotFound $e) { $record->account_id = Tinebase_User::getInstance()->getNonExistentUser('Tinebase_Model_FullUser')->toArray(); } } } break; case 'Tinebase_Model_Container': case 'Tinebase_Model_CustomField_Config': $applications = Tinebase_Application::getInstance()->getApplications(); foreach ($_records as $record) { $idx = $applications->getIndexById($record->application_id); if ($idx !== FALSE) { $record->application_id = $applications[$idx]; } } break; } $result = parent::_multipleRecordsToJson($_records, $_filter); return $result; }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup * @param Tinebase_Model_Pagination $_pagination * @return array data * * @todo move to converter * @todo get multiple grants at once */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL, $_pagination = NULL) { $result = parent::_multipleRecordsToJson($_records, $_filter); foreach ($result as $idx => $recordArray) { $recordIdx = $_records->getIndexById($recordArray['id']); try { if (!is_object($_records[$recordIdx]->filters)) { throw new Tinebase_Exception_UnexpectedValue('no filter group found'); } $result[$idx]['filters'] = $_records[$recordIdx]->filters->toArray(TRUE); } catch (Exception $e) { if (Tinebase_Core::isLogLevel(Zend_Log::NOTICE)) { Tinebase_Core::getLogger()->notice(__METHOD__ . '::' . __LINE__ . ' Skipping filter: ' . $e->getMessage()); } unset($result[$idx]); continue; } // resolve grant users/groups if (isset($result[$idx]['grants'])) { $result[$idx]['grants'] = Tinebase_Frontend_Json_Container::resolveAccounts($result[$idx]['grants']); $result[$idx]['account_grants'] = Tinebase_PersistentFilter::getInstance()->getGrantsOfAccount(Tinebase_Core::getUser(), $_records[$recordIdx])->toArray(); } } return array_values($result); }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL) { if ($_records->getRecordClassName() == 'Tasks_Model_Task') { // NOTE: in contrast to calendar, organizers in tasks are accounts atm. Tinebase_User::getInstance()->resolveMultipleUsers($_records, 'organizer', true); } //if (Tinebase_Core::isLogLevel(Zend_Log::DEBUG)) Tinebase_Core::getLogger()->debug(print_r($_records->toArray(), true)); return parent::_multipleRecordsToJson($_records); }
/** * returns multiple records prepared for json transport * * @param Tinebase_Record_RecordSet $_records Tinebase_Record_Abstract * @param Tinebase_Model_Filter_FilterGroup * @return array data */ protected function _multipleRecordsToJson(Tinebase_Record_RecordSet $_records, $_filter = NULL) { $result = parent::_multipleRecordsToJson($_records, $_filter); foreach ($result as $idx => $recordArray) { $recordIdx = $_records->getIndexById($recordArray['id']); try { $result[$idx]['filters'] = $_records[$recordIdx]->filters->toArray(TRUE); } catch (Exception $e) { // skip filter unset($result[$idx]); } } return array_values($result); }