- 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.
121 lines
4.6 KiB
PHP
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();
|
|
}
|
|
}
|