Файл: forum.php
Строк: 601
<?php
include 'system/sys.php';
include 'system/funcs.php';
if (!isset ($us['id'])) {
header ('location: /');
exit;
}
/*
---
Форум
---
*/
switch ($_GET['mod']) {
/*
---
Главная
---
*/
default:
header ('location: /forum.php?mod=index');
break;
case index:
H ('Форум', '<a href="/index.php" style="color:white;">Главная</a> | Форум');
echo '<div class="list1">';
echo '<img src="/design/tema.png" alt="" align="middle"/> Темы: <a href="/thems' . $us['id'] . '">Мои</a>';
echo ' | ';
echo '<a href="/forum.php?mod=stat&new_thems">Новые</a>';
echo ' | ';
echo '<a href="/forum.php?mod=stat&obn_thems">Обновлённые</a><br/>';
echo '<img src="/design/npost.png" alt="" align="middle"/>Посты: <a href="/posts' . $us['id'] . '">Мои</a>';
echo ' | ';
echo '<a href="/forum?mod=stat&new_posts">Новые</a><br/>';
echo '<img src="/images/book3.png" alt=""/> <a href="/forums/nep.php">Непрочитанное</a> (' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` LEFT JOIN `forum_visit` ON `forum_t`.`id`=`forum_visit`.`id_t` AND `forum_visit`.`us`='" . $us['id'] . "' WHERE `forum_t`.`type` != '2' AND (`forum_visit`.`id_t` IS NULL)") . ')';
echo '</div>';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_r` ORDER BY `id`");
while ($r = $query -> fetch()) {
echo '<div class="menu2"><img src="/design/inet.png" alt="" align="middle"/> <a href="/forum/razd' . $r['id'] . '/" style="text-decoration:none; color:white;"><b>' . $r['name'] . '</b></a> (' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`type`!='2')')) . '/' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`del`='0')')) . ')</div>';
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "')") != 0) {
echo '<div class="navg">';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "') ORDER BY `id`");
while ($pr = $q -> fetch ()) {
echo '<img src="/design/categ.png" alt="" align="middle"/> <a href="/forum/' . $r['id'] . '/' . $pr['id'] .'">' . $pr['name'] . '</a> (' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '':'AND (`type`!='2')')) . '/' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`del`='0')')) . ')<br/>';
}
echo '</div>';
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`type`!='2')')) != 0) {
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`type`!='2')') . " ORDER BY `time` DESC LIMIT 1");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $t['id_r'] . "') AND (`id_pr`='" . $t['id_pr'] . "') AND (`id_t`='" . $t['id'] . "') " . ($us['level']>0 ? '' : 'AND (`del` = '0')'));
$pr = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_pr` WHERE (`id`='" . $t['id_pr'] . "')");
echo '<div class="list1">';
echo '<small>Подраздел: <a href="/forum/' . $t['id_r'] . '/' . $t['id_pr'] . '">' . $pr['name'] . '</a><br/>';
echo '<img src="/design/' . ($t['top']==1 ? 'prikrep' : ($t['type']==0 ? 'closed' : 'the')) . '.png" alt=""/> <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p . ') <a href="/forum/thema' . $t['id'] . '/page' . ceil ( $c_p / 10 ) .'">></a><br/>' . uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) . ')</small>';
echo '</div>';
}
}
else {
echo '<div class="navg">Подразделов нет!</div>';
}
echo '</div>';
}
echo '<div class="menu2">';
echo '<img src="/design/alll.png" alt="" align="middle"/> <a href="/all/rulls.php?all" style="text-decoration:none; color:white;">Правила</a>';
echo ' | ';
echo '<img src="/design/emoc.png" alt="" align="middle"/> <a href="/all/smiles_r.php" style="text-decoration:none; color:white;">Смайлы</a>';
echo ' | ';
echo '<img src="/design/cod.png" alt="" align="middle"/> <a href="/all/bb.php" style="text-decoration:none; color:white;">ББ коды</a>';
echo ' | ';
echo '<img src="/design/usear.png" alt="*" align="middle"/> <a href="/fsearch.php" style="text-decoration:none; color:white;">Поиск</a>';
echo '</div>';
break;
/*
---
Раздел
---
*/
case r:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_r` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$r = $query -> fetch ();
H ('Раздел ' . $r['name'], '<a href="/forum.php" style="color:white;">Форум</a> | ' . $r['name']);
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "')")!=0) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "') ORDER BY `id`");
while ($pr = $query -> fetch ()) {
echo '<div class="menu2"><img src="/design/categ.png" alt="" align="middle"/><a href="/forum/' . $r['id'] . '/' . $pr['id'] . '" style="text-decoration:none;color:white;">' . $pr['name'] . '</a> (' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level']>0 ? '' : ' AND (`type`!='2')')) . '/' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '':'AND (`del`='0')')).')</div>';
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`type`!='2')')) != 0) {
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '' : 'AND (`type`!='2')') . " ORDER BY (`time`) LIMIT 1");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') AND (`id_t`='" . $t['id'] . "') " . ($us['level'] > 0 ? '':'AND (`del`='0')'));
echo '<div class="navg">';
echo '<img src="/design/' . ($t['top'] ==1 ? 'prikrep' : ($t['type'] == 0 ? 'closed':'the')) . '.png" alt=""/> <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p .') <a href="/forum/thema' . $t['id'] . '/page' . ceil ($c_p / 10) . '">></a><br/>';
echo uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) . ')';
echo '</div>';
}
}
}
else {
echo '<div class="list1">Подразделов нет!</div>';
}
break;
/*
---
Подраздел
---
*/
case pr:
if (!isset ($_GET['id']) || !isset ($_GET['r'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$pr = $query -> fetch ();
$_GET['r'] = intval ($_GET['r']);
if ($pr['id_r']!=$_GET['r']) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_r` WHERE (`id`=?)", array ($_GET['r']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$r = $query -> fetch ();
H ('Подраздел ' . $pr['name'], '<a href="/forum.php" style="color:white;">Форум</a> | <a href="/forum/razd' . $r['id'] . '" style="color:white;">' . $r['name'] . '</a> | ' . $pr['name']);
echo '<div class="menu2"><img src="/design/nt.png" alt="" align="middle"/> <a href="/forum/' . $r['id'] . '/' . $pr['id'] . '?nt" style="text-decoration:none;color:white;">Новая тема</a></div>';
if (isset ($_GET['nt'])) {
echo '<div class="list1">';
echo '<form action="/forum/' . $r['id'] . '/' . $pr['id'] . '?nt&add" method="post">';
echo 'Название темы:<br/>';
echo '<input type="text" name="name"/><br/>';
echo 'Текст:<br/>';
echo '<textarea name="text" rows="10"></textarea><br/>';
echo '<input type="checkbox" name="podp"/> Оповещать об оставленных сообщениях<br/>';
echo 'Ознакомьтесь с <a href="/forum/rulls' . $pr['id'] . '">правилами</a> п.д!<br/>';
echo '<input type="submit" value="Добавить"/>';
echo '</form>';
echo '</div>';
if (isset ($_GET['add'])) {
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`us`='" . $us['id'] . "') AND (`date`>'" . (time () - ( 60 * 15 )) . "')") != 0) {
echo '<div class="list1"><b style="color:red;">Темы можно создавать только раз в 15 минут!</b></div>';
}
else {
$_POST['name'] = htmlspecialchars (addslashes (trim ($_POST['name'])));
$_POST['text'] = htmlspecialchars (addslashes (trim ($_POST['text'])));
if (empty ($_POST['name'])) {
echo '<div class="list1"><b>Вы не ввели название темы..</b></div>';
}
elseif (empty ($_POST['text'])) {
echo '<div class="list1"><b>Вы не ввели текст..</b></div>';
}
else {
DB :: $dbs -> query ("INSERT INTO `forum_t` (`id_r`,`id_pr`,`name`,`us`, `last`,`time`, `date`) VALUES ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $_POST['name'] . "', '" . $us['id'] . "', '" . $us['id'] . "', '" . time () . "', '" . time () . "')");
$id = DB :: $dbs -> lastInsertId ();
DB :: $dbs -> query ("INSERT INTO `forum_p` (`id_r`,`id_pr`,`id_t`,`us`,`text`,`time`) VALUES ('" . $r['id'] . "','" . $pr['id'] . "','" . $id . "','" . $us['id'] . "','" . $_POST['text'] . "','" . time () . "')");
if (isset ($_POST['podp'])) {
DB :: $dbs -> query ("INSERT INTO `forum_podp` (`id_r`,`id_pr`, `id_t`,`us`) values ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $id . "','" . $us['id'] . "')");
}
header ('location: /forum/thema' . $id);
}
}
}
}
else {
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '':'AND (`type`!='2')'));
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
if ($items != 0) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id_pr`='" . $pr['id'] . "') " . ($us['level'] > 0 ? '':'AND (`type`!='2')') . " ORDER BY `top` DESC, `id` DESC LIMIT $start, $items_per_page");
while ($t = $query -> fetch ()) {
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') AND (`id_t`='" . $t['id'] . "') " . ($us['level'] > 0 ? '':'AND (`del`='0')'));
echo '<div class="navg">';
echo '<img src="/design/' . ($t['top'] != 0 ? 'prikrep' : ($t['type'] == 0 ? 'closed':'the')) . '.png" alt=""/> <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p .') <a href="/forum/thema' . $t['id'] . '/page' . ceil ($c_p / 10) . '">></a><br/>';
$c_f = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_t`= '" . $t['id'] . "')");
if ($c_f != 0) {
echo '<img src="/images/page_white_get.png" alt="" align="middle"/> Файлов: <a href="/forum/files' . $t['id'] . '">' . $c_f . '</a><br/>';
}
echo uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) .')';
echo '</div>';
}
echo '<div class="lst">' . pages ('/forum/' . $r['id'] . '/' . $pr['id']) . '</div>';
}
else {
echo '<div class="lst">Тем нет!</div>';
}
}
echo '<div class="menu2">';
echo '<img src="/design/alll.png" alt="" align="middle"/> Правила: <a href="/all/rulls.php?all" style="text-decoration:none; color:white;">сайта</a>/<a href="/forum/rulls' . $pr['id'] . '" style="text-decoration:none; color:white;">подраздела</a>';
echo ' | ';
echo '<img src="/design/emoc.png" alt="" align="middle"/> <a href="/all/smiles_r.php" style="text-decoration:none; color:white;">Смайлы</a>';
echo ' | ';
echo '<img src="/design/cod.png" alt="" align="middle"/> <a href="/all/bb.php" style="text-decoration:none; color:white;">ББ коды</a>';
echo ' | ';
echo '<img src="/design/usear.png" alt="" align="middle"/> <a href="/fsearch.php" style="text-decoration:none; color:white;">Поиск</a>';
echo '</div>';
break;
/*
---
Правила подраздела
---
*/
case rulls:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$pr = $query -> fetch ();
H ('Правила подраздела ' . $pr['name'], 'Правила подраздела ' . $pr['name']);
echo '<div class="list1">' . (empty ($pr['rulls']) ? 'Правил пока нет..' : bb ($pr['rulls'])) . '</div>';
break;
/*
---
Тема
---
*/
case thema:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$a = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
$query = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id`='" . $t['id_pr'] . "')");
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$pr = $query -> fetch ();
$query = DB :: $dbs -> query ("SELECT * FROM `forum_r` WHERE (`id`='" . $t['id_r'] . "')");
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$r = $query -> fetch ();
H ($t['name'], '<a href="/forum" style="color:white;">Форум</a> | <a href="/forum/razd' . $r['id'] . '" style="color:white;">' . $r['name'].'</a> | <a href="/forum/' . $r['id'] . '/' . $pr['id'] . '" style="color:white;">' . $pr['name'] . '</a> | ' . $t['name']);
if ($t['type']==2) {
echo '<div class="list1">Тема удалена!</div>';
if ($us['level']>1) {
if (isset ($_GET['up'])) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `type`='1' WHERE (`id`='" . $t['id'] . "')");
header ('location: /forum/thema' . $t['id']);
}
echo '<div class="list1"><a href="/forum/thema' . $t['id'] . '=up">Восстановить</a></div>';
}
}
else {
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $us['id'] . "')") == 0) {
DB :: $dbs -> query ("INSERT INTO `forum_visit` (`id_r`, `id_pr`, `id_t`,`us`,`time`) VALUES ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $t['id'] . "','" . $us['id'] . "','" . time () . "')");
}
else {
DB :: $dbs -> query ("UPDATE `forum_visit` SET `time`='" . time () . "' WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $us['id'] . "')");
}
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_r`='" . $r['id'] . "') AND (`id_pr`='" . $pr['id'] . "') AND (`id_t`='" . $t['id'] . "') " . ($us['level']>0?'':'AND (`del`='0')'));
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
if ($page == 1)
$i = $page;
else if ($page == 2) $i = $page + 9;
else $i = ($page * 10) - 9;
/*
---
Ответ
---
*/
if (isset ($_GET['otv_i'])) {
$query = DB :: $dbs -> query ("SELECT * FROM `us` WHERE (`id`=?)", array ((int) $_GET['otv_i']));
if ($query -> rowCount () == 0) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
$u = $query -> fetch ();
if ($u['id']==$us['id']) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
echo '<div class="list1">';
echo '<form action="/form2/msg.php?id=' . $t['id'] . '&otv&otv_i=' . $u['id'] . '&page=' . $pages . '" method="post" enctype="multipart/form-data">';
echo 'Сообщение:<br/><textarea name="msg">[b]' . $u['nick'] . '[/b], </textarea><br/>';
if ($us['file']==1) {
echo 'Файл:<br/><input type="file" name="filename"/><br/>';
}
echo '<input type="submit" value="Написать"/>';
echo '</form>';
echo '</div>';
}
/*
---
Цитирование поста
---
*/
else if (isset ($_GET['cit'])) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`=?)", array ((int) $_GET['cit']));
if ($query -> rowCount () == 0) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
$p = $query -> fetch ();
if ($p['del']!=0) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
if ($p['us']==$us['id']) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `us` WHERE (`id`='" . $p['us'] . "')");
if ($query -> rowCount () == 0) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
$u = $query -> fetch ();
echo '<div class="list1">';
echo 'Цитата:';
echo '<div class="cit"><b style="color:red;">' . $u['nick'] . '</b>: ' . bb ($p['text']) . '</div>';
echo '<form action="/form2/msg.php?id=' . $t['id'] . '&otv&cit=' . $p['id'] .'&page=' . $pages . '" method="post" enctype="multipart/form-data">';
echo 'Сообщение:<br/><textarea name="msg"></textarea><br/>';
if($us['file'] == 1) {
echo 'Файл:<br/><input type="file" name="filename"/><br/>';
}
echo '<input type="submit" value="Написать"/>';
echo '</form>';
echo '</div>';
}
else {
echo '<div class="list1">';
echo '<small>';
echo '<a href="/forum/thema' . $t['id'] . '/page' . $pages . '?' . passgen () . '">Обновить</a>';
echo ' | ';
echo '<a href="/forum/thema' . $t['id'] . '=thp">' . (DB :: $dbs -> querySingle ("SELECT * FROM `forum_podp` WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $us['id'] . "')") == 0 ? 'Подписаться' : 'Отписаться') . '</a>';
/*
---
Подписка/Отписка с темы
---
*/
if (isset ($_GET['thp'])) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_podp` WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $us['id'] . "')");
if ($query -> rowCount () == 0) {
DB :: $dbs -> query ("INSERT INTO `forum_podp` (`id_r`,`id_pr`,`id_t`,`us`) VALUES ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $t['id'] . "','" . $us['id'] . "')");
}
else {
DB :: $dbs -> query ("DELETE FROM `forum_podp` WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $us['id'] . "')");
}
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
/*
---
Открыть/Зыкрыть тему
---
*/
if ($t['type'] == 1) {
if ($a['id']==$us['id'] || $us['level']>$a['level']) {
if (isset ($_GET['close'])) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `type`='0', `time`='" . time () . "',`last`='" . $us['id'] . "' WHERE (`id`='" . $t['id'] . "')");
DB :: $dbs -> query ("INSERT INTO `forum_p` (`id_r`,`id_pr`,`id_t`,`us`,`text`,`time`) VALUES ('" . $r['id'] . "','" . $pr['id'] . "','" . $t['id'] . "','" . $us['id'] . "','[b]Тема закрыта для обсуждения![/b] :-)','" . time () . "')");
header ('location: /forum/thema' . $t['id'] . '/page' . $pages);
exit;
}
echo ' | ';
echo '<a href="/forum/thema' . $t['id'] . '=close">Закрыть</a>';
}
}
else {
if ($a['id']==$us['id'] && $us['level']>0 || $us['level']>$a['level']) {
if (isset($_GET['open'])) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `type`='1', `time`='" . time () . "',`last`='" . $us['id'] . "' WHERE (`id`='" . $t['id'] . "')");
DB :: $dbs -> query ("INSERT INTO `forum_p` (`id_r`,`id_pr`,`id_t`,`us`,`text`,`time`) VALUES ('" . $r['id'] . "','" . $pr['id'] . "','" . $t['id'] . "','" . $us['id'] . "','[b]Тема открыта для обсуждения![/b] :-)','" . time () . "')");
header ('location: /forum/thema' . $t['id'] . '/page' . $pages);
exit;
}
echo ' | ';
echo '<a href="/forum/thema' . $t['id'] . '=open">Открыть</a>';
}
}
/*
---
Открепить/Закрепить тему
---
*/
if ($t['us']==$us['id'] && $us['level']>1 || $us['level']>$a['level']) {
if (isset ($_GET['top'])) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `top`='" . ($t['top']==0?1:0) . "' WHERE (`id`='" . $t['id'] . "')");
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
echo ' | ';
echo '<a href="/forum/thema' . $t['id'] . '=top">' . ($t['top']==0?'Закрепить' : 'Открепить') . '</a>';
}
if ($a['id']==$us['id'] && $us['level']>0 || $us['level']>$a['level']) {
echo ' | ';
echo '<a href="/forum.php?mod=thm&id=' . $t['id'] . '">Переместить</a>';
}
if ($a['id']==$us['id'] && $us['level']>0 || $us['level']>$a['level']) {
echo ' | ';
echo '<a href="/forum.php?mod=thn&id=' . $t['id'].'">Переименовать</a>';
}
/*
---
Удаление темы
---
*/
if ($a['id']==$us['id'] && $us['level']>2 || $us['level']>$a['level']) {
if (isset ($_GET['del'])) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `type`='2' WHERE (`id`='" . $t['id'] . "')");
header ('location:/forum/thema' . $t['id']);
}
echo ' | ';
echo '<a href="/forum/thema' . $t['id'].'=del">Удалить</a>';
}
if ($t['type']==1) {
if ($t['us']==$us['id'] || $us['level']>$a['level']) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "')");
if ($query -> rowCount () == 0) {
echo ' | ';
echo '<a href="/forum.php?mod=op_add&thema=' . $t['id'] . '">Добавить опрос</a>';
}
}
}
echo '</small>';
echo '</div>';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "')");
if ($query -> rowCount () != 0) {
$op = $query -> fetch ();
echo '<div class="post2">';
echo 'Вопрос: ' . $op['vopros'] . ' (' . ($op['type']==1?'открытое':'закрытое') . ' голосование)<br/>';
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_op_vote` WHERE (`id_op`='" . $op['id'] . "') AND (`us`='" . $us['id'] . "')")==0) {
if (isset ($_GET['op_vote'])) {
$_POST['otv'] = (int) $_POST['otv'];
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_op_otv` WHERE (`id_op`='" . $op['id'] . "') AND (`id`=?)", array ($_POST['otv'])) == 0) {
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
exit;
}
DB :: $dbs -> query ("INSERT INTO `forum_op_vote` (`id_r`,`id_pr`,`id_t`,`id_op`,`id_otv`,`us`,`t`) VALUES ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $t['id'] . "', '" . $op['id'] . "',?,'" . $us['id'] . "','" . time () . "')", array ($_POST['otv']));
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
}
echo '<form action="/forum/thema' . $t['id'] . '/page' . $page . '?op_vote" method="post">';
echo '<select name="otv">';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op_otv` WHERE (`id_op`='" . $op['id'] . "')");
while ($otv = $query -> fetch ()) {
echo '<option value="' . $otv['id'] . '">' . $otv['text'] . '</option>';
}
echo '</select><br/>';
echo '<input type="submit" value="Проголосовать"/>';
echo '</form>';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op_otv` WHERE (`id_op`='" . $op['id'] . "')");
while ($otv = $query -> fetch ()) {
echo '<b>' . $otv['text'] . '</b> (голосов: ' . DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_op_vote` WHERE (`id_op`='" . $op['id'] . "') AND (`id_otv`='" . $otv['id'] . "')") . ')<br/>';
}
if ($op['type']==1) {
echo '- <a href="/form2/opros.php?id=' . $t['id'] . '">Список проголосовавших</a><br/>';
}
}
if ($a['id']==$us['id'] || $a['level']<$us['level']) {
//
if (isset ($_GET['delo'])) {
DB :: $dbs -> query ("DELETE FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "')");
DB :: $dbs -> query ("DELETE FROM `forum_op_otv` WHERE (`id_t`='" . $t['id'] . "')");
DB :: $dbs -> query ("DELETE FROM `forum_op_vote` WHERE (`id_t`='" . $t['id'] . "')");
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
}
echo '- <a href="/forum.php?mod=vop_add&thema=' . $t['id'] . '&op=' . $op['id'] . '">Добавить</a> | <a href="/forum.php?mod=redop&thema=' . $t['id'] . '&op=' . $op['id'] . '">удалить</a> варианты<br/>';
echo '- <a href="/forum.php?mod=thema&id=' . $t['id'] . '&delo">Удалить опрос</a>';
}
echo '</div>';
}
if ($t['type'] == 0) {
echo '<div class="post2"><img src="/design/closed.png" alt="" align="middle"/> <b>Тема закрыта!</b></div>';
}
if ($items == 0) {
echo 'Сообщений нет..';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . ($us['level']>0 ? '':'AND (`del`='0')') . " ORDER BY `id` LIMIT $start, $items_per_page");
while ($p = $query -> fetch ()) {
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['us'] . "')");
// display post
echo '<div class="lst">';
echo $i++ . '. ' . uNick ($u['id']) . ' ' . ( $p['us'] == $t['us'] ? '<b><font color="green">[автор]</font></b>' : '' ) . ' (' . datef ($p['time']) . ')';
// if post is delete
if ($p['del'] != 0) {
$who = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['del'] . "')");
echo ' <b style="color:red;">пост удалил</b> ' . uNick ($p['del']);
}
// if post recovered
if ($p['ups'] != 0) {
$who = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['ups'] . "')");
echo ' <b style="color:green;">пост восстановил</b> ' . uNick ($p['ups']);
}
if ($t['type'] == 1) {
if ($p['us']==$us['id']) {
echo ' [<a href="/forum/redk' . $p['id'] . '"">ред</a>] ';
}
else {
if ($u['level']<$us['level']) {
echo ' [<a href="/forum/redk' . $p['id'] . '"">ред</a>] ';
}
if ($p['del'] == 0) {
echo ' [<a href="/forum/thema' . $t['id'] . '=otv_i' . $p['us'] . '">отв</a>] [<a href="/forum/thema' . $t['id'] . '=cit' . $p['id'] . '">цит</a>] ';
}
}
}
if ($p['us']!=$us['id']) {
echo ' [<a href="/msg' . $p['us'] . '">лс</a>] ';
}
if ($p['us']!=$us['id']) {
if ($u['level']<$us['level']) {
echo ' [<a href="/nar.php?id=' . $u['id'] . '">нар</a>] ';
}
}
if ($p['del']==0) {
echo ' [<a href="/form2/pos.php?id=' . $t['id'] . '&poslike=' . $p['id'] . '">под</a>] ';
if ($t['type'] == 1) {
if ($p['us']!=$us['id']) {
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_vote` WHERE (`id_t`='" . $t['id'] . "') AND (`us`='" . $p['us'] . "') AND (`kem`='" . $us['id'] . "')") == 0) {
echo '<a href="/forum.php?mod=vote&id=' . $p['id'] . '&vot=za&v=' . $p['us'] . '&page=' . $page . '">+1</a> | <a href="/forum.php?mod=vote&id=' . $p['id'] . '&vot=protiv&v=' . $p['us'] . '&page=' . $page . '">-1</a>';;
}
}
}
}
//
if ($u['id'] == $us['id'] && $us['level']>1 || $u['level']<$us['level']) {
echo ' [<a href="/forum.php?mod=post&post=' . $p['id'] . '&page=' . $page . '">' . ( $p['del'] != 0 ? 'вос' : 'x' ) . '</a>]';
}
$za = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_vote` WHERE (`id_p`='" . $p['id'] . "') AND (`vot`='za')");
$protiv = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_vote` WHERE (`id_p`='" . $p['id'] . "') AND (`vot`='protiv')");
// display post votes
echo ' (<span style="color:green;">' . $za . '</span>/<span style="color:red;">' . $protiv . '</span>)<br/>';
// if post have quote
if ($p['cit'] != 0) {
echo 'Цитата:';
echo '<div class="cit">';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`='" . $p['cit'] . "')");
if ($q -> rowCount () == 0) {
echo '<b>Сообщение удалено!</b>';
}
else {
//
$cit = $q -> fetch ();
if ($cit['del'] !=0 ) {
echo '<b>Сообщение удалено!</b>';
}
else {
$citu = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $cit['us'] . "')");
echo '<b style="color:red;">' . $citu['nick'] . '</b>: ' . bb ($cit['text']);
}
}
echo '</div>';
}
// display post text
echo bb ($p['text']) . '<br/>';
// if post have attachment files
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "')") != 0) {
echo '<b>Прикрепленные файлы:</b><br/>';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id`");
while ($f = $q -> fetch ()) {
echo ' <a href="/files/forum/' . $f['name'] . '">' . $f['name'] . '</a> (' . sizef ($f['size']) . ') ' . ($f['size'] != 0 ? ($p['us']==$us['id'] && $us['level'] > 1 || $u['level']<$us['level'] && $us['level']>1 ? ' [<a href="/forum.php?mod=file&id=' . $f['id'] . '&page=' . $page . '">x</a>]' : '' ) : '') . '<br/>';
}
}
// if post has been edition
$q = DB :: $dbs -> query ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "')");
if ($q -> rowCount () != 0) {
// find last edit message
$last_redk = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id` DESC LIMIT 1");
echo '_____<br/>';
echo '<small>Пост изменён <a href="/forums/reds.php?id=' . $p['id'] . '">' . $q -> rowCount () . ' раз.</a> Посл. ред. ' . uNick ($last_redk['us']) . ' (' . datef ($last_redk['time']) . ')</small>';
}
// if post user have status
if(isset ($u['status'])) {
echo '<hr/>';
echo '<b>Статус: ' . $u['status'] . '</b>';
}
echo '</div>';
}
}
if ($t['type'] == 1) {
echo '<div class="list1">';
echo '<form action="/form2/msg.php?id=' . $t['id'] . '&otv&page=' . $pages . '" method="POST" enctype="multipart/form-data">';
echo 'Сообщение:<br/><textarea name="msg"></textarea><br/>';
//
if ($us['file']==1) {
echo 'Файл:<br/><input type="file" name="filename"/><br/>';
}
echo '<input type="submit" value="Написать"/>';
echo '</form>';
echo '</div>';
}
//
if ($pages > 1) {
echo '<div class="lst">' . pages ('/forum/thema' . $t['id']) . '</div>';
}
echo '<div class="list1">';
$who = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "') AND (`time`>'" . (time () - 60) . "')");
$visit = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "')");
echo 'В теме: <a href="/forum/who' . $t['id'] . '">' . endi ($who, array ('человек', 'человека', 'человек')) . '</a>, <a href="/forum/visit' . $t['id'] . '">' . $visit . '</a> заходили<br/>';
echo '<img src="/images/download.png" alt="" align="middle"/> <a href="/dthema.php?id=' . $t['id'] . '&do">Скачать тему</a>';
echo ' | ';
echo '<img src="/images/files.png" alt="" align="middle"/> <a href="/forum/files' . $t['id'] . '">Файлы темы</a>';
echo '</div>';
echo '<div class="menu2">';
echo '<img src="/design/alll.png" alt="" align="middle"/> Правила: <a href="/all/rulls.php?all" style="text-decoration:none; color:white;">сайта</a>/<a href="/forum/rulls' . $pr['id'] . '" style="text-decoration:none; color:white;">подраздела</a>';
echo ' | ';
echo '<img src="/design/emoc.png" alt="" align="middle"/> <a href="/all/smiles_r.php" style="text-decoration:none; color:white;">Смайлы</a>';
echo ' | ';
echo '<img src="/design/cod.png" alt="" align="middle"/> <a href="/all/bb.php" style="text-decoration:none; color:white;">ББ коды</a>';
echo ' | ';
echo '<img src="/design/usear.png" alt="" align="middle"/> <a href="/fsearch.php" style="text-decoration:none; color:white;">Поиск</a>';
echo '</div>';
}
}
break;
/*
---
Кто в теме
---
*/
case who:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)" . ($us['level']>0?'':'AND (`type`!='2')'), array ((int) $_GET['id']));
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "') AND (`time`>'" . (time () - 60) . "')");
H ('В теме ' . $items, 'В теме "' . $t['name'] . '" ' . $items . ' человек');
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1) {
$page = 1;
}
if ($page > $pages) {
$page = $pages;
}
$start = $page * $items_per_page - $items_per_page;
if ($items ==0) {
echo '<div class="lst">В теме никого нет!</div>';
}
else {
echo '<div class="list1">';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "') AND (`time`>'" . (time () - 60) . "') ORDER BY `time` DESC LIMIT $start, $items_per_page");
while ($visit = $query -> fetch ()) {
echo uNick ($visit['us']).', ';
}
echo '</div>';
echo '<div class="lst">' . pages ('/forum/who' . $t['id']) . '</div>';
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
/*
---
Кто был в теме
---
*/
case visit:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)" . ($us['level']>0?'':'AND (`type`!='2')'), array ((int) $_GET['id']));
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "')");
H ('В теме ' . $items, 'В тему "' . $t['name'] . '" зашло ' . $items . ' человек');
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
if ($items == 0) {
echo '<div class="lst">В теме никого небыло!</div>';
}
else {
echo ' <div class="list1">';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_visit` WHERE (`id_t`='" . $t['id'] . "') ORDER BY `time` DESC LIMIT $start, $items_per_page");
while ($visit = $query -> fetch ()) {
echo uNick ($visit['us']) . ' (' . datef ($visit['time']) . ')<br/>';
}
echo '</div>';
echo '<div class="lst">' . pages ('/forum/visit' . $t['id']) . '</div>';
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
case post:
if (!isset ($_GET['post'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`=?)", array ((int) $_GET['post']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$p = $query -> fetch ();
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t'] . "')");
if ($t['type']==2) {
header ('location: /forum.php');
exit;
}
$page = isset ($_GET['page']) ? (int) $_GET['page'] : 1;
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['us'] . "')");
if ($u['id']==$us['id'] && $us['level']>0 || $u['level']<$us['level']) {
if ($p['del']==0) {
if ($p['ups']!=0) {
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['ups'] . "')");
if ($u['id'] == $us['id'] || $u['level']<$us['level']) {
DB :: $dbs -> query ("UPDATE `forum_p` SET `del` = '" . $us['id'] . "', `ups`='0' WHERE (`id`='" . $p['id'] . "')");
}
}
else {
DB :: $dbs -> query ("UPDATE `forum_p` SET `del`='" . $us['id'] . "' WHERE (`id`='" . $p['id'] . "')");
}
}
else {
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['del'] . "')");
if ($u['id'] == $us['id'] || $u['level']<$us['level']) {
DB :: $dbs -> query ("UPDATE `forum_p` SET `del` = '0', `ups`='" . $us['id'] . "' WHERE (`id`='" . $p['id'] . "')");
}
}
}
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
break;
case redk:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$p = $query -> fetch ();
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t'] . "')");
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
H ('Редактирование сообщения', $t['name']);
if ($t['type']==2) {
echo '<div class="lst">Данная тема удалена!</div>';
}
else {
if ($t['type']==0) {
echo '<div class="lst">Ошибка!</div>';
}
else {
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $p['us'] . "')");
if ($p['us']==$us['id'] || $p['us']!=$us['id'] && $u['level']<$us['level']) {
echo '<div class="list1">';
echo '<form action="/forum/redk' . $p['id'] . '?ok" method="post" enctype="multipart/form-data">';
echo 'Сообщение:<br/>';
echo '<textarea name="msg">' . $p['text'] . '</textarea><br/>';
if ($us['file']==1) {
echo 'Файл:<br/>';
echo '<input type="file" name="filename"/><br/>';
}
echo '<input type="submit" value="Написать"/>';
echo '</form>';
echo '</div>';
if (isset ($_GET['ok'])) {
$_POST['msg'] = htmlspecialchars (addslashes (trim ($_POST['msg'])));
if (empty ($_POST['msg'])) {
echo '<div class="list1"><b>Вы не ввели сообщение..</b></div>';
}
else {
if ($_POST['msg']!=$p['text']) {
DB :: $dbs -> query ("UPDATE `forum_p` SET `text`=? WHERE (`id`='" . $p['id'] . "')", array ($_POST['msg']));
DB :: $dbs -> query ("INSERT INTO `forum_reds` (`id_p`,`us`,`time`) VALUES ('" . $p['id'] . "', '" . $us['id'] . "', '" . time () . "')");
}
$filename = NULL;
$ext = substr ($_FILES['filename']['name'], strrpos ($_FILES['filename']['name'], '.') + 1);
if (in_array ($ext, array ('jpg','gif','png','jpeg','bmp','zip','rar','7z','txt','mp3','avi','mp4','3gp'))) {
$filename = $us['id'] . '_' . passgen () . '.' . $ext;
copy ($_FILES['filename']['tmp_name'], $_SERVER['DOCUMENT_ROOT'] . '/files/forum/' . $filename);
DB :: $dbs -> query ("INSERT INTO `forum_f` (`id_t`,`id_p`, `name`, `size`) VALUES ('" . $t['id'] . "', '" . $p['id'] . "', '" . $filename . "', '" . $_FILES['filename']['size'] . "')");
}
header ('location: /forum/thema' . $t['id'] . '/page' . ceil ( DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . ($us['level']>0 ? '' : 'AND (`del` = '0')')) / 10));
}
}
}
}
}
break;
case vote:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$p = $query -> fetch ();
if (DB :: $dbs -> querySingle ("SELECT * FROM `forum_vote` WHERE (`id_t`='" . $p['id_t'] . "') AND (`id_p`='" . $p['id'] . "') AND (`us`='" . $us['id'] . "')") != 0) {
header ('location: /forum.php');
exit;
}
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t'] . "')");
if ($t['type']!=1) {
header ('location: /forum.php');
exit;
}
if ($p['del']!=0) {
header ('location: /forum.php');
exit;
}
if (!isset ($_GET['vot'])) {
header ('location: /forum.php');
exit;
}
if (!isset ($_GET['v'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `us` WHERE (`id`=?)", array ((int) $_GET['v']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$v = $query -> fetch ();
if ($v['id'] == $us['id']) {
header ('location: /forum.php');
exit;
}
$page = isset ($_GET['page']) ? (int) $_GET['page'] : 1;
if ($_GET['vot']=='za') {
DB :: $dbs -> query ("UPDATE `us` SET `reit`='" . ($v['reit'] + 0.01) . "' WHERE (`id`='" . $v['id'] . "')");
DB :: $dbs -> query ("INSERT INTO `action` (`value`,`t`,`us`,`see`) VALUES ('us{" . $us['id'] . "} оценил [b]положительно[/b] ваш пост:[br]" . $p['text'] . " в теме [url=/forum/thema" . $t['id'] . "/page" . $page . "]" . $t['name'] . "[/url]!', '" . time () . "', '" . $v['id'] . "', '1')");
DB :: $dbs -> query ("INSERT INTO `forum_vote` (`id_t`,`id_p`,`us`,`vot`, `kem`,`t`) VALUES ('" . $t['id'] . "','" . $p['id'] . "','" . $v['id'] . "','za', '" . $us['id'] . "', '" . time () . "')");
}
elseif ($_GET['vot']=='protiv') {
DB :: $dbs -> query ("UPDATE `us` SET `reit`='" . ($v['reit'] - 0.01) . "' WHERE (`id`='" . $v['id'] . "')");
DB :: $dbs -> query ("INSERT INTO `action` (`value`,`t`,`us`,`see`) VALUES ('us{" . $us['id'] . "} оценил [b]отрицательно[/b] ваш пост:[br]" . $p['text'] . " в теме [url=/forum/thema" . $t['id'] . "/page" . $page . "]" . $t['name'] . "[/url]!', '" . time () . "', '" . $v['id'] . "', '1')");
DB :: $dbs -> query ("INSERT INTO `forum_vote` (`id_t`,`id_p`,`us`,`vot`, `kem`,`t`) VALUES ('" . $t['id'] . "','" . $p['id'] . "','" . $us['id'] . "','protiv', '" . $us['id'] . "','" . time () ."')");
}
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
break;
case thems:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `us` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$u = $query -> fetch ();
H ('Темы ' . $u['nick'], '<a href="/forum.php" style="color:white;">Форум</a> | Темы ' . uNick ($u['id']));
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`us`='" . $u['id'] . "') " . ($us['level']>0 ? '' : 'AND (`type`!='2')'));
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
echo '<div class="menu2">Вcего ' . endi ($items, array ('тема', 'темы', 'тем')) . '</div>';
if ($items == 0) {
echo '<div class="lst">' . uNick ($u['id']) . ' не создавал тем на форуме!</div>';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`us`='" . $u['id'] . "') " . ($us['level']>0 ? '' : 'AND (`type`!='2')') . " ORDER BY `id` DESC LIMIT $start, $items_per_page");
while ($t = $query -> fetch ()) {
$r = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_r` WHERE (`id`='" . $t['id_r'] . "')");
$pr= DB :: $dbs -> queryFetch ("SELECT * FROM `forum_pr` WHERE (`id`='" . $t['id_pr'] . "')");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . ($us['level']>0? '' : 'AND `del`='0''));
echo '<div class="lst">Раздел: <a href="/forum/' . $t['id_r'] . '">' . $r['name'] . '</a><br/>';
echo 'Подраздел: <a href="/forum/' . $t['id_r'] . '/' . $t['id_pr'] . '">' . $pr['name'] . '</a><br/>';
echo '<img src="/design/' . ($t['top'] == 1 ? 'prikrep' : ($t['type'] == 0 ? 'closed' : 'the')) . '.png" alt=""/> Тема: <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p . ') <a href="/forum/thema' . $t['id'] . '/page' . ceil ($c_p/10) . '">></a><br/>' . uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) . ')<br/>';
$c_f = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_t`= '" . $t['id'] . "')");
if ($c_f != 0) {
echo '<img src="/images/page_white_get.png" alt="" align="middle"/> Файлов: <a href="/forum/files' . $t['id'] . '">' . $c_f . '</a><br/>';
}
echo '</div>';
}
echo '<div class="lst">' . pages ('/thems' . $u['id']) . '</div>';
}
break;
case posts:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `us` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$u = $query -> fetch ();
H ('Посты ' . $u['nick'], '<a href="/forum.php" style="color:white;">Форум</a> | Посты ' . uNick ($u['id']));
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` LEFT JOIN `forum_t` ON `forum_t`.`id`=`forum_p`.`id_t` WHERE (`forum_p`.`us`='" . $u['id'] . "') " . ($us['level']>0 ? '' : 'AND (`forum_t`.`type`!='2') AND (`forum_p`.`del`='0')'));
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
echo '<div class="menu2">Вcего ' . endi ($items, array ('пост', 'поста', 'постов')) . '</div>';
if ($items == 0) {
echo '<div class="lst">' . uNick ($u['id']) . ' не оставлял постов на форуме!</div>';
}
else {
$query = DB :: $dbs -> query ("SELECT `forum_p`.* FROM `forum_p` LEFT JOIN `forum_t` ON `forum_t`.`id`=`forum_p`.`id_t` WHERE (`forum_p`.`us`='" . $u['id'] . "') " . ($us['level']>0 ? '' : 'AND (`forum_t`.`type`!='2') AND (`forum_p`.`del`='0')') . " ORDER BY `forum_p`.`id` DESC LIMIT $start, $items_per_page");
while ($p = $query -> fetch ()) {
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t'] . "')");
echo '<div class="list1">';
echo '<img src="/design/' . ($t['top']==1? 'prikrep' : ($t['type']==0 ? 'closed' : 'the')) . '.png" alt=""/> Тема: <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a><br/>';
echo uNick ($p['us']) . ' (' . datef ($p['time']) . ')';
$za = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_vote` WHERE (`id_p`='" . $p['id'] . "') AND (`vot`='za')");
$protiv = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_vote` WHERE (`id_p`='" . $p['id'] . "') AND (`vot`='protiv')");
// display post votes
echo ' (<span style="color:green;">' . $za . '</span>/<span style="color:red;">' . $protiv . '</span>)<br/>';
// if post have quote
if ($p['cit'] != 0) {
echo 'Цитата:';
echo '<div class="cit">';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`='" . $p['cit'] . "')");
if ($q -> rowCount () == 0) {
echo '<b>Сообщение удалено!</b>';
}
else {
//
$cit = $q -> fetch ();
if ($cit['del'] !=0 ) {
echo '<b>Сообщение удалено!</b>';
}
else {
$citu = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $cit['us'] . "')");
echo '<b style="color:red;">' . $citu['nick'] . '</b>: ' . bb ($cit['text']);
}
}
echo '</div>';
}
echo bb ($p['text']) . '<br/>';
// if post have attachment files
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "')") != 0) {
echo '<b>Прикрепленные файлы:</b><br/>';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id`");
while ($f = $q -> fetch ()) {
echo '<a href="/files/forum/' . $f['name'] . '">' . $f['name'] . '</a> (' . sizef ($f['size']) . ')<br/>';
}
}
$q = DB :: $dbs -> query ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "')");
if ($q -> rowCount () != 0) {
$redk = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id` DESC LIMIT 1");
echo '
________<br/>
<small>Пост изменён <a href="/forums/reds.php?id=' . $p['id'] . '">' . $q -> rowCount () . ' раз.</a> Посл. ред. ' . uNick ($redk['us']) . ' (' . datef ($redk['time']) . ')</small>
';
}
echo '</div>';
}
echo '<div class="list1">' . pages ('/posts' . $u['id']) . '</div>';
}
break;
case filez:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)" . ($us['level']>0?'':'AND (`type`!='2')'), array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_t`='" . $t['id'] . "')");
H ('В теме ' . $items . ' файлов', 'В теме "' . $t['name'].'" ' . endi ($items, array ('файл', 'файла', 'файлов')));
if ($t['type']==2) {
echo '<div class="list1">Данная тема удалена!</div>';
}
else {
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1)
$page = 1;
if ($page > $pages)
$page = $pages;
$start = $page * $items_per_page - $items_per_page;
if ($items==0) {
echo '<div class="list1">В этой теме файлов нет!</div>';
}
else {
echo '<div class="list1">';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_f` WHERE (`id_t`='" . $t['id'] . "') ORDER BY `id` DESC LIMIT $start, $items_per_page");
while ($f = $query -> fetch ()) {
echo 'Файл: <a href="/files/forum/' . $f['name'] . '">' . $f['name'] . '</a> (' . sizef ($f['size']) . ')<br/>';
}
echo '</div>';
echo '<div class="lst">' . pages ('/forum/visit' . $t['id']) . '</div>';
}
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
/*
---
Добавление опроса
---
*/
case op_add:
if (!isset ($_GET['thema'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['thema']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
if ($u['id']!=$us['id'] || $u['id']!= $us['id'] && $u['level']>$us['level']) {
header ('location: /forum.php');
exit;
}
H ('Добавление голосования', $t['name']);
if ($t['type']==2) {
echo '<div class="list1">Данная тема удалена!</div>';
}
else {
if ($t['type']==0) {
echo '
<div class="list1">
Тема закрыта!
</div>
';
}
else {
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "')") != 0) {
header ('location: /forum/thema' . $t['id']);
exit;
}
echo '
<div class="list1">
<form action="/forum.php?mod=op_add&thema=' . $t['id'] . '&add" method="post">
Вопрос:<br/>
<input name="vopros"/><br/>
';
for ($i = 1; $i < 9; $i++) {
echo '
Вариант ответа ' . $i . ':<br/>
<input name="otv[]"/><br/>
';
}
echo 'Тип:<br/><select name="type">';
echo '<option value="1">открытое</option>';
echo '<option value="0">закрытое</option>';
echo '</select><br/>';
echo '<input type="submit" value="Добавить опрос"/>';
echo '</form>';
echo '</div>';
if (isset ($_GET['add'])) {
$_POST['vopros'] = htmlspecialchars (addslashes (trim ($_POST['vopros'])));
if (empty ($_POST['vopros'])) {
echo '
<div class="list1">
<b style="color:red;">Вы не ввели вопрос..</b>
</div>
';
}
else {
//
foreach ($_POST['otv'] as $otv) {
$otv = htmlspecialchars (addslashes (trim ($otv)));
if (!empty ($otv)) {
$otv_[] = $otv;
}
}
if (count ($otv_)==0) {
echo '
<div class="list1">
<b style="color:red;">Вы не указали ни одного ответа..</b>
</div>
';
}
else {
if (count ($otv_)<2) {
echo '
<div class="list1">
<b style="color:red;">Ошибка!</b>
</div>
';
}
else {
$_POST['type'] == intval ($_POST['type']);
DB :: $dbs -> query ("INSERT INTO `forum_op` (`id_t`,`vopros`,`type`) VALUES ('" . $t['id'] . "',?, ?)", array ($_POST['vopros'], $_POST['type']));
$id = DB :: $dbs -> lastInsertId ();
foreach ($otv_ as $otv) {
DB :: $dbs -> query ("INSERT INTO `forum_op_otv` (`id_r`,`id_pr`,`id_t`,`id_op`,`text`) VALUES ('" . $t['id_r'] . "', '" . $t['id_pr'] . "', '" . $t['id'] . "','" . $id . "',?)", array ($otv));
}
header ('location: /forum/thema' . $t['id']);
}
}
}
}
}
echo '
<div class="navg">
<a href="/forum/thema' . $t['id'] . '">Вернуться</a>
</div>
';
}
break;
/*
---
Добавление пунктов
---
*/
case 'vop_add':
if (!isset ($_GET['thema'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['thema']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
if ($u['id']!=$us['id'] || $u['level']>$us['level']) {
header ('location: /forum.php');
exit;
}
H ('Добавление пунктов', $t['name']);
if ($t['type']==2) {
echo '
<div class="list1">
Данная тема удалена!
</div>
';
}
else {
if ($t['type']==0) {
echo '
<div class="list1">
Тема закрыта!
</div>
';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "') AND (`id`=?)", array ((int) $_GET['op']));
if ($query -> rowCount () == 0) {
header ('location: /forum/thema' . $t['id']);
exit;
}
$op = $query -> fetch ();
echo '
<div class="list1">
<form action="/forum.php?mod=vop_add&thema=' . $t['id'] . '&op=' . $op['id'] . '&add" method="post">
';
for ($i = 1; $i < 9; $i++) {
echo '
Вариант ответа ' . $i . ':<br/>
<input name="otv[]"/><br/>
';
}
echo '
<input type="submit" value="Добавить"/>
</form>
</div>
';
if (isset ($_GET['add'])) {
foreach ($_POST['otv'] as $otv) {
$otv = htmlspecialchars (addslashes (trim ($otv)));
if (!empty ($otv)) {
$otv_[] = $otv;
}
}
if (count ($otv_)==0) {
echo '
<div class="list1">
<b style="color:red;">Вы не указали ни одного ответа..</b>
</div>
';
}
else {
foreach ($otv_ as $otv) {
DB :: $dbs -> query ("INSERT INTO `forum_op_otv` (`id_r`,`id_pr`,`id_t`,`id_op`,`text`) VALUES ('" . $t['id_r'] . "', '" . $t['id_pr'] . "', '" . $t['id'] . "','" . $op['id'] . "',?)", array ($otv));
}
header ('location: /forum/thema' . $t['id']);
}
}
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
}
break;
/*
---
Удаление пунктов
---
*/
case redop:
if (!isset ($_GET['thema'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['thema']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
if ($u['id']!=$us['id'] || $u['level']>$us['level']) {
header ('location: /forum.php');
exit;
}
H ('Удаление пунктов', $t['name']);
if ($t['type']==2) {
echo '
<div class="list1">
Данная тема удалена!
</div>
';
}
else {
if ($t['type']==0) {
echo '
<div class="list1">
Тема закрыта!
</div>
';
}
else {
if (!isset ($_GET['op'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op` WHERE (`id_t`='" . $t['id'] . "') AND (`id`=?)", array ((int) $_GET['op']));
if ($query -> rowCount () == 0) {
header ('location: /forum/thema' . $t['id']);
exit;
}
$op = $query -> fetch ();
echo '
<div class="list1">
<form action="/forum.php?mod=redop&thema=' . $t['id'] . '&op=' . $op['id'] . '&del" method="post">
';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_op_otv` WHERE (`id_op`='" . $op['id'] . "')");
while ($otv = $query -> fetch ()) {
echo '
<input type="checkbox" name="otv[]" value="' . $otv['id'] . '"/> ' . $otv['text'] . '<br/>
';
}
echo '
<input type="submit" value="Удалить"/>
</form>
</div>
';
if (isset ($_GET['del'])) {
foreach ($_POST['otv'] as $otv) {
$otv = (int) $otv;
if ($otv!=0) {
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_op_otv` WHERE (`id_op`='" . $op['id'] . "') AND (`id`='" . $otv . "')")!=0) {
DB :: $dbs -> query ("DELETE FROM `forum_op_otv` WHERE (`id`='" . $otv . "')");
DB :: $dbs -> query ("DELETE FROM `forum_op_vote` WHERE (`otv`='" . $otv . "')");
}
}
}
header ('location: /forum/thema' . $t['id']);
}
}
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
case stat:
if (isset ($_GET['new_thems'])) {
H ('Новые темы', 'Новые темы');
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`date`>'" . ( time () - 86400 ) . "')");
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1) {
$page = 1;
}
if ($page > $pages) {
$page = $pages;
}
$start = $page * $items_per_page - $items_per_page;
if ($items==0) {
echo '<div class="list1">Новых тем нет..</div>';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`date`>'" . (time () - 86400) . "') ORDER BY `id` DESC LIMIT $start, $items_per_page");
while ($t = $query -> fetch()) {
$r = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_r` WHERE (`id`='" . $t['id_r'] . "')");
$pr = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_pr` WHERE (`id`='" . $t['id_pr']. "')");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . (isset ($us) ? ($us['level']>0 ? '' : 'AND (`del`='0')') : 'AND (`del`='0')'));
echo '<div class="list1">';
echo 'Раздел: <a href="/forum/razd' . $r['id'] . '">' . $r['name'] . '</a><br/>';
echo 'Подраздел: <a href="/forum/' . $r['id'] . '/' . $pr['id'] . '">' . $pr['name'] . '</a><br/>';
echo '<img src="/design/' . ($t['top']==1? 'prikrep' : ($t['type']==0 ? 'closed' : 'the')) . '.png" alt=""/> Тема: <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p.') <a href="/forum/thema' . $t['id'] . '/page' . ceil ( $c_p / 10 ) . '">>></a><br/>';
echo uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) . ')';
echo '</div>';
}
echo '<div class="list1">' . pages ('/forum/new_thems') . '</div>';
}
}
elseif (isset ($_GET['obn_thems'])) {
H ('Обновленные темы', 'Обновленные темы');
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_t` WHERE (`time`>'" . ( time () - 3600 ). "')");
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1) {
$page = 1;
}
if ($page > $pages) {
$page = $pages;
}
$start = $page * $items_per_page - $items_per_page;
if ($items==0) {
echo '<div class="list1">Обновленных тем нет..</div>';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`time`>'" . (time () - 3600) . "') ORDER BY `id` DESC LIMIT $start, $items_per_page");
while ($t = $query -> fetch()) {
$r = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_r` WHERE (`id`='" . $t['id_r'] . "')");
$pr = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_pr` WHERE (`id`='" . $t['id_pr']. "')");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . (isset ($us) ? ($us['level']>0 ? '' : 'AND (`del`='0')') : 'AND (`del`='0')'));
echo '<div class="list1">';
echo 'Раздел: <a href="/forum/razd' . $r['id'] . '">' . $r['name'] . '</a><br/>';
echo 'Подраздел: <a href="/forum/' . $r['id'] . '/' . $pr['id'] . '">' . $pr['name'] . '</a><br/>';
echo 'Тема: <img src="/design/' . ($t['top']==1? 'prikrep' : ($t['type']==0 ? 'closed' : 'the')) . '.png" alt=""/> <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p.') <a href="/forum/thema' . $t['id'] . '/page' . ceil ( $c_p / 10 ) . '">>></a><br/>';
echo uNick ($t['us']) . '/' . uNick ($t['last']) . ' (' . datef ($t['time']) . ')';
echo '</div>';
}
echo '<div class="list1">' . pages ('/forum/obn_thems') . '</div>';
}
}
else if (isset ($_GET['new_posts'])) {
H ('Новые посты', 'Новые посты');
$items = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`time`>'" . ( time () - 86400 ). "')");
$items_per_page = 10;
$pages = ceil ( $items / $items_per_page );
$page = (int) $_GET['page'];
if ($page < 1) {
$page = 1;
}
if ($page > $pages) {
$page = $pages;
}
$start = $page * $items_per_page - $items_per_page;
if ($items==0) {
echo '<div class="list1">Новых постов нет..</div>';
}
else {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`time`>'" . (time () - 86400) . "') ORDER BY `id` DESC LIMIT $start, $items_per_page");
while ($p = $query -> fetch()) {
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t']. "')");
$c_p = DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_p` WHERE (`id_t`='" . $t['id'] . "') " . (isset ($us) ? ($us['level']>0 ? '' : 'AND (`del`='0')') : 'AND (`del`='0')'));
echo '<div class="list1">';
echo 'Тема: <img src="/design/' . ($t['top']==1? 'prikrep' : ($t['type']==0 ? 'closed' : 'the')) . '.png" alt=""/> <a href="/forum/thema' . $t['id'] . '">' . $t['name'] . '</a> (' . $c_p.') <a href="/forum/thema' . $t['id'] . '/page' . ceil ( $c_p / 10 ) . '">>></a><br/>';
echo uNick ($p['us']) . ' (' . datef ($p['time']) . ')<br/>';
// if post have quote
if ($p['cit'] != 0) {
echo '
Цитата:
<div class="cit">
';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_p` WHERE (`id`='" . $p['cit'] . "')");
if ($q -> rowCount () == 0) {
echo '
<b>Сообщение удалено!</b>
';
}
else {
//
$cit = $q -> fetch ();
if ($cit['del'] !=0 ) {
echo '
<b>Сообщение удалено!</b>
';
}
else {
$citu = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $cit['us'] . "')");
echo '
<b style="color:red;">' . $citu['nick'] . '</b>: ' . bb ($cit['text']);
}
}
echo '
</div>
';
}
echo bb ($p['text']) . '<br/>
';
// if post have attachment files
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "')") != 0) {
echo '
<b>Прикрепленные файлы:</b><br/>
';
$q = DB :: $dbs -> query ("SELECT * FROM `forum_f` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id`");
while ($f = $q -> fetch ()) {
echo '<a href="/files/forum/' . $f['name'] . '">' . $f['name'] . '</a> (' . sizef ($f['size']) . ')<br/>
';
}
}
$q = DB :: $dbs -> query ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "')");
if ($q -> rowCount () != 0) {
$redk = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_reds` WHERE (`id_p`='" . $p['id'] . "') ORDER BY `id` DESC LIMIT 1");
echo '
________<br/>
<small>Пост изменён <a href="/forums/reds.php?id=' . $p['id'] . '">' . $q -> rowCount () . ' раз.</a> Посл. ред. ' . uNick ($redk['us']) . ' (' . datef ($redk['time']) . ')</small>
';
}
echo '
</div>
';
}
echo '<div class="list1">' . pages ('/forum/new_posts') . '</div>';
}
}
else {
}
break;
/*
---
Переименование темы
---
*/
case thn:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$a = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
if ($t['us'] != $us['id'] && $us['level']<1 || $a['level']>$us['level']) {
header ('location: /forum/thema' . $t['id']);
exit;
}
H ('Переименовать тему', '<a href="/forum/thema' . $t['id'] . '" style="color:white;">' . $t['name'] . '</a>');
echo '
<div class="list1">
<form action="/forum.php?mod=thn&id=' . $t['id'] . '&ok" method="post">
Введите название темы:<br/>
<input name="name" value="' . $t['name'] . '"/><br/>
<input type="submit" value="Изменить"/>
</form>
</div>
';
if (isset ($_GET['ok'])) {
$_POST['name'] = htmlspecialchars (addslashes (trim ($_POST['name'])));
if (empty ($_POST['name'])) {
echo '
<div class="list1">
<b style="color:red;">Вы не ввели название темы..</b>
</div>
';
}
else {
if ($t['name']!=$_POST['name']) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `name`=? WHERE (`id`='" . $t['id'] . "')", array ($_POST['name']));
}
header ('location: /forum/thema' . $t['id']);
}
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
/*
---
Перемещение темы
---
*/
case thm:
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_t` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount ()==0) {
header ('location: /forum.php');
exit;
}
$t = $query -> fetch ();
$a = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
if ($t['us'] != $us['id'] && $us['level']<1 || $a['level']>$us['level']) {
header ('location: /forum/thema' . $t['id']);
exit;
}
H ('Переместить тему', '<a href="/forum/thema' . $t['id'] . '" style="color:white;">' . $t['name'] . '</a>');
echo '
<div class="list1">
<form action="/forum.php?mod=thm&id=' . $t['id'] . '&ok" method="post">
<select name="pr"/>
';
$query = DB :: $dbs -> query ("SELECT * FROM `forum_r` ORDER BY `id`");
while ($r = $query -> fetch()) {
echo '
<option value="">' . $r['name'] . '</option>
';
if (DB :: $dbs -> querySingle ("SELECT COUNT(*) FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "')") != 0) {
$q = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id_r`='" . $r['id'] . "') ORDER BY `id`");
while ($pr = $q -> fetch ()) {
echo '
<option value="' . $pr['id'] . '">---' . $pr['name'] . '</option>
';
}
}
}
echo '
</select><br/>
<input type="submit" value="Переместить"/>
</form>
</div>
';
if (isset ($_GET['ok'])) {
$query = DB :: $dbs -> query ("SELECT * FROM `forum_pr` WHERE (`id`=?)", array (intval ($_POST['pr'])));
if ($query -> rowCount () == 0) {
header ('location: /forum.php?mod=thm&id=' . $t['id']);
exit;
}
$pr = $query -> fetch ();
$r = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_r` WHERE (`id`='" . $pr['id_r'] . "')");
if ($t['id_r']!=$r['id'] || $t['id_pr']!=$pr['id']) {
DB :: $dbs -> query ("UPDATE `forum_t` SET `id_r`='" . $pr['id_r'] . "', `id_pr`='" . $pr['id'] . "', `name`='" . $t['name'] . " (Перемещена)' WHERE (`id`='" . $t['id'] . "')");
DB :: $dbs -> query ("UPDATE `forum_visit` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_podp` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_op` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_op_otv` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_op_vote` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_p` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_reds` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_vote` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
//
DB :: $dbs -> query ("UPDATE `forum_f` SET `id_r`='" . $r['id'] . "', `id_pr`='" . $pr['id'] . "' WHERE (`id_t`='" . $t['id'] . "')");
DB :: $dbs -> query ("INSERT INTO `forum_p` (`id_r`, `id_pr`, `id_t`,`us`, `text`, `time`) VALUES ('" . $r['id'] . "', '" . $pr['id'] . "', '" . $t['id'] . "', '" . $us['id'] . "', '[b]Тема перемещена в " . $r['name'] . "/" . $pr['name'] . "![/b]', '" . time () . "')");
}
header ('location: /forum/thema' . $t['id']);
}
echo '<div class="navg"><a href="/forum/thema' . $t['id'] . '">Вернуться</a></div>';
break;
/*
---
Удаление файла
---
*/
case 'file':
if (!isset ($_GET['id'])) {
header ('location: /forum.php');
exit;
}
$query = DB :: $dbs -> query ("SELECT * FROM `forum_f` WHERE (`id`=?)", array ((int) $_GET['id']));
if ($query -> rowCount () == 0) {
header ('location: /forum.php');
exit;
}
$f = $query -> fetch ();
$p = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_p` WHERE (`id`='" . $f['id_p'] . "')");
$u = DB :: $dbs -> queryFetch ("SELECT * FROM `us` WHERE (`id`='" . $t['us'] . "')");
$t = DB :: $dbs -> queryFetch ("SELECT * FROM `forum_t` WHERE (`id`='" . $p['id_t'] . "')");
if ($t['type']==2) {
header ('location: /forum.php');
exit;
}
if ($f['size']==0) {
header ('location: /forum.php');
exit;
}
$page = isset ($_GET['page']) ? (int) $_GET['page'] : 1;
if ($p['us']==$us['id'] && $us['level']>1 || $u['level']<$us['level']) {
DB :: $dbs -> query ("UPDATE `forum_f` SET `size`='0' WHERE (`id`='" . $f['id'] . "')");
if (file_exists ($_SERVER['DOCUMENT_ROOT'] . '/files/forum/' . $f['filename'])) {
unlink ('files/forum/' . $f['name']);
}
}
header ('location: /forum/thema' . $t['id'] . '/page' . $page);
break;
}
F ();
?>