Files
crm.clientright.ru/modules/EMAILMaker/actions/RelationAjax.php
Fedor ac7467f0b4 Major CRM updates: AI Assistant, Court Status API, S3 integration improvements, and extensive file storage system
- 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.
2025-10-16 11:17:21 +03:00

121 lines
4.6 KiB
PHP

<?php
/* * *******************************************************************************
* The content of this file is subject to the EMAIL Maker license.
* ("License"); You may not use this file except in compliance with the License
* The Initial Developer of the Original Code is IT-Solutions4You s.r.o.
* Portions created by IT-Solutions4You s.r.o. are Copyright(C) IT-Solutions4You s.r.o.
* All Rights Reserved.
* ****************************************************************************** */
class EMAILMaker_RelationAjax_Action extends Vtiger_Action_Controller
{
public function __construct()
{
parent::__construct();
$this->exposeMethod('addRelation');
$this->exposeMethod('deleteRelation');
$this->exposeMethod('getRelatedListPageCount');
}
public function checkPermission(Vtiger_Request $request)
{
}
public function preProcess(Vtiger_Request $request)
{
return true;
}
public function postProcess(Vtiger_Request $request)
{
return true;
}
public function process(Vtiger_Request $request)
{
$mode = $request->get('mode');
if (!empty($mode)) {
$this->invokeExposedMethod($mode, $request);
return;
}
}
public function addRelation($request)
{
$adb = PearDatabase::getInstance();
$sourceModule = $request->getModule();
$sourceRecordId = $request->get('src_record');
if (substr($sourceRecordId, 0, 1) == "t") {
$sourceRecordId = substr($sourceRecordId, 1);
}
$relatedModule = $request->get('related_module');
$relatedRecordIdList = $request->get('related_record_list');
foreach ($relatedRecordIdList as $relatedRecordId) {
$Atr = array($sourceRecordId, $relatedRecordId);
if ($relatedModule == "ITS4YouStyles") {
$sql1 = "DELETE FROM its4you_stylesrel WHERE parentid = ? AND styleid = ? AND module = ?";
$sql2 = "INSERT INTO its4you_stylesrel (parentid, styleid, module) VALUES (?,?,?)";
$Atr[] = "EMAILMaker";
} else {
$sql1 = "DELETE FROM vtiger_emakertemplates_documents WHERE templateid = ? AND documentid = ?";
$sql2 = "INSERT INTO vtiger_emakertemplates_documents (templateid, documentid) VALUES (?,?)";
}
$adb->pquery($sql1, $Atr);
$adb->pquery($sql2, $Atr);
}
}
public function deleteRelation($request)
{
$adb = PearDatabase::getInstance();
$sourceModule = $request->getModule();
$sourceRecordId = $request->get('src_record');
if (substr($sourceRecordId, 0, 1) == "t") {
$sourceRecordId = substr($sourceRecordId, 1);
}
$relatedModule = $request->get('related_module');
$relatedRecordIdList = $request->get('related_record_list');
vglobal('currentModule', $relatedModule);
foreach ($relatedRecordIdList as $relatedRecordId) {
$Atr = array($sourceRecordId, $relatedRecordId);
if ($relatedModule == "ITS4YouStyles") {
$sql = "DELETE FROM its4you_stylesrel WHERE parentid = ? AND styleid = ? AND module = ?";
$Atr[] = "EMAILMaker";
} else {
$sql = "DELETE FROM vtiger_emakertemplates_documents WHERE templateid = ? AND documentid = ?";
}
$adb->pquery($sql, $Atr);
}
return true;
}
public function getRelatedListPageCount(Vtiger_Request $request)
{
$moduleName = $request->getModule();
$relatedModuleName = $request->get('relatedModule');
$parentId = $request->get('record');
$label = $request->get('tab_label');
$pagingModel = new Vtiger_Paging_Model();
$parentRecordModel = Vtiger_Record_Model::getInstanceById($parentId, $moduleName);
$relationListView = Vtiger_RelationListView_Model::getInstance($parentRecordModel, $relatedModuleName, $label);
$totalCount = $relationListView->getRelatedEntriesCount();
$pageLimit = $pagingModel->getPageLimit();
$pageCount = ceil((int)$totalCount / (int)$pageLimit);
if ($pageCount == 0) {
$pageCount = 1;
}
$result = array();
$result['numberOfRecords'] = $totalCount;
$result['page'] = $pageCount;
$response = new Vtiger_Response();
$response->setResult($result);
$response->emit();
}
}