exposeMethod('deleteUserCalendar'); $this->exposeMethod('addUserCalendar'); $this->exposeMethod('deleteCalendarView'); $this->exposeMethod('addCalendarView'); } public function checkPermission(Vtiger_Request $request) { $moduleName = $request->getModule(); $record = $request->get('record'); if(!Users_Privileges_Model::isPermitted($moduleName, 'Save', $record)) { throw new AppException('LBL_PERMISSION_DENIED'); } } public function process(Vtiger_Request $request) { $mode = $request->getMode(); if(!empty($mode) && $this->isMethodExposed($mode)) { $this->invokeExposedMethod($mode, $request); return; } } /** * Function to delete the user calendar from shared calendar * @param Vtiger_Request $request * @return Vtiger_Response $response */ function deleteUserCalendar(Vtiger_Request $request) { $currentUser = Users_Record_Model::getCurrentUserModel(); $userId = $currentUser->getId(); $sharedUserId = $request->get('userid'); $db = PearDatabase::getInstance(); $result = $db->pquery('SELECT 1 FROM vtiger_shareduserinfo WHERE userid=? AND shareduserid=?', array($userId, $sharedUserId)); if($db->num_rows($result) > 0) { $db->pquery('UPDATE vtiger_shareduserinfo SET visible=? WHERE userid=? AND shareduserid=?', array('0', $userId, $sharedUserId)); } else { $db->pquery('INSERT INTO vtiger_shareduserinfo (userid, shareduserid, visible) VALUES(?, ?, ?)', array($userId, $sharedUserId, '0')); } $result = array('userid' => $userId, 'sharedid' => $sharedUserId, 'username' => getUserFullName($sharedUserId)); $response = new Vtiger_Response(); $response->setResult($result); $response->emit(); } /** * Function to add other user calendar to shared calendar * @param Vtiger_Request $request * @return Vtiger_Response $response */ function addUserCalendar(Vtiger_Request $request) { $currentUser = Users_Record_Model::getCurrentUserModel(); $userId = $currentUser->getId(); $sharedUserId = $request->get('selectedUser'); $color = $request->get('selectedColor'); $db = PearDatabase::getInstance(); $queryResult = $db->pquery('SELECT 1 FROM vtiger_shareduserinfo WHERE userid=? AND shareduserid=?', array($userId, $sharedUserId)); if($db->num_rows($queryResult) > 0) { $db->pquery('UPDATE vtiger_shareduserinfo SET color=?, visible=? WHERE userid=? AND shareduserid=?', array($color, '1', $userId, $sharedUserId)); } else { $db->pquery('INSERT INTO vtiger_shareduserinfo (userid, shareduserid, color, visible) VALUES(?, ?, ?, ?)', array($userId, $sharedUserId, $color, '1')); } $response = new Vtiger_Response(); $response->setResult(array('success' => true)); $response->emit(); } /** * Function to delete the calendar view from My Calendar * @param Vtiger_Request $request * @return Vtiger_Response $response */ function deleteCalendarView(Vtiger_Request $request) { $currentUser = Users_Record_Model::getCurrentUserModel(); $userId = $currentUser->getId(); $viewmodule = $request->get('viewmodule'); $viewfieldname = $request->get('viewfieldname'); $db = PearDatabase::getInstance(); $db->pquery('UPDATE vtiger_calendar_user_activitytypes INNER JOIN vtiger_calendar_default_activitytypes ON vtiger_calendar_default_activitytypes.id = vtiger_calendar_user_activitytypes.defaultid SET vtiger_calendar_user_activitytypes.visible=? WHERE vtiger_calendar_user_activitytypes.userid=? AND vtiger_calendar_default_activitytypes.module=? AND vtiger_calendar_default_activitytypes.fieldname=?', array('0', $userId, $viewmodule, $viewfieldname)); $result = array('viewmodule' => $viewmodule, 'viewfieldname' => $viewfieldname, 'viewfieldlabel' => $request->get('viewfieldlabel')); $response = new Vtiger_Response(); $response->setResult($result); $response->emit(); } /** * Function to add calendar views to My calendar * @param Vtiger_Request $request * @return Vtiger_Response $response */ function addCalendarView(Vtiger_Request $request) { $currentUser = Users_Record_Model::getCurrentUserModel(); $userId = $currentUser->getId(); $viewmodule = $request->get('viewmodule'); $viewfieldname = $request->get('viewfieldname'); $viewcolor = $request->get('viewColor'); $db = PearDatabase::getInstance(); $db->pquery('UPDATE vtiger_calendar_user_activitytypes INNER JOIN vtiger_calendar_default_activitytypes ON vtiger_calendar_default_activitytypes.id = vtiger_calendar_user_activitytypes.defaultid SET vtiger_calendar_user_activitytypes.color=?, vtiger_calendar_user_activitytypes.visible=? WHERE vtiger_calendar_user_activitytypes.userid=? AND vtiger_calendar_default_activitytypes.module=? AND vtiger_calendar_default_activitytypes.fieldname=?', array($viewcolor, '1', $userId, $viewmodule, $viewfieldname)); $response = new Vtiger_Response(); $response->setResult(array('success' => true)); $response->emit(); } }