- 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.
140 lines
4.8 KiB
PHP
140 lines
4.8 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 Users_Save_Action extends Vtiger_Save_Action {
|
|
|
|
public function requiresPermission(\Vtiger_Request $request) {
|
|
return array();
|
|
}
|
|
|
|
public function checkPermission(Vtiger_Request $request) {
|
|
$allowed = parent::checkPermission($request);
|
|
if ($allowed) {
|
|
$moduleName = $request->getModule();
|
|
$record = $request->get('record');
|
|
$recordModel = Vtiger_Record_Model::getInstanceById($record, $moduleName);
|
|
$currentUserModel = Users_Record_Model::getCurrentUserModel();
|
|
// Deny access if not administrator or account-owner or self
|
|
if(!$currentUserModel->isAdminUser()) {
|
|
if (empty($record)) {
|
|
$allowed = false;
|
|
} else if (($currentUserModel->get('id') != $recordModel->getId())) {
|
|
$allowed = false;
|
|
}
|
|
}
|
|
}
|
|
if(!$allowed) {
|
|
throw new AppException('LBL_PERMISSION_DENIED');
|
|
}
|
|
return $allowed;
|
|
}
|
|
|
|
/**
|
|
* 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
|
|
*/
|
|
public function getRecordModelFromRequest(Vtiger_Request $request) {
|
|
$moduleName = $request->getModule();
|
|
$recordId = $request->get('record');
|
|
$currentUserModel = Users_Record_Model::getCurrentUserModel();
|
|
|
|
if(!empty($recordId)) {
|
|
$recordModel = Vtiger_Record_Model::getInstanceById($recordId, $moduleName);
|
|
$modelData = $recordModel->getData();
|
|
$recordModel->set('id', $recordId);
|
|
$sharedType = $request->get('sharedtype');
|
|
if(!empty($sharedType))
|
|
$recordModel->set('calendarsharedtype', $request->get('sharedtype'));
|
|
$recordModel->set('mode', 'edit');
|
|
} else {
|
|
$recordModel = Vtiger_Record_Model::getCleanInstance($moduleName);
|
|
$modelData = $recordModel->getData();
|
|
$recordModel->set('mode', '');
|
|
}
|
|
|
|
foreach ($modelData as $fieldName => $value) {
|
|
$requestFieldExists = $request->has($fieldName);
|
|
if(!$requestFieldExists){
|
|
continue;
|
|
}
|
|
$fieldValue = $request->get($fieldName, null);
|
|
if ($fieldName === 'is_admin' && (!$currentUserModel->isAdminUser() || !$fieldValue)) {
|
|
$fieldValue = 'off';
|
|
}
|
|
//to not update is_owner from ui
|
|
if ($fieldName == 'is_owner') {
|
|
$fieldValue = null;
|
|
}
|
|
if ($fieldName == 'roleid' && !($currentUserModel->isAdminUser())) {
|
|
$fieldValue = null;
|
|
}
|
|
|
|
if($fieldValue !== null) {
|
|
if(!is_array($fieldValue)) {
|
|
$fieldValue = trim($fieldValue);
|
|
}
|
|
$recordModel->set($fieldName, $fieldValue);
|
|
}
|
|
}
|
|
$homePageComponents = $recordModel->getHomePageComponents();
|
|
$selectedHomePageComponents = $request->get('homepage_components', array());
|
|
foreach ($homePageComponents as $key => $value) {
|
|
if(in_array($key, $selectedHomePageComponents)) {
|
|
$request->setGlobal($key, $key);
|
|
} else {
|
|
$request->setGlobal($key, '');
|
|
}
|
|
}
|
|
if($request->has('tagcloudview')) {
|
|
// Tag cloud save
|
|
$tagCloud = $request->get('tagcloudview');
|
|
if($tagCloud == "on") {
|
|
$recordModel->set('tagcloud', 0);
|
|
} else {
|
|
$recordModel->set('tagcloud', 1);
|
|
}
|
|
}
|
|
return $recordModel;
|
|
}
|
|
|
|
public function process(Vtiger_Request $request) {
|
|
$result = Vtiger_Util_Helper::transformUploadedFiles($_FILES, true);
|
|
$_FILES = $result['imagename'];
|
|
|
|
$recordId = $request->get('record');
|
|
if (!$recordId) {
|
|
$module = $request->getModule();
|
|
$userName = $request->get('user_name');
|
|
$userModuleModel = Users_Module_Model::getCleanInstance($module);
|
|
$status = $userModuleModel->checkDuplicateUser($userName);
|
|
if ($status == true) {
|
|
throw new AppException(vtranslate('LBL_DUPLICATE_USER_EXISTS', $module));
|
|
}
|
|
}
|
|
$recordModel = $this->saveRecord($request);
|
|
|
|
if ($request->get('relationOperation')) {
|
|
$parentRecordModel = Vtiger_Record_Model::getInstanceById($request->get('sourceRecord'), $request->get('sourceModule'));
|
|
$loadUrl = $parentRecordModel->getDetailViewUrl();
|
|
} else if ($request->get('isPreference')) {
|
|
$loadUrl = $recordModel->getPreferenceDetailViewUrl();
|
|
} else if ($request->get('returnmodule') && $request->get('returnview')){
|
|
$loadUrl = 'index.php?'.$request->getReturnURL();
|
|
} else if($request->get('mode') == 'Calendar'){
|
|
$loadUrl = $recordModel->getCalendarSettingsDetailViewUrl();
|
|
}else {
|
|
$loadUrl = $recordModel->getDetailViewUrl();
|
|
}
|
|
|
|
header("Location: $loadUrl");
|
|
}
|
|
}
|