From dc783becfd403b639e9c72dccaaeb9f27ba745d6 Mon Sep 17 00:00:00 2001 From: AlekVolsk Date: Wed, 20 Feb 2019 18:24:46 +0400 Subject: [PATCH] v1.3.3 --- README.md | 12 +- README.ru.md | 6 +- admin/config.xml | 4 + admin/controller.php | 20 +- admin/controllers/items.php | 5 - admin/language/en-GB/en-GB.com_vlogs.ini | 4 +- admin/language/ru-RU/ru-RU.com_vlogs.ini | 8 +- admin/models/ajax.php | 247 ++++++------- admin/models/fields/fileselect.css | 435 ++++++++++++++--------- admin/models/fields/fileselect.php | 74 ++-- admin/models/items.php | 20 +- admin/views/items/tmpl/default.php | 10 +- admin/views/items/view.html.php | 35 +- admin/vlogs.php | 5 +- vlogs.xml | 2 +- 15 files changed, 451 insertions(+), 436 deletions(-) diff --git a/README.md b/README.md index 4327260..89da8ea 100644 --- a/README.md +++ b/README.md @@ -1,8 +1,6 @@ # View logs -![Github Releases](https://img.shields.io/github/downloads/AlekVolsk/com_vlogs/latest/total.svg) - -### Component view the saved logs of core and extensions Joomla +## Component view the saved logs of core and extensions Joomla **Scope**: @@ -18,7 +16,7 @@ - (upd 1.2.0) reading PHP error log file (provided that it is installed in php.ini and available for reading from the site) -- (upd 1.3.0) archiving a log file to an archive with a log file name + current datetime (assuming the php-zip extension is connected), the log file is not cleared or deleted, the archive is saved to the site folder specified in the component settings, by default / tmp +- (upd 1.3.0) archiving a log file to an archive with a log file name + current datetime (assuming the php-zip extension is connected), the archive is saved to the site folder specified in the component settings, by default `/tmp`, where optionally deleting the original file after archiving is also configured **Requirements**: @@ -26,8 +24,10 @@ - PHP 5.6 or later -**Disadvantage**: the log file is read and displayed entirely, if it is large, it will take time, create a load on resources and traffic, so
**Recommendation for extension developers**: with intensive logging provide avtorezina logs into parts, task types, period, either, but that logs your not weighed megatons +**Disadvantage**: the log file is read and displayed entirely, if it is large, it will take time, create a load on resources and traffic, so + +**Recommendation for extension developers**: with intensive logging provide avtorezina logs into parts, task types, period, either, but that logs your not weighed megatons - +![screen](https://image.prntscr.com/image/pbf3-h1UT8G8QvcGtZ3Hbw.png) About how the native extension to use logging, see the Joomla documentation: https://docs.joomla.org/Using_JLog#Logging_a_specific_log_file diff --git a/README.ru.md b/README.ru.md index 0d84122..d6a7c1c 100644 --- a/README.ru.md +++ b/README.ru.md @@ -1,6 +1,6 @@ # View logs -### Компонент просмотра сохраненных логов ядра и расширений Joomla +## Компонент просмотра сохраненных логов ядра и расширений Joomla **Возможности**: @@ -16,7 +16,7 @@ - (upd 1.2.0) чтение файла лога ошибок PHP (при условии, что он установлен в php.ini и доступен для чтения с сайта) -- (upd 1.3.0) архивирование файла лога в архив с именем файла лога + текущая дата и время (при условии подключенного расширения php-zip), файл лога при этом не очищается и не удаляется, архив сохраняется в папку сайта, указанную в параметрах компонента, по умолчанию /tmp. +- (upd 1.3.0) архивирование файла лога в архив с именем файла лога + текущая дата и время (при условии подключенного расширения php-zip), архив сохраняется в папку сайта, указанную в параметрах компонента, по умолчанию `/tmp`, где также настраивается опциональное удаление исходного файла после архивирования **Требования**: @@ -28,6 +28,6 @@ **Рекомендация разработчикам расширений**: при интенсивном логировании предусмотрите авторазбиение логов на части, по типам задач, по периода, еще как-либо, но чтобы логи ваши не весили мегатонны - +![screen](https://image.prntscr.com/image/pbf3-h1UT8G8QvcGtZ3Hbw.png) О том, как в собственном расширении использовать логирование, можно узнать из документаци Joomla: https://docs.joomla.org/Using_JLog#Logging_a_specific_log_file diff --git a/admin/config.xml b/admin/config.xml index 274ec43..26a29d6 100644 --- a/admin/config.xml +++ b/admin/config.xml @@ -3,6 +3,10 @@
+ + + +
diff --git a/admin/controller.php b/admin/controller.php index d0e8fb8..250b00c 100644 --- a/admin/controller.php +++ b/admin/controller.php @@ -1,33 +1,25 @@ -default_view = 'items'; - parent::display( $cachable, $urlparams ); + parent::display($cachable, $urlparams); return $this; } public function getAjax() { - $input = JFactory::getApplication()->input; $model = $this->getModel('ajax'); - $action = $input->getCmd('action'); + $action = filter_input(INPUT_GET, 'action'); $reflection = new ReflectionClass($model); $methods = $reflection->getMethods(ReflectionMethod::IS_PUBLIC); $methodList = array(); - foreach ($methods as $method) - { + foreach ($methods as $method) { $methodList[] = $method->name; } - if (in_array($action, $methodList)) - { + if (in_array($action, $methodList)) { $model->$action(); } exit; diff --git a/admin/controllers/items.php b/admin/controllers/items.php index d3db62d..3e314cf 100644 --- a/admin/controllers/items.php +++ b/admin/controllers/items.php @@ -1,9 +1,4 @@ %s successfully packaged in %s.
Please note: the source file is not deleted or cleared." +COM_VLOGS_ARCHIVEFILE_ALERT_0="Log file %s successfully packaged in %s.
The source file has not been deleted or cleaned." +COM_VLOGS_ARCHIVEFILE_ALERT_1="Log file %s successfully packaged in %s.
The source file has been deleted." COM_VLOGS_NO_ARCHIVE_PHP_LOG="You can't archive a PHP file log from the site administration panel. Please use the control panel or the console of your server." COM_VLOGS_NO_PHPZIP="The php-zip library is not installed, archiving is not possible." COM_VLOGS_ARCHIVEFILE_ERROR_CREATE="Error creating archive file %s." diff --git a/admin/language/ru-RU/ru-RU.com_vlogs.ini b/admin/language/ru-RU/ru-RU.com_vlogs.ini index 04f8152..202e338 100644 --- a/admin/language/ru-RU/ru-RU.com_vlogs.ini +++ b/admin/language/ru-RU/ru-RU.com_vlogs.ini @@ -3,6 +3,7 @@ COM_VLOGS_DESC="Компонент просмотра сохраненных л COM_VLOGS_PRM_STRLEN="Длина строки файла лога" COM_VLOGS_PRM_ARCHPATH="Путь к папке архивов логов" +COM_VLOGS_PRM_DELAFTERARCH="Удалять исходный файл после архивации" COM_VLOGS_DATA_EMPTY="Нет данных для отображения: список пуст." COM_VLOGS_COUNT_ITEMS_VIEW="Показано записей: " @@ -22,11 +23,12 @@ COM_VLOGS_DOWNLOAD_BOM_BUTTON="Скачать как CSV (для MS Excel)" COM_VLOGS_DELETEFILE_BUTTON="Удалить файл лога" COM_VLOGS_DELETEFILE_SUCCESS="Файл %s успешно удален." COM_VLOGS_DELETEFILE_ALERT="Ошибка удаления файла. Удалите файл фручную." -COM_VLOGS_NO_DELETE_PHP_LOG="Нельзя удалить файл лога PHP из административной панели сайта. Пожалуйста, воспользуйтесь для этого панелью управлением или консолью вашего сервера." +COM_VLOGS_NO_DELETE_PHP_LOG="Нельзя удалить файл лога PHP из административной панели сайта. Пожалуйста, воспользуйтесь для этого консолью или панелью управлением вашего сервера." COM_VLOGS_ARCHIVEFILE_BUTTON="Архирировать текущий лог" COM_VLOGS_ARCHIVEFILE_NO_FOLDER="Папка хранения архивов логов не указана" COM_VLOGS_ARCHIVEFILE_NO_EXISTS_FOLDER="Папка хранения архивов логов не существует" -COM_VLOGS_ARCHIVEFILE_ALERT="Файл лога %s успешно упакован в %s.
Обратите внимание: исходный файл не удаляется и не очищается." -COM_VLOGS_NO_ARCHIVE_PHP_LOG="Нельзя архивировать файллога PHP из административной панели сайта. Пожалуйста, воспользуйтесь для этого панелью управлением или консолью вашего сервера." +COM_VLOGS_ARCHIVEFILE_ALERT_0="Файл лога %s успешно упакован в %s.
Исходный файл не был удален или очищен." +COM_VLOGS_ARCHIVEFILE_ALERT_1="Файл лога %s успешно упакован в %s.
Исходный файл был удален." +COM_VLOGS_NO_ARCHIVE_PHP_LOG="Нельзя архивировать файл лога PHP из административной панели сайта. Пожалуйста, воспользуйтесь для этого консолью или панелью управлением вашего сервера." COM_VLOGS_NO_PHPZIP="Библиотекак php-zip не установлена, архивирование невозможно." COM_VLOGS_ARCHIVEFILE_ERROR_CREATE="Ошибка создания файла архива %s." diff --git a/admin/models/ajax.php b/admin/models/ajax.php index 1109847..0e366bc 100644 --- a/admin/models/ajax.php +++ b/admin/models/ajax.php @@ -1,28 +1,21 @@ '; } - + $jsonData = ['result' => $result, 'message' => $message]; - - foreach ($custom as $key => $value) - { + + foreach ($custom as $key => $value) { $jsonData[$key] = $value; } - + echo json_encode($jsonData); - + exit; } @@ -30,15 +23,13 @@ private function getPhpLog() { $a = []; - if (($handle = fopen(ini_get('error_log'), 'r')) !== false) - { - while (($data = fgets($handle)) !== false) - { + if (($handle = fopen(ini_get('error_log'), 'r')) !== false) { + while (($data = fgets($handle)) !== false) { $a[] = $data; - } - fclose($handle); + } + fclose($handle); } - + $a = array_reverse($a); return $a; @@ -49,13 +40,11 @@ private function getCSV($file, $delimiter = ';') $a = []; $slen = JComponentHelper::getParams('com_vlogs')->get('slen', 32768); - if (($handle = fopen($file, 'r')) !== false) - { - while (($data = fgetcsv($handle, $slen, $delimiter)) !== false) - { + if (($handle = fopen($file, 'r')) !== false) { + while (($data = fgetcsv($handle, $slen, $delimiter)) !== false) { $a[] = $data; - } - fclose($handle); + } + fclose($handle); } return $a; @@ -63,27 +52,22 @@ private function getCSV($file, $delimiter = ';') private function setCSV($file, $data, $delimiter = ';', $bom = false) { - if (($handle = fopen($file, 'w')) !== false) - { - if ($bom) - { - fwrite($handle, b"\xEF\xBB\xBF"); + if (($handle = fopen($file, 'w')) !== false) { + if ($bom) { + fwrite($handle, "\xEF\xBB\xBF"); } - foreach ($data as $item) - { + foreach ($data as $item) { fputcsv($handle, $item, $delimiter); - } - fclose($handle); + } + fclose($handle); } } private function file_force_download($file) { set_time_limit(0); - if (file_exists($file)) - { - if (ob_get_level()) - { + if (file_exists($file)) { + if (ob_get_level()) { ob_end_clean(); } header('Content-Description: File Transfer'); @@ -95,9 +79,7 @@ private function file_force_download($file) header('Pragma: public'); header('Content-Length: ' . filesize($file)); return (bool)readfile($file); - } - else - { + } else { return false; } } @@ -108,22 +90,19 @@ protected function ListPHPEL() $cnt = 0; $html = []; - if (!empty($data)) - { + if (!empty($data)) { $html[] = ''; $html[] = ''; $html[] = ''; $html[] = ''; $html[] = ''; - foreach ($data as $item) - { - if (empty($item)) - { + foreach ($data as $item) { + if (empty($item)) { continue; } $tmp = explode('] ', $item); - $date = substr($tmp[0], 1, strlen($tmp[0])-1); + $date = substr($tmp[0], 1, strlen($tmp[0]) - 1); $date = explode(' ', $date); $date = new DateTime($date[0] . 'T' . $date[1], new DateTimeZone($date[2])); $date = date_format($date, 'Y-m-d H:i:s'); @@ -148,40 +127,32 @@ protected function ListPHPEL() $cnt++; } $html[] = '
' . JText::_('COM_VLOGS_COLUMN_DT') . '' . JText::_('COM_VLOGS_COLUMN_PRIORITY') . '' . JText::_('COM_VLOGS_COLUMN_MSG') . '
'; - } - else - { + } else { $html[] = '
' . JText::_('COM_VLOGS_DATA_EMPTY') . '
'; } $this->printJson(implode('', $html), true, ['count' => $cnt]); } - + public function List() { $log_path = str_replace('\\', '/', JFactory::getConfig()->get('log_path')); $file = filter_input(INPUT_GET, 'filename'); - - if ($file === 'PHP error log') - { + if ($file === 'PHP error log') { $this->ListPHPEL(); } $columns = ''; $data = $this->getCSV($log_path . '/' . $file, ' '); - for ($i = 0; $i < 6; $i++) - { - if (count($data[$i]) < 4 || $data[$i][0][0] == '#') - { - if (strpos($data[$i][0], '#Fields:') !== false) - { + for ($i = 0; $i < 6; $i++) { + if (count($data[$i]) < 4 || $data[$i][0][0] == '#') { + if (strpos($data[$i][0], '#Fields:') !== false) { $columns = $data[$i]; } unset($data[$i]); } } - if ($columns) - { + if ($columns) { $columns = explode(' ', implode(' ', $columns)); unset($columns[0]); $columns = array_values($columns); @@ -190,15 +161,12 @@ public function List() $data = array_reverse($data); $html = []; $cnt = count($data); - - if ($columns && $cnt) - { + + if ($columns && $cnt) { $html[] = ''; - - foreach ($columns as $col) - { - switch ($col) - { + + foreach ($columns as $col) { + switch ($col) { case 'datetime': $html[] = ''; break; @@ -226,18 +194,15 @@ public function List() $html[] = ''; } } - + $html[] = ''; - foreach ($data as $i => $item) - { - if (count($item) == 1) - { + foreach ($data as $i => $item) { + if (count($item) == 1) { $item = explode(' ', $item[0]); } - if (count($item) < count($columns)) - { + if (count($item) < count($columns)) { $ci = count($item) - 1; $msg = $item[$ci]; unset($item[$ci]); @@ -245,12 +210,10 @@ public function List() $item[] = $msg; unset($msg); } - + $html[] = ''; - foreach ($item as $j => $dataitem) - { - switch (strtolower($columns[$j])) - { + foreach ($item as $j => $dataitem) { + switch (strtolower($columns[$j])) { case 'datetime': $date = new DateTime($dataitem); $dataitem = $date->format('U'); @@ -300,9 +263,7 @@ public function List() $html[] = '
' . JText::_('COM_VLOGS_COLUMN_DT') . '' . $col . '
'; - } - else - { + } else { $html[] = '
' . JText::_('COM_VLOGS_DATA_EMPTY') . '
'; } @@ -315,19 +276,16 @@ public function dwFile() $file = filter_input(INPUT_GET, 'filename'); $bom = (bool)filter_input(INPUT_GET, 'bom'); $fpath = str_replace('\\', '/', JFactory::getConfig()->get('tmp_path')); - - if ($file === 'PHP error log') - { + + if ($file === 'PHP error log') { $data = []; $log = $this->getPhpLog(); - foreach ($log as $item) - { - if (empty($item)) - { + foreach ($log as $item) { + if (empty($item)) { continue; } $tmp = explode('] ', $item); - $date = substr($tmp[0], 1, strlen($tmp[0])-1); + $date = substr($tmp[0], 1, strlen($tmp[0]) - 1); $date = explode(' ', $date); $date = new DateTime($date[0] . 'T' . $date[1], new DateTimeZone($date[2])); $date = date_format($date, 'Y-m-d H:i:s'); @@ -336,24 +294,15 @@ public function dwFile() } $fileName = pathinfo(ini_get('error_log'))['filename']; - } - else - { + } else { $data = $this->getCSV($log_path . '/' . $file, ' '); - foreach ($data as $i => $item) - { - if ($i < 6 && (count($item) < 4 || $item[0][0] == '#')) - { + foreach ($data as $i => $item) { + if ($i < 6 && (count($item) < 4 || $item[0][0] == '#')) { unset($data[$i]); - } - else - { - if (count($item) == 1) - { + } else { + if (count($item) == 1) { $item = explode(' ', $item[0]); - } - else - { + } else { $ci = count($item) - 1; $msg = $item[$ci]; unset($item[$ci]); @@ -370,13 +319,13 @@ public function dwFile() } $data = array_reverse($data); - + $file = $fpath . '/' . $fileName . '_' . JHtml::_('date', time(), 'Y-m-d-H-i-s') . '.csv'; - + $this->setCSV($file, $data, $bom ? ';' : ',', $bom); $this->file_force_download($file); unlink($file); - + exit; } @@ -384,14 +333,11 @@ public function DelFile() { $log_path = str_replace('\\', '/', JFactory::getConfig()->get('log_path')); $file = filter_input(INPUT_GET, 'filename'); - - if ($file !== 'PHP error log') - { + + if ($file !== 'PHP error log') { $result = unlink($log_path . '/' . $file); $this->printJson($result ? JText::sprintf('COM_VLOGS_DELETEFILE_SUCCESS', $file) : JText::_('COM_VLOGS_DELETEFILE_ALERT'), $result); - } - else - { + } else { $this->printJson(JText::_('COM_VLOGS_NO_DELETE_PHP_LOG') . ' ' . $file, false); } } @@ -399,43 +345,50 @@ public function DelFile() public function ArchiveFile() { $apath = JComponentHelper::getParams('com_vlogs')->get('apath', 'tmp'); - + $delAfterArch = (int)JComponentHelper::getParams('com_vlogs')->get('delafterarch', 0); + if (!$apath) { - $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_NO_FOLDER'), false); + $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_NO_FOLDER'), false); } $apath = str_replace('\\', '/', JPATH_ROOT . '/' . $apath); - + if (!is_dir($apath)) { - $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_NO_EXISTS_FOLDER'), false); + $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_NO_EXISTS_FOLDER'), false); } $log_path = str_replace('\\', '/', JFactory::getConfig()->get('log_path')); $file = filter_input(INPUT_GET, 'filename'); - - if ($file !== 'PHP error log') - { - if (!extension_loaded('zip')) { - $this->printJson(JText::_('COM_VLOGS_NO_PHPZIP'), false); - } - - $zip = new ZipArchive(); - - $archFile = pathinfo($log_path . DIRECTORY_SEPARATOR . $file, PATHINFO_FILENAME) . '__' . date('Y-m-d_h-i-s') . '.zip'; - $archPath = $apath . '/' . $archFile; - - if ($zip->open($archPath, ZIPARCHIVE::CREATE) !== true) { - $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_ERROR_CREATE'), false); - } else { - $zip->addFile($log_path . '/' . $file, $file); - $zip->close(); - } - - $this->printJson(JText::sprintf('COM_VLOGS_ARCHIVEFILE_ALERT', $file, $archPath), true); - } - else - { - $this->printJson(JText::_('COM_VLOGS_NO_ARCHIVE_PHP_LOG') . ' ' . $file, false); + + if ($file !== 'PHP error log') { + if (!extension_loaded('zip')) { + $this->printJson(JText::_('COM_VLOGS_NO_PHPZIP'), false); + } + + $zip = new ZipArchive(); + + $archFile = pathinfo($log_path . DIRECTORY_SEPARATOR . $file, PATHINFO_FILENAME) . '__' . date('Y-m-d_h-i-s') . '.zip'; + $archPath = $apath . '/' . $archFile; + + if ($zip->open($archPath, ZIPARCHIVE::CREATE) !== true) { + $this->printJson(JText::_('COM_VLOGS_ARCHIVEFILE_ERROR_CREATE'), false); + } else { + $zip->addFile($log_path . '/' . $file, $file); + $zip->close(); + } + + $resultDel = 0; + if ($delAfterArch) { + $resultDel = unlink($log_path . '/' . $file); + } + + $this->printJson( + JText::sprintf('COM_VLOGS_ARCHIVEFILE_ALERT_' . (int)($delAfterArch && $resultDel), $file, str_replace(str_replace('\\', '/', JPATH_ROOT), '', $archPath)), + true, + ['del' => (int)($delAfterArch && $resultDel)] + ); + } else { + $this->printJson(JText::_('COM_VLOGS_NO_ARCHIVE_PHP_LOG') . ' ' . $file, false); } } } diff --git a/admin/models/fields/fileselect.css b/admin/models/fields/fileselect.css index e7d05ea..2439657 100644 --- a/admin/models/fields/fileselect.css +++ b/admin/models/fields/fileselect.css @@ -1,339 +1,426 @@ .av-modal { - position: absolute; - display: none; - top: 100%; - left: 0; - right: 0; - padding: 20px; - border-radius: 3px; - background-color: #f8f8f8; - box-shadow: inset 0 0 0 1px #eee; - z-index: 1; -} + position: absolute; + display: none; + top: 100%; + left: 0; + right: 0; + padding: 20px; + border-radius: 3px; + background-color: #f8f8f8; + box-shadow: inset 0 0 0 1px #eee; + z-index: 1; +} + .av-folderlist { - display: inline-block; - box-sizing: border-box; - margin: 0; - width: 100%; - max-width: 100%; - max-height: 250px; - overflow: auto; - list-style: none; - border-radius: 3px; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} + display: inline-block; + box-sizing: border-box; + margin: 0; + width: 100%; + max-width: 100%; + max-height: 250px; + overflow: auto; + list-style: none; + border-radius: 3px; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + .av-folderlist * { - box-sizing: border-box; - margin: 0; - padding: 0; -} -.av-folderlist li > ul { - padding-left: 20px; - list-style: none; - height: 0; - opacity: 0; - overflow: hidden; - -webkit-transition: height,opacity .2s; - -moz-transition: height,opacity .2s; - -ms-transition: height,opacity .2s; - transition: height,opacity .2s; -} -.av-folderlist li.open > ul { - height: auto; - opacity: 1; -} + box-sizing: border-box; + margin: 0; + padding: 0; +} + +.av-folderlist li>ul { + padding-left: 20px; + list-style: none; + height: 0; + opacity: 0; + overflow: hidden; + -webkit-transition: height, opacity .2s; + -moz-transition: height, opacity .2s; + -ms-transition: height, opacity .2s; + transition: height, opacity .2s; +} + +.av-folderlist li.open>ul { + height: auto; + opacity: 1; +} + .av-folderlist .av-folderlist-item { - display: block; - position: relative; - font-size: 13px; - line-height: 21px; + display: block; + position: relative; + font-size: 13px; + line-height: 21px; } -.av-folderlist .av-folderlist-item:before, -.av-folderlist .av-folderlist-item:after { - content: ''; - display: table; + +.av-folderlist .av-folderlist-item:before, .av-folderlist .av-folderlist-item:after { + content: ''; + display: table; } + .av-folderlist .av-folderlist-item:after { - clear: both; + clear: both; } + .av-folderlist .av-folderlist-tree { - position: absolute; - display: inline-block; - top: 4px; - left: 0; - width: 13px; - height: 13px; - background-color: #fff; - box-shadow: inset 0 0 0 1px #aaa; - z-index: 1; - cursor: pointer; -} -.av-folderlist .av-folderlist-tree:before, + position: absolute; + display: inline-block; + top: 4px; + left: 0; + width: 13px; + height: 13px; + background-color: #fff; + box-shadow: inset 0 0 0 1px #aaa; + z-index: 1; + cursor: pointer; +} + +.av-folderlist .av-folderlist-tree:before, .av-folderlist .av-folderlist-tree:after { + content: ''; + position: absolute; + top: 6px; + left: 4px; + width: 5px; + height: 1px; + background-color: #aaa; + -webkit-transition: opacity .2s; + -moz-transition: opacity .2s; + -ms-transition: opacity .2s; + transition: opacity .2s; +} + .av-folderlist .av-folderlist-tree:after { - content: ''; - position: absolute; - top: 6px; - left: 4px; - width: 5px; - height: 1px; - background-color: #aaa; - -webkit-transition: opacity .2s; - -moz-transition: opacity .2s; - -ms-transition: opacity .2s; - transition: opacity .2s; -} -.av-folderlist .av-folderlist-tree:after { - transform: rotate(90deg); - opacity: 1; + transform: rotate(90deg); + opacity: 1; } + .av-folderlist .av-folderlist-label { - position: relative; - display: block; - padding-left: 38px; - cursor: pointer; + position: relative; + display: block; + padding-left: 38px; + cursor: pointer; } + .av-folderlist .av-folderlist-label:after { - content: ''; - position: absolute; - top: 0; - left: 18px; - bottom: 0; - width: 16px; - background-image: url(''); - background-repeat: no-repeat; - background-position: 0 center; -} + content: ''; + position: absolute; + top: 0; + left: 18px; + bottom: 0; + width: 16px; + background-image: url(''); + background-repeat: no-repeat; + background-position: 0 center; +} + .av-folderlist .av-folderlist-label.selected { - font-weight: bold; + font-weight: bold; } + .av-folderlist .av-folderlist-label:hover { - text-decoration: underline; + text-decoration: underline; } + .av-folderlist .av-folderlist-dir .av-folderlist-label:after { - background-position: -64px center; + background-position: -64px center; } + .av-folderlist .av-folderlist-file .av-folderlist-label:after { - background-position: -112px center; + background-position: -112px center; } + .av-folderlist .av-folderlist-file-3gp .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-afp .av-folderlist-label:after { - background-position: - 16px center; + background-position: - 16px center; } + .av-folderlist .av-folderlist-file-afpa .av-folderlist-label:after { - background-position: - 16px center; + background-position: - 16px center; } + .av-folderlist .av-folderlist-file-asp .av-folderlist-label:after { - background-position: - 16px center; + background-position: - 16px center; } + .av-folderlist .av-folderlist-file-aspx .av-folderlist-label:after { - background-position: - 16px center; + background-position: - 16px center; } + .av-folderlist .av-folderlist-file-avi .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-bat .av-folderlist-label:after { - background-position: 0px center; + background-position: 0px center; } + .av-folderlist .av-folderlist-file-bmp .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-bpg .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-c .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-cfm .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-cgi .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-com .av-folderlist-label:after { - background-position: 0px center; + background-position: 0px center; } + .av-folderlist .av-folderlist-file-cpp .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-css .av-folderlist-label:after { - background-position: -32px center; + background-position: -32px center; } + .av-folderlist .av-folderlist-file-less .av-folderlist-label:after { - background-position: -32px center; + background-position: -32px center; } + .av-folderlist .av-folderlist-file-sass .av-folderlist-label:after { - background-position: -32px center; + background-position: -32px center; } + .av-folderlist .av-folderlist-file-scss .av-folderlist-label:after { - background-position: -32px center; + background-position: -32px center; } + .av-folderlist .av-folderlist-file-doc .av-folderlist-label:after { - background-position: -80px center; + background-position: -80px center; } + .av-folderlist .av-folderlist-file-docx .av-folderlist-label:after { - background-position: -80px center; + background-position: -80px center; } + .av-folderlist .av-folderlist-file-exe .av-folderlist-label:after { - background-position: 0px center; + background-position: 0px center; } + .av-folderlist .av-folderlist-file-gif .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-fla .av-folderlist-label:after { - background-position: -144px center; + background-position: -144px center; } + .av-folderlist .av-folderlist-file-h .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-htm .av-folderlist-label:after { - background-position: -176px center; + background-position: -176px center; } + .av-folderlist .av-folderlist-file-html .av-folderlist-label:after { - background-position: -176px center; + background-position: -176px center; } + .av-folderlist .av-folderlist-file-jar .av-folderlist-label:after { - background-position: -192px center; + background-position: -192px center; } + .av-folderlist .av-folderlist-file-jpg .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-jpeg .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-js .av-folderlist-label:after { - background-position: -336px center; + background-position: -336px center; } + .av-folderlist .av-folderlist-file-lasso .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-log .av-folderlist-label:after { - background-position: -352px center; + background-position: -352px center; } + .av-folderlist .av-folderlist-file-m4p .av-folderlist-label:after { - background-position: -224px center; + background-position: -224px center; } + .av-folderlist .av-folderlist-file-mov .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-mp3 .av-folderlist-label:after { - background-position: -224px center; + background-position: -224px center; } + .av-folderlist .av-folderlist-file-mp4 .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-mpg .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-mpeg .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-ogg .av-folderlist-label:after { - background-position: -224px center; + background-position: -224px center; } + .av-folderlist .av-folderlist-file-pcx .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-pdf .av-folderlist-label:after { - background-position: -240px center; + background-position: -240px center; } + .av-folderlist .av-folderlist-file-php .av-folderlist-label:after { - background-position: -256px center; + background-position: -256px center; } + .av-folderlist .av-folderlist-file-png .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-ppt .av-folderlist-label:after { - background-position: -288px center; + background-position: -288px center; } + .av-folderlist .av-folderlist-file-pptx .av-folderlist-label:after { - background-position: -288px center; + background-position: -288px center; } + .av-folderlist .av-folderlist-file-psd .av-folderlist-label:after { - background-position: -288px center; + background-position: -288px center; } + .av-folderlist .av-folderlist-file-cdr .av-folderlist-label:after { - background-position: -288px center; + background-position: -288px center; } + .av-folderlist .av-folderlist-file-ai .av-folderlist-label:after { - background-position: -288px center; + background-position: -288px center; } + .av-folderlist .av-folderlist-file-pl .av-folderlist-label:after { - background-position: -336px center; + background-position: -336px center; } + .av-folderlist .av-folderlist-file-py .av-folderlist-label:after { - background-position: -336px center; + background-position: -336px center; } + .av-folderlist .av-folderlist-file-rb .av-folderlist-label:after { - background-position: -320px center; + background-position: -320px center; } + .av-folderlist .av-folderlist-file-rbx .av-folderlist-label:after { - background-position: -320px center; + background-position: -320px center; } + .av-folderlist .av-folderlist-file-rhtml .av-folderlist-label:after { - background-position: -320px center; + background-position: -320px center; } + .av-folderlist .av-folderlist-file-rpm .av-folderlist-label:after { - background-position: -208px center; + background-position: -208px center; } + .av-folderlist .av-folderlist-file-ruby .av-folderlist-label:after { - background-position: -320px center; + background-position: -320px center; } + .av-folderlist .av-folderlist-file-sql .av-folderlist-label:after { - background-position: -48px center; + background-position: -48px center; } + .av-folderlist .av-folderlist-file-swf .av-folderlist-label:after { - background-position: -144px center; + background-position: -144px center; } + .av-folderlist .av-folderlist-file-tif .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-tiff .av-folderlist-label:after { - background-position: -272px center; + background-position: -272px center; } + .av-folderlist .av-folderlist-file-txt .av-folderlist-label:after { - background-position: -352px center; + background-position: -352px center; } + .av-folderlist .av-folderlist-file-vb .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-wav .av-folderlist-label:after { - background-position: -224px center; + background-position: -224px center; } + .av-folderlist .av-folderlist-file-wmv .av-folderlist-label:after { - background-position: -128px center; + background-position: -128px center; } + .av-folderlist .av-folderlist-file-xls .av-folderlist-label:after { - background-position: -368px center; + background-position: -368px center; } + .av-folderlist .av-folderlist-file-xlsx .av-folderlist-label:after { - background-position: -368px center; + background-position: -368px center; } + .av-folderlist .av-folderlist-file-xml .av-folderlist-label:after { - background-position: -16px center; + background-position: -16px center; } + .av-folderlist .av-folderlist-file-zip .av-folderlist-label:after { - background-position: -384px center; + background-position: -384px center; } + .av-folderlist .av-folderlist-file-gzip .av-folderlist-label:after { - background-position: -384px center; + background-position: -384px center; } + .av-folderlist .av-folderlist-file-7z .av-folderlist-label:after { - background-position: -384px center; + background-position: -384px center; } + .av-folderlist .av-folderlist-file-tar .av-folderlist-label:after { - background-position: -384px center; + background-position: -384px center; } + .av-folderlist .av-folderlist-file-rar .av-folderlist-label:after { - background-position: -384px center; -} -.av-folderlist li.open > .av-folderlist-tree:after { - opacity: 0; + background-position: -384px center; } -.av-folderlist li.open.av-folderlist-dir > .av-folderlist-label:after { - background-position: -160px center; + +.av-folderlist li.open>.av-folderlist-tree:after { + opacity: 0; } + +.av-folderlist li.open.av-folderlist-dir>.av-folderlist-label:after { + background-position: -160px center; +} \ No newline at end of file diff --git a/admin/models/fields/fileselect.php b/admin/models/fields/fileselect.php index 87ae7fa..8408d1a 100644 --- a/admin/models/fields/fileselect.php +++ b/admin/models/fields/fileselect.php @@ -13,7 +13,7 @@ class showroot="true|false" // show root directori no tree (val 'true'), default 'false' /> -*/ + */ JFormHelper::loadFieldClass('list'); @@ -24,80 +24,74 @@ class JFormFieldFileselect extends JFormField public $type = 'fileselect'; protected $uid; - - protected function showdir - ( + + protected function showdir( $dir, $folderOnly = false, $showRoot = false, $level = 0, // do not use!!! $ef = '' // do not use!!! - ) - { + ) { $html = ''; - if ((int)$level == 0) - { + if ((int)$level == 0) { $dir = realpath($dir); $ef = ($showRoot ? realpath($dir . DIRECTORY_SEPARATOR . '..') . DIRECTORY_SEPARATOR : $dir . DIRECTORY_SEPARATOR); } if (!file_exists($dir)) return ''; - - if ($showRoot && (int)$level == 0) - { + + if ($showRoot && (int)$level == 0) { $html = '
    '; $subdir = $this->showdir($dir, $folderOnly, $showRoot, $level + 1, $ef); $name = substr(strrchr($dir, DIRECTORY_SEPARATOR), 1); $html .= '
  • ' . ($subdir ? '' : '') . '' . $name . '' . $subdir . '
  • '; $html .= '
'; - } - else - { + } else { $list = scandir($dir); - if (is_array($list)) - { + if (is_array($list)) { $list = array_diff($list, array('.', '..')); - if ($list) - { + if ($list) { $folders = array(); $files = array(); - + foreach ($list as $name) - if (is_dir($dir . DIRECTORY_SEPARATOR . $name)) {$folders[] = $name;} else {$files[] = $name;} - + if (is_dir($dir . DIRECTORY_SEPARATOR . $name)) { + $folders[] = $name; + } else { + $files[] = $name; + } + if (!($folderOnly && !$folders) || !(!$folders || !$files)) $html .= ''; - + sort($folders); sort($files); - - foreach ($folders as $name) - { + + foreach ($folders as $name) { $fpath = $dir . DIRECTORY_SEPARATOR . $name; $subdir = $this->showdir($fpath, $folderOnly, $showRoot, $level + 1, $ef); $fpath = str_replace($ef, '', $fpath); $html .= '
  • ' . ($subdir ? '' : '') . '' . $name . '' . $subdir . '
  • '; } - + if (!$folderOnly) - foreach ($files as $name) - { - $fpath = $dir . DIRECTORY_SEPARATOR . $name; - $fpath = str_replace($ef, '', $fpath); - $ext = substr(strrchr($name, '.'), 1); - $html .= '
  • ' . $name . '
  • '; - } - + foreach ($files as $name) { + $fpath = $dir . DIRECTORY_SEPARATOR . $name; + $fpath = str_replace($ef, '', $fpath); + $ext = substr(strrchr($name, '.'), 1); + $html .= '
  • ' . $name . '
  • '; + } + if (!($folderOnly && !$folders) || !(!$folders || !$files)) $html .= ''; unset($folders, $files, $fpath, $ext); } } } - + return $html; } - + protected function getInput() { // include jq && css @@ -108,10 +102,10 @@ protected function getInput() // get attributes $folder = $this->getAttribute('folder'); $folder = ($folder && file_exists(realpath(JPATH_ROOT . DIRECTORY_SEPARATOR . $folder)) ? $folder : 'images'); - + $folderOnly = $this->getAttribute('folderonly'); $folderOnly = ($folderOnly && (strtolower($folderOnly) === 'true' || strtolower($folderOnly) === 'folderonly') ? true : false); - + $showRoot = $this->getAttribute('showroot'); $showRoot = ($showRoot && (strtolower($showRoot) === 'true' || strtolower($showRoot) === 'showroot') ? true : false); @@ -123,7 +117,7 @@ protected function getInput() // input $html .= '
    '; - $html .= 'class ? ' class="' . $this->class .'"' : '') . ' value="' . $this->value . '" placeholder="' . JText::_('Select file or folder') . '" readonly ' . ($this->required ? 'required' : '') . '/>'; + $html .= 'class ? ' class="' . $this->class . '"' : '') . ' value="' . $this->value . '" placeholder="' . JText::_('Select file or folder') . '" readonly ' . ($this->required ? 'required' : '') . '/>'; if (!$this->readonly) $html .= ''; @@ -155,7 +149,7 @@ protected function getInput() }); "; $html .= '
    '; - + return $html; } } diff --git a/admin/models/items.php b/admin/models/items.php index ee4d2b5..db275ac 100644 --- a/admin/models/items.php +++ b/admin/models/items.php @@ -1,9 +1,4 @@ get('log_path')); $items = glob($log_path . '/*.*'); - - foreach ($items as $i => &$item) - { + + foreach ($items as $i => &$item) { $item = basename($item); - if ($item == 'index.html') - { + if ($item == 'index.html') { unset($items[$i]); } } $items = array_values($items); - + $phpErrorLog = ini_get('error_log'); - if (file_exists($phpErrorLog)) - { + if (file_exists($phpErrorLog)) { $items[] = 'PHP error log'; } - + return $items; } } diff --git a/admin/views/items/tmpl/default.php b/admin/views/items/tmpl/default.php index 953720c..2312354 100644 --- a/admin/views/items/tmpl/default.php +++ b/admin/views/items/tmpl/default.php @@ -1,9 +1,4 @@ @@ -99,6 +94,11 @@ response = JSON.parse(this.response); if (response.result) { + if (response.del) { + var sel = document.querySelector('#view_select_files'); + sel.removeChild(sel.options[sel.selectedIndex]); + getLog(sel.value); + } Joomla.renderMessages({'info':[response.message]}); } else diff --git a/admin/views/items/view.html.php b/admin/views/items/view.html.php index f094c0a..6b0a5f2 100644 --- a/admin/views/items/view.html.php +++ b/admin/views/items/view.html.php @@ -1,9 +1,4 @@ items = $this->get('Items'); - + JToolBarHelper::title(JText::_('COM_VLOGS'), 'health'); - + $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); - + $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); - + $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); - + $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); - + $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); - + if (extension_loaded('zip')) { $custom_button_html = ''; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'custom'); } - + $custom_button_html = '' . JText::_('COM_VLOGS_COUNT_ITEMS_VIEW') . ' 0'; JToolBar::getInstance('toolbar')->appendButton('Custom', $custom_button_html, 'options'); - + $canDo = JHelperContent::getActions('com_vlogs'); - if ($canDo->get('core.admin')) - { + if ($canDo->get('core.admin')) { JToolBarHelper::preferences('com_vlogs'); } - - parent::display( $tpl ); + + parent::display($tpl); } } diff --git a/admin/vlogs.php b/admin/vlogs.php index 805e515..8ca680b 100644 --- a/admin/vlogs.php +++ b/admin/vlogs.php @@ -1,12 +1,13 @@ authorise('core.manage', 'com_vlogs')) +if (!JFactory::getUser()->authorise('core.manage', 'com_vlogs')) { return JError::raiseWarning(403, JText::_('JERROR_ALERTNOAUTHOR')); +} $controller = JControllerLegacy::getInstance('vlogs'); $controller->execute(JFactory::getApplication()->input->get('task')); diff --git a/vlogs.xml b/vlogs.xml index 972dede..90440ec 100644 --- a/vlogs.xml +++ b/vlogs.xml @@ -6,7 +6,7 @@ https://alekvolsk.pw © 2019 Aleksey A. Morozov. All right reserved. GNU General Public License version 3 or later; see http://www.gnu.org/licenses/gpl-3.0.txt - 1.3.2 + 1.3.3 COM_VLOGS_DESC February 2019