View file forum/forum.php

File size: 12.67Kb
<?php
#-----------------------------------------------------#
#          ********* ROTORCMS *********               #
#              Made by  :  VANTUZ                     #
#               E-mail  :  [email protected]         #
#                 Site  :  http://pizdec.ru           #
#             WAP-Site  :  http://visavi.net          #
#                  ICQ  :  36-44-66                   #
#  Вы не имеете право вносить изменения в код скрипта #
#        для его дальнейшего распространения          #
#-----------------------------------------------------#
require_once ('../includes/start.php');
require_once ('../includes/functions.php');
require_once ('../includes/header.php');
include_once ('../themes/header.php');

if (isset($_GET['fid'])) {
	$fid = abs(intval($_GET['fid']));
} else {
	$fid = 0;
} 
if (isset($_GET['start'])) {
	$start = abs(intval($_GET['start']));
} else {
	$start = 0;
} 
if (isset($_GET['act'])) {
	$act = check($_GET['act']);
} else {
	$act = 'index';
} 

show_title('menu.png', 'Форум '.$config['title']);

switch ($act):
############################################################################################
##                                    Главная страница                                    ##
############################################################################################
	case 'index':

		if (!empty($fid)) {
			$forums = DB::run() -> queryFetch("SELECT * FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($fid));

			if (!empty($forums)) {

				$page = floor(1 + $start / $config['forumtem']);
				$config['newtitle'] = $forums['forums_title'].' (Стр. '.$page.')';

				echo '<a href="#down"><img src="../images/img/downs.gif" alt="Вниз" /></a> ';
				echo '<a href="index.php?'.SID.'">Форум</a> / ';

				if (!empty($forums['forums_parent'])) {
					$sub = DB::run() -> queryFetch("SELECT `forums_id`, `forums_title` FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($forums['forums_parent']));

					echo '<a href="forum.php?fid='.$sub['forums_id'].'&amp;'.SID.'">'.$sub['forums_title'].'</a> / ';
				} 

				echo '<a href="forum.php?fid='.$fid.'&amp;start='.$start.'&amp;rand='.mt_rand(1000, 9999).'&amp;'.SID.'">Обновить</a>';

				if (empty($forums['forums_closed'])) {
					echo ' / <a href="forum.php?act=addtheme&amp;fid='.$fid.'&amp;'.SID.'">Создать тему</a>';
				} 
				echo '<br /><br />';

				echo '<img src="../images/img/themes.gif" alt="image" /> <b>'.$forums['forums_title'].'</b>';

				if (is_admin()) {
					echo ' (<a href="'.ADMINDIR.'forum.php?act=forum&amp;fid='.$fid.'&amp;start='.$start.'&amp;'.SID.'">Управление</a>)';
				} 
				echo '<hr />';

				$querysub = DB::run() -> query("SELECT * FROM `forums` WHERE `forums_parent`=? ORDER BY `forums_order` ASC;", array($fid));
				$sub = $querysub -> fetchAll();

				if (count($sub) > 0 && $start == 0) {
					foreach($sub as $subdata) {
						echo '<div class="b"><img src="../images/img/forums.gif" alt="image" /> ';
						echo '<b><a href="forum.php?fid='.$subdata['forums_id'].'&amp;'.SID.'">'.$subdata['forums_title'].'</a></b> ('.$subdata['forums_topics'].'/'.$subdata['forums_posts'].')</div>';

						if ($subdata['forums_last_id'] > 0) {
							echo '<div>Тема: <a href="topic.php?act=end&amp;tid='.$subdata['forums_last_id'].'&amp;'.SID.'">'.$subdata['forums_last_themes'].'</a><br />';
							echo 'Сообщение: '.nickname($subdata['forums_last_user']).' ('.date_fixed($subdata['forums_last_time']).')</div>';
						} else {
							echo '<div>Темы еще не созданы!</div>';
						} 
					} 
					echo '<hr />';
				} 

				$total = DB::run() -> querySingle("SELECT count(*) FROM `topics` WHERE `topics_forums_id`=?;", array($fid));

				if ($total > 0) {
					if ($start >= $total) {
						$start = last_page($total, $config['forumtem']);
					} 

					$querytopic = DB::run() -> query("SELECT * FROM `topics` WHERE `topics_forums_id`=? ORDER BY `topics_locked` DESC, `topics_last_time` DESC LIMIT ".$start.", ".$config['forumtem'].";", array($fid));

					while ($data = $querytopic -> fetch()) {
						echo '<div id="'.$data['topics_id'].'" class="b">';

						if ($data['topics_locked'] == 1) {
							echo '<img src="../images/img/lock.gif" alt="image" /> ';
						} elseif ($data['topics_closed'] == 1) {
							echo '<img src="../images/img/closed.gif" alt="image" /> ';
						} else {
							echo '<img src="../images/img/topics.gif" alt="image" /> ';
						} 

						echo '<b><a href="topic.php?tid='.$data['topics_id'].'&amp;'.SID.'">'.$data['topics_title'].'</a></b> ('.$data['topics_posts'].')</div>';
						echo '<div>Страницы: ';
						forum_navigation('topic.php?tid='.$data['topics_id'].'&amp;', $config['forumpost'], $data['topics_posts']);
						echo 'Сообщение: '.nickname($data['topics_last_user']).' ('.date_fixed($data['topics_last_time']).')</div>';
					} 

					page_strnavigation('forum.php?fid='.$fid.'&amp;', $config['forumtem'], $start, $total);
				} else {
					if (empty($forums['forums_closed'])) {
						show_error('Тем еще нет, будь первым!');
					} 
				} 

				if (!empty($forums['forums_closed'])) {
					show_error('В данном разделе запрещено создавать темы!');
				} 

				echo '<a href="#up"><img src="../images/img/ups.gif" alt="up" /></a> ';
				echo '<a href="forum.php?act=addtheme&amp;fid='.$fid.'&amp;'.SID.'">Создать тему</a> / ';
				echo '<a href="../pages/rules.php?'.SID.'">Правила</a> / ';
				echo '<a href="top.php?act=themes&amp;'.SID.'">Топ тем</a> / ';
				echo '<a href="search.php?fid='.$fid.'&amp;'.SID.'">Поиск</a><br />';
			} else {
				show_error('Ошибка! Данного раздела не существует!');
			} 
		} else {
			redirect("index.php?".SID);

		} 
	break;

	############################################################################################
	##                               Подготовка к созданию темы                               ##
	############################################################################################
	case 'addtheme':

		$config['newtitle'] = 'Создание новой темы';

		if (is_user()) {
			$queryforum = DB::run() -> query("SELECT `forums_id`, `forums_parent`, `forums_title` FROM `forums` WHERE `forums_closed`=? ORDER BY `forums_order` ASC;", array(0));
			$forums = $queryforum -> fetchAll();

			if (count($forums) > 0) {
				echo '<div class="form">';
				echo '<form action="forum.php?act=add&amp;fid='.$fid.'&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post">';

				echo 'Раздел:<br />';

				$output = array();

				foreach ($forums as $row) {
					$i = $row['forums_id'];
					$p = $row['forums_parent'];
					$output[$p][$i] = $row;
				} 

				echo '<select name="fid">';

				foreach ($output[0] as $key => $data) {
					$selected = ($fid == $data['forums_id']) ? ' selected="selected"' : '';
					echo '<option value="'.$data['forums_id'].'"'.$selected.'>'.$data['forums_title'].'</option>';

					if (isset($output[$key])) {
						foreach($output[$key] as $datasub) {
							$selected = ($fid == $datasub['forums_id']) ? ' selected="selected"' : '';
							echo '<option value="'.$datasub['forums_id'].'"'.$selected.'>– '.$datasub['forums_title'].'</option>';
						} 
					} 
				} 

				echo '</select><br />';

				echo 'Заголовок:<br />';
				echo '<input type="text" name="title" size="50" maxlength="50" /><br />';
				echo '<textarea id="markItUp" cols="25" rows="5" name="msg" id="msg"></textarea><br />';
				echo '<input value="Создать тему" type="submit" /></form></div><br />';

				echo 'Прежде чем создать новую тему необходимо ознакомиться с правилами<br />';
				echo '<a href="../pages/rules.php?'.SID.'">Правила сайта</a><br />';
				echo 'Также убедись что такой темы нет, чтобы не создавать одинаковые, для этого введи ключевое слово в поиске<br />';
				echo '<a href="search.php?'.SID.'">Поиск по форуму</a><br />';
				echo 'И если после этого вы уверены, что ваша тема будет интересна другим пользователям, то можете ее создать<br /><br />';
			} else {
				show_error('Разделы форума еще не созданы!');
			} 
		} else {
			show_login('Вы не авторизованы, для создания новой темы, необходимо');
		} 

		echo '<img src="../images/img/back.gif" alt="image" /> <a href="forum.php?fid='.$fid.'&amp;'.SID.'">Вернуться</a><br />';
	break;

	############################################################################################
	##                                     Cоздание темы                                      ##
	############################################################################################
	case 'add':

		$uid = check($_GET['uid']);
		$fid = abs(intval($_POST['fid']));
		$title = check($_POST['title']);
		$msg = check($_POST['msg']);

		if (is_user()) {
			if ($uid == $_SESSION['token']) {
				if (utf_strlen($title) >= 5 && utf_strlen($title) <= 50) {
					if (utf_strlen($msg) >= 5 && utf_strlen($msg) <= $config['forumtextlength']) {
						$forums = DB::run() -> queryFetch("SELECT * FROM `forums` WHERE `forums_id`=? LIMIT 1;", array($fid));

						if (!empty($forums)) {
							if (empty($forums['forums_closed'])) {
								if (is_quarantine($log)) {
									if (is_flood($log)) {
										$title = antimat($title);
										$msg = no_br($msg);
										$msg = antimat($msg);
										$msg = smiles($msg);

										DB::run() -> query("UPDATE `users` SET `users_allforum`=`users_allforum`+1, `users_point`=`users_point`+1, `users_money`=`users_money`+5 WHERE `users_login`=?", array($log));

										DB::run() -> 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));

										$lastid = DB::run() -> lastInsertId();

										DB::run() -> 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));

										DB::run() -> 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)); 
										// Обновление родительского форума
										if ($forums['forums_parent'] > 0) {
											DB::run() -> 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']));
										} 

										$_SESSION['note'] = 'Новая тема успешно добавлена!';
										redirect("topic.php?tid=$lastid&".SID);

									} else {
										show_error('Антифлуд! Разрешается отправлять сообщения раз в '.flood_period().' секунд!');
									} 
								} else {
									show_error('Карантин! Вы не можете писать в течении '.round($config['karantin'] / 3600).' часов!');
								} 
							} else {
								show_error('Ошибка! В данном разделе запрещено создавать темы!');
							} 
						} else {
							show_error('Ошибка! Раздела для новой темы не существует!');
						} 
					} else {
						show_error('Ошибка! Слишком длинное или короткое сообщение!');
					} 
				} else {
					show_error('Ошибка! Слишком длинный или короткий заголовок темы!');
				} 
			} else {
				show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
			} 
		} else {
			show_login('Вы не авторизованы, для создания новой темы, необходимо');
		} 

		echo '<img src="../images/img/back.gif" alt="image" /> <a href="forum.php?fid='.$fid.'&amp;'.SID.'">К темам</a><br />';
	break;

default:
	redirect("index.php?".SID);
endswitch;

echo '<img src="../images/img/reload.gif" alt="image" /> <a href="index.php?'.SID.'">К форумам</a><br />';

include_once ('../themes/footer.php');
?>