63 lines
2.3 KiB
PHP
63 lines
2.3 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_Delete_Action extends Vtiger_Action_Controller {
|
||
|
|
|
||
|
|
public function requiresPermission(\Vtiger_Request $request) {
|
||
|
|
$permissions = parent::requiresPermission($request);
|
||
|
|
$permissions[] = array('module_parameter' => 'module', 'action' => 'DetailView', 'record_parameter' => 'record');
|
||
|
|
$permissions[] = array('module_parameter' => 'module', 'action' => 'Delete', 'record_parameter' => 'record');
|
||
|
|
return $permissions;
|
||
|
|
}
|
||
|
|
|
||
|
|
function checkPermission(Vtiger_Request $request) {
|
||
|
|
$moduleName = $request->getModule();
|
||
|
|
$record = $request->get('record');
|
||
|
|
|
||
|
|
parent::checkPermission($request);
|
||
|
|
|
||
|
|
$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'));
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
public function process(Vtiger_Request $request) {
|
||
|
|
$moduleName = $request->getModule();
|
||
|
|
$recordId = $request->get('record');
|
||
|
|
$ajaxDelete = $request->get('ajaxDelete');
|
||
|
|
$recurringEditMode = $request->get('recurringEditMode');
|
||
|
|
|
||
|
|
$recordModel = Vtiger_Record_Model::getInstanceById($recordId, $moduleName);
|
||
|
|
$recordModel->set('recurringEditMode', $recurringEditMode);
|
||
|
|
$moduleModel = $recordModel->getModule();
|
||
|
|
|
||
|
|
$recordModel->delete();
|
||
|
|
$cv = new CustomView();
|
||
|
|
$cvId = $cv->getViewId($moduleName);
|
||
|
|
deleteRecordFromDetailViewNavigationRecords($recordId, $cvId, $moduleName);
|
||
|
|
$listViewUrl = $moduleModel->getListViewUrl();
|
||
|
|
if($ajaxDelete) {
|
||
|
|
$response = new Vtiger_Response();
|
||
|
|
$response->setResult($listViewUrl);
|
||
|
|
return $response;
|
||
|
|
} else {
|
||
|
|
header("Location: $listViewUrl");
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
public function validateRequest(Vtiger_Request $request) {
|
||
|
|
$request->validateWriteAccess();
|
||
|
|
}
|
||
|
|
}
|