Файл: chat/index.php
Строк: 538
<?php
/**
* @package Chat for JohnCMS
* @link http://johncms.com
* @copyright Copyright (C) 2010-2017 k_2
* @license LICENSE.txt (see attached file)
* @version VERSION.txt (see attached file)
* @author http://johncms.com/profile/?user=6251
*/
define('_IN_JOHNCMS', 1);
require('../incfiles/core.php');
$lng_chat = core::load_lng('chat');
// Задаем настройки системы
$req = db::query("SELECT * FROM `chat_settings`");
$chat_settings = array();
while ($res = mysqli_fetch_row($req)) $chat_settings[$res[0]] = $res[1];
mysqli_free_result($req);
/*
-----------------------------------------------------------------
Ограничиваем доступ к Чату
-----------------------------------------------------------------
*/
$error = '';
if (!$chat_settings['access'] && $rights < 7)
$error = $lng_chat['chat_close'];
elseif ($chat_settings['access'] == 1 && !$user_id)
$error = $lng['access_guest_forbidden'];
if ($error) {
require('../incfiles/head.php');
echo functions::display_error($error);
require('../incfiles/end.php');
exit;
}
/*
-----------------------------------------------------------------
Функция статистики онлайн в чате
-----------------------------------------------------------------
*/
function wch($id = 0)
{
if ($id)
return db::result(db::query("SELECT COUNT(*) FROM `users` WHERE `lastdate` > '" . (time() - 300) . "' AND `place` = 'chat," . $id . "'"), 0);
else
return db::result(db::query("SELECT COUNT(*) FROM `users` WHERE `lastdate` > '" . (time() - 300) . "' AND `place` LIKE 'chat%'"), 0);
}
/*
-----------------------------------------------------------------
Функция кодирования сообщения
-----------------------------------------------------------------
*/
function str_code($str)
{
global $_SESSION;
$len = strlen($str);
$gamma = '';
$n = $len>100 ? 8 : 2;
while( strlen($gamma)<$len )
{
$gamma .= substr(pack('H*', sha1($_SESSION['key'].$gamma.$_SESSION['salt'])), 0, $n);
}
return $str^$gamma;
}
$id_k = isset($_REQUEST['id_k']) ? abs(intval($_REQUEST['id_k'])) : false;
/*
-----------------------------------------------------------------
Получаем пользовательские данные
-----------------------------------------------------------------
*/
$chat_us_d = array();
if ($user_id)
$chat_us = db::query("SELECT `ban_naz_time`, `ban_time`, `ban_text`, `postchat`, `otvetov`, `rights`, `balans`, `set_chat` FROM `chat_users` WHERE `id_u` = '" . $user_id . "' LIMIT 1");
if (mysqli_num_rows($chat_us)) {
$chat_us_d = mysqli_fetch_assoc($chat_us);
} else {
if ($user_id)
db::query("INSERT INTO `chat_users` SET `id_u` = '" . $user_id . "', `ban_time` = '0', `postchat` = '0', `otvetov` = '0', `rights` = '0', `balans` = '0'");
$chat_us_d = array(
'set_chat' => '',
'ban_time' => 0,
'ban_text' => '',
'postchat' => 0,
'otvetov' => 0,
'rights' => 0,
'balans' => 0
);
}
/*
-----------------------------------------------------------------
Настройки чата
-----------------------------------------------------------------
*/
$set_chat = array();
if (mysqli_num_rows($chat_us))
$set_chat = unserialize($chat_us_d['set_chat']);
// Настроки по-умолчанию
if (!isset($set_chat) || empty($set_chat))
$set_chat = array(
'refresh' => 20,
'chmes' => 10,
'carea' => 0,
'avatar' => 1,
'cvet' => '',
'cvet_n' => '',
'cvet_ns' => ''
);
$headmod = !empty ($id) ? 'chat,' . $id : 'chat';
/*
-----------------------------------------------------------------
Переключаем режимы работы
-----------------------------------------------------------------
*/
$array = array(
'password',
'faq',
'messages',
'delete',
'close',
'dell',
'filter',
'massdel',
'who',
'moders',
'post',
'my_set',
'ban',
'top',
'reset'
);
if ($act && ($key = array_search($act, $array)) !== false && file_exists('includes/' . $array[$key] . '.php')) {
$zag = array(
'faq' => $lng_chat['rules'],
'messages' => $lng_chat['say'],
'delete' => $lng_chat['remove_post'],
'dell' => $lng_chat['cleaning_room'],
'filter' => $lng_chat['filter_messages'],
'massdel' => $lng_chat['mass_removal'],
'who' => $lng_chat['stats_chat'],
'moders' => $lng_chat['chat_moderators'],
'post' => $lng_chat['separate_post'],
'my_set' => $lng_chat['settings'],
'ban' => $lng_chat['ban_panel'],
'top' => $lng_chat['top_chat']
);
if ($zag[$act])
$textl = $zag[$act];
$stat = array(
'faq' => 'chatfaq',
'who' => 'chatwho',
'moders' => 'chatmoders',
'my_set' => 'chatset',
'top' => 'chattop'
);
if ($stat[$act] && !$id)
$headmod = $stat[$act];
require('../incfiles/head.php');
// Выводим сообщение о Бане
if ($chat_us_d['ban_time'] > time() && $act != 'ban')
echo '<div class="alarm">' . $lng['ban'] . ' <a href="index.php?act=ban">' . $lng['in_detail'] . '</a></div>';
require('includes/' . $array[$key] . '.php');
require('../incfiles/end.php');
} else {
/*
-----------------------------------------------------------------
Определяем тип запроса (комната, или прихожая)
-----------------------------------------------------------------
*/
if ($id) {
// Отображаем комнату Чата
$room_true = db::query("SELECT `name`, `tip`, `bot`, `nev` FROM `chat_rooms` WHERE `id` = '" . $id . "' LIMIT 1");
$k_d = mysqli_fetch_assoc($room_true);
// Переадресация при несущ. комнаты
if (!mysqli_num_rows($room_true)) {
header("location: index.php");
exit;
}
$textl = $k_d['name'];
/*
-----------------------------------------------------------------
Очищаем комнаты от старых сообщений (если опция включена)
-----------------------------------------------------------------
*/
if ($chat_settings['time'] < time() - $chat_settings['auto_delete'] && $chat_settings['auto_delete']) {
$room = db::query("SELECT * FROM `chat_rooms`");
while ($room_d = mysqli_fetch_assoc($room)) {
if ($chat_settings['leave_post'])
$count_posts = db::result(db::query("SELECT COUNT(*) FROM `chat_room_" . $room_d['id'] . "`"), 0);
db::query("DELETE FROM `chat_room_" . $room_d['id'] . "` WHERE `time` < '" . (time() - $chat_settings['auto_delete']) . "'" . ($chat_settings['leave_post'] ? "ORDER BY `time` ASC LIMIT " . ($count_posts - $chat_settings['leave_post']) : "") . "");
db::query("OPTIMIZE TABLE `chat_room_" . $room_d['id'] . "`");
}
db::query("UPDATE `chat_settings` SET `val` = '" . time() . "' WHERE `key` = 'time' LIMIT 1");
}
/*
-----------------------------------------------------------------
Подключаем файл с ботами если это необходимо
-----------------------------------------------------------------
*/
if ($k_d['bot'] && $user_id && $k_d['tip'] != 'in' && $k_d['tip'] != 'an')
require('incfiles/bot.php');
/*
-----------------------------------------------------------------
Определяем тип комнаты (интим, инкогнито, беспредел, простая)
-----------------------------------------------------------------
*/
switch ($k_d['tip']) {
case 'in':
if (!$user_id) {
header("Location: index.php");
exit;
}
// Интим
if (empty ($_SESSION['key'])) {
require('../incfiles/head.php');
echo '<div class="phdr"><a href="index.php"><b>' . $lng_chat['chat'] . '</b></a> >> ' . $k_d['name'] . '</div>' .
'<div class="gmenu">' .
'<center><img src="img/in.gif" alt="" /> </center>' .
'<form action="index.php?act=password&id=' . $id . '" method="post">' . $lng_chat['password'] . '<br /><input type="text" name="password" size="10" maxlength="10"/><p><input type="submit" name="submit" value="' . $lng['continue'] . '"/></p></form></div>' .
'<div class="phdr"><a href="index.php"><b>' . $lng["back"] . '</b></a></div>';
require('../incfiles/end.php');
exit;
}
break;
case 'an':
// Инкогнито
if (empty ($_SESSION['key']) && $chat_settings['faq']) {
require('../incfiles/head.php');
echo '<div class="phdr"><a href="index.php"><b>' . $lng_chat['chat'] . '</b></a> >> ' . $k_d['name'] . '</div>' .
'<div class="menu">' .
'<center><img src="img/an.gif" alt="" /> </center>' .
$lng_chat['incognito_rules'] . '<br />' .
'<p><a href ="index.php?act=password&mod=rand&id=' . $id . '"><b>' . $lng['continue'] . '</b></a></p></div>' .
'<div class="phdr"><a href="index.php"><b>' . $lng["back"] . '</b></a></div>';
require('../incfiles/end.php');
exit;
} elseif (empty($_SESSION['key'])) {
header("Location: $home/chat/index.php?act=password&mod=rand&id=$id");
exit;
}
break;
case 'sr':
// Беспредел
if (empty ($_SESSION['key']) && $chat_settings['faq']) {
require('../incfiles/head.php');
echo '<div class="phdr"><a href="index.php"><b>' . $lng_chat['chat'] . '</b></a> >> ' . $k_d['name'] . '</div>' .
'<div class="menu">' .
'<center><img src="img/sr.gif" alt="" /> </center>' .
'<span class="red"><b>' . $lng_chat['warning'] . '</b></span><br />' . $lng_chat['lawlessness_rules'] . '<br />' .
'<p><a href ="index.php?act=password&mod=rand&id=' . $id . '"><b>' . $lng['continue'] . '</b></a></p></div>' .
'<div class="phdr"><a href="index.php"><b>' . $lng["back"] . '</b></a></div>';
require('../incfiles/end.php');
exit;
}
break;
default:
echo '';
}
/*
-----------------------------------------------------------------
Оповещаем о новом посетителе в комнате (если опция включена)
-----------------------------------------------------------------
*/
if ($k_d['nev'] && $user_id) {
if ($_SESSION['nev'] != $id) {
$_SESSION['nev'] = $id;
$password = $k_d['tip'] == 'in' || $k_d['tip'] == 'an' ? db::escape($_SESSION['key']) : 0;
$login_u = $k_d['tip'] == 'an' ? 'Аноним [i](№: ' . $password . ')[/i]' : $login;
$new_text = explode("|", $k_d['nev']);
$new_text = $datauser['sex'] == 'm' || count($new_text) == 1 ? $new_text[0] : $new_text[1];
$new_text = strtr($new_text, array(
'[login]' => $login_u,
':login:' => $login_u
));
$mass_bot_post = serialize(array(
'av' => '',
'sex' => 'm',
'status' => '',
'name' => $lng_chat['ticker'],
'name_delete' => '',
'cvet' => '',
'cvet_n' => '',
'ip' => '2130706433',
'soft' => 'k_2_bot',
'rights' => 0
));
// Заносим данные в б.д.
db::query("INSERT INTO `chat_room_" . $id . "` SET
`id_bot` = '1',
`time` = '" . time() . "',
`text` = '" . $new_text . "',
`author` = '" . db::escape($mass_bot_post) . "',
`tip` = '2',
`password` = '" . $password . "'
");
}
}
/*
-----------------------------------------------------------------
Отображаем комнату
-----------------------------------------------------------------
*/
$refr = rand(0, 999);
require('incfiles/head.php');
if ($chat_us_d['ban_time'] > time()) {
echo '<div class="alarm">' . $lng['ban'] . ' <a href="index.php?act=ban">' . $lng['in_detail'] . '</a></div>';
}
$notification = '';
if (!empty($_SESSION['notification'])) {
$notification = $_SESSION['notification'] == 'room_reset' ? '<div class="gmenu">' . $lng_chat['room_reset'] . '</div>' : '';
unset($_SESSION['notification']);
}
if ($set_chat['carea'] && $user_id) {
echo '<div class="phdr"><a href="index.php?id=' . $id . '&refr=' . $refr . '"><b>' . $lng_chat['refresh'] . '</b></a></div>' .
$notification .
'<div class="gmenu">' .
'<form name="form2" action="index.php?act=messages&id=' . $id . '" method="post">';
if (!$is_mobile)
echo bbcode::auto_bb('form2', 'msg');
echo '<textarea rows="' . $set_user['field_h'] . '" name="msg"></textarea><br />';
if ($set_user['translit'])
echo '<input type="checkbox" name="msgtrans" value="1" /> ' . $lng['translit'] . '<br />';
if ($rights == 9 && $k_d['tip'] != 'in')
echo '<input type="checkbox" name="msgrooms" value="1" /> <span style="color:blue">' . $lng_chat['notification'] . '</span><br />';
echo '<input type="submit" name="submit" value="' . $lng_chat['say'] . '"/><br /></form>' .
'</div>';
} elseif ($user_id) {
echo '<div class="phdr"><a href="index.php?act=messages&id=' . $id . '"><b>' . $lng_chat['say'] . '</b></a> | ' .
'<a href="index.php?id=' . $id . '&refr=' . $refr . '"><b>' . $lng_chat['refresh'] . '</b></a></div>' . $notification;
} else {
echo '<div class="phdr"><a href="index.php?id=' . $id . '&refr=' . $refr . '"><b>Обновить</b></a></div>' . $notification;
}
$sql = $rights > 6 ? "" : " `tip` != '1'";
$sql .= ($k_d['tip'] != 'in') ? "" : " " . ($sql ? 'AND ' : '') . "`password` = '" . db::escape($_SESSION['key']) . "'";
if ($k_d['tip'] != 'an')
$filter = isset ($_SESSION['chat_id']) && $_SESSION['chat_k'] == $id ? 1 : 0;
else
$filter = '';
if ($filter) {
// Подготавливаем запрос на фильтрацию юзеров
$sw = 0;
$sql .= ' ' . ($sql ? "AND " : "") . '(';
$fsort_users = unserialize($_SESSION['chat_id']);
foreach ($fsort_users as $val) {
if ($sw)
$sql .= ' OR ';
$sortid = intval($val);
$sql .= "`id_u` = '$sortid'";
$sw = 1;
}
$sql .= ')';
echo '<div class="rmenu">' . $lng_chat['filtering'] . '</div>';
}
if ($rights != 9 && $user_id)
$sql .= " " . ($sql ? 'AND ' : '') . "(`id_s` = '0' OR `id_u` = '" . $user_id . "' OR `id_s` = '" . $user_id . "')";
elseif (!$user_id)
$sql .= " " . ($sql ? 'AND ' : '') . "`id_s` = '0'";
// Счётчик постов в комнате
$total = db::result(db::query("SELECT COUNT(*) FROM `chat_room_" . $id . "`" . ($sql ? ' WHERE' : '') . $sql . ""), 0);
if ($total) {
// Запрос в базу для вывода постов
$soob = db::query("SELECT `id`, `id_u`, `id_s`, `time`, `text`, `author`, `tip`, `password` FROM `chat_room_" . $id . "`" . ($sql ? ' WHERE' : '') . $sql . " ORDER BY `time` DESC LIMIT $start, $kmess");
$i = 0;
echo '<form action="index.php?act=massdel&id=' . $id . '" method="post">';
while ($message = mysqli_fetch_assoc($soob)) {
// Метка о том, что пост удалён
if ($rights >= 7 && $message['tip'] == 1)
echo '<div class="rmenu">';
else
echo is_integer($i / 2) ? '<div class="list1">' : '<div class="list2">';
$vrp = (core::$system_set['timeshift'] + core::$user_set['timeshift']) * 3600;
if (date("d.m.Y", $message['time'] + $vrp) == date("d.m.Y"))
$vr = date("H:i", $message['time'] + $vrp); // Время "сегодняшнего" поста
else
$vr = date("d.m.Y/H:i", $message['time'] + $vrp); // Время "старых" постов
$text = $k_d['tip'] != 'in' ? $message['text'] : str_code(base64_decode($message['text']));
$text = functions::checkout($text, 1, 1);
// Подсветка ника в тексте
if ($set_chat['cvet_ns'])
$text = preg_replace('|' . $login . '|si', '<span style="color:' . $set_chat['cvet_ns'] . '">' . $login . '</span>', $text);
/*
-----------------------------------------------------------------
Выбор отображения данных автора поста (пользователь, аноним или бот)
-----------------------------------------------------------------
*/
$set_author = array();
$set_author = unserialize($message['author']);
// Настроки по-умолчанию
if (!isset($set_author) || empty($set_author))
$set_author = serialize(array(
'av' => '',
'sex' => 'm',
'status' => '',
'name' => $lng_chat['ticker'],
'name_delete' => '',
'cvet' => '',
'cvet_n' => '',
'ip' => '2130706433',
'soft' => 'k_2_bot',
'rights' => 0
));
if ($message['tip'] < 2) {
if ($message['id_u'] != $user_id || !$user_id) {
$us_d = mysqli_fetch_assoc(db::query("SELECT `datereg`, `lastdate`, `rights` FROM `users` WHERE `id` = '" . $message['id_u'] . "'"));
} else {
$us_d = $datauser;
}
$rights_p = $us_d['rights'] ? $us_d['rights'] : $set_author['rights'];
if ($set_user['smileys'])
$text = functions::smileys($text, $rights_p ? 1 : 0);
$sex = ($set_author['sex'] == 'm' ? 'm' : 'w') . ($us_d['datereg'] > time() - 86400 ? '_new' : '') . '.png';
//$sex = '../theme/' . $set_user['skin'] . '/images/' . ($set_author['sex'] == 'm' ? 'm' : 'w') . ($us_d['datereg'] > time() - 86400 ? '_new' : '') . '.png';
if ($user_id && $user_id != $message['id_u'])
$nik = '<a href="../users/profile.php?user=' . $message['id_u'] . '">' . ($set_author['cvet_n'] ? '<span style="color: ' . $set_author['cvet_n'] . '">' : '') . '<b>' . $set_author['name'] . '</b>' . ($set_author['cvet_n'] ? '</span>' : '') . '</a> ';
else
$nik = ($set_author['cvet_n'] ? '<span style="color: ' . $set_author['cvet_n'] . '">' : '') . '<b>' . $set_author['name'] . '</b>' . ($set_author['cvet_n'] ? '</span>' : '');
if ($k_d['tip'] == 'an')
$nik .= ' <b><small>(№: <span class="green">' . $message['password'] . '</span>)</small></b>';
$user_stat = array(6 => ' (Smd)', 7 => ' (Adm)', 9 => ' (SV!)');
$nik .= $user_stat[$us_d['rights']];
if ($set_author['rights'] == 1)
$nik .= ' (Cmod)';
$onl = $us_d['lastdate'];
if ($k_d['tip'] != 'an' && $user_id && $user_id != $message['id_u'])
$otv_cit = '<a href="index.php?act=messages&mod=txt&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['reply_btn'] . '</a> <a href="index.php?act=messages&mod=citata&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['cytate_btn'] . '</a> ';
else
$otv_cit = '';
if (!empty ($set_author['status']))
$stat = '<div class="status">' . functions::image('label.png', array('class' => 'icon-inline')) . ' ' . $set_author['status'] . '</div>';
else
$stat = '';
if ($set_author['cvet'] && $k_d['tip'] != 'an')
$text = '<span style="color: ' . $set_author['cvet'] . '">' . $text . '</span>';
$avatar = '../files/users/avatar/' . $message['id_u'] . '.png';
if ($k_d['tip'] == 'an' && !$chat_us_d['rights'] && $rights < 6) {
// Пост Анонима
$avatar = '../images/empty.png';
// Отображение номера Анонима
if (trim($_SESSION['key']) == $message['password'])
$nik = '<b>' . $lng_chat['anonymous'] . ' №: <span class="red">' . $message['password'] . '</span></b>';
else
$nik = '<b>' . $lng_chat['anonymous'] . ' №: ' . $message['password'] . '</b>';
$otv_cit = '';
$stat = '';
}
} else {
// Пост Бота
$rights_p = 0;
if ($set_user['smileys'])
$text = functions::smileys($text, 0);
$avatar = 'img/' . $set_author['av'] . '.png';
$sex = ($set_author['sex'] == 'm' ? 'm' : 'w') . '.png';
if ($message['id_u'] && $user_id)
$nik = '<a href="profile.php?user=' . $message['id_u'] . '"><b>' . $set_author['name'] . '</b></a> ';
else
$nik = '<b>' . $set_author['name'] . '</b> ';
$onl = time();
if ($k_d['tip'] != 'an' && $message['id_u'] && $user_id)
$otv_cit = '<a href="index.php?act=messages&mod=txt&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['reply_btn'] . '</a> <a href="index.php?act=messages&mod=citata&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['cytate_btn'] . '</a> ';
else
$otv_cit = '';
if (!empty ($set_author['status']))
$stat = '<div class="status">' . functions::image('label.png', array('class' => 'icon-inline')) . ' ' . $set_author['status'] . '</div>';
else
$stat = '';
}
/*
-----------------------------------------------------------------
Вывод данных автора поста
-----------------------------------------------------------------
*/
// Аватар
if ($set_user['avatar'] && $set_chat['avatar']) {
echo '<table cellpadding="0" cellspacing="0"><tr><td>';
if (file_exists($avatar))
echo '<img src="' . $avatar . '" width="32" height="32" alt="" /> ';
else
echo '<img src="../images/empty.png" width="32" height="32" alt="" /> ';
echo '</td><td>';
}
// Метка пола
echo functions::image($sex, array('class' => 'icon-inline')) . ' ' .
// Ник и должность
$nik .
// Метка Онлайн / Офлайн
(time() > $onl + 300 ? '<span class="red"> [Off]</span> ' : '<span class="green"> [ON]</span> ') .
$otv_cit .
'<span class="gray">(' . $vr . ')</span><br />';
echo $stat;
// Метка о приватности сообщения
if ($message['id_s'] && $user_id) {
if ($user_id == $message['id_s'])
echo '<small><span class="red">' . $lng_chat['privately'] . '</span></small><br />';
elseif ($user_id == $message['id_u'])
echo '<small><span class="green">' . $lng_chat['privately'] . '</span></small><br />';
elseif ($rights == 9) {
$dn = mysqli_fetch_assoc(db::query("SELECT `name` FROM `users` WHERE `id` = '" . $message['id_s'] . "' LIMIT 1"));
echo '<small><span class="red">' . $lng_chat['privately'] . ' =>> <a href="../users/profile.php?user=' . $message['id_s'] . '">' . $dn['name'] . '</a></span></small><br />';
}
}
// Аватар
if ($set_user['avatar'] && $set_chat['avatar'])
echo '</td></tr></table>';
/*
-----------------------------------------------------------------
Вывод текста поста
-----------------------------------------------------------------
*/
echo $text . '<br />';
// Ссылки скрыть/восстановить, удалить сообщение:
if ($chat_us_d['rights'] && $rights >= $rights_p || $rights >= 6 && $rights > $rights_p || $rights == 9) {
echo '<div class="sub">';
if ($message['tip'] < 2)
echo '<input type="checkbox" name="delch[]" value="' . $message['id'] . '"/> ';
if ($rights == 9) {
echo '<a href="index.php?act=delete&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng['delete'] . '</a>';
if ($message['tip'] == 1 && !$message['id_s'])
echo ' | <a href="index.php?act=close&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['restore'] . '</a>';
elseif (!$message['tip'] && !$message['id_s'])
echo ' | <a href="index.php?act=close&id=' . $message['id'] . '&id_k=' . $id . '&mod=closed">' . $lng_chat['hide'] . '</a>';
}
if ($chat_us_d['rights'] == 1 && !$message['tip'] && $rights < 6 || $rights == 6)
echo '<a href="index.php?act=close&id=' . $message['id'] . '&id_k=' . $id . '&mod=closed">' . $lng['delete'] . '</a>';
if ($rights == 7 && !$message['id_s']) {
if ($message['tip'] == 1)
echo '<a href="index.php?act=close&id=' . $message['id'] . '&id_k=' . $id . '">' . $lng_chat['restore'] . '</a>';
elseif (!$message['tip'])
echo '<a href="index.php?act=close&id=' . $message['id'] . '&id_k=' . $id . '&mod=closed">' . $lng['delete'] . '</a>';
}
if ($message['tip'] < 2 && ($rights > $rights_p || $chat_us_d['rights'] > $rights_p) && $k_d['tip'] != 'sr')
echo ' | <a href="index.php?act=ban&mod=ban&id=' . $id . '&user=' . $message['id_u'] . '">' . $lng['ban_do'] . '</a>';
// Метка о том, что пост удалён
if ($message['tip'] == 1 && $rights > 6 && $set_author['name_delete'])
echo '<br /><span class="red">' . $lng_chat['post_delete'] . ': <b>' . $set_author['name_delete'] . '</b></span>';
elseif ($set_author['name_delete'] && $rights > 6)
echo '<br /><span class="green">' . $lng_chat['post_off_delete'] . ': <b>' . $set_author['name_delete'] . '</b></span>';
echo '<br /><span class="gray">' . long2ip($set_author['ip']) . ' - ' . $set_author['soft'] . '</span>' .
'</div>';
}
echo '</div>';
++$i;
}
if ($chat_us_d['rights'] == 1 || $rights >= 6)
echo '<div class="rmenu"><input type="submit" value="' . $lng['delete'] . '"/></div>';
echo '</form>';
} else {
echo '<div class="menu">' . $lng_chat['no_message'] . '</div>';
}
echo '<div class="phdr"><a href="index.php?act=messages&id=' . $id . '"><b>' . $lng_chat['say'] . '</b></a> | ' .
'<a href="index.php?id=' . $id . '&refr=' . $refr . '"><b>' . $lng_chat['refresh'] . '</b></a></div>';
// Постраничная навигация
if ($total > $kmess) {
echo '<div class="topmenu">' . functions::display_pagination('?id=' . $id . '&', $start, $total, $kmess) . '</div>' .
'<p><form action="index.php?id=' . $id . '" method="post">' .
'<input type="text" name="page" size="2"/>' .
'<input type="submit" value="' . $lng['to_page'] . ' >>"/></form></p>';
}
if ($k_d['tip'] == 'in') {
echo '<p><a href="index.php?act=password&mod=new&id=' . $id . '"><b>' . $lng_chat['change_password'] . '</b></a></p>';
echo '<p><a href="index.php?act=reset&id=' . $id . '"><b>' . $lng_chat['cleaning'] . '</b></a></p>';
} elseif ($k_d['tip'] == 'an') {
echo '<p><a href="index.php?act=password&mod=rand&id=' . $id . '"><b>' . $lng_chat['change_number'] . '</b></a></p>';
} else {
if ($filter) {
echo '<p><a href="index.php?act=filter&id=' . $id . '&do=unset"><b>' . $lng_chat['off_filter'] . '</b></a></p>';
} else {
echo '<p><a href="index.php?act=filter&id=' . $id . '"><b>' . $lng_chat['on_filter'] . '</b></a></p>';
}
}
// Ссылка на очистку комнаты (только Супервизор)
if ($rights == 9)
echo '<p><div class="func"><a href="index.php?act=dell&id=' . $id . '"><b>' . $lng_chat['cleaning'] . '</b></a></div></p>';
require('incfiles/end.php');
} else {
/*
-----------------------------------------------------------------
Отображаем прихожую Чата
-----------------------------------------------------------------
*/
$textl = $lng_chat['hallway'];
require('../incfiles/head.php');
// Выводим сообщение о Бане
if ($chat_us_d['ban_time'] > time())
echo '<div class="alarm">' . $lng['ban'] . ' <a href="index.php?act=ban">' . $lng['in_detail'] . '</a></div>';
// Выводим сообщение Админу при закрытом чате
if (!$chat_settings['access'])
echo '<div class="alarm">' . $lng_chat['chat_close'] . '</div>';
echo '<div class="phdr"><b>' . $lng_chat['chat'] . '</b></div>';
$_SESSION['key'] = '';
$_SESSION['salt'] = '';
$_SESSION['nev'] = '';
$_SESSION['notification'] = '';
$sql = ($user_id) ? "" : " WHERE `tip` != 'in'";
$total = db::result(db::query("SELECT COUNT(*) FROM `chat_rooms`" . $sql . ""), 0);
$req = db::query("SELECT `id`, `name`, `op` FROM `chat_rooms`" . $sql . " LIMIT $start, $kmess");
// Вывод списка комнат
while ($mass = mysqli_fetch_assoc($req)) {
echo is_integer($i / 2) ? '<div class="list1">' : '<div class="list2">';
echo '<a href="index.php?id=' . $mass['id'] . '">' . $mass['name'] . '</a> <small>(' . (wch($mass['id']) ? '<a href="index.php?act=who&id=' . $mass['id'] . '">' . wch($mass['id']) . '</a>' : '<span class="gray">' . wch($mass['id']) . '</span>') . ')</small>';
// Вывод описания комнаты
if (!empty($mass['op']))
echo '<div class="sub"><span class="gray">' . functions::checkout($mass['op'], 1, 0) . '</span></div>';
echo '</div>';
++$i;
}
echo '<div class="phdr"><a href="index.php?act=who"><b>' . $lng_chat['who_s_chatting'] . '</b></a> <b>(' . wch() . ')</b></div>';
// Навигация внизу страницы
if ($total > $kmess) {
echo '<div class="topmenu">' . functions::display_pagination('index.php?', $start, $total, $kmess) . '</div>' .
'<p><form action="index.php" method="post">' .
'<input type="text" name="page" size="2"/>' .
'<input type="submit" value="' . $lng['to_page'] . ' >>"/></form></p>';
}
// Ссылка на админку чата
if ($rights == 9)
echo '<p><div class="func"><a href="menu.php">' . $lng['admin_panel'] . '</a></div></p>';
if ($user_id)
echo '<p><a href="index.php?act=my_set">' . $lng['settings'] . '</a><br />';
else
echo '<p>';
echo '<a href="index.php?act=moders">' . $lng['moders'] . '</a><br />';
if ($user_id)
echo '<a href="index.php?act=top">' . $lng_chat['top_10'] . '</a> | ';
echo '<a href="index.php?act=faq">FAQ</a></p>';
require('../incfiles/end.php');
}
}