- 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.
127 lines
4.8 KiB
PHP
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'); |