Source of file LogController.php

Size: 3,247 Bytes - Last Modified: 2020-10-24T02:46:31+00:00

/home/travis/build/NextDom/nextdom-core/src/Controller/Diagnostic/LogController.php

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
<?php

/* This file is part of NextDom Software.
 *
 * NextDom is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * NextDom Software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with NextDom Software. If not, see <http://www.gnu.org/licenses/>.
 *
 * @Support <https://www.nextdom.org>
 * @Email   <admin@nextdom.org>
 * @Authors/Contributors: Sylvaner, Byackee, cyrilphoenix71, ColonelMoutarde, edgd1er, slobberbone, Astral0, DanoneKiD
 */

namespace NextDom\Controller\Diagnostic;

use NextDom\Controller\BaseController;
use NextDom\Enums\ControllerData;
use NextDom\Helpers\Render;
use NextDom\Helpers\Utils;

/**
 * Class LogController
 * @package NextDom\Controller\Diagnostic
 */
class LogController extends BaseController
{
    /**
     * Render log page
     *
     * @param array $pageData Page data
     *
     * @return string Content of log page
     *
     */
    public static function get(&$pageData): string
    {

        $currentLogfile = Utils::init('logfile');
        $logFilesList = [];
        $dir = opendir(NEXTDOM_LOG);
        while ($file = readdir($dir)) {
            if ($file != '.' && $file != '..' && $file != '.htaccess' && !is_dir(NEXTDOM_LOG . '/' . $file)) {
                $logFilesList[] = $file;
            }
        }
        $pageData['logFilesList'] = [];
        foreach ($logFilesList as $logFile) {
            $logFileData = [];
            $logFileData['name'] = $logFile;
            if ($currentLogfile == $logFile) {
                $logFileData['active'] = true;
            } else {
                $logFileData['active'] = false;
            }
            $logFileData['size'] = round(filesize(NEXTDOM_LOG . '/' . $logFile) / 1024);
            $logFileData['icon'] = 'check';
            $logFileData['color'] = 'green';
            $logFileData['timing'] = date("YmdHis", filemtime(NEXTDOM_LOG . '/' . $logFile));
            if ($logFileData['size'] < 10000) {
                if (shell_exec('grep -c -E "\[ERROR\]|\[error\]" ' . NEXTDOM_LOG . '/' . $logFile) != 0) {
                    $logFileData['icon'] = 'exclamation-triangle';
                    $logFileData['color'] = 'red';
                } elseif (shell_exec('grep -c -E "\[WARNING\]" ' . NEXTDOM_LOG . '/' . $logFile) != 0) {
                    $logFileData['icon'] = 'exclamation-circle';
                    $logFileData['color'] = 'orange';
                }
            } else {
                $logFileData['icon'] = 'exclamation-triangle';
                $logFileData['color'] = 'red';
            }
            $pageData['logFilesList'][] = $logFileData;
        }

        $pageData[ControllerData::JS_END_POOL][] = '/public/js/desktop/diagnostic/log.js';

        return Render::getInstance()->get('/desktop/diagnostic/log.html.twig', $pageData);
    }


}