- 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.
59 lines
2.2 KiB
PHP
59 lines
2.2 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
|
|
************************************************************************************/
|
|
|
|
class ShutdownHandler {
|
|
|
|
private $logFile = 'logs/application.log';
|
|
private $startExecutionDirectory;
|
|
|
|
public function __construct() {
|
|
/* On shutdown apache can change dir - so in handler need restore it */
|
|
$this->startExecutionDirectory = getcwd();
|
|
}
|
|
|
|
public function registerSystemEventsLog() {
|
|
register_shutdown_function(function() {
|
|
$error = error_get_last();
|
|
if($error != null) {
|
|
chdir($this->startExecutionDirectory);
|
|
|
|
$type = $error['type'];
|
|
if($type == E_ERROR || $type == E_CORE_ERROR || $type == E_COMPILE_ERROR
|
|
|| $type == E_USER_ERROR || $type == E_RECOVERABLE_ERROR || $type == E_PARSE) {
|
|
|
|
$this->log("Error on process request. Details: ", $error);
|
|
error_log("Error on process request. Details: " . $error);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
private function log($message, $error = null) {
|
|
$date = date("Y-m-d H:i:s");
|
|
|
|
$logMessage = "[" . $date . "] " . $message;
|
|
if($error != null) {
|
|
$logMessage .= "\n" . $this->prepareErrorListMessage($error);
|
|
}
|
|
|
|
error_log($logMessage);
|
|
file_put_contents($this->logFile, $logMessage . "\n", FILE_APPEND);
|
|
}
|
|
|
|
private function prepareErrorListMessage($error) {
|
|
$message = "Code - " . $error['type'] . "\n";
|
|
$message .= "Message - " . $error['message'] . "\n";
|
|
$message .= "File - " . $error['file'] . "\n";
|
|
$message .= "Line - " . $error['line'] . "\n";
|
|
|
|
return $message;
|
|
}
|
|
}
|