Просмотр файла admin/minichat.php

Размер файла: 10.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');

$act = (isset($_GET['act'])) ? check($_GET['act']) : 'index';
$start = (isset($_GET['start'])) ? abs(intval($_GET['start'])) : 0;
$id = (isset($_GET['id'])) ? abs(intval($_GET['id'])) : "";

if (is_admin()) {

	show_title('Управление мини-чатом');

	############################################################################################
	##                                    Главная страница                                    ##
	############################################################################################
	if ($act == 'index') {
		echo '<a href="#down"><img src="/images/img/downs.gif" alt="image" /></a> ';
		echo '<a href="minichat.php?rand=' . mt_rand(100, 990) . '">Обновить</a> / ';
		echo '<a href="/chat/index.php?start=' . $start . '">Обзор</a><br /><hr />';

		if (! file_exists(DATADIR . "/temp/chat.dat")){
			touch(DATADIR . "/temp/chat.dat");
		}

		$file = file(DATADIR . "/temp/chat.dat");
		$file = array_reverse($file);
		$total = count($file);

		if ($total > 0) {
			echo '<form action="minichat.php?act=del&amp;start=' . $start . '&amp;uid=' . $_SESSION['token'] . '" method="post">';

			if ($start < 0 || $start > $total) {
				$start = 0;
			}
			if ($total < $start + $config['chatpost']) {
				$end = $total;
			} else {
				$end = $start + $config['chatpost'];
			}
			for ($i = $start; $i < $end; $i++) {
				$data = explode("|", $file[$i]);

				$num = $total - $i - 1;

				$useronline = user_online($data[1]);
				$useravatars = user_avatars($data[1]);
				$anketa = '<a href="/pages/anketa.php?uz=' . $data[1] . '"> ' . nickname($data[1]) . '</a>';

				if ($data[1] == 'Вундер-киндер') {
					$useravatars = '<img src="/chat/img/mag.gif" alt="image" /> ';
					$useronline = '<img src="/images/img/on.gif" alt="image">';
					$anketa = 'Вундер-киндер';
				}
				if ($data[1] == 'Настюха') {
					$useravatars = '<img src="/chat/img/bot.gif" alt="image" /> ';
					$useronline = '<img src="/images/img/on.gif" alt="image">';
					$anketa = 'Настюха';
				}
				if ($data[1] == 'Весельчак') {
					$useravatars = '<img src="/chat/img/shut.gif" alt="image" /> ';
					$useronline = '<img src="/images/img/on.gif" alt="image">';
					$anketa = 'Весельчак';
				}

				echo '<div class="b">';

				echo $useravatars;

				echo '<b>' . $anketa . '</b> ' . user_title($data[1]) . ' ' . $useronline . ' <small> (' . date_fixed($data[3]) . ')</small><br />';
				echo '<input type="checkbox" name="del[]" value="' . $num . '" /> ';
				echo '<a href="minichat.php?act=edit&amp;id=' . $num . '&amp;start=' . $start . '">Редактировать</a>';

				echo '</div><div>' . bb_code($data[0]) . '<br />';
				echo '<span style="color:#cc00cc"><small>(' . $data[4] . ', ' . $data[5] . ')</small></span></div>';
			}

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

			page_strnavigation('minichat.php?', $config['chatpost'], $start, $total);

			echo '<p>Всего сообщений: <b>' . (int)$total . '</b></p>';

			if (is_admin(array(101))) {
				echo '<img src="/images/img/error.gif" alt="image" /> <a href="minichat.php?act=prodel">Очистить</a><br />';
			}
		} else {
			show_error('Сообщений еще нет!');
		}
	}
	# ###########################################################################################
	# #                                 Подтверждение очистки                                  ##
	# ###########################################################################################
	if ($act == "prodel") {
		echo '<br />Вы уверены что хотите удалить все сообщения в мини-чате?<br />';

		echo '<img src="/images/img/error.gif" alt="image" /> <b><a href="minichat.php?act=alldel&amp;uid=' . $_SESSION['token'] . '">Да уверен!</a></b><br /><br />';

		echo '<img src="/images/img/back.gif" alt="image" /> <a href="minichat.php">Вернуться</a><br />';
	}
	# ###########################################################################################
	# #                                   Очистка мини-чата                                    ##
	# ###########################################################################################
	if ($act == "alldel") {
		$uid = check($_GET['uid']);

		if (is_admin(array(101))) {
			if ($uid == $_SESSION['token']) {
				clear_files(DATADIR . "/temp/chat.dat");

				notice('Мини-чат успешно очищен!');
				redirect("minichat.php");

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

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

	############################################################################################
	##                                 Удаление сообщений                                     ##
	############################################################################################
	if ($act == "del") {
		$uid = check($_GET['uid']);
		$del = (isset($_REQUEST['del'])) ? intar($_REQUEST['del']) : "";

		if ($uid == $_SESSION['token']) {
			if ($del !== "") {
				delete_lines(DATADIR . "/temp/chat.dat", $del);

				notice('Выбранные сообщения успешно удалены!');
				redirect("minichat.php?start=$start");

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

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

	############################################################################################
	##                                    Редактирование                                      ##
	############################################################################################
	if ($act == "edit") {
		if ($id !== "") {
			$file = file(DATADIR . "/temp/chat.dat");
			if (isset($file[$id])) {
				$data = explode("|", $file[$id]);

				$data[0] = yes_br($data[0]);

				$config['header'] = 'Редактирование сообщения';

				echo '<div class="form"><form action="minichat.php?act=addedit&amp;id=' . $id . '&amp;start=' . $start . '&amp;uid=' . $_SESSION['token'] . '" method="post">';

				echo '<img src="/images/img/edit.gif" alt="image" /> <b>' . nickname($data[1]) . '</b> <small>(' . date_fixed($data[3]) . ')</small><br />';

				echo '<textarea id="markItUp" cols="25" rows="5" name="msg">' . $data[0] . '</textarea><br/>';
				echo '<input type="submit" value="Изменить" /></form></div><br />';
			} else {
				show_error('Ошибка! Сообщения для редактирования не существует!');
			}
		} else {
			show_error('Ошибка! Не выбрано сообщение для редактирования!');
		}

		echo '<img src="/images/img/back.gif" alt="image" /> <a href="minichat.php?start=' . $start . '">Вернуться</a><br />';
	}
	# ###########################################################################################
	# #                                 Изменение сообщения                                    ##
	# ###########################################################################################
	if ($act == "addedit") {
		$uid = check($_GET['uid']);
		$msg = check($_POST['msg']);

		if ($uid == $_SESSION['token']) {
			if ($id !== "") {
				if ($msg != "") {
					$file = file(DATADIR . "/temp/chat.dat");
					if (isset($file[$id])) {
						$data = explode("|", $file[$id]);

						$msg = no_br($msg);

						$text = no_br($msg . '|' . $data[1] . '|' . $data[2] . '|' . $data[3] . '|' . $data[4] . '|' . $data[5] . '|' . $data[6] . '|' . $data[7] . '|' . $data[8] . '|');

						replace_lines(DATADIR . "/temp/chat.dat", $id, $text);

						notice('Сообщение успешно отредактировано!');
						redirect("minichat.php?start=$start");

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

		echo '<img src="/images/img/back.gif" alt="image" /> <a href="minichat.php?act=edit&amp;id=' . $id . '&amp;start=' . $start . '">Вернуться</a><br />';
	}
	// -------------------------------- КОНЦОВКА ----------------------------------//
	echo '<img src="/images/img/panel.gif" alt="image" /> <a href="index.php">В админку</a><br />';
	echo '<img src="/images/img/homepage.gif" alt="image" /> <a href="/index.php">На главную</a><br />';

} else {
	redirect("/index.php");
}

include_once ("../themes/footer.php");

?>