Файл: admin/checker.php
Строк: 56
<?php
#---------------------------------------------#
#      ********* RotorCMS *********           #
#           Author  :  Vantuz                 #
#            Email  :  visavi.net@mail.ru     #
#             Site  :  http://visavi.net      #
#              ICQ  :  36-44-66               #
#            Skype  :  vantuzilla             #
#---------------------------------------------#
require_once ('../includes/start.php');
require_once ('../includes/functions.php');
require_once ('../includes/header.php');
include_once ('../themes/header.php');
if (isset($_GET['act'])) {
    $act = check($_GET['act']);
} else {
    $act = 'index';
}
if (is_admin(array(101))) {
    show_title('Сканирование сайта');
    switch ($act):
    ############################################################################################
    ##                                    Главная страница                                    ##
    ############################################################################################
        case 'index':
            if (file_exists(DATADIR."/temp/checker.dat")) {
                echo 'Последнее сканирование: <b>'.date_fixed(filemtime(DATADIR."/temp/checker.dat")).'</b><br /><br />';
                $arr = scan_check('../');
                $arr['files'] = str_replace('..//', '', $arr['files']);
                $arrnewskan = unserialize(file_get_contents(DATADIR."/temp/checker.dat"));
                $arr1 = array_diff($arr['files'], $arrnewskan);
                $arr2 = array_diff($arrnewskan, $arr['files']);
                $count_arr1 = count($arr1);
                $count_arr2 = count($arr2);
                if (($count_arr1 + $count_arr2) > 0) {
                    echo '<b><span style="color:#ff0000">Новые файлы и новые параметры файлов:</span></b><br /><br />';
                    if ($count_arr1 > 0) {
                        foreach($arr1 as $val) {
                            echo check($val).'<br />';
                        }
                        echo '<br />';
                    } else {
                        show_error('Нет новых изменений!');
                    }
                    echo '<b><span style="color:#ff0000">Удаленные файлы и старые параметры файлов:</span></b><br /><br />';
                    if ($count_arr2 > 0) {
                        foreach($arr2 as $val) {
                            echo check($val).'<br />';
                        }
                        echo '<br />';
                    } else {
                        show_error('Нет старых изменений!');
                    }
                    echo 'Всего папок: <b>'.$arr['totaldirs'].'</b><br />';
                    echo 'Всего файлов: <b>'.$arr['totalfiles'].'</b><br /><br />';
                } else {
                    show_error('Изменений файлов со времени последнего сканирования не обнаружено!');
                }
            } else {
                show_error('Необходимо провести начальное сканирование!');
            }
            echo 'Сканирование системы позволяет узнать какие файлы или папки менялись в течении определенного времени<br />';
            echo 'Внимание сервис не учитывает некоторые расширения файлов: '.$config['nocheck'].'<br /><br />';
            echo '<img src="/images/img/reload.gif" alt="image" /> <a href="checker.php?act=skan&uid='.$_SESSION['token'].'">Сканировать</a><br />';
        break;
        ############################################################################################
        ##                                      Сканирование                                      ##
        ############################################################################################
        case 'skan':
            $uid = check($_GET['uid']);
            if ($uid == $_SESSION['token']) {
                if (is_writeable(DATADIR."/temp")) {
                    $arr = scan_check('../');
                    $arr['files'] = str_replace('..//', '', $arr['files']);
                    file_put_contents(DATADIR."/temp/checker.dat", serialize($arr['files']), LOCK_EX);
                    $_SESSION['note'] = 'Сайт успешно отсканирован!';
                    redirect("checker.php");
                } else {
                    show_error('Ошибка! Директория temp недоступна для записи!');
                }
            } else {
                show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
            }
            echo '<img src="/images/img/back.gif" alt="image" /> <a href="checker.php">Вернуться</a><br />';
        break;
    default:
        redirect("checker.php");
    endswitch;
    echo '<img src="/images/img/panel.gif" alt="image" /> <a href="index.php">В админку</a><br />';
} else {
    redirect('/index.php');
}
include_once ('../themes/footer.php');
?>