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

Размер файла: 13.01Kb
  1. <?php
  2. #-----------------------------------------------------#
  3. # ********* ROTORCMS ********* #
  4. # Made by : VANTUZ #
  5. # E-mail : visavi.net@mail.ru #
  6. # Site : http://pizdec.ru #
  7. # WAP-Site : http://visavi.net #
  8. # ICQ : 36-44-66 #
  9. # Вы не имеете право вносить изменения в код скрипта #
  10. # для его дальнейшего распространения #
  11. #-----------------------------------------------------#
  12. require_once ('../includes/start.php');
  13. require_once ('../includes/functions.php');
  14. require_once ('../includes/header.php');
  15. include_once ('../themes/' . $config['themes'] . '/index.php');
  16.  
  17. if (isset($_GET['fid'])) {
  18. $fid = abs(intval($_GET['fid']));
  19. } else {
  20. $fid = 0;
  21. }
  22. if (isset($_GET['start'])) {
  23. $start = abs(intval($_GET['start']));
  24. } else {
  25. $start = 0;
  26. }
  27. if (isset($_GET['act'])) {
  28. $act = check($_GET['act']);
  29. } else {
  30. $act = 'index';
  31. }
  32.  
  33. show_title('menu.png', 'Форум ' . $config['title']);
  34.  
  35. switch ($act):
  36. # ###########################################################################################
  37. # # Главная страница ##
  38. # ###########################################################################################
  39. case "index":
  40. $queryforum = DB :: $dbh -> query("SELECT * FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($fid));
  41. $forums = $queryforum -> fetch();
  42.  
  43. if (!empty($forums)) {
  44. $config['newtitle'] = $forums['forums_title'];
  45.  
  46. echo '<a href="#down"><img src="../images/img/downs.gif" alt="Вниз" /></a> ';
  47. echo '<a href="index.php?' . SID . '">Форум</a> / ';
  48.  
  49. if (!empty($forums['forums_parent'])) {
  50. $querysub = DB :: $dbh -> query("SELECT `forums_id`, `forums_title` FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($forums['forums_parent']));
  51. $sub = $querysub -> fetch();
  52. echo '<a href="forum.php?fid=' . $sub['forums_id'] . '&amp;' . SID . '">' . $sub['forums_title'] . '</a> / ';
  53. }
  54.  
  55. echo '<a href="forum.php?fid=' . $fid . '&amp;start=' . $start . '&amp;rand=' . mt_rand(1000, 9999) . '&amp;' . SID . '">Обновить</a> / ';
  56. echo '<a href="forum.php?act=addtheme&amp;fid=' . $fid . '&amp;' . SID . '">Создать тему</a><br /><br />';
  57.  
  58. echo '<img src="../images/img/themes.gif" alt="image" /> <b>' . $forums['forums_title'] . '</b>';
  59.  
  60. if (is_admin()) {
  61. echo ' (<a href="' . ADMINDIR . 'forum.php?act=forum&amp;fid=' . $fid . '&amp;start=' . $start . '&amp;' . SID . '">Управление</a>)';
  62. }
  63. echo '<hr />';
  64.  
  65. $querysub = DB :: $dbh -> query("SELECT * FROM `forums` WHERE `forums_parent`=?;", array($fid));
  66. $sub = $querysub -> fetchAll();
  67.  
  68. if (count($sub) > 0 && $start == 0) {
  69. foreach($sub as $subdata) {
  70. echo '<div class="b"><img src="../images/img/forums.gif" alt="image" /> ';
  71. echo '<b><a href="forum.php?fid=' . $subdata['forums_id'] . '&amp;' . SID . '">' . $subdata['forums_title'] . '</a></b> (' . $subdata['forums_topics'] . '/' . $subdata['forums_posts'] . ')</div>';
  72.  
  73. if ($subdata['forums_last_id'] > 0) {
  74. echo '<div>Тема: <a href="topic.php?act=end&amp;tid=' . $subdata['forums_last_id'] . '&amp;' . SID . '">' . $subdata['forums_last_themes'] . '</a><br />';
  75. echo 'Сообщение: ' . nickname($subdata['forums_last_user']) . ' (' . date_fixed($subdata['forums_last_time']) . ')</div>';
  76. } else {
  77. echo '<div>Темы еще не созданы!</div>';
  78. }
  79. }
  80. echo '<hr />';
  81. }
  82.  
  83. $total = DB :: $dbh -> querySingle("SELECT count(*) FROM `topics` WHERE `topics_forums_id`=?;", array($fid));
  84.  
  85. if ($total > 0) {
  86. if ($start >= $total) {
  87. $start = 0;
  88. }
  89.  
  90. $querytopic = DB :: $dbh -> query("SELECT * FROM `topics` WHERE `topics_forums_id`=? ORDER BY `topics_locked` DESC, `topics_last_time` DESC LIMIT " . $start . ", " . $config['forumtem'] . ";", array($fid));
  91.  
  92. while ($data = $querytopic -> fetch()) {
  93. echo '<div class="b">';
  94.  
  95. if ($data['topics_locked'] == 1) {
  96. echo '<img src="../images/img/lock.gif" alt="image" /> ';
  97. } elseif ($data['topics_closed'] == 1) {
  98. echo '<img src="../images/img/closed.gif" alt="image" /> ';
  99. } else {
  100. echo '<img src="../images/img/topics.gif" alt="image" /> ';
  101. }
  102.  
  103. echo '<b><a href="topic.php?tid=' . $data['topics_id'] . '&amp;' . SID . '">' . $data['topics_title'] . '</a></b> (' . $data['topics_posts'] . ')</div>';
  104. echo '<div>Страницы: ';
  105. forum_navigation('topic.php?tid=' . $data['topics_id'] . '&amp;', $config['forumpost'], $data['topics_posts']);
  106. echo 'Сообщение: ' . nickname($data['topics_last_user']) . ' (' . date_fixed($data['topics_last_time']) . ')</div>';
  107. }
  108.  
  109. page_strnavigation('forum.php?fid=' . $fid . '&amp;', $config['forumtem'], $start, $total);
  110.  
  111. echo '<a href="#up"><img src="../images/img/ups.gif" alt="up" /></a> ';
  112. echo '<a href="forum.php?act=addtheme&amp;fid=' . $fid . '&amp;' . SID . '">Создать тему</a> / ';
  113. echo '<a href="../pages/rules.php?' . SID . '">Правила</a> / ';
  114. echo '<a href="top.php?act=themes&amp;' . SID . '">Топ тем</a> / ';
  115. echo '<a href="search.php?fid=' . $fid . '&amp;' . SID . '">Поиск</a><br />';
  116. } else {
  117. show_error('Тем еще нет, будь первым!');
  118. }
  119. } else {
  120. show_error('Ошибка! Данного раздела не существует!');
  121. }
  122. break;
  123. # ###########################################################################################
  124. # # Подготовка к созданию темы ##
  125. # ###########################################################################################
  126. case "addtheme":
  127.  
  128. $config['newtitle'] = 'Создание новой темы';
  129.  
  130. if (is_user()) {
  131. $queryforum = DB :: $dbh -> query("SELECT `forums_id`, `forums_parent`, `forums_title` FROM `forums` ORDER BY `forums_order` ASC;");
  132. $forums = $queryforum -> fetchAll();
  133.  
  134. if (count($forums) > 0) {
  135. echo '<div class="form" id="form">';
  136. echo '<form action="forum.php?act=add&amp;fid=' . $fid . '&amp;uid=' . $_SESSION['token'] . '&amp;' . SID . '" name="form" method="post">';
  137.  
  138. echo 'Раздел:<br />';
  139.  
  140. $output = array();
  141.  
  142. foreach ($forums as $row) {
  143. $i = $row['forums_id'];
  144. $p = $row['forums_parent'];
  145. $output[$p][$i] = $row;
  146. }
  147.  
  148. echo '<select name="fid">';
  149.  
  150. foreach ($output[0] as $key => $data) {
  151. $selected = ($fid == $data['forums_id']) ? ' selected="selected"' : '';
  152. echo '<option value="' . $data['forums_id'] . '"' . $selected . '>' . $data['forums_title'] . '</option>';
  153.  
  154. if (isset($output[$key])) {
  155. foreach($output[$key] as $datasub) {
  156. $selected = ($fid == $datasub['forums_id']) ? ' selected="selected"' : '';
  157. echo '<option value="' . $datasub['forums_id'] . '"' . $selected . '>– ' . $datasub['forums_title'] . '</option>';
  158. }
  159. }
  160. }
  161.  
  162. echo '</select><br />';
  163.  
  164. echo 'Заголовок:<br />';
  165. echo '<input type="text" name="title" size="50" maxlength="50" /><br />';
  166. echo 'Сообщение:<br />';
  167. echo '<textarea cols="25" rows="3" name="msg" id="msg"></textarea><br />';
  168.  
  169. if (!empty($udata['users_bbpanel'])) {
  170. quickpaste('msg');
  171. quickcode();
  172. quicksmiles();
  173. }
  174.  
  175. echo '<input value="Создать тему" type="submit" /></form></div><br />';
  176.  
  177. echo 'Прежде чем создать новую тему необходимо ознакомиться с правилами<br />';
  178. echo '<a href="../pages/rules.php?' . SID . '">Правила сайта</a><br />';
  179. echo 'Также убедись что такой темы нет, чтобы не создавать одинаковые, для этого введи ключевое слово в поиске<br />';
  180. echo '<a href="search.php?' . SID . '">Поиск по форуму</a><br />';
  181. echo 'И если после этого вы уверены, что ваша тема будет интересна другим пользователям, то можете ее создать<br /><br />';
  182. } else {
  183. show_error('Разделы форума еще не созданы!');
  184. }
  185. } else {
  186. show_login('Вы не авторизованы, для создания новой темы, необходимо');
  187. }
  188.  
  189. echo '<img src="../images/img/back.gif" alt="image" /> <a href="forum.php?fid=' . $fid . '&amp;' . SID . '">Вернуться</a><br />';
  190. break;
  191. # ###########################################################################################
  192. # # Подготовка к созданию темы ##
  193. # ###########################################################################################
  194. case "add":
  195.  
  196. $uid = check($_GET['uid']);
  197. $fid = abs(intval($_POST['fid']));
  198. $title = check($_POST['title']);
  199. $msg = check($_POST['msg']);
  200.  
  201. if (is_user()) {
  202. if ($uid == $_SESSION['token']) {
  203. if (utf_strlen($title) >= 5 && utf_strlen($title) <= 50) {
  204. if (utf_strlen($msg) >= 5 && utf_strlen($msg) <= $config['forumtextlength']) {
  205. $queryforum = DB :: $dbh -> query("SELECT * FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($fid));
  206. $forums = $queryforum -> fetch();
  207.  
  208. if (!empty($forums)) {
  209. if (is_quarantine($log)) {
  210. if (is_flood($log)) {
  211. $msg = no_br($msg);
  212. $msg = antimat($msg);
  213. $msg = smiles($msg);
  214.  
  215. DB :: $dbh -> query("UPDATE `users` SET `users_allforum`=`users_allforum`+1, `users_point`=`users_point`+1, `users_money`=`users_money`+5 WHERE `users_login`=?", array($log));
  216.  
  217. DB :: $dbh -> query("INSERT INTO `topics` (`topics_forums_id`, `topics_title`, `topics_author`, `topics_posts`, `topics_last_user`, `topics_last_time`) VALUES (?, ?, ?, ?, ?, ?);", array($fid, $title, $log, 1, $log, SITETIME));
  218.  
  219. $lastid = DB :: $dbh -> lastInsertId();
  220.  
  221. DB :: $dbh -> query("INSERT INTO `posts` (`posts_topics_id`, `posts_forums_id`, `posts_user`, `posts_text`, `posts_time`, `posts_ip`, `posts_brow`) VALUES (?, ?, ?, ?, ?, ?, ?);", array($lastid, $fid, $log, $msg, SITETIME, $ip, $brow));
  222.  
  223. DB :: $dbh -> query("UPDATE `forums` SET `forums_topics`=`forums_topics`+1, `forums_posts`=`forums_posts`+1, `forums_last_id`=?, `forums_last_themes`=?, `forums_last_user`=?, `forums_last_time`=? WHERE `forums_id`=?", array($lastid, $title, $log, SITETIME, $fid));
  224. // Обновление родительского форума
  225. if ($forums['forums_parent'] > 0) {
  226. DB :: $dbh -> query("UPDATE `forums` SET `forums_last_id`=?, `forums_last_themes`=?, `forums_last_user`=?, `forums_last_time`=? WHERE `forums_id`=?", array($lastid, $title, $log, SITETIME, $forums['forums_parent']));
  227. }
  228.  
  229. $_SESSION['note'] = 'Новая тема успешно добавлена!';
  230. header ("Location: topic.php?tid=$lastid&" . SID);
  231. exit;
  232. } else {
  233. show_error('Антифлуд! Разрешается отправлять сообщения раз в ' . flood_period() . ' секунд!');
  234. }
  235. } else {
  236. show_error('Карантин! Вы не можете писать в течении ' . round($config['karantin'] / 3600) . ' часов!');
  237. }
  238. } else {
  239. show_error('Ошибка! Раздела для новой темы не существует!');
  240. }
  241. } else {
  242. show_error('Ошибка! Слишком длинное или короткое сообщение!');
  243. }
  244. } else {
  245. show_error('Ошибка! Слишком длинный или короткий заголовок темы!');
  246. }
  247. } else {
  248. show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
  249. }
  250. } else {
  251. show_login('Вы не авторизованы, для создания новой темы, необходимо');
  252. }
  253.  
  254. echo '<img src="../images/img/back.gif" alt="image" /> <a href="forum.php?fid=' . $fid . '&amp;' . SID . '">К темам</a><br />';
  255. break;
  256.  
  257. default:
  258. header("location: index.php?" . SID);
  259. exit;
  260. endswitch;
  261.  
  262. echo '<img src="../images/img/reload.gif" alt="image" /> <a href="index.php?' . SID . '">К форумам</a><br />';
  263. echo '<img src="../images/img/homepage.gif" alt="image" /> <a href="../index.php?' . SID . '">На главную</a>';
  264.  
  265. include_once ('../themes/' . $config['themes'] . '/foot.php');
  266.  
  267. ?>