Files
crm.clientright.ru/modules/Workflow2/extends/conditions/Relations.inc.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

127 lines
4.8 KiB
PHP

<?php
/**
* Created by JetBrains PhpStorm.
* User: Stefan Warnat <support@stefanwarnat.de>
* Date: 18.06.15 16:21
* You must not use this file without permission.
*/
namespace Workflow\Plugin;
use Workflow\VtUtils;
class RelationsConditionOperator extends \Workflow\ConditionPlugin
{
public function getOperators($moduleName) {
$adb = \PearDatabase::getInstance();
$tabid = getTabid($moduleName);
$methodNames = array('get_related_list', 'get_campaigns');
$sql = 'SELECT * FROM vtiger_relatedlists WHERE name IN ('.generateQuestionMarks($methodNames).') AND (tabid = ? OR related_tabid = ?)';
$result = $adb->pquery($sql, array($methodNames, $tabid, $tabid));
$operators = array();
if($adb->num_rows($result) == 0) {
return $operators;
}
$campaignMode = false;
while($row = $adb->fetchByAssoc($result)) {
if($row['tabid'] == $tabid) {
$relModuleName = \Workflow\VtUtils::getModuleName($row['related_tabid']);
} else {
$relModuleName = \Workflow\VtUtils::getModuleName($row['tabid']);
}
if($relModuleName == 'Campaigns') {
$campaignMode = true;
}
$modules[] = vtranslate($relModuleName, $relModuleName);
}
$modules = array_unique($modules);
$description = 'ID from this Modules: '.implode(', ', $modules);
$operators['related'] = array(
'config' => array (
'related_to' => array (
'type' => 'default',
'default' => '$crmid',
'description' => $description
),
),
'label' => 'related to',
'fieldtypes' => array ('crmid'),
);
if($campaignMode == true) {
$operators['related_campaign_'.strtolower($moduleName)] = array(
'config' => array (
'related_to' => array (
'type' => 'default',
'default' => '',
'description' => 'Part of this Campaign:'
),
),
'label' => 'part of campaign',
'fieldtypes' => array ('crmid'),
);
}
return $operators;
}
public function generateSQLCondition($key, $columnName, $config, $not) {
$adb = \PearDatabase::getInstance();
if(is_string($config)) {
$config = array('related_to' => $config);
}
// default calculations
switch($key) {
case 'related':
// Tested by swa 2016-01-28
$query = "".$columnName." " . ($not ? "!" : "" ) . " IN (SELECT crmid FROM vtiger_crmentityrel WHERE relcrmid = ".intval($config['related_to']).")";
if($not) {
$query .= ' AND ';
} else {
$query .= ' OR ';
}
$query .= "".$columnName." " . ($not ? "!" : "" ) . " IN (SELECT relcrmid FROM vtiger_crmentityrel WHERE crmid = ".intval($config['related_to']).")";
break;
case 'related_campaign_accounts':
$query = "".$columnName." " . ($not ? "!" : "" ) . " IN (SELECT accountid FROM vtiger_campaignaccountrel WHERE campaignid = ".intval($config['related_to']).")";
break;
case 'related_campaign_leads':
$query = "".$columnName." " . ($not ? "!" : "" ) . " IN (SELECT leadid FROM vtiger_campaignleadrel WHERE campaignid = ".intval($config['related_to']).")";
break;
case 'related_campaign_contacts':
$query = "".$columnName." " . ($not ? "!" : "" ) . " IN (SELECT contactid FROM vtiger_campaigncontrel WHERE campaignid = ".intval($config['related_to']).")";
break;
}
return $query;
}
public function checkValue($context, $key, $fieldvalue, $config, $checkConfig)
{
// old check functions
switch ($key) {
case "related":
$adb = \PearDatabase::getInstance();
$sql = '(SELECT crmid FROM vtiger_crmentityrel WHERE crmid = '.$fieldvalue.' AND relcrmid = '.intval($checkConfig['related_to']).') UNION (SELECT relcrmid FROM vtiger_crmentityrel WHERE relcrmid = '.$fieldvalue.' AND crmid = '.intval($checkConfig['related_to']).')';
$result = $adb->query($sql);
if($adb->num_rows($result) > 0) {
return true;
} else {
return false;
}
break;
}
return false;
}
}
\Workflow\ConditionPlugin::register('relations', '\\Workflow\\Plugin\\RelationsConditionOperator');