- Added comprehensive AI Assistant system (aiassist/ directory): * Vector search and embedding capabilities * Typebot proxy integration * Elastic search functionality * Message classification and chat history * MCP proxy for external integrations - Implemented Court Status API (GetCourtStatus.php): * Real-time court document status checking * Integration with external court systems * Comprehensive error handling and logging - Enhanced S3 integration: * Improved file backup system with metadata * Batch processing capabilities * Enhanced error logging and recovery * Copy operations with URL fixing - Added Telegram contact creation API - Improved error logging across all modules - Enhanced callback system for AI responses - Extensive backup file storage with timestamps - Updated documentation and README files - File storage improvements: * Thousands of backup files with proper metadata * Fix operations for broken file references * Project-specific backup and recovery systems * Comprehensive file integrity checking Total: 26,461+ files added/modified including AWS SDK, vendor dependencies, and extensive backup system.
214 lines
8.0 KiB
PHP
214 lines
8.0 KiB
PHP
<?php
|
|
/*+***********************************************************************************
|
|
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
|
|
* ("License"); You may not use this file except in compliance with the License
|
|
* The Original Code is: vtiger CRM Open Source
|
|
* The Initial Developer of the Original Code is vtiger.
|
|
* Portions created by vtiger are Copyright (C) vtiger.
|
|
* All Rights Reserved.
|
|
*************************************************************************************/
|
|
|
|
class Calendar_Save_Action extends Vtiger_Save_Action {
|
|
|
|
public function checkPermission(Vtiger_Request $request) {
|
|
$moduleName = $request->getModule();
|
|
$record = $request->get('record');
|
|
parent::checkPermission($request);
|
|
if ($record) {
|
|
$activityModulesList = array('Calendar', 'Events');
|
|
$recordEntityName = getSalesEntityType($record);
|
|
|
|
if (!in_array($recordEntityName, $activityModulesList) || !in_array($moduleName, $activityModulesList)) {
|
|
throw new AppException(vtranslate('LBL_PERMISSION_DENIED'));
|
|
}
|
|
}
|
|
}
|
|
|
|
public function process(Vtiger_Request $request) {
|
|
try {
|
|
$recordModel = $this->saveRecord($request);
|
|
$loadUrl = $recordModel->getDetailViewUrl();
|
|
|
|
if ($request->get('returntab_label')) {
|
|
$loadUrl = 'index.php?'.$request->getReturnURL();
|
|
} else if($request->get('relationOperation')) {
|
|
$parentModuleName = $request->get('sourceModule');
|
|
$parentRecordId = $request->get('sourceRecord');
|
|
$parentRecordModel = Vtiger_Record_Model::getInstanceById($parentRecordId, $parentModuleName);
|
|
//TODO : Url should load the related list instead of detail view of record
|
|
$loadUrl = $parentRecordModel->getDetailViewUrl();
|
|
} else if ($request->get('returnToList')) {
|
|
$moduleModel = $recordModel->getModule();
|
|
$listViewUrl = $moduleModel->getListViewUrl();
|
|
|
|
if ($recordModel->get('visibility') === 'Private') {
|
|
$loadUrl = $listViewUrl;
|
|
} else {
|
|
$userId = $recordModel->get('assigned_user_id');
|
|
$sharedType = $moduleModel->getSharedType($userId);
|
|
if ($sharedType === 'selectedusers') {
|
|
$currentUserModel = Users_Record_Model::getCurrentUserModel();
|
|
$sharedUserIds = Calendar_Module_Model::getCaledarSharedUsers($userId);
|
|
if (!array_key_exists($currentUserModel->id, $sharedUserIds)) {
|
|
$loadUrl = $listViewUrl;
|
|
}
|
|
} else if ($sharedType === 'private') {
|
|
$loadUrl = $listViewUrl;
|
|
}
|
|
}
|
|
} else if ($request->get('returnmodule') && $request->get('returnview')){
|
|
$loadUrl = 'index.php?'.$request->getReturnURL();
|
|
}
|
|
header("Location: $loadUrl");
|
|
} catch (DuplicateException $e) {
|
|
$mode = '';
|
|
if ($request->getModule() === 'Events') {
|
|
$mode = 'Events';
|
|
}
|
|
|
|
$requestData = $request->getAll();
|
|
unset($requestData['action']);
|
|
unset($requestData['__vtrftk']);
|
|
|
|
if ($request->isAjax()) {
|
|
$response = new Vtiger_Response();
|
|
$response->setError($e->getMessage(), $e->getDuplicationMessage(), $e->getMessage());
|
|
$response->emit();
|
|
} else {
|
|
$requestData['view'] = 'Edit';
|
|
$requestData['mode'] = $mode;
|
|
$requestData['module'] = 'Calendar';
|
|
$requestData['duplicateRecords'] = $e->getDuplicateRecordIds();
|
|
|
|
global $vtiger_current_version;
|
|
$viewer = new Vtiger_Viewer();
|
|
$viewer->assign('REQUEST_DATA', $requestData);
|
|
$viewer->assign('REQUEST_URL', "index.php?module=Calendar&view=Edit&mode=$mode&record=".$request->get('record'));
|
|
$viewer->view('RedirectToEditView.tpl', 'Vtiger');
|
|
}
|
|
} catch (Exception $e) {
|
|
throw new Exception($e->getMessage());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Function to save record
|
|
* @param <Vtiger_Request> $request - values of the record
|
|
* @return <RecordModel> - record Model of saved record
|
|
*/
|
|
public function saveRecord($request) {
|
|
$recordModel = $this->getRecordModelFromRequest($request);
|
|
$recordModel->save();
|
|
if($request->get('relationOperation')) {
|
|
$parentModuleName = $request->get('sourceModule');
|
|
$parentModuleModel = Vtiger_Module_Model::getInstance($parentModuleName);
|
|
$parentRecordId = $request->get('sourceRecord');
|
|
$relatedModule = $recordModel->getModule();
|
|
if($relatedModule->getName() == 'Events'){
|
|
$relatedModule = Vtiger_Module_Model::getInstance('Calendar');
|
|
}
|
|
$relatedRecordId = $recordModel->getId();
|
|
|
|
$relationModel = Vtiger_Relation_Model::getInstance($parentModuleModel, $relatedModule);
|
|
$relationModel->addRelation($parentRecordId, $relatedRecordId);
|
|
}
|
|
return $recordModel;
|
|
}
|
|
|
|
/**
|
|
* Function to get the record model based on the request parameters
|
|
* @param Vtiger_Request $request
|
|
* @return Vtiger_Record_Model or Module specific Record Model instance
|
|
*/
|
|
protected function getRecordModelFromRequest(Vtiger_Request $request) {
|
|
$moduleName = $request->getModule();
|
|
$recordId = $request->get('record');
|
|
|
|
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
|
|
|
|
if(!empty($recordId)) {
|
|
$recordModel = Vtiger_Record_Model::getInstanceById($recordId, $moduleName);
|
|
$modelData = $recordModel->getData();
|
|
$recordModel->set('id', $recordId);
|
|
$recordModel->set('mode', 'edit');
|
|
//Due to dependencies on the activity_reminder api in Activity.php(5.x)
|
|
$_REQUEST['mode'] = 'edit';
|
|
} else {
|
|
$recordModel = Vtiger_Record_Model::getCleanInstance($moduleName);
|
|
$modelData = $recordModel->getData();
|
|
$recordModel->set('mode', '');
|
|
}
|
|
|
|
$fieldModelList = $moduleModel->getFields();
|
|
foreach ($fieldModelList as $fieldName => $fieldModel) {
|
|
$fieldValue = $request->get($fieldName, null);
|
|
// For custom time fields in Calendar, it was not converting to db insert format(sending as 10:00 AM/PM)
|
|
$fieldDataType = $fieldModel->getFieldDataType();
|
|
if($fieldValue){
|
|
$fieldValue = Vtiger_Util_Helper::validateFieldValue($fieldValue,$fieldModel);
|
|
}
|
|
if($fieldDataType == 'time' && $fieldValue !== null){
|
|
$fieldValue = Vtiger_Time_UIType::getTimeValueWithSeconds($fieldValue);
|
|
}
|
|
// End
|
|
if ($fieldName === $request->get('field')) {
|
|
$fieldValue = $request->get('value');
|
|
}
|
|
|
|
//SalesPlatform.ru begin
|
|
if($fieldModel->isCKEEnabled()) {
|
|
$fieldValue = vtlib_purify(decode_html($fieldValue));
|
|
}
|
|
//SalesPlatform.ru end
|
|
|
|
if($fieldValue !== null) {
|
|
if(!is_array($fieldValue)) {
|
|
$fieldValue = trim($fieldValue);
|
|
}
|
|
$recordModel->set($fieldName, $fieldValue);
|
|
}
|
|
}
|
|
|
|
//Start Date and Time values
|
|
if($request->get('date_start') && $request->get('time_start')) {
|
|
$startTime = Vtiger_Time_UIType::getTimeValueWithSeconds($request->get('time_start'));
|
|
$startDateTime = Vtiger_Datetime_UIType::getDBDateTimeValue($request->get('date_start')." ".$startTime);
|
|
list($startDate, $startTime) = explode(' ', $startDateTime);
|
|
|
|
$recordModel->set('date_start', $startDate);
|
|
$recordModel->set('time_start', $startTime);
|
|
}
|
|
|
|
//End Date and Time values
|
|
if($request->get('due_date')) {
|
|
$endTime = $request->get('time_end');
|
|
$endDate = Vtiger_Date_UIType::getDBInsertedValue($request->get('due_date'));
|
|
|
|
if ($endTime) {
|
|
$endTime = Vtiger_Time_UIType::getTimeValueWithSeconds($endTime);
|
|
$endDateTime = Vtiger_Datetime_UIType::getDBDateTimeValue($request->get('due_date')." ".$endTime);
|
|
list($endDate, $endTime) = explode(' ', $endDateTime);
|
|
}
|
|
|
|
$recordModel->set('time_end', $endTime);
|
|
$recordModel->set('due_date', $endDate);
|
|
}
|
|
|
|
$activityType = $request->get('activitytype');
|
|
if(empty($activityType)) {
|
|
$recordModel->set('activitytype', 'Task');
|
|
$recordModel->set('visibility', 'Private');
|
|
}
|
|
|
|
//Due to dependencies on the older code
|
|
$setReminder = $request->get('set_reminder');
|
|
if($setReminder) {
|
|
$_REQUEST['set_reminder'] = 'Yes';
|
|
} else {
|
|
$_REQUEST['set_reminder'] = 'No';
|
|
}
|
|
|
|
return $recordModel;
|
|
}
|
|
}
|