Файл: chat/room.php
Строк: 252
<?php
require '../sid.php';
require '../config.php';
$link = connect_db();
list($user, $id, $ps) = check_login($link);
include '../head.php';
include '../navigator.php';
$rm = my_int($_GET['rm']); // фильтр $rm
$open = mysql_fetch_array(mysql_query("SELECT `open_chat` FROM `setting` WHERE `ids` = '1'"));
if ($open[0] == 2) {
err('Чат закрыт Администратором!');
include '../foot.php';
exit();
}
$empty = mysql_query("SELECT * FROM `rooms` WHERE `id` = '$rm' LIMIT 1");
// проверка на несуществующую комнату
if (mysql_num_rows($empty) == FALSE) {
header('Location: ../index.php?' . $ref);
die();
} else {
$inf = mysql_fetch_assoc($empty);
}
$_SESSION['NameRoom'] = $user['room'];
whorm($rm, 'room' . $rm); // Запись онлайна
// заголовок (назв комнаты)
echo (empty($inf['top'])) ? $div_title . $inf['name'] . $div_end : $div_title . $inf['top'] . $div_end;
$topic = ($user['level'] == 2 || $user['level'] == 4 || $user['level'] == 5) ? ' | <a href="topic.php?rm='.$rm.'">Топ</a> | <a href="room.php?clean&rm='.$rm.'">Очистить</a>' : '';
if ($inf['umnik'] == 1) $top10 = ' | <a href="top_umnik.php?rm='.$rm.'">ТОП-10 умники</a>';
$ASnum = mysql_num_rows(mysql_query("SELECT * FROM `users` WHERE `room` = 'room$rm' AND `onl` + '200' > '" . time() . "' ORDER BY `onl` DESC"));
echo $div_left . $div_menu . '
<a href="index.php?'.$ref.'">Комнаты</a> | <b>' . $inf['name'] . '</b> | <a href="say.php?rm='.$rm.'">Сказать</a> | <a href="whoroom.php?rm='.$rm.'">Кто здесь(' . $ASnum . ')</a>' . $topic . $top10 . '
' . $div_end;
if (isset($_GET['f'])) {
$f = my_int($_GET['f']);
if ($f < 1 || $f > 3) {
header('Location: room.php?rm='.$rm.'&' . $ref);
} else {
mysql_query("UPDATE `users` SET `chat_filtr` = '$f' WHERE `id` = '$user[id]' LIMIT 1");
header('Location: room.php?rm='.$rm.'&' . $ref);
}
}
// БАР
if ($inf['barmen'] == 1) echo $div_aut . 'Для просмотра меню бара наберите "!меню"' . $div_end;
// Бк
if ($inf['bk'] == 1) echo $div_aut . 'Для просмотра ударов наберите "!удары"' . $div_end;
// Тренировочная
if ($inf['bk'] == 2) echo $div_aut . 'Для выбора тренажера наберите "!тренажер"' . $div_end;
/*
* УМНИК
*/
if ($inf['umnik'] == 1) {
include 'umnik1.php';
$umn = mysql_query("SELECT * FROM `message` WHERE `who` = '0' AND `user` = 'Умник' ORDER BY `time` DESC LIMIT 1");
echo $div_left;
$InStr = mysql_fetch_assoc(mysql_query("SELECT * FROM `vopros` WHERE `ids` = '1' LIMIT 1"));
while($umnig = mysql_fetch_assoc($umn)) {
// задаем вопрос
if ($InStr['number'] == 0) {
echo $div_tworazdel . '<b>' . $umnig['user'] . ':</b> ' . $umnig['msg'] . ' (' . ($umnig['time'] - time() + 90) . ' сек)' . $div_end;
}
// первая подсказка
elseif ($InStr['number'] == 1) {
echo $div_tworazdel . '<b>' . $umnig['user'] . ':</b> ' . $InStr['question'] . $div_end .
$div_razdel . $umnig['msg'] . ' (' . ($umnig['time'] - time() + 75) . ' сек)' . $div_end;
}
// вторая подсказка
elseif ($InStr['number'] == 2) {
echo $div_tworazdel . '<b>' . $umnig['user'] . ':</b> ' . $InStr['question'] . $div_end .
$div_razdel . $umnig['msg'] . ' (' . ($umnig['time'] - time() + 75) . ' сек)' . $div_end;
}
// остальные сообщения
else
{
echo $div_razdel . '<b>' . $umnig['user'] . ':</b> ' . $umnig['msg'] . $div_end;
}
}
echo $div_end;
}
/*
* АНАГРАММА
*/
if ($inf['anagram'] == 1) {
include 'anagram1.php';
$ang = mysql_query("SELECT * FROM `message` WHERE `who` = '0' AND `user` = 'Анаграмма' ORDER BY `time` DESC LIMIT 1");
echo $div_left;
$InStr = mysql_fetch_assoc(mysql_query("SELECT * FROM `vopros` WHERE `ids` = '2' LIMIT 1"));
while($angaramm = mysql_fetch_assoc($ang)) {
// задаем вопрос
if ($InStr['number'] == 0) {
echo $div_razdel . '<b>' . $angaramm['user'] . ':</b> ' . $angaramm['msg'] . ' (' . ($angaramm['time'] - time() + 90) . ' сек)' . $div_end;
}
// первая подсказка
elseif ($InStr['number'] == 1) {
echo '<b>' . $angaramm['user'] . ':</b> ' . $InStr['question'] . '<br/>';
echo $div_razdel . $angaramm['msg'] . ' (' . ($angaramm['time'] - time() + 75) . ' сек)' . $div_end;
}
// вторая подсказка
elseif ($InStr['number'] == 2) {
echo '<b>' . $angaramm['user'] . ':</b> ' . $InStr['question'] . '<br/>';
echo $div_razdel . $angaramm['msg'] . ' (' . ($angaramm['time'] - time() + 75) . ' сек)' . $div_end;
}
// остальные сообщения
else
{
echo $div_razdel . '<b>' . $angaramm['user'] . ':</b> ' . $angaramm['msg'] . $div_end;
}
}
echo $div_end;
}
// выключение/выключение фильтра
if (isset($_GET['filtr'])) {
if ($user['chat_filtr'] == 1) {
echo $div_tworazdel . 'Фильтр: <b>Выкл</b> |
<a href="room.php?rm='.$rm.'&f=2">Мои [!п]</a> |
<a href="room.php?rm='.$rm.'&f=3">Мои все</a>' . $div_end;
} elseif ($user['chat_filtr'] == 2) {
echo $div_tworazdel . 'Фильтр: <a href="room.php?rm='.$rm.'&f=1">Выкл</a> |
<b>Мои [!п]</b> |
<a href="room.php?rm='.$rm.'&f=3">Мои все</a>' . $div_end;
} elseif ($user['chat_filtr'] == 3) {
echo $div_tworazdel . 'Фильтр: <a href="room.php?rm='.$rm.'&f=1">Выкл</a> |
<a href="room.php?rm='.$rm.'&f=2">Мои [!п]</a> |
<b>Мои все</b>' . $div_end;
}
} else {
echo '<a href="room.php?rm='.$rm.'&filtr">[Фильтр]</a>';
}
echo '<FORM method="POST" action="room.php?rm='.$rm.'">
<fieldset>
<textarea name="msg" cols="50" rows="5" style="width: 99%;"></textarea>
<br/>';
if ($user['level'] == 2 || $user['level'] == 4 || $user['level'] == 5) {
echo '<input type="checkbox" name="b" value="1"/> <b>Жирный</b>
<br/>
<input type="checkbox" name="u" value="1"/> <u>Подчеркнутый</u>
<br/>
<input type="checkbox" name="r" value="1"/> <span style="color:#FF0000;">Красный</span>
<br/>';
}
echo '<input type="submit" name="send" value="Сказать"/>
</fieldset>
</FORM>' . $block;
// действия
echo (isset($_GET['flood'])) ? err('Антифлуд 10сек.') : '';
echo (isset($_GET['empty'])) ? err('Ваши сообщения повторяются!') : '';
echo (isset($_GET['okdel'])) ? msg('Пост удален!') : '';
echo (isset($_GET['errdel'])) ? err('Пост не удален!') : '';
echo (isset($_GET['clroom'])) ? msg('Комната очищена!') : '';
// очистка комнаты
if (isset($_GET['clean'])) {
mysql_query("DELETE FROM `message` WHERE `room` = '$rm'");
header('Location: room.php?rm=' . $rm);
}
// запись поста в бд
if (isset($_POST['send'])) {
$msg = trim(mysql_real_escape_string(check($_POST['msg'])));
// Антифлуд
if (!isset($_SESSION['flood_time'])) $_SESSION['flood_time'] = 0;
if ($_SESSION['flood_time'] > time() && $inf['bk'] != 1 && $inf['bk'] != 2 && $inf['barmen'] != 2)
{
$mess = mysql_result(mysql_query("SELECT COUNT(*) FROM `message` WHERE
`who` = '$user[id]'
AND
`time` < '" . $_SESSION['flood_time'] . "'"), 0);
if ($mess > 0) {
header('Location: room.php?rm='.$rm.'&flood');
die();
}
}
$_SESSION['flood_time'] = time() + 10; // Время интервала антифлуда
// редирект в меню бара
if ($inf['barmen'] == 1 && $msg == '!меню') {
header('Location: list_drink.php?rm='. $rm);
die();
}
// редирект в меню оружий
if ($inf['bk'] == 1 && $msg == '!удары') {
header('Location: fight.php?rm='. $rm);
die();
}
// редирект в тренажерку
if ($inf['bk'] == 2 && $msg == '!тренажер') {
header('Location: trainers.php?rm='. $rm);
die();
}
if ($inf['barmen'] == 1) include 'bot_bartender.php'; // инклуд бармена
if ($inf['umnik'] == 1) include 'umnik2.php'; // инклуд умника
if ($inf['anagram'] == 1) include 'anagram2.php'; // инклуд анаграммы
if ($inf['bk'] == 1) include '../bk/fight.php'; // инклуд бк
if ($inf['bk'] == 2) include_once '../bk/trainers.php'; // инклуд тренажерки
// Повтор сообщений
$NumDouble = mysql_result(mysql_query("SELECT COUNT(*) FROM `message` WHERE
`who` = '$user[id]'
AND
`msg` = '$msg'
AND
`room` = '$rm'
AND
`time` > '" . (time() - 60) . "' LIMIT 1"), 0);
if ($NumDouble > 0 && $inf['bk'] != 1 && $inf['bk'] != 2 && $inf['barmen'] != 2)
{
header('Location: room.php?rm='.$rm.'&empty');
die();
}
// если пишут флудеру
if (isset($_POST['komu']) && my_int($_POST['komu']) == 0 && $inf['pizdun'] == 1) {
include 'pizdun.php';
$msg_1 = bot($msg);
$msg_2 = '<u>' . $user['user'] . '</u>, ' . $msg_1;
$ids = mt_rand(100000, 999999);
$Priv = (my_int($_POST['private']) == 1) ? "`private` = '1'," : "`private` = '0',";
mysql_query("INSERT INTO `message` SET
`id` = '$ids',
`time` = '" . (time() + 1) . "',
`who` = '0',
`user` = 'Терпила',
$Priv
`msg` = '$msg_2',
`room` = '$rm',
`komu` = '$user[id]'");
header('Location: room.php?rm=' . $rm);
}
// Написание сообщения
if (!empty($msg)) {
$ids = mt_rand(100000, 999999);
// Антиреклама
$_ant = mysql_fetch_assoc(mysql_query("SELECT `on_rekl`, `text_rekl` FROM `setting` WHERE `ids` = '1'"));
if ($_ant['on_rekl'] == 1) {
$ex = explode(',', file_get_contents('../domains.dat'));
foreach($ex as $value) {
if ($user['level'] != 2 && $user['level'] != 4 && $user['level'] != 5) {
$msg = preg_replace("/(.*)(s|,|.|*|_|-|+)+$value/si", $_ant['text_rekl'], $msg);
}
}
}
// транслит
if ($user['translit'] == 1) {
$msg = trun_to_rus($msg);
}
// антимат
$ant = mysql_fetch_array(mysql_query("SELECT `antimat` FROM `setting` WHERE `ids` = '1'"));
$msg = ($ant[0] == 1 && $inf['type'] != 1) ? mat($msg) : $msg;
if ($user['level'] == 2 || $user['level'] == 4 || $user['level'] == 5) {
$b = my_int($_POST['b']);
$u = my_int($_POST['u']);
$r = my_int($_POST['r']);
if ($b == 1) $msg = '<b>' . $msg . '</b>';
if ($u == 1) $msg = '<u>' . $msg . '</u>';
if ($r == 1) $msg = '<span style="color:#FF0000;">' . $msg . '</span>';
}
// оповещание об оставленном сообщении
$komu = my_int($_POST['komu']);
if (user_inf($komu, 'room') != 'room' . $rm && $user['id'] != $komu && user_inf($komu, 'sistem_mes') == 1) {
$q = 'Вам оставили сообщение в комнате <a href="/chat/room.php?rm='.$rm.'">'.$inf['name'].'</a>.';
mysql_query("INSERT INTO `letters` (`id`,`who`,`idwho`,`message`,`data`,`read`,`mod`)
VALUES (0,'0','$komu','$q','" . time() . "','0','i')");
header('Location: room.php?rm='.$rm.'&' . $ref);
}
mysql_query("INSERT INTO `message` SET
`id` = '$ids',
`time` = '" . time() . "',
`msg` = '$msg',
`who` = '$user[id]',
`user` = '$user[user]',
`room` = '$rm',
`private` = '" . my_int($_POST['private']) . "',
`komu` = '" . my_int($_POST['komu']) . "'");
header('Location: room.php?rm=' . $rm);
}
}
// сообщение системы о входе в комнату
$WhoSex = ($user['sex'] == 1) ? 'вошла' : 'вошел';
$Intrvl = mysql_query("SELECT COUNT(*) FROM `message` WHERE
`room` = '$rm'
AND
`user` = 'Система'
AND
`msg` = 'В комнату $WhoSex <a href="/$user[id]">$user[user]</a>'
AND
`time` > '" . (time() - 200) . "'");
if (mysql_result($Intrvl, 0) == 0 && $_SESSION['NameRoom'] != 'room' . $rm) {
$mes = 'В комнату ' . $WhoSex . ' <a href="/'.$user['id'].'">' . $user['user'] . '</a>';
$ids = mt_rand(100000, 999999);
mysql_query("INSERT INTO `message` SET
`id` = '$ids',
`who` = '0',
`user` = 'Система',
`msg` = '$mes',
`time` = '" . time() . "',
`room` = '$rm'");
}
// приодический пост бота
if ($inf['pizdun'] == 1) {
if (!isset($_SESSION['pizdun_time'])) $_SESSION['pizdun_time'] = 0;
if ($_SESSION['pizdun_time'] < time()) {
$b = mysql_fetch_assoc(mysql_query("SELECT * FROM `dialog` WHERE `type` = 'other' ORDER BY RAND() DESC LIMIT 1"));
$mes = $b['message'];
$ids = mt_rand(100000, 999999);
mysql_query("INSERT INTO `message` SET
`id` = '$ids',
`who` = '0',
`user` = 'Терпила',
`msg` = '$mes',
`time` = '" . time() . "',
`room` = '$rm'");
mysql_query("ANALYZE TABLE `message`");
}
$_SESSION['pizdun_time'] = time() + 120;
}
// удаление поста
if (isset($_GET['delete'])) {
if ($user['level'] != 2 && $user['level'] != 4 && $user['level'] != 5) {
header('Location: room.php?rm=' . $rm);
die();
}
$x = my_int($_GET['x']);
$em = mysql_query("SELECT * FROM `message` WHERE `id` = '$x' LIMIT 1");
if (mysql_num_rows($em) != FALSE) {
mysql_query("DELETE FROM `message` WHERE `id` = '$x' LIMIT 1");
header('Location: room.php?rm='.$rm.'&okdel');
} else {
header('Location: room.php?rm='.$rm.'&errdel');
}
}
// сообщения системы
$sis = ($user['sistem_mes'] != 1) ? "AND `user` != 'Система'" : "";
// фильтр сообщений
if ($user['chat_filtr'] == 1) $FiltrMes = "";
if ($user['chat_filtr'] == 2) $FiltrMes = "AND `private` = '1' AND `komu` = '$user[id]' OR `private` = '1' AND `who` = '$user[id]' AND `komu` = '0' AND `room` = '$rm'";
if ($user['chat_filtr'] == 3) $FiltrMes = "AND `komu` = '$user[id]' AND `komu` != '0' OR `who` = '$user[id]' AND `komu` = '0' AND `room` = '$rm'";
$count = mysql_result(mysql_query("SELECT COUNT(*) FROM `message` WHERE `room` = '$rm' $sis AND `user` != 'Умник' AND `user` != 'Анаграмма' $FiltrMes AND `who` NOT IN (SELECT `ig_id` FROM `ignor` WHERE `user_id` = '$user[id]')"), 0);
if ($count != false) {
$n = new navigator($count, $user['room_post'], '?rm='.$rm.'&');
$result = mysql_query("SELECT * FROM `message` WHERE `room` = '$rm' AND `user` != 'Анаграмма' AND `user` != 'Умник' $sis $FiltrMes AND `who` NOT IN (SELECT `ig_id` FROM `ignor` WHERE `user_id` = '$user[id]') ORDER BY `time` DESC {$n->limit}");
$i = 0;
while($sql = mysql_fetch_assoc($result)) {
// Если в сообщении мой ник, выделяем его
$sql['msg'] = str_replace($user['user'], '<u>' . $user['user'] . '</u>', $sql['msg']);
/*$sql['msg'] = (stripos($sql['msg'], $user['user']) !== FALSE)
? $sql['msg'] = str_replace($user['user'], '<u>' . $user['user'] . '</u>', $sql['msg'])
: $sql['msg'] = $sql['msg'];*/
// Обновление
$refresh = $user['refresh'];
$refresh = $refresh / 2;
if ($refresh !== 0) echo '<META HTTP-EQUIV="Refresh" CONTENT="' . $refresh . '; URL=room.php?rm='.$rm.'">';
// Распределение ников...
if ($sql['who'] == 0 && $sql['user'] == 'Терпила') {
$kto_id = '<a href="inside.php?nk=0&rm='.$sql['room'].'"><b>Терпила</b></a>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Система') {
$kto_id = '<b>Система</b>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Бармен') {
$kto_id = '<b>Бармен</b>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Умник') {
$kto_id = '<b>Умник</b>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Анаграмма') {
$kto_id = '<b>Анаграмма</b>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Рефери') {
$kto_id = '<b>Рефери</b>';
} else {
$kto_id = '<a href="inside.php?nk='.$sql['who'].'&rm='.$sql['room'].'&'.rand(1000, 9999).'"><b>'.cvetnik($sql['who']).'</b></a>';
}
$delpost = ($user['level'] == 2 || $user['level'] == 4 || $user['level'] == 5) ? '[<a href="room.php?delete&rm='.$rm.'&x='.$sql['id'].'">x</a>] ' : '';
// Если пишут не в приват
if ($sql['private'] == 0)
{
echo ($i ++ % 2) ? $div_tworazdel : $div_razdel;
echo $delpost . $kto_id . ' (' . date('H:i', $sql['time']) . ') > ' . smiles($sql['msg']) . $div_end;
// Если пишут в приват (+ видно Администраторам)
} elseif ($user['level'] == 5 || $sql['private'] == 1 && $sql['komu'] == $user['id'] || $sql['private'] == 1 && $sql['who'] == $user['id']) {
echo ($i ++ % 2) ? $div_tworazdel : $div_razdel;
echo $delpost . $kto_id . ' (' . date('H:i', $sql['time']) . ') <b>[!п]</b>> ' . smiles($sql['msg']) . $div_end;
}
}
echo $n->navi();
} else {
echo 'В этой комнате никто не писал.<br/>';
}
echo $div_end;
include '../foot.php';
?>