- 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.
139 lines
4.3 KiB
PHP
139 lines
4.3 KiB
PHP
<?php
|
|
/*+**********************************************************************************
|
|
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
|
|
* ("License"); You may not use this file except in compliance with the License
|
|
* The Original Code is: SalesPlatform Ltd
|
|
* The Initial Developer of the Original Code is SalesPlatform Ltd.
|
|
* All Rights Reserved.
|
|
* If you have any questions or comments, please email: devel@salesplatform.ru
|
|
************************************************************************************/
|
|
|
|
require_once 'include/utils/utils.php';
|
|
require_once 'vtlib/Vtiger/Unzip.php';
|
|
|
|
/**
|
|
* Describes operations, need to save files from one es and prepare them
|
|
* to import.
|
|
* @author alexd
|
|
*/
|
|
class ImportFileManager {
|
|
|
|
/* File uploads directories */
|
|
const UPLOAD_DIR = 'test/upload/1c/';
|
|
|
|
/**
|
|
* Initilizate load directory to import files.
|
|
*/
|
|
public function __construct() {
|
|
if(!file_exists(self::UPLOAD_DIR)) {
|
|
mkdir(self::UPLOAD_DIR);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return an array of files name, sorted by $order and
|
|
* satisfy mask $mask. Not my realization.
|
|
* @param string $searchDirectory
|
|
* @param string $mask
|
|
* @return array
|
|
*/
|
|
private function getFiles($searchDirectory, $mask = '*') {
|
|
$searchFiles = array();
|
|
if (false !== ($files = scandir($searchDirectory)) ) {
|
|
foreach ($files as $i => $entry) {
|
|
if ($entry != '.' && $entry != '..' && fnmatch($mask, $entry)) {
|
|
$searchFiles[] = $entry;
|
|
}
|
|
}
|
|
}
|
|
return $searchFiles;
|
|
}
|
|
|
|
/**
|
|
* Return name of the offers file by import file name.
|
|
* @param String $offersFileName
|
|
* @return String
|
|
*/
|
|
private function getImportFileName($offersFileName) {
|
|
$suffixName = substr($offersFileName, strlen('offers'));
|
|
return 'import' . $suffixName;
|
|
}
|
|
|
|
/**
|
|
* Save file content by file named $fileName and return save status.
|
|
* If file exists, append content to the end.
|
|
* @param String $fileName
|
|
* @return boolean
|
|
*/
|
|
public function saveRequestFile($fileName) {
|
|
$filePath = self::UPLOAD_DIR.$fileName;
|
|
$fileContent = file_get_contents("php://input");
|
|
if (!$fileContent) {
|
|
return false;
|
|
}
|
|
|
|
$writeStatus = file_put_contents($filePath, $fileContent, FILE_APPEND | LOCK_EX);
|
|
if(!$writeStatus) {
|
|
return false;
|
|
}
|
|
chmod($filePath, 0666);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Unzip all zip files and delete unzipped archives.
|
|
*/
|
|
public function unzipLoadedFiles() {
|
|
$files = $this->getFiles(self::UPLOAD_DIR, "*.zip");
|
|
foreach ($files as $file) {
|
|
$unzip = new Vtiger_Unzip(self::UPLOAD_DIR.$file);
|
|
if (!$unzip) {
|
|
unlink(self::UPLOAD_DIR.$file);
|
|
continue;
|
|
}
|
|
$unzip->unzipAllEx(self::UPLOAD_DIR);
|
|
$unzip->close();
|
|
unlink(self::UPLOAD_DIR.$file);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return order.xml file content
|
|
*/
|
|
public function getOrdersFileContent() {
|
|
$this->unzipLoadedFiles();
|
|
$files = $this->getFiles(self::UPLOAD_DIR, "orders*.xml");
|
|
$ordersContent = file_get_contents(self::UPLOAD_DIR.$files[0]);
|
|
unlink(self::UPLOAD_DIR.$files[0]);
|
|
return $ordersContent;
|
|
}
|
|
|
|
/**
|
|
* Return import.xml file content.
|
|
* @param type $offersFileName
|
|
*/
|
|
public function getImportFileContentByOffersFileName($offersFileName) {
|
|
$importFileName = $this->getImportFileName($offersFileName);
|
|
return file_get_contents(self::UPLOAD_DIR . $importFileName);
|
|
}
|
|
|
|
/**
|
|
* Return offers file content
|
|
* @param type $offerFileName
|
|
*/
|
|
public function getOffersFileContent($offerFileName) {
|
|
return file_get_contents(self::UPLOAD_DIR . $offerFileName);
|
|
}
|
|
|
|
public function isOrdersZipFull($importFileName) {
|
|
$zip = new ZipArchive();
|
|
$res = $zip->open(self::UPLOAD_DIR . $importFileName, ZipArchive::CHECKCONS);
|
|
if($res === true) {
|
|
$zip->close();
|
|
}
|
|
|
|
return ($res === true);
|
|
}
|
|
|
|
}
|