Files
crm.clientright.ru/modules/EMAILMaker/actions/ExportData.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

142 lines
5.1 KiB
PHP

<?php
/* * *******************************************************************************
* The content of this file is subject to the EMAIL Maker license.
* ("License"); You may not use this file except in compliance with the License
* The Initial Developer of the Original Code is IT-Solutions4You s.r.o.
* Portions created by IT-Solutions4You s.r.o. are Copyright(C) IT-Solutions4You s.r.o.
* All Rights Reserved.
* ****************************************************************************** */
class EMAILMaker_ExportData_Action extends Vtiger_Mass_Action
{
private $moduleInstance;
private $focus;
public function checkPermission(Vtiger_Request $request)
{
}
public function process(Vtiger_Request $request)
{
$this->ExportData($request);
}
public function ExportData(Vtiger_Request $request)
{
$adb = PearDatabase::getInstance();
$moduleName = $request->get('source_module');
$this->moduleInstance = Vtiger_Module_Model::getInstance($moduleName);
$this->focus = CRMEntity::getInstance($moduleName);
$orderBy = $request->get('orderby');
$sortOrder = $request->get('sortorder');
$EMAILMakerModel = Vtiger_Module_Model::getInstance('EMAILMaker');
$mode = $request->getMode();
if ($mode == "ExportAllData") {
$result = $EMAILMakerModel->GetListviewResult($orderBy, $sortOrder, false);
} elseif ($mode == "ExportCurrentPage") {
$result = $EMAILMakerModel->GetListviewResult($orderBy, $sortOrder, $request);
} else {
$sql = $this->getExportQuery($request);
if (!empty($orderby)) {
$sql .= " ORDER BY vtiger_emakertemplates." . $orderBy . " " . $sortOrder;
}
$result = $adb->pquery($sql, array());
}
$entries = array();
$num_rows = $adb->num_rows($result);
while ($row = $adb->fetchByAssoc($result)) {
$currModule = $row['module'];
$templateid = $row['templateid'];
$Template_Permissions_Data = $EMAILMakerModel->returnTemplatePermissionsData($currModule, $templateid);
if ($Template_Permissions_Data["detail"] === false) {
continue;
}
$entries[] = $row;
}
$this->output($entries);
}
public function getExportQuery(Vtiger_Request $request)
{
$query = "SELECT vtiger_emakertemplates.* FROM vtiger_emakertemplates LEFT JOIN vtiger_emakertemplates_displayed USING(templateid)";
$idList = $this->getRecordsListFromRequest($request);
$query .= "WHERE vtiger_emakertemplates.deleted = '0'";
if (!empty($idList)) {
$idList = implode(',', $idList);
$query .= 'AND vtiger_emakertemplates.templateid IN (' . $idList . ')';
}
return $query;
}
public function output($entries)
{
foreach ($entries as $templateResult) {
$templatename = $templateResult["templatename"];
$subject = $templateResult["subject"];
$description = $templateResult["description"];
$module = $templateResult["module"];
$is_listview = $templateResult["is_listview"];
$is_theme = $templateResult["is_theme"];
$body = decode_html($templateResult["body"]);
$c .= "<template>";
$c .= "<type>EMAILMaker</type>";
$c .= "<templatename>" . $this->cdataEncode($templatename, true) . "</templatename>";
$c .= "<subject>" . $this->cdataEncode($subject, true) . "</subject>";
$c .= "<description>" . $this->cdataEncode($description, true) . "</description>";
$c .= "<module>" . $this->cdataEncode($module) . "</module>";
$c .= "<is_listview>" . $this->cdataEncode($is_listview) . "</is_listview>";
$c .= "<is_theme>" . $this->cdataEncode($is_theme) . "</is_theme>";
$c .= "<body>";
$c .= $this->cdataEncode($body, true);
$c .= "</body>";
$c .= "</template>";
}
header('Content-Type: application/xhtml+xml');
header("Content-Disposition: attachment; filename=export.xml");
echo "<?xml version='1.0'?" . ">";
echo "<export>";
echo $c;
echo "</export>";
exit;
}
private function cdataEncode($text, $encode = false)
{
$From = array("<![CDATA[", "]]>");
$To = array("<|!|[%|CDATA|[%|", "|%]|]|>");
if ($text != "") {
$pos1 = strpos("<![CDATA[", $text);
$pos2 = strpos("]]>", $text);
if ($pos1 === false && $pos2 === false && $encode == false) {
$content = $text;
} else {
$text = decode_html($text);
$encode_text = str_replace($From, $To, $text);
$content = "<![CDATA[" . $encode_text . "]]>";
}
} else {
$content = "";
}
return $content;
}
}