Files
crm.clientright.ru/modules/Workflow2/tasks/WfTaskLooprecords.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

101 lines
3.3 KiB
PHP

<?php
require_once(realpath(dirname(__FILE__).'/../autoload_wf.php'));
class WfTaskLooprecords extends \Workflow\Task
{
/**
* @var \Workflow\Preset\RecordSources
*/
private $RecordSources = null;
public function handleTask(&$context) {
unset($_FILES);
/* Insert here source code to execute the task */
$records = $this->RecordSources->getRecordIds($context);
$loopSettings = $this->get('loop');
foreach($records as $recordId) {
$loopContext = \Workflow\VTEntity::getForId($recordId);
/**
* @var \TrackableObject $data
*/
$data = $loopContext->getData();
if($data instanceof \TrackableObject) {
$data = $data->getColumnFields();
}
$data['crmid'] = $data['id'] = $loopContext->getId();
$this->addStat('Run Loop with '.$loopContext->getModuleName().' ID ' . $recordId . '');
$logger = \Workflow\ExecutionLogger::getCurrentInstance();
if (!empty($loopSettings['path'])) {
$obj = new \Workflow\Main($this->get('workflow'), false, $context->getUser());
$obj->setExecutionTrigger(\Workflow\Main::MANUAL_START);
$context->setEnvironment('record', $data);
$obj->setContext($context);
$obj->isSubWorkflow(true);
$nextTasks = $this->getNextTasks(array('loop'));
$obj->handleTasks($nextTasks, $this->getBlockId(), 'loop');
}
if (!empty($loopSettings['expression'])) {
$parser = new \Workflow\ExpressionParser($this->get('expression'), $context, false); # Last Parameter = DEBUG
$context->setEnvironment('record', $data);
try {
$parser->run();
} catch (\Workflow\ExpressionException $exp) {
Workflow2::error_handler(E_EXPRESSION_ERROR, $exp->getMessage(), "", "");
}
}
if (!empty($loopSettings['workflow'])) {
$obj = new \Workflow\Main($this->get('workflow'), false, $context->getUser());
$obj->setExecutionTrigger(\Workflow\Main::MANUAL_START);
$obj->setContext($context);
$context->setEnvironment('record', $data);
$obj->isSubWorkflow(true);
$obj->start();
}
\Workflow\ExecutionLogger::setCurrentInstance($logger);
$context->clearEnvironment('record');
}
return "next";
}
public function init() {
$this->RecordSources = $this->addPreset("RecordSources", "recordsource", array(
'moduleselect' => true,
'default' => 'condition',
));
}
public function beforeGetTaskform($viewer) {
$targetModule = $this->RecordSources->getTargetModule();
if(!empty($targetModule)) {
$workflows = $workflows = Workflow2::getWorkflowsForModule($targetModule, 1, "", false);
} else {
$workflows = array();
}
$viewer->assign("workflows", $workflows);
/* Insert here source code to create custom configurations pages */
}
public function beforeSave(&$values) {
/* Insert here source code to modify the values the user submit on configuration */
}
}