2017-06-24 00:58:56 +03:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/**
|
2018-04-19 19:11:58 +03:00
|
|
|
|
* AVE.cms
|
|
|
|
|
*
|
|
|
|
|
* Класс, предназначенный для управления журналом системных сообщений
|
|
|
|
|
*
|
|
|
|
|
* @package AVE.cms
|
|
|
|
|
* @version 3.x
|
|
|
|
|
* @filesource
|
|
|
|
|
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
class AVE_Logs
|
|
|
|
|
{
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Свойства класса
|
|
|
|
|
*/
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Файлы для хранения записей
|
|
|
|
|
*
|
|
|
|
|
* @public
|
|
|
|
|
*/
|
|
|
|
|
public $_404dir = '/tmp/logs/404.php';
|
|
|
|
|
public $_logdir = '/tmp/logs/log.php';
|
|
|
|
|
public $_sqldir = '/tmp/logs/sql.php';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
|
|
/**
|
2018-04-19 19:11:58 +03:00
|
|
|
|
* Внутренние методы класса
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Внешние методы класса
|
|
|
|
|
*/
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для отображения всех записей Журнала событий
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function logList()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logdata = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR.$this->_logdir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
@eval(' ?>'.file_get_contents($logfile).'<?php ');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
arsort($logdata);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Передаем данные в шаблон для вывода и отображаем страницу
|
|
|
|
|
$AVE_Template->assign('logs', $logdata);
|
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('logs/logs.tpl'));
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для отображения всех записей Журнала событий 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function List404()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$log404 = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_404dir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
include($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
arsort($log404);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Передаем данные в шаблон для вывода и отображаем страницу
|
|
|
|
|
$AVE_Template->assign('logs', $log404);
|
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('logs/404.tpl'));
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для отображения всех записей Журнала событий 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function ListSql()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logsql = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_sqldir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
include($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
arsort($logsql);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Передаем данные в шаблон для вывода и отображаем страницу
|
|
|
|
|
$AVE_Template->assign('logs', $logsql);
|
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('logs/sql.tpl'));
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для удаление записей Журнала событий
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function logDelete()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_logdir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
unlink($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_CLEAN'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
header('Location:index.php?do=logs&cp=' . SESSION);
|
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для удаление записей Журнала событий 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function DeleteSql()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_sqldir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
unlink($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_SQL_CLEAN'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
header('Location:index.php?do=logs&action=logsql&cp=' . SESSION);
|
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для удаление записей Журнала событий 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function Delete404()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_404dir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
unlink($logfile);
|
|
|
|
|
|
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_404_CLEAN'));
|
|
|
|
|
|
|
|
|
|
header('Location:index.php?do=logs&action=log404&cp=' . SESSION);
|
|
|
|
|
exit;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для экспорта системных сообщений
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function logExport()
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
global $AVE_Template;
|
|
|
|
|
|
|
|
|
|
// Определяем тип файла (CSV), формат имени файла, разделители и т.д.
|
|
|
|
|
$datstring = '';
|
|
|
|
|
$dattype = 'text/csv';
|
|
|
|
|
$datname = 'system_log_' . date('dmyhis', time()) . '.csv';
|
|
|
|
|
|
|
|
|
|
$separator = ';';
|
|
|
|
|
$enclosed = '"';
|
|
|
|
|
|
|
|
|
|
// Выполняем запрос к БД на получение списка всех системных сообщений
|
|
|
|
|
$logdata=array();
|
|
|
|
|
$logfile = BASE_DIR.$this->_logdir;
|
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
@eval(' ?>'.file_get_contents($logfile).'<?php ');
|
|
|
|
|
arsort($logdata);
|
|
|
|
|
$fieldcount = count($logdata[0]);
|
|
|
|
|
|
|
|
|
|
foreach($logdata[0] as $k=>$v)
|
|
|
|
|
$datstring .= $enclosed . $k . $enclosed . $separator;
|
|
|
|
|
$datstring .= PHP_EOL;
|
|
|
|
|
|
|
|
|
|
// Циклически обрабатываем данные и формируем CSV файл с учетом указаны выше параметров
|
|
|
|
|
foreach($logdata as $k=>$v)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
foreach ($v as $key => $val)
|
|
|
|
|
{
|
|
|
|
|
$val = ($key=='log_time') ? date('d-m-Y, H:i:s', $val) : $val;
|
|
|
|
|
$datstring .= ($val == '') ? $separator : $enclosed . stripslashes($val) . $enclosed . $separator;
|
|
|
|
|
}
|
|
|
|
|
$datstring .= PHP_EOL;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Определяем заголовки документа
|
|
|
|
|
header('Content-Encoding: windows-1251');
|
|
|
|
|
header('Content-type: text/csv; charset=windows-1251');
|
|
|
|
|
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
|
|
|
|
|
header('Content-Disposition: attachment; filename="' . $datname . '"');
|
|
|
|
|
header('Content-Length: ' . strlen($datstring));
|
|
|
|
|
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
|
|
|
|
|
header('Pragma: public');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Выводим данные
|
|
|
|
|
echo mb_convert_encoding($datstring, 'windows-1251', 'UTF-8');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_EXPORT'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для экспорта сообщений 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function Export404()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Определяем тип файла (CSV), формат имени файла, разделители и т.д.
|
|
|
|
|
$datstring = '';
|
|
|
|
|
$dattype = 'text/csv';
|
|
|
|
|
$datname = 'system_log_' . date('dmyhis', time()) . '.csv';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$separator = ';';
|
|
|
|
|
$enclosed = '"';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Выполняем запрос к БД на получение списка всех системных сообщений
|
|
|
|
|
$log404 = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR.$this->_404dir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
include($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
arsort($log404);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$fieldcount = count($log404[0]);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
foreach($log404[0] as $k=>$v)
|
|
|
|
|
$datstring .= $enclosed . $k . $enclosed . $separator;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$datstring .= PHP_EOL;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Циклически обрабатываем данные и формируем CSV файл с учетом указаны выше параметров
|
|
|
|
|
foreach($log404 as $k=>$v)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
foreach ($v as $key => $val)
|
|
|
|
|
{
|
|
|
|
|
$val = ($key=='log_time') ? date('d-m-Y, H:i:s', $val) : $val;
|
|
|
|
|
$datstring .= ($val == '') ? $separator : $enclosed . stripslashes($val) . $enclosed . $separator;
|
|
|
|
|
}
|
|
|
|
|
$datstring .= PHP_EOL;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Определяем заголовки документа
|
|
|
|
|
header('Content-Encoding: windows-1251');
|
|
|
|
|
header('Content-type: text/csv; charset=windows-1251');
|
|
|
|
|
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
|
|
|
|
|
header('Content-Disposition: attachment; filename="' . $datname . '"');
|
|
|
|
|
header('Content-Length: ' . strlen($datstring));
|
|
|
|
|
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
|
|
|
|
|
header('Pragma: public');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Выводим данные
|
|
|
|
|
echo mb_convert_encoding(strip_tags($datstring), 'windows-1251', 'UTF-8');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_404_EXPORT'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для экспорта сообщений 404
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function ExportSql()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Определяем тип файла (CSV), формат имени файла, разделители и т.д.
|
|
|
|
|
$datstring = '';
|
|
|
|
|
$dattype = 'text/csv';
|
|
|
|
|
$datname = 'system_log_' . date('dmyhis', time()) . '.csv';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$separator = ';';
|
|
|
|
|
$enclosed = '"';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Выполняем запрос к БД на получение списка всех системных сообщений
|
|
|
|
|
$logsql = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$logfile = BASE_DIR . $this->_sqldir;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if(file_exists($logfile))
|
|
|
|
|
include($logfile);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
arsort($logsql);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$fieldcount = count($logsql[0]);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
foreach($logsql[0] as $k=>$v)
|
|
|
|
|
$datstring .= $enclosed . $k . $enclosed . $separator;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$datstring .= PHP_EOL;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Циклически обрабатываем данные и формируем CSV файл с учетом указаны выше параметров
|
|
|
|
|
foreach($logsql as $k => $v)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
foreach ($v as $key => $val)
|
|
|
|
|
{
|
|
|
|
|
$val = ($key == 'log_time') ? date('d-m-Y, H:i:s', $val) : $val;
|
|
|
|
|
$val = ($key == 'log_text') ? serialize($val) : $val;
|
|
|
|
|
$datstring .= ($val == '') ? $separator : $enclosed . stripslashes($val) . $enclosed . $separator;
|
|
|
|
|
}
|
|
|
|
|
$datstring .= PHP_EOL;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Определяем заголовки документа
|
|
|
|
|
header('Content-Encoding: windows-1251');
|
|
|
|
|
header('Content-type: text/csv; charset=windows-1251');
|
|
|
|
|
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
|
|
|
|
|
header('Content-Disposition: attachment; filename="' . $datname . '"');
|
|
|
|
|
header('Content-Length: ' . strlen($datstring));
|
|
|
|
|
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
|
|
|
|
|
header('Pragma: public');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Выводим данные
|
|
|
|
|
echo mb_convert_encoding(strip_tags($datstring), 'windows-1251', 'UTF-8');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
// Сохраняем системное сообщение в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('LOGS_SQL_EXPORT'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
?>
|