Файл: includes/main_forum/rootkit.php
Строк: 81
<?php
$command=substr($addmsg,1);
//Команда не опознана...
$sysmsg='<b>Команда не опознана ['.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command)))).']</b><br/>';
$access_denied='<b>Недостаточно прав... ['.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command)))).']</b><br/>';
for ($k=1;$k<10;$k++) $command=str_replace(' ',' ',$command);
$command=explode(" ",$command,2);
$q=@mysql(DBName,"SELECT `status` FROM `$tableu` WHERE `login` = '".$command[1]."'");
$s=round(mysql_num_rows($q));
$f=mysql_fetch_array($q);
$status_=$f['status'];
switch (strtolower($command[0]))
{
case 'noop':
$sysmsg='<b>Пустая команда.</b><br/>';
break;
case 'ban':
//Недостаточно прав...
if ($status<1) {$sysmsg=$access_denied;break;}
//Пользователь не найден
if ($s<1) {$sysmsg='<b>Пользователь '.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command[1])))).' не найден...</b><br/>';break;}
//Конфликт статусов
if ($status<=$status_) {$sysmsg='<b>Конфликт статусов...</b><br/>';break;}
@mysql(DBName,"UPDATE `$tableu` SET `status` = '-1' WHERE `login` = '".$command[1]."' LIMIT 1");
$sysmsg='<b>Для '.$command[1].' установлен бан (написанеи в форум запрещено).</b><br/>';
break;
case 'user':
//Недостаточно прав...
if ($status<1) {$sysmsg=$access_denied;break;}
//Пользователь не найден
if ($s<1) {$sysmsg='<b>Пользователь '.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command[1])))).' не найден...</b><br/>';break;}
//Конфликт статусов
if ($status<=$status_) {$sysmsg='<b>Конфликт статусов...</b><br/>';break;}
@mysql(DBName,"UPDATE `$tableu` SET `status` = '0' WHERE `login` = '".$command[1]."' LIMIT 1");
$sysmsg='<b>Для '.$command[1].' установлен статус обычного пользователя (написанеи в форум разрешено).</b><br/>';
break;
case 'moder':
//Недостаточно прав...
if ($status<2) {$sysmsg=$access_denied;break;}
//Пользователь не найден
if ($s<1) {$sysmsg='<b>Пользователь '.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command[1])))).' не найден...</b><br/>';break;}
//Конфликт статусов
if ($status<=$status_) {$sysmsg='<b>Конфликт статусов...</b><br/>';break;}
@mysql(DBName,"UPDATE `$tableu` SET `status` = '1' WHERE `login` = '".$command[1]."' LIMIT 1");
$sysmsg='<b>Для '.$command[1].' установлен статус "Модератор".</b><br/>';
break;
/*
case 'admin':
//Недостаточно прав...
if ($status<2) {$sysmsg=$access_denied;break;}
//Пользователь не найден
if ($s<1) {$sysmsg='<b>Пользователь '.cyr2utf(str_replace("$","$$",htmlspecialchars(stripslashes($command[1])))).' не найден...</b><br/>';break;}
@mysql(DBName,"UPDATE `$tableu` SET `status` = '2' WHERE `login` = '".$command[1]."' LIMIT 1");
$sysmsg='<b>Для '.$command[1].' установлен статус "Администратор".</b><br/>';
break;
*/
# Закрытие темы
case 'lock':
# Статус темы
$q=mysql(DBName,"SELECT `status` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic AND `l3` = 0 LIMIT 0, 1");
$f=mysql_fetch_array($q);
$topic_status=$f['status'];
if ($topic_status==1) {$sysmsg='<b>Тема уже закрыта!</b><br/>';include($rootpath."messages.php");}
# Логин автора темы
$q=mysql(DBName,"SELECT `l3`, `login` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic AND `l3` = 0");
$s=mysql_num_rows($q)+0;
$f=mysql_fetch_array($q);
$flogin=$f['login'];
if (($status<1)&&($flogin!=$login)) {$sysmsg='<b>Нельзя закрыть чужую тему!</b><br/>';include($rootpath."messages.php");}
# Колличество сообщений не автора
$q=mysql(DBName,"SELECT `l3` FROM `$table` WHERE `login` != $login AND `l1` = $razdel AND `l2` = $topic");
$s=mysql_num_rows($q)+0;
if (($status<1)&&($s==0)) {$sysmsg='<b>Темы содержащие только ваши сообщения можно только удалять.</b><br/>';include($rootpath."messages.php");}
# Номер последнего сообщения в теме
$q=mysql(DBName,"SELECT `l3` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic ORDER BY `l3` DESC LIMIT 0, 1");
$f=mysql_fetch_array($q);
$message=$f['l3']+1;
$sysmsg='<b>Тема закрыта.</b><br/>';
@mysql(DBName,"UPDATE `$table` SET `status` = '1', `time` = '".time()."' WHERE `l1` = '$razdel' AND `l2` = '$topic' AND `l3` = '0' LIMIT 1");
@mysql(DBName,"INSERT INTO `$table` ( `l1` , `l2` , `l3` , `status` , `login` , `time` , `text` ) VALUES ( '$razdel', '$topic', '$message', '0', '$login', '".time()."', 'Тема закрыта: ".$command[1]." ".$command[2]." ".$command[3]."')");
include($rootpath."messages.php");
break;
# Открытие темы
case 'unlock':
if ($status<1) {$sysmsg=$access_denied;include($rootpath."messages.php");}
# Статус темы
$q=mysql(DBName,"SELECT `status` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic AND `l3` = 0 LIMIT 0, 1");
$f=mysql_fetch_array($q);
$topic_status=$f['status'];
if ($topic_status==0) {$sysmsg='<b>Тема не закрыта!</b><br/>';include($rootpath."messages.php");}
# Номер последнего сообщения в теме
$q=mysql(DBName,"SELECT `l3` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic ORDER BY `l3` DESC LIMIT 0, 1");
$f=mysql_fetch_array($q);
$message=$f['l3'];
$sysmsg='<b>Тема открыта.</b><br/>';
@mysql(DBName,"UPDATE `$table` SET `status` = '0', `time` = '".time()."' WHERE `l1` = '$razdel' AND `l2` = '$topic' AND `l3` = '0' LIMIT 1");
@mysql(DBName,"DELETE FROM `$table` WHERE `l1` = '$razdel' AND `l2` = '$topic' AND `l3` = '$message' LIMIT 1");
include($rootpath."messages.php");
break;
# Приклеить тему
case 'fix':
if ($status<2) {$sysmsg=$access_denied;include($rootpath."messages.php");}
# Статус темы
$q=mysql(DBName,"SELECT `fixed` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic AND `l3` = 0 LIMIT 0, 1");
$f=mysql_fetch_array($q);
$topic_fixed=$f['fixed'];
if ($topic_fixed==1) {$sysmsg='<b>Тема уже приклеена!</b><br/>';include($rootpath."messages.php");}
$sysmsg='<b>Тема приклеена.</b><br/>';
@mysql(DBName,"UPDATE `$table` SET `fixed` = '1', `time` = '".time()."' WHERE `l1` = '$razdel' AND `l2` = '$topic' AND `l3` = '0' LIMIT 1");
include($rootpath."messages.php");
break;
# Освободить тему
case 'unfix':
if ($status<2) {$sysmsg=$access_denied;include($rootpath."messages.php");}
# Статус темы
$q=mysql(DBName,"SELECT `fixed` FROM `$table` WHERE `l1` = $razdel AND `l2` = $topic AND `l3` = 0 LIMIT 0, 1");
$f=mysql_fetch_array($q);
$topic_fixed=$f['fixed'];
if ($topic_fixed==0) {$sysmsg='<b>Тема не приклеена!</b><br/>';include($rootpath."messages.php");}
$sysmsg='<b>Тема освобождена.</b><br/>';
@mysql(DBName,"UPDATE `$table` SET `fixed` = '0', `time` = '".time()."' WHERE `l1` = '$razdel' AND `l2` = '$topic' AND `l3` = '0' LIMIT 1");
include($rootpath."messages.php");
break;
case 'del':
$q=mysql(DBName,"SELECT `l3`, `login` FROM `$table` WHERE 1 AND `l1` = $razdel AND `l2` = $topic");
$s=mysql_num_rows($q)+0;
if ($s<1)
{$sysmsg='<b>Тема не существует (уже удалена).</b><br/>';}
else
{
$q=mysql(DBName,"SELECT `l3`, `login` FROM `$table` WHERE 1 AND `l1` = $razdel AND `l2` = $topic AND `l3` = 0");
$f=mysql_fetch_array($q);
$flogin=$f['login'];
if (($status<2)&&($flogin!=$login)) {$sysmsg='<b>Нельзя удалить чужую тему.</b><br/>';include($rootpath."messages.php");}
if (($status<2)&&($flogin==$login)&&(($s>2))) {$sysmsg='<b>Для удаления в теме должно быть не более одного сообщения.</b><br/>';include($rootpath."messages.php");}
$f=mysql_fetch_array($q);
@mysql(DBName,"DELETE FROM `$table` WHERE `l1` = '$razdel' AND `l2` = '$topic'");
$sysmsg='<b>Тема удалена.</b><br/>';
}
$message=0;
$topic=0;
include($rootpath."topics.php");
break;
}
?>