View file mpanel/spam.php

File size: 21.38Kb
<?php
#-----------------------------------------------------#
#          ********* ROTORCMS *********               #
#              Made by  :  VANTUZ                     #
#               E-mail  :  [email protected]         #
#                 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/header.php');

$config['spamlist'] = 10;

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

if (is_admin(array(101, 102, 103))) {
	show_title('site.png', 'Список жалоб');
	$config['newtitle'] = 'Список жалоб';

	switch ($act):
	############################################################################################
	##                                         Форум                                          ##
	############################################################################################
		case 'forum':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalguest = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalpriv = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalwall = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalload = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));
			$totalblog = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));

			echo '<b>Форум</b> ('.$total.') / <a href="spam.php?act=guest&amp;'.SID.'">Гостевая ('.$totalguest.')</a> / <a href="spam.php?act=privat&amp;'.SID.'">Приват ('.$totalpriv.')</a> / <a href="spam.php?act=wall&amp;'.SID.'">Стена</a> ('.$totalwall.') / <a href="spam.php?act=load&amp;'.SID.'">Загрузки</a> ('.$totalload.') / <a href="spam.php?act=blog&amp;'.SID.'">Блоги</a> ('.$totalblog.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(1));

				echo '<form action="spam.php?act=del&amp;ref=forum&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo '<a href="'.$data['spam_link'].'">Перейти к сообщению</a><br />';
					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=forum&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                         Гостевая                                       ##
		############################################################################################
		case 'guest':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalforum = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalpriv = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalwall = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalload = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));
			$totalblog = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));

			echo '<a href="spam.php?act=forum&amp;'.SID.'">Форум ('.$totalforum.')</a> / <b>Гостевая</b> ('.$total.') / <a href="spam.php?act=privat&amp;'.SID.'">Приват ('.$totalpriv.')</a> / <a href="spam.php?act=wall&amp;'.SID.'">Стена</a> ('.$totalwall.') / <a href="spam.php?act=load&amp;'.SID.'">Загрузки</a> ('.$totalload.') / <a href="spam.php?act=blog&amp;'.SID.'">Блоги</a> ('.$totalblog.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(2));

				echo '<form action="spam.php?act=del&amp;ref=guest&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo '<a href="'.$data['spam_link'].'">Перейти к сообщению</a><br />';
					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=guest&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                           Приват                                       ##
		############################################################################################
		case 'privat':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalforum = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalguest = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalwall = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalload = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));
			$totalblog = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));

			echo '<a href="spam.php?act=forum&amp;'.SID.'">Форум ('.$totalforum.')</a> / <a href="spam.php?act=guest&amp;'.SID.'">Гостевая</a> ('.$totalguest.') / <b>Приват ('.$total.')</b> / <a href="spam.php?act=wall&amp;'.SID.'">Стена</a> ('.$totalwall.') / <a href="spam.php?act=load&amp;'.SID.'">Загрузки</a> ('.$totalload.') / <a href="spam.php?act=blog&amp;'.SID.'">Блоги</a> ('.$totalblog.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(3));

				echo '<form action="spam.php?act=del&amp;ref=privat&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=privat&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                    Стена сообщений                                     ##
		############################################################################################
		case 'wall':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalforum = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalguest = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalpriv = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalload = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));
			$totalblog = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));

			echo '<a href="spam.php?act=forum&amp;'.SID.'">Форум ('.$totalforum.')</a> / <a href="spam.php?act=guest&amp;'.SID.'">Гостевая</a> ('.$totalguest.') / <a href="spam.php?act=privat&amp;'.SID.'">Приват</a> ('.$totalpriv.') / <b>Стена</b> ('.$total.') / <a href="spam.php?act=load&amp;'.SID.'">Загрузки</a> ('.$totalload.') / <a href="spam.php?act=blog&amp;'.SID.'">Блоги</a> ('.$totalblog.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(4));

				echo '<form action="spam.php?act=del&amp;ref=wall&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo '<a href="'.$data['spam_link'].'">Перейти к сообщению</a><br />';
					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=wall&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                Комментарии в Загрузках                                 ##
		############################################################################################
		case 'load':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));
			$totalforum = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalguest = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalpriv = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalwall = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalblog = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));

			echo '<a href="spam.php?act=forum&amp;'.SID.'">Форум ('.$totalforum.')</a> / <a href="spam.php?act=guest&amp;'.SID.'">Гостевая</a> ('.$totalguest.') / <a href="spam.php?act=privat&amp;'.SID.'">Приват</a> ('.$totalpriv.') / <a href="spam.php?act=wall&amp;'.SID.'">Стена</a> ('.$totalwall.') / <b>Загрузки</b> ('.$total.') / <a href="spam.php?act=blog&amp;'.SID.'">Блоги</a> ('.$totalblog.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(5));

				echo '<form action="spam.php?act=del&amp;ref=load&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo '<a href="'.$data['spam_link'].'">Перейти к сообщению</a><br />';
					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=load&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                 Комментарии в блогах                                   ##
		############################################################################################
		case 'blog':

			$total = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(6));
			$totalforum = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(1));
			$totalguest = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(2));
			$totalpriv = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(3));
			$totalwall = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(4));
			$totalload = DB::run() -> querySingle("SELECT count(*) FROM `spam` WHERE `spam_key`=?;", array(5));

			echo '<a href="spam.php?act=forum&amp;'.SID.'">Форум ('.$totalforum.')</a> / <a href="spam.php?act=guest&amp;'.SID.'">Гостевая</a> ('.$totalguest.') / <a href="spam.php?act=privat&amp;'.SID.'">Приват</a> ('.$totalpriv.') / <a href="spam.php?act=wall&amp;'.SID.'">Стена</a> ('.$totalwall.') / <a href="spam.php?act=load&amp;'.SID.'">Загрузки</a> ('.$totalload.') / <b>Блоги</b> ('.$total.')<br /><br />';

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

				$queryban = DB::run() -> query("SELECT * FROM `spam` WHERE `spam_key`=? ORDER BY `spam_addtime` DESC LIMIT ".$start.", ".$config['spamlist'].";", array(6));

				echo '<form action="spam.php?act=del&amp;ref=blog&amp;start='.$start.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';
				echo '<div class="form">';
				echo '<input type="checkbox" id="all" onchange="var o=this.form.elements;for(var i=0;i&lt;o.length;i++)o[i].checked=this.checked" /> <b><label for="all">Отметить все</label></b>';
				echo '</div>';

				while ($data = $queryban -> fetch()) {
					echo '<div class="b">';
					echo '<input type="checkbox" name="del[]" value="'.$data['spam_id'].'" /> ';
					echo '<img src="../images/img/files.gif" alt="image" /> <b>'.profile($data['spam_login']).'</b> <small>('.date_fixed($data['spam_time'], "d.m.y / H:i:s").')</small></div>';
					echo '<div>Сообщение: '.bb_code($data['spam_text']).'<br />';

					echo '<a href="'.$data['spam_link'].'">Перейти к сообщению</a><br />';
					echo 'Жалоба: '.profile($data['spam_user']).' ('.date_fixed($data['spam_addtime']).')</div>';
				} 
				echo '<br /><input type="submit" value="Удалить выбранное" /></form>';

				page_strnavigation('spam.php?act=blog&amp;', $config['spamlist'], $start, $total);

				if (is_admin(array(101, 102))) {
					echo '<img src="../images/img/error.gif" alt="image" /> <a href="spam.php?act=clear&amp;uid='.$_SESSION['token'].'&amp;'.SID.'">Очистить</a><br />';
				} 
			} else {
				show_error('Жалоб еще нет!');
			} 
		break;

		############################################################################################
		##                                 Удаление сообщений                                     ##
		############################################################################################
		case "del":

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

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

					DB::run() -> query("DELETE FROM `spam` WHERE `spam_id` IN (".$del.");");

					$_SESSION['note'] = 'Выбранные жалобы успешно удалены!';
					redirect("spam.php?act=$ref&start=$start&".SID);

				} else {
					show_error('Ошибка! Отсутствуют выбранные жалобы!');
				} 
			} else {
				show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
			} 

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

		############################################################################################
		##                                     Очистка жалоб                                      ##
		############################################################################################
		case 'clear':

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

			if ($uid == $_SESSION['token']) {
				if (is_admin(array(101, 102))) {
					DB::run() -> query("TRUNCATE `spam`;");

					$_SESSION['note'] = 'Жалобы успешно очищены!';
					redirect("spam.php?".SID);

				} else {
					show_error('Ошибка! Очищать жалобы могут только админы!');
				} 
			} else {
				show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
			} 

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

	default:
		redirect("spam.php?".SID);
	endswitch;

	echo '<img src="../images/img/panel.gif" alt="image" /> <a href="index.php?'.SID.'">В админку</a><br />';

} else {
	redirect(BASEDIR.'index.php?'.SID);
} 

include_once ('../themes/footer.php');
?>