Вход Регистрация
Файл: public_html/mpanel/ban.php
Строк: 108
<?php
#-----------------------------------------------------#
#          ********* ROTORCMS *********               #
#              Made by  :  VANTUZ                     #
#               E-mail  :  visavi.net@mail.ru         #
#                 Site  :  http://pizdec.ru           #
#             WAP-Site  :  http://visavi.net          #
#                  ICQ  :  36-44-66                   #
#  Вы не имеете право вносить изменения в код скрипта #
#        для его дальнейшего распространения          #
#-----------------------------------------------------#    
require_once ('../includes/start.php');
require_once (
'../includes/functions.php');
require_once (
'../includes/header.php');
include_once (
'../themes/' $config['themes'] . '/index.php');

if (isset(
$_GET['act'])) {
  
$act check($_GET['act']);
} else {
  
$act 'index';

if (isset(
$_GET['start'])) {
  
$start abs(intval($_GET['start']));
} else {
  
$start 0;


if (
is_admin(array(101102))) {
  
show_title('site.png''IP-бан панель');
  
$config['newtitle'] = 'IP-бан панель';

  switch (
$act):
  
# ###########################################################################################
  # #                                    Главная страница                                    ##
  # ###########################################################################################
  
case "index":

    
$total DB :: $dbh -> querySingle("SELECT count(*) FROM ban;");

    if (
$total 0) {
      if (
$start >= $total) {
        
$start 0;
      } 

      
$queryban DB :: $dbh -> query("SELECT * FROM ban ORDER BY ban_time DESC LIMIT " $start ", " $config['ipbanlist'] . ";");

      echo 
'<form action="ban.php?act=del&amp;start=' $start '&amp;uid=' $_SESSION['token'] . '&amp;' SID '" method="post">';

      while (
$data $queryban -> fetch()) {
        echo 
'<div class="b">';
        echo 
'<input type="checkbox" name="del[]" value="' $data['ban_id'] . '" />';
        echo 
'<img src="../images/img/files.gif" alt="image" /> <b>' $data['ban_ip'] . '</b></div>';

        echo 
'<div>Добавлено: <b><a href="../pages/anketa.php?uz=' $data['ban_user'] . '&amp;' SID '">' nickname($data['ban_user']) . '</a></b><br />';

        echo 
'Время: ' date_fixed($data['ban_time']) . '</div>';
      } 

      echo 
'<br /><input type="submit" value="Удалить выбранное" /></form>';

      
page_jumpnavigation('ban.php?'$config['ipbanlist'], $start$total);
      
page_strnavigation('ban.php?'$config['ipbanlist'], $start$total);

      echo 
'Всего заблокировано: <b>' $total '</b><br /><br />';
    } else {
      
show_error('В бан-листе пока пусто!');
    } 

    echo 
'<div class="form">';
    echo 
'<form action="ban.php?act=add&amp;start=' $start '&amp;uid=' $_SESSION['token'] . '&amp;' SID '" method="post">';
    echo 
'IP-адрес:<br />';
    echo 
'<input type="text" name="ips" />';
    echo 
'<input value="Добавить" type="submit" /></form></div><br />';

    echo 
'Примеры банов: 127.0.0.1 без отступов и пробелов<br />';
    echo 
'Или по маске 127.0.0.* , 127.0.*.* , будут забанены все IP совпадающие по начальным цифрам<br /><br />';

    if (
$total && is_admin(array(101))) {
      echo 
'<img src="../images/img/error.gif" alt="image" /> <a href="ban.php?act=clear&amp;uid=' $_SESSION['token'] . '&amp;' SID '">Очистить список</a><br />';
    } 
    break;
  
# ###########################################################################################
  # #                                   Занесение в список                                   ##
  # ###########################################################################################
  
case "add":

    
$uid check($_GET['uid']);
    
$ips check($_POST['ips']);

    if (
$uid == $_SESSION['token']) {
      if (
preg_match('|^[0-9]{1,3}.[0-9,*]{1,3}.[0-9,*]{1,3}.[0-9,*]{1,3}$|'$ips)) {
        
$banip DB :: $dbh -> querySingle("SELECT ban_id FROM ban WHERE ban_ip=? LIMIT 1;", array($ips));
        if (empty(
$banip)) {
          
DB :: $dbh -> query("INSERT INTO ban (ban_ip, ban_user, ban_time) VALUES (?, ?, ?);", array($ips$logSITETIME));
          
save_ipban();

          
$_SESSION['note'] = 'IP успешно занесен в список!';
          
header ("Location: ban.php?start=$start&" SID);
          exit;
        } else {
          
show_error('Ошибка! Введенный IP уже имеетеся в списке!');
        } 
      } else {
        
show_error('Ошибка! Вы ввели недопустимый IP-адрес для бана!');
      } 
    } else {
      
show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
    } 

    echo 
'<img src="../images/img/back.gif" alt="image" /> <a href="ban.php?' SID '">Вернуться</a><br />';
    break;
  
# ###########################################################################################
  # #                                   Удаление из списка                                   ##
  # ###########################################################################################
  
case "del":

    
$uid check($_GET['uid']);
    if (isset(
$_POST['del'])) {
      
$del intar($_POST['del']);
    } else {
      
$del 0;
    } 

    if (
$uid == $_SESSION['token']) {
      if (!empty(
$del)) {
        
$del implode(','$del);

        
DB :: $dbh -> query("DELETE FROM ban WHERE ban_id IN (" $del ");");
        
save_ipban();

        
$_SESSION['note'] = 'Выбранные IP успешно удалены из списка!';
        
header ("Location: ban.php?start=$start&" SID);
        exit();
      } else {
        echo 
'<img src="../images/img/error.gif" alt="image" /> <b>Ошибка удаления! Отсутствуют выбранные IP</b><br />';
      } 
    } else {
      echo 
'<img src="../images/img/error.gif" alt="image" /> <b>Ошибка! Неверный идентификатор сессии, повторите действие!</b><br />';
    } 

    echo 
'<img src="../images/img/back.gif" alt="image" /> <a href="ban.php?start=' $start '&amp;' SID '">Вернуться</a><br />';
    break;
  
# ###########################################################################################
  # #                                     Очистка списка                                     ##
  # ###########################################################################################
  
case "clear":

    
$uid check($_GET['uid']);

    if (
is_admin(array(101))) {
      if (
$uid == $_SESSION['token']) {
        
DB :: $dbh -> query("TRUNCATE `ban`;");
        
save_ipban();

        
$_SESSION['note'] = 'Список IP успешно очищен!';
        
header ("Location: ban.php?" SID);
        exit;
      } else {
        
show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
      } 
    } else {
      
show_error('Ошибка! Очищать бан-лист могут только суперадмины!');
    } 

    echo 
'<img src="../images/img/back.gif" alt="image" /> <a href="ban.php?start=' $start '&amp;' SID '">Вернуться</a><br />';
    break;

  default:
    
header("location: ban.php?" SID);
    endswitch;

    echo 
'<img src="../images/img/panel.gif" alt="image" /> <a href="index.php?' SID '">В админку</a><br />';
    echo 
'<img src="../images/img/homepage.gif" alt="image" /> <a href="../index.php?' SID '">На главную</a><br />';
  } else {
  
header ('Location: ' BASEDIR 'index.php?' SID);
  exit;


include_once (
'../themes/' $config['themes'] . '/foot.php');

?>
Онлайн: 1
Реклама