- 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.
72 lines
2.1 KiB
PHP
72 lines
2.1 KiB
PHP
<?php
|
|
/**
|
|
This File was developed by Stefan Warnat <vtiger@stefanwarnat.de>
|
|
|
|
It belongs to the Workflow Designer and must not be distributed without complete extension
|
|
**/
|
|
require_once('autoload_wf.php');
|
|
|
|
$allow_parallel = $_POST["allow_parallel"] == "1";
|
|
|
|
$sql = "SELECT * FROM vtiger_wf_settings WHERE id = ? AND active = 1";
|
|
$result = $adb->pquery($sql, array(intval($_POST["workflow"])));
|
|
|
|
while($row = $adb->fetch_array($result)) {
|
|
if($row["execution_user"] == "0") {
|
|
$row["execution_user"] = $current_user->id;
|
|
}
|
|
|
|
$user = new Users();
|
|
$user->retrieveCurrentUserInfoFromFile($row["execution_user"]);
|
|
|
|
\Workflow\VTEntity::setUser($user);
|
|
|
|
$objWorkflow = new Workflow_Main($row["id"], false, $user);
|
|
$objWorkflow->setExecutionTrigger("WF2_MANUELL");
|
|
if($allow_parallel == false && $objWorkflow->isRunning($_POST["crmid"])) {
|
|
continue;
|
|
}
|
|
|
|
$context = \Workflow\VTEntity::getForId(intval($_POST["crmid"]), $_POST["return_module"]);
|
|
|
|
if(!empty($row["startfields"]) && !isset($_POST["startfields"])) {
|
|
$startfields = unserialize($row["startfields"]);
|
|
foreach($startfields as $key => $value) {
|
|
$value["default"] = trim(VTTemplate::parse($value["default"], $context));
|
|
|
|
$startfields[$key] = $value;
|
|
}
|
|
|
|
die(json_encode(array("result" => "startfields", "workflow" => intval($_POST["workflow"]), "fields" => $startfields)));
|
|
}
|
|
|
|
if(isset($_POST["startfields"]) && count($_POST["startfields"]) > 0) {
|
|
$tmpStartfields = $_POST["startfields"];
|
|
$startfields = array();
|
|
foreach($tmpStartfields as $values) {
|
|
$startfields[$values["name"]] = trim($values["value"]);
|
|
}
|
|
$context->setEnvironment("value", $startfields);
|
|
}
|
|
|
|
$objWorkflow->setContext($context);
|
|
|
|
$objWorkflow->start();
|
|
|
|
$context->save();
|
|
}
|
|
|
|
Workflow2::$enableError = false;
|
|
|
|
|
|
$result = array("result" => "ok");
|
|
$redirection = $objWorkflow->getSuccessRedirection();
|
|
|
|
if($redirection !== false) {
|
|
$result["redirection"] = $redirection;
|
|
$result["redirection_target"] = $objWorkflow->getSuccessRedirectionTarget();
|
|
}
|
|
|
|
die(json_encode($result));
|
|
|
|
?>
|