- 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.
93 lines
3.4 KiB
PHP
93 lines
3.4 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 PriceBooks_RelationAjax_Action extends Vtiger_RelationAjax_Action {
|
|
|
|
function process(Vtiger_Request $request) {
|
|
$mode = $request->get('mode');
|
|
if(!empty($mode) && method_exists($this, "$mode")) {
|
|
$this->$mode($request);
|
|
return;
|
|
}
|
|
}
|
|
|
|
public function requiresPermission(Vtiger_Request $request){
|
|
$permissions = parent::requiresPermission($request);
|
|
$mode = $request->getMode();
|
|
if(!empty($mode)) {
|
|
switch ($mode) {
|
|
case 'addListPrice':
|
|
$permissions[] = array('module_parameter' => 'module', 'action' => 'DetailView', 'record_parameter' => 'src_record');
|
|
$permissions[] = array('module_parameter' => 'related_module', 'action' => 'DetailView');
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
return $permissions;
|
|
}
|
|
|
|
/**
|
|
* Function adds PriceBooks-Products Relation
|
|
* @param type $request
|
|
*/
|
|
function addListPrice($request) {
|
|
$sourceModule = $request->getModule();
|
|
$sourceRecordId = $request->get('src_record');
|
|
$relatedModule = $request->get('related_module');
|
|
$relInfos = $request->get('relinfo');
|
|
|
|
$sourceModuleModel = Vtiger_Module_Model::getInstance($sourceModule);
|
|
$relatedModuleModel = Vtiger_Module_Model::getInstance($relatedModule);
|
|
$relationModel = Vtiger_Relation_Model::getInstance($sourceModuleModel, $relatedModuleModel);
|
|
foreach($relInfos as $relInfo) {
|
|
$price = CurrencyField::convertToDBFormat($relInfo['price'], null, true);
|
|
$relationModel->addListPrice($sourceRecordId, $relInfo['id'], $price);
|
|
}
|
|
}
|
|
/*
|
|
* Function to add relation for specified source record id and related record id list
|
|
* @param <array> $request
|
|
*/
|
|
function addRelation($request) {
|
|
$sourceModule = $request->getModule();
|
|
$sourceRecordId = $request->get('src_record');
|
|
|
|
$relatedModule = $request->get('related_module');
|
|
$relatedRecordIdList = $request->get('related_record_list');
|
|
|
|
$sourceModuleModel = Vtiger_Module_Model::getInstance($sourceModule);
|
|
$relatedModuleModel = Vtiger_Module_Model::getInstance($relatedModule);
|
|
$relationModel = Vtiger_Relation_Model::getInstance($sourceModuleModel, $relatedModuleModel);
|
|
foreach($relatedRecordIdList as $relatedRecordId) {
|
|
$relationModel->addRelation($sourceRecordId,$relatedRecordId,$listPrice);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Function to delete the relation for specified source record id and related record id list
|
|
* @param <array> $request
|
|
*/
|
|
function deleteRelation($request) {
|
|
$sourceModule = $request->getModule();
|
|
$sourceRecordId = $request->get('src_record');
|
|
|
|
$relatedModule = $request->get('related_module');
|
|
$relatedRecordIdList = $request->get('related_record_list');
|
|
|
|
$sourceModuleModel = Vtiger_Module_Model::getInstance($sourceModule);
|
|
$relatedModuleModel = Vtiger_Module_Model::getInstance($relatedModule);
|
|
$relationModel = PriceBooks_Relation_Model::getInstance($sourceModuleModel, $relatedModuleModel);
|
|
foreach($relatedRecordIdList as $relatedRecordId) {
|
|
$relationModel->deleteRelation($sourceRecordId,$relatedRecordId);
|
|
}
|
|
}
|
|
}
|