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

Размер файла: 11.27Kb
  1. <?php
  2.  
  3. require_once('../includes/start.php');
  4. require_once('../includes/functions.php');
  5. require_once('../includes/header.php');
  6. include_once ("../themes/".$config['themes']."/verh.dat");
  7. $act = (isset($_GET['act'])) ? check($_GET['act']) : 'index';
  8. $start = (isset($_GET['start'])) ? abs(intval($_GET['start'])) : 0;
  9. $fid = (isset($_GET['fid'])) ? abs(intval($_GET['fid'])) : 0;
  10.  
  11. switch ($act):
  12. ############################################################################################
  13. ## Вывод перечня тем в категории ##
  14. ############################################################################################
  15. case "index":
  16. $forum = search_string(DATADIR . "dataforum/mainforum.dat", $fid, 0);
  17. if ($forum) {
  18. $config['newtitle'] = $forum[1];
  19. $total = counter_string(DATADIR . "dataforum/topic$fid.dat");
  20. echo'<a href="index.php">Дневник</a>';
  21. if (is_admin()) {
  22. echo' / <a href="forum.php?act=new&amp;fid=' . $fid . '">Новая тема</a>';
  23. echo' / <a href="' . ADMINDIR . 'forum.php?act=forum&amp;fid=' . $fid . '&amp;start=' . $start . '">Управление</a>';
  24. }
  25. echo'<br><br><h1>' . $forum[1] . '</h1> (' . $total . ' тем.)<hr>';
  26. if ($total > 0) {
  27. $files = file(DATADIR . "dataforum/topic$fid.dat");
  28. $files = array_reverse($files);
  29. // Выводим сперва закрепленные темы
  30. $fixed = [];
  31. foreach ($files as $key => $value) {
  32. $data = explode("|", $value);
  33. if (! empty($data[5])) {
  34. unset($files[$key]);
  35. $fixed[] = $value;
  36. }
  37. }
  38. $files = array_merge($fixed, $files);
  39. //-------------------------------//
  40. if ($start < 0 || $start >= $total) {
  41. $start = 0;
  42. }
  43. if ($total < $start + $config['forumtem']) {
  44. $end = $total;
  45. } else {
  46. $end = $start + $config['forumtem'];
  47. }
  48. for ($i = $start; $i < $end; $i++) {
  49. $data = explode("|", $files[$i]);
  50. if ($data[5] == 1) {
  51. } elseif ($data[6] == 1) {
  52. } else {
  53. }
  54. $totalpost = counter_string(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
  55. echo'<div class="b">';
  56. echo'<b><a href="topic.php?fid=' . $fid . '&amp;id=' . $data[0] . '">' . $data[3] . '</a></b> (' . $totalpost . ')</div>';
  57. if ($totalpost > 0) {
  58. $filepost = file(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
  59. $datapost = explode("|", end($filepost));
  60. $lastpage = ceil($totalpost / $config['forumpost']) * $config['forumpost'] - $config['forumpost'];
  61. echo'<div>Страницы: ';
  62. forum_navigation('topic.php?fid=' . $datapost[1] . '&amp;id=' . $datapost[0] . '&amp;', $config['forumpost'], $totalpost);
  63. echo'Сообщение: ' . nickname($datapost[2]) . ' (' . date_fixed($datapost[5]) . ')</div>';
  64. } else {
  65. echo'Тема пустая! Сообщений еще нет!';
  66. }
  67. }
  68. page_strnavigation('forum.php?fid=' . $fid . '&amp;', $config['forumtem'], $start, $total);
  69. } else {
  70. show_error('Раздел пустой! Темы еще не созданы!');
  71. }
  72. } else {
  73. show_error('Ошибка! Данного раздела не существует!');
  74. }
  75. echo'<a href="index.php">Вернуться</a><br>';
  76. break;
  77.  
  78.  
  79. ############################################################################################
  80. ## Подготовка к созданию новой темы ##
  81. ############################################################################################
  82. case 'new':
  83. $config['newtitle'] = 'Создание новой темы';
  84. if (is_user()) {
  85. $forums = file(DATADIR . "dataforum/mainforum.dat");
  86. if (count($forums) > 0) {
  87. echo'<div class="form">';
  88. echo'<form action="forum.php?act=create&amp;fid=' . $fid . '&amp;uid=' . $_SESSION['token'] . '" method="post">';
  89. echo'Раздел:<br>';
  90. echo'<select name="fid">';
  91. foreach ($forums as $data) {
  92. $data = explode("|", $data);
  93. $selected = ($fid == $data[0]) ? ' selected="selected"' : '';
  94. echo'<option value="' . $data[0] . '"' . $selected . '>' . $data[1] . '</option>';
  95. }
  96. echo'</select><br>';
  97. echo'Заголовок:<br>';
  98. echo'<input type="text" name="title" size="50" maxlength="50"><br>';
  99. echo'Сообщение:<br>';
  100. echo'<textarea cols="15" rows="10" name="msg" id="msg"></textarea><br>';
  101. echo'<input value="Создать тему" type="submit"></form></div><br>';
  102. } else {
  103. show_error('Разделы Дневника еще не созданы!');
  104. }
  105. } else {
  106. show_login('');
  107. }
  108. echo'<a href="forum.php?fid=' . $fid . '">Вернуться</a><br>';
  109. break;
  110.  
  111. ############################################################################################
  112. ## Создание новой темы ##
  113. ############################################################################################
  114. case 'create':
  115. $config['newtitle'] = 'Создание новой темы';
  116. $uid = check($_GET['uid']);
  117. $fid = abs(intval($_POST['fid']));
  118. $forum = search_string(DATADIR . "dataforum/mainforum.dat", $fid, 0);
  119. if ($forum) {
  120. if (is_user()) {
  121. if ($uid == $_SESSION['token']) {
  122. $title = check($_POST['title']);
  123. $msg = check($_POST['msg']);
  124. if (is_flood($log)) {
  125. if (is_quarantine($log)) {
  126. if (utf_strlen(trim($title)) >= 5 && utf_strlen($title) <= 50) {
  127. if (utf_strlen(trim($msg)) >= 5 && utf_strlen($msg) <= 3000) {
  128. statistics(1);
  129. statistics(2);
  130. $title = no_br($title);
  131. $title = antimat($title);
  132. $msg = no_br($msg, '<br>');
  133. $msg = antimat($msg);
  134. $msg = smiles($msg);
  135. $id = unifile(DATADIR . "dataforum/topic$fid.dat", 0);
  136. // Создание темы в списке тем
  137. $text = $id . '|' . $fid . '|' . $log . '|' . $title . '|' . SITETIME . '|0|0|';
  138. write_files(DATADIR . "dataforum/topic$fid.dat", "$text\r\n", 0, 0666);
  139. // Создание файла темы и запись сообщения
  140. $topictext = $id . '|' . $fid . '|' . $log . '|' . $msg . '|' . $brow . ', ' . $ip . '|' . SITETIME . '|';
  141. write_files(DATADIR . 'dataforum/' . $fid . '-' . $id . '.dat', "$topictext\r\n", 1, 0666);
  142. // Обновление mainforum
  143. $maintext = $forum[0] . '|' . $forum[1] . '|' . ($forum[2] + 1) . '|' . ($forum[3] + 1) . '|';
  144. replace_lines(DATADIR . "dataforum/mainforum.dat", $forum['line'], $maintext);
  145. //Удаление старых тем
  146. $file = file(DATADIR . "dataforum/topic$fid.dat");
  147. if (count($file) > $config['topforum']) {
  148. foreach ($file as $key => $value) {
  149. $data = explode("|", $value);
  150. if (empty($data[5])) { // если тема не закреплена
  151. if (file_exists(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat')) {
  152. unlink(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
  153. }
  154. unset($file[$key]);
  155. file_put_contents(DATADIR . "dataforum/topic$fid.dat", $file, LOCK_EX);
  156. break;
  157. }
  158. }
  159. }
  160. change_profil($log, [8 => $udata[8] + 1, 14 => $ip, 36 => $udata[36] + 1, 41 => $udata[41] + 1]);
  161. $_SESSION['note'] = 'Тема успешно создана!';
  162. redirect("topic.php?fid=$fid&id=$id");
  163. } else {
  164. show_error('Слишком длинный или короткий текст сообщения (Необходимо от 5 до 3000 символов)');
  165. }
  166. } else {
  167. show_error('Слишком длинный или короткий заголовок (Необходимо от 5 до 50 символов)');
  168. }
  169. } else {
  170. show_error('Карантин! Вы не можете писать в течении ' . round($config['karantin'] / 3600) . ' часов!');
  171. }
  172. } else {
  173. show_error('Антифлуд! Разрешается отправлять сообщения раз в ' . flood_period() . ' секунд!');
  174. }
  175. } else {
  176. show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
  177. }
  178. } else {
  179. show_login('');
  180. }
  181. } else {
  182. show_error('Ошибка! Даннго раздела для создании темы не существует!');
  183. }
  184. echo'<a href="forum.php?act=new&amp;fid=' . $fid . '">Вернуться</a><br>';
  185. break;
  186. default:
  187. redirect('index.php');
  188. endswitch;
  189. echo'<a href="search.php">Поиск</a><br>';
  190. echo'<a href="/index.php"></a><br>';
  191.  
  192. include_once ("../themes/".$config['themes']."/niz.dat");
  193.  
  194. ?>