180 lines
6.5 KiB
PHP
180 lines
6.5 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 Vtiger_Save_Action extends Vtiger_Action_Controller {
|
||
|
|
|
||
|
|
public function requiresPermission(\Vtiger_Request $request) {
|
||
|
|
$permissions = parent::requiresPermission($request);
|
||
|
|
$moduleParameter = $request->get('source_module');
|
||
|
|
if (!$moduleParameter) {
|
||
|
|
$moduleParameter = 'module';
|
||
|
|
}else{
|
||
|
|
$moduleParameter = 'source_module';
|
||
|
|
}
|
||
|
|
$record = $request->get('record');
|
||
|
|
$recordId = $request->get('id');
|
||
|
|
if (!$record) {
|
||
|
|
$recordParameter = '';
|
||
|
|
}else{
|
||
|
|
$recordParameter = 'record';
|
||
|
|
}
|
||
|
|
$actionName = ($record || $recordId) ? 'EditView' : 'CreateView';
|
||
|
|
$permissions[] = array('module_parameter' => $moduleParameter, 'action' => 'DetailView', 'record_parameter' => $recordParameter);
|
||
|
|
$permissions[] = array('module_parameter' => $moduleParameter, 'action' => $actionName, 'record_parameter' => $recordParameter);
|
||
|
|
return $permissions;
|
||
|
|
}
|
||
|
|
|
||
|
|
public function checkPermission(Vtiger_Request $request) {
|
||
|
|
$moduleName = $request->getModule();
|
||
|
|
$record = $request->get('record');
|
||
|
|
|
||
|
|
$nonEntityModules = array('Users', 'Events', 'Calendar', 'Portal', 'Reports', 'Rss', 'EmailTemplates');
|
||
|
|
if ($record && !in_array($moduleName, $nonEntityModules)) {
|
||
|
|
$recordEntityName = getSalesEntityType($record);
|
||
|
|
if ($recordEntityName !== $moduleName) {
|
||
|
|
throw new AppException(vtranslate('LBL_PERMISSION_DENIED'));
|
||
|
|
}
|
||
|
|
}
|
||
|
|
return parent::checkPermission($request);
|
||
|
|
}
|
||
|
|
|
||
|
|
public function validateRequest(Vtiger_Request $request) {
|
||
|
|
return $request->validateWriteAccess();
|
||
|
|
}
|
||
|
|
|
||
|
|
public function process(Vtiger_Request $request) {
|
||
|
|
try {
|
||
|
|
$recordModel = $this->saveRecord($request);
|
||
|
|
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')) {
|
||
|
|
$loadUrl = $recordModel->getModule()->getListViewUrl();
|
||
|
|
} else if ($request->get('returnmodule') && $request->get('returnview')) {
|
||
|
|
$loadUrl = 'index.php?'.$request->getReturnURL();
|
||
|
|
} else {
|
||
|
|
$loadUrl = $recordModel->getDetailViewUrl();
|
||
|
|
}
|
||
|
|
//append App name to callback url
|
||
|
|
//Special handling for vtiger7.
|
||
|
|
$appName = $request->get('appName');
|
||
|
|
if(strlen($appName) > 0){
|
||
|
|
$loadUrl = $loadUrl.$appName;
|
||
|
|
}
|
||
|
|
header("Location: $loadUrl");
|
||
|
|
} catch (DuplicateException $e) {
|
||
|
|
$requestData = $request->getAll();
|
||
|
|
$moduleName = $request->getModule();
|
||
|
|
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['duplicateRecords'] = $e->getDuplicateRecordIds();
|
||
|
|
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
|
||
|
|
|
||
|
|
global $vtiger_current_version;
|
||
|
|
$viewer = new Vtiger_Viewer();
|
||
|
|
|
||
|
|
$viewer->assign('REQUEST_DATA', $requestData);
|
||
|
|
$viewer->assign('REQUEST_URL', $moduleModel->getCreateRecordUrl().'&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);
|
||
|
|
if($request->get('imgDeleted')) {
|
||
|
|
$imageIds = $request->get('imageid');
|
||
|
|
foreach($imageIds as $imageId) {
|
||
|
|
$status = $recordModel->deleteImage($imageId);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
$recordModel->save();
|
||
|
|
if($request->get('relationOperation')) {
|
||
|
|
$parentModuleName = $request->get('sourceModule');
|
||
|
|
$parentModuleModel = Vtiger_Module_Model::getInstance($parentModuleName);
|
||
|
|
$parentRecordId = $request->get('sourceRecord');
|
||
|
|
$relatedModule = $recordModel->getModule();
|
||
|
|
$relatedRecordId = $recordModel->getId();
|
||
|
|
if($relatedModule->getName() == 'Events'){
|
||
|
|
$relatedModule = Vtiger_Module_Model::getInstance('Calendar');
|
||
|
|
}
|
||
|
|
|
||
|
|
$relationModel = Vtiger_Relation_Model::getInstance($parentModuleModel, $relatedModule);
|
||
|
|
$relationModel->addRelation($parentRecordId, $relatedRecordId);
|
||
|
|
}
|
||
|
|
$this->savedRecordId = $recordModel->getId();
|
||
|
|
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);
|
||
|
|
$recordModel->set('id', $recordId);
|
||
|
|
$recordModel->set('mode', 'edit');
|
||
|
|
} else {
|
||
|
|
$recordModel = Vtiger_Record_Model::getCleanInstance($moduleName);
|
||
|
|
$recordModel->set('mode', '');
|
||
|
|
}
|
||
|
|
|
||
|
|
$fieldModelList = $moduleModel->getFields();
|
||
|
|
foreach ($fieldModelList as $fieldName => $fieldModel) {
|
||
|
|
$fieldValue = $request->get($fieldName, null);
|
||
|
|
|
||
|
|
//SalesPlatform.ru begin
|
||
|
|
if($fieldModel->isCKEEnabled()) {
|
||
|
|
$fieldValue = vtlib_purify(decode_html($fieldValue));
|
||
|
|
}
|
||
|
|
//SalesPlatform.ru end
|
||
|
|
|
||
|
|
$fieldDataType = $fieldModel->getFieldDataType();
|
||
|
|
if($fieldDataType == 'time' && $fieldValue !== null){
|
||
|
|
$fieldValue = Vtiger_Time_UIType::getTimeValueWithSeconds($fieldValue);
|
||
|
|
}
|
||
|
|
if($fieldValue !== null) {
|
||
|
|
if(!is_array($fieldValue) && $fieldDataType != 'currency') {
|
||
|
|
$fieldValue = trim($fieldValue);
|
||
|
|
}
|
||
|
|
$recordModel->set($fieldName, $fieldValue);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
return $recordModel;
|
||
|
|
}
|
||
|
|
}
|