Файл: chat/index.php
Строк: 113
<?php
require '../system/sid.php';
require '../system/config.php';
include '../system/user.php';
include '../system/head.php';
include '../system/navigator.php';
$open = mysql_fetch_array(mysql_query("SELECT `open_chat` FROM `setting` WHERE `ids` = '1'"));
if ($open[0] == 2)
{
err('Чат закрыт Администратором!');
include '../system/foot.php';
exit();
}
$_SESSION['NameRoom'] = 'room';
whorm(0, 'chat'); // Запись онлайна
// заголовок (назв комнаты)
echo $div_title . 'Мини-чат' . $div_end;
$topic = ($user['level'] >= 3 && $user['level'] <= 5) ? ' | <a href="?clean">Очистить</a>' : '';
$ASnum = mysql_num_rows(mysql_query("SELECT * FROM `users` WHERE `room` = 'chat' AND `onl` + '300' > '" . time() . "' ORDER BY `onl` DESC"));
echo $div_menu . '<a href="say.php?">Сказать</a> | <a href="whoroom.php?">Кто здесь(' . $ASnum . ')</a>' . $topic . $div_end;
if (isset($_GET['f'])) {
$f = my_int($_GET['f']);
if ($f < 1 && $f > 3) {
header('Location: ?');
} else {
mysql_query("UPDATE `users` SET `chat_filtr` = '$f' WHERE `id` = '$user[id]' LIMIT 1");
header('Location: ?');
}
}
// выключение/выключение фильтра
if (isset($_GET['filtr'])) {
if ($user['chat_filtr'] == 1) {
echo $div_tworazdel . 'Фильтр: <b>Выкл</b> |
<a href="?f=2">Мои [!п]</a> |
<a href="?f=3">Мои все</a>' . $div_end;
} elseif ($user['chat_filtr'] == 2) {
echo $div_tworazdel . 'Фильтр: <a href="?f=1">Выкл</a> |
<b>Мои [!п]</b> |
<a href="?f=3">Мои все</a>' . $div_end;
} elseif ($user['chat_filtr'] == 3) {
echo $div_tworazdel . 'Фильтр: <a href="?f=1">Выкл</a> |
<a href="?f=2">Мои [!п]</a> |
<b>Мои все</b>' . $div_end;
}
} else {
echo '<a href="?filtr">[Фильтр]</a>';
}
echo '<FORM method="POST" action="?">
<textarea name="msg" cols="50" rows="5" style="width: 99%;"></textarea>
<br/>';
if ($user['level'] == 3 || $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="Сказать"/>
</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']) && $user['level'] >= 3 && $user['level'] <= 5)
{
mysql_query("DELETE FROM `message`");
header('Location: ?');
}
// запись поста в бд
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())
{
$mess = mysql_result(mysql_query("SELECT COUNT(id) FROM `message` WHERE
`who` = '$user[id]'
AND
`time` < '" . $_SESSION['flood_time'] . "'"), 0);
if ($mess > 0) {
header('Location: ?flood');
die();
}
}
$_SESSION['flood_time'] = time() + 10; // Время интервала антифлуда
// Повтор сообщений
$NumDouble = mysql_result(mysql_query("SELECT COUNT(id) FROM `message` WHERE
`who` = '$user[id]'
AND
`msg` = '$msg'
AND
`time` > '" . (time() - 60) . "' LIMIT 1"), 0);
if ($NumDouble > 0)
{
header('Location: ?empty');
die();
}
// если пишут флудеру
if (isset($_POST['komu']) && my_int($_POST['komu']) == 0) {
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',
`komu` = '$user[id]'");
header('Location: ?');
}
// Написание сообщения
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 && filesize($_SERVER['DOCUMENT_ROOT'] . '/domains.dat') > 0) {
$ex = explode(',', file_get_contents('../domains.dat'));
foreach($ex as $value) {
if ($user['level'] != 3 && $user['level'] != 4 && $user['level'] != 5) {
$msg = preg_replace("/(w)(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) ? mat($msg) : $msg;
if ($user['level'] == 3 || $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' && $user['id'] != $komu && user_inf($komu, 'sistem_mes') == 1) {
$q = 'Вам оставили сообщение в <a href="/chat/?">чате</a>.';
mysql_query("INSERT INTO `letters` (`id`,`who`,`idwho`,`message`,`data`,`read`,`mod`)
VALUES (0,'0','$komu','$q','" . time() . "','0','i')");
header('Location: ?');
}
mysql_query("INSERT INTO `message` SET
`id` = '$ids',
`time` = '" . time() . "',
`msg` = '$msg',
`who` = '$user[id]',
`user` = '$user[user]',
`private` = '" . my_int($_POST['private']) . "',
`komu` = '" . my_int($_POST['komu']) . "'");
header('Location: ?');
}
}
// сообщение системы о входе в комнату
$WhoSex = ($user['sex'] == 1) ? 'вошла' : 'вошел';
$Intrvl = mysql_query("SELECT COUNT(*) FROM `message` WHERE
`user` = 'Система'
AND
`msg` = 'В комнату $WhoSex <a href="/$user[id]">$user[user]</a>'
AND
`time` > '" . (time() - 200) . "'");
if (mysql_result($Intrvl, 0) == 0 && $_SESSION['NameRoom'] != 'room') {
$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() . "'");
}
// периодический пост флудера
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() . "'");
mysql_query("ANALYZE TABLE `message`");
}
$_SESSION['pizdun_time'] = time() + 300;
// удаление поста
if (isset($_GET['delete'])) {
if ($user['level'] < 2) {
header('Location: ?');
die();
}
$x = my_int($_GET['x']);
$em = mysql_query("SELECT id 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: ?okdel');
} else {
header('Location: ?errdel');
}
}
// сообщения системы
$sis = ($user['sistem_mes'] != 1) ? "`user` != 'Система' AND" : '';
// фильтр сообщений
if ($user['chat_filtr'] == 1) $FiltrMes = '';
if ($user['chat_filtr'] == 2) $FiltrMes = "`private` = '1' AND `komu` = '$user[id]' OR `private` = '1' AND `who` = '$user[id]' AND `komu` = '0' AND";
if ($user['chat_filtr'] == 3) $FiltrMes = "`komu` = '$user[id]' AND `komu` != '0' OR `who` = '$user[id]' AND `komu` = '0' AND";
$count = mysql_result(mysql_query("SELECT COUNT(*) FROM `message` WHERE $FiltrMes $sis `who` NOT IN (SELECT `ig_id` FROM `ignor` WHERE `user_id` = '$user[id]')"), 0);
if ($count != false) {
$n = new navigator($count, $user['room_post'], '?');
$result = mysql_query("SELECT * FROM `message` WHERE $FiltrMes $sis `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']);
echo ($user['refresh'] != 0 ? '<META HTTP-EQUIV="Refresh" CONTENT="'.$user['refresh'].'; URL=?">' : '');
// Распределение ников...
if ($sql['who'] == 0 && $sql['user'] == 'Терпила') {
$kto_id = '<a href="inside.php?nk=0"><b>Терпила</b></a>';
}
elseif ($sql['who'] == 0 && $sql['user'] == 'Система') {
$kto_id = '<b>Система</b>';
} else {
$kto_id = '<a href="inside.php?nk='.$sql['who'].'&'.mt_rand(1000, 9999).'"><b>' . cvetnik($sql['who']) . '</b></a>';
}
$delpost = ($user['level'] >= 2 && $user['level'] <= 5) ? '[<a href="?delete&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/>';
}
include '../system/foot.php';
?>