<?php
define('PROTECTOR', 1);
$path = '../'; //путь
$textl = 'Форум';
include($path.'files/db.php');
include($path.'files/auth.php');
include($path.'files/func.php');
include($path . 'files/core.php');
include('head.php');
echo'<div class="menu">';
$id = intval($_GET['id']);
/* Уберу пока, а то народ бесится =)
if($udata['lvl']=='0'){
echo'Писать на форуме можно только с первого уровня!';
include('end.php');exit;
} */
switch($_GET['act']){
###############################################################################
## Добавление сообщения ##
###############################################################################
case 'msg_add':
$page = intval($_GET['page']);
$topic = mysql_fetch_assoc(mysql_query("SELECT `id`, `id_cat`, `closed` FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($topic['closed'] == 0){
if(!empty($_POST['text'])){
$text = sec($_POST['text']);
$text=eregi_replace("((https?|ftp|http)://[[:alnum:]_=/-]+(\\.[[:alnum:]_=/-]+)*(/[[:alnum:]+&._=/%]*(\\?[[:alnum:]?+&_=/%]*)?)?).(ru|org|net|info|org.ua|h2m.ru|wen.ru|com|game-l2.ru з|l2wap.ru з|l2full.ru з|game-l2 .ru з)", "Реклама запрещена", $text);
$text=eregi_replace("([[:alnum:]_=/-]+(\\.[[:alnum:]_=/-]+)*(/[[:alnum:]+&._=/%]*(\\?[[:alnum:]?+&_=/%]*)?)?).(ru|org|net|info|org.ua|h2m.ru|wen.ru|com|game-l2.ru з|l2wap.ru з|l2full.ru з|game-l2 .ru з)", "Реклама запрещена", $text);
mysql_query("INSERT INTO `forum_msg` SET `id_cat` = '".$topic['id_cat']."', `id_topic` = '".$topic['id']."', `text` = '$text', `login` = '".$log."', `time` = '".time()."'");
mysql_query("UPDATE `forum_topics` SET `time` = '".time()."' WHERE `id` = '".$topic['id']."'");
echo'Ваше сообщение успешно добавлено!';
}else{
echo'Вы не заполнили поле!';
}
}else{
echo'Тема закрыта! Добавить сообщение невозможно!';
}
}else{
echo'Выбранная тема не существует!';
}
nav2('topic.php?id='.$topic['id'].'&page='.$page.'', 'Назад');
break;
###############################################################################
## Форма ответа на сообщение ##
###############################################################################
case 'answer':
$page = intval($_GET['page']);
$msg = mysql_fetch_assoc(mysql_query("SELECT `id`, `id_topic`, `login` FROM `forum_msg` WHERE `id` = '$id'"));
if(isset($msg['id'])){
$topic = mysql_fetch_assoc(mysql_query("SELECT `closed` FROM `forum_topics` WHERE `id` = '".$msg['id_topic']."'"));
if($topic['closed'] == 0 or $udata['prava'] > 1){
echo '<div class="s1">Ответ пользователю '.$msg['login'].'</div><div class="event">';
echo '<form action="?act=answered&id='.$id.'&page='.$page.'" method="post" name="form">';
echo '<textarea name="text" rows="4">[b]'.$msg['login'].'[/b], </textarea><br/>';
echo '<input name="submit" type="submit" value="Ответить" /></form></div>';
}else{
echo'Тема закрыта, ответ невозможен!';
}
}else{
echo'Сообщение, на которое вы хотите ответить не существует!';
}
nav2('topic.php?id='.$msg['id_topic'].'&page='.$page.'', 'Назад');
break;
###############################################################################
## Ответ на сообщение ##
###############################################################################
case 'answered':
$page = intval($_GET['page']);
$msg = mysql_fetch_assoc(mysql_query("SELECT `id`, `id_cat`, `id_topic` FROM `forum_msg` WHERE `id` = '$id'"));
if(isset($msg['id'])){
$topic = mysql_fetch_assoc(mysql_query("SELECT `closed` FROM `forum_topics` WHERE `id` = '".$msg['id_topic']."'"));
if($topic['closed'] == 0 or $udata['prava'] > 1){
if(!empty($_POST['text'])){
$text = sec($_POST['text']);
mysql_query("INSERT INTO `forum_msg` SET `id_cat` = '".$msg['id_cat']."', `id_topic` = '".$msg['id_topic']."', `text` = '$text', `login` = '".$log."', `time` = '".time()."'");
mysql_query("UPDATE `forum_topics` SET `time` = '".time()."' WHERE `id` = '".$msg['id_topic']."'");
echo'Вы успешно оставили ответ!';
}else{
echo'Вы не заполнили поле!';
}
}else{
echo'Тема закрыта, ответ невозможен!'; }
}else{
echo'Сообщение, на которое вы хотите ответить не существует!';
}
nav2('topic.php?id='.$msg['id_topic'].'', 'Назад');
break;
###############################################################################
## Форма редактирования сообщения ##
###############################################################################
case 'msg_edit':
$id = intval($_GET['id']);
$msg = mysql_fetch_assoc(mysql_query("SELECT * FROM `forum_msg` WHERE `id` = '$id'"));
if(isset($msg['id'])){
if($msg['login'] == $log or $udata['prava'] > 1){
if($msg['time']+900 > time() or $udata['prava'] > 0){
echo '<center><b>Редактирование сообщения</b></center>';
echo '<form action="?act=msg_edited&id='.$id.'" method="post" name="form">';
echo 'Сообщение:<br/><textarea name="text" rows="3">'.$msg['text'].'</textarea><br/>';
echo '<input name="submit" type="submit" value="Редактировать" /></form>';
}else{
echo'Время в течение которого вы могли изменить сообщение истекло!';
}
}else{
echo'Вы не можете изменить это сообщение!';
}
}else{
echo'Сообщение не существует!';}
nav2('topic.php?id='.$msg['id_topic'].'', 'Назад');
break;
###############################################################################
## Редактирование сообщения ##
###############################################################################
case 'msg_edited':
$id = intval($_GET['id']);
$msg = mysql_fetch_assoc(mysql_query("SELECT * FROM `forum_msg` WHERE `id` = '$id'"));
if(isset($msg['id'])){
if($msg['login'] == $log or $udata['prava'] > 0){
if($msg['time']+900 > time() or $udata['prava'] > 1){
$text = htmlspecialchars(addslashes($_POST['text']));
mysql_query("UPDATE `forum_msg` SET `text` = '$text', `edit_login` = '".$log."', `edit_time` = '".time()."' WHERE `id` = '$id'");
echo'Сообщение успешно отредактировано!';
}else{
echo'Время в течение которого вы могли отредактировать сообщение истекло!';
}
}else{
echo'Вы не можете отредактировать это сообщение!';
}
}else{
echo'Сообщение не существует!';
}
break;
###############################################################################
## Удаление сообщения ##
###############################################################################
case 'msg_del':
$page = intval($_GET['page']);
$id = intval($_GET['id']);
$msg = mysql_fetch_assoc(mysql_query("SELECT * FROM `forum_msg` WHERE `id` = '$id'"));
if(isset($msg['id'])){
if($msg['login'] == $user_id or $udata['prava'] > 1){
if($msg['time']+900 > time() or $udata['prava'] > 1){
mysql_query("DELETE FROM `forum_msg` WHERE `id` = '$id'");
echo'Сообщение успешно удалено!';
}else{echo'Время в течение которого вы могли удалить сообщение истекло!<br/>';}
}else{echo'Вы не можете удалить это сообщение!';}
}else{echo'Сообщение не существует!';}
nav2('topic.php?id='.$msg['id_topic'].'&page='.$page.'', 'Назад');
break;
###############################################################################
## Форма создания темы ##
###############################################################################
case 'topic_add':
echo '<center><b>Начать новую тему</b></center>';
echo '<form action="posting.php?act=topic_added&id='.$id.'" method="post" name="form">';
echo 'Название (max70)<br/><input name="title" type="text" maxlength="70" /><br/>';
echo 'Сообщение<br/><textarea name="text" rows="4"></textarea><br/>';
echo '<input name="submit" type="submit" value="Создать тему" /></form>';
nav2('index.php?act=cat_view&id='.$id.'', 'Назад');
break;
###############################################################################
## Cозданиt темы ##
###############################################################################
case 'topic_added':
if(time() >= $_SESSION['antispam']){
if(!empty($_POST['title']) && !empty($_POST['text'])){
if(strlen($_POST['text']) <= 1699){
$title = htmlspecialchars(addslashes($_POST['title']));
$text = htmlspecialchars(addslashes($_POST['text']));
mysql_query("INSERT INTO `forum_topics` SET `id_cat` = '$id', `title` = '$title', `authour` = '".$log."', `time` = '".time()."'");
$last_id = mysql_insert_id();
mysql_query("INSERT INTO `forum_msg` SET `id_cat` = '$id', `id_topic` = '$last_id', `text` = '$text', `login` = '".$log."', `time` = '".time()."'");
$_SESSION['antispam'] = time() + 10;
echo'Тема успешно создана!';
}else{
echo'Слишком длинное сообщение! Не больше 1000 символов!';
}
}else{
echo'Вы не заполнили поля!';
}
}else{
echo'Антиспам! Разрешено писать раз в 10 сек.!';
}
nav2('index.php?act=cat_view&id='.$id.'', 'Назад');
break;
###############################################################################
## Закрытие темы ##
###############################################################################
case 'topic_close':
$topic = mysql_fetch_assoc(mysql_query("SELECT `id`, `authour` FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($topic['authour'] == $log or $udata['prava'] > 1){
$result = mysql_query("UPDATE `forum_topics` SET `closed` = 1 WHERE `id` = '$id'");
echo'Тема успешно закрыта!';
}else{
echo'Вы не можете закрыть эту тему!';
}
}else{
echo'Выбранная тема не существует!';
}
nav2('topic.php?id='.$id.'', 'В тему');
break;
###############################################################################
## Открытие темы ##
###############################################################################
case 'topic_open':
$topic = mysql_fetch_assoc(mysql_query("SELECT `id` FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($udata['prava'] > 1){
$result = mysql_query("UPDATE `forum_topics` SET `closed` = 0 WHERE `id` = '$id'");
echo'Тема успешно открыта!';
}else{
echo'Вы не можете открыть эту тему!';
}
}else{
echo'Выбранная тема не существует!';
}
nav2('topic.php?id='.$id.'', 'В тему');
break;
###############################################################################
## Форма редактирования темы ##
###############################################################################
case 'topic_edit':
$topic = mysql_fetch_assoc(mysql_query("SELECT * FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($topic['authour'] == $log or $udata['prava'] > 1){
echo '<b>Редактирование темы</b><div class="event">';
echo '<form action="?act=topic_edited&id='.$id.'" method="post" name="form">';
echo 'Название:<br/><input name="title" type="text" maxlength="50" value="'.$topic['title'].'" /><br/>';
$msg = mysql_fetch_assoc(mysql_query("SELECT `text` FROM `forum_msg` WHERE `id_topic` = '$id' ORDER BY `time` LIMIT 1")) or die(mysql_error());
echo 'Сообщение:<br/><textarea name="text" rows="3">'.$msg['text'].'</textarea><br/>';
echo '<input name="submit" type="submit" value="Редактировать" /></form></div>';
}else{
echo'Вы не можете изменить эту тему!';
}
}else{
echo'Тема не существует!';
}
nav2('topic.php?id='.$id.'', 'Назад');
break;
###############################################################################
## Редактирование темы ##
###############################################################################
case 'topic_edited':
$topic = mysql_fetch_assoc(mysql_query("SELECT * FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($topic['login'] == $log or $udata['prava'] > 1){
$title = sec($_POST['title']);
$text = sec($_POST['text']);
mysql_query("UPDATE `forum_topics` SET `title` = '$title' WHERE `id` = '$id'");
mysql_query("UPDATE `forum_msg` SET `text` = '$text', `edit_login` = '".$log."', `edit_time` = '".time()."' WHERE `id_topic` = '$id' ORDER BY `time` LIMIT 1");
echo'Тема успешно отредактирована!';
}else{
echo'Вы не можете отредактировать эту тему!';
}
}else{
echo'Тема не существует!';
}
nav2('topic.php?id='.$id.'', 'Назад');
break;
###############################################################################
## Удаление темы ##
###############################################################################
case 'topic_del':
$topic = mysql_fetch_assoc(mysql_query("SELECT `id`, `id_cat` FROM `forum_topics` WHERE `id` = '$id'"));
if(isset($topic['id'])){
if($udata['prava'] > 1){
$result = mysql_query("DELETE FROM `forum_topics` WHERE `id` = '$id'");
$result2 = mysql_query("DELETE FROM `forum_msg` WHERE `id_topic` = '$id'");
echo'Тема успешно удалена!';
}else{
echo'Нет доступа! Вам делать здесь нечего =)';
}
}else{
echo'Темы не существует!';
}
nav2('index.php?act=cat_view&id='.$topic['id_cat'].'', 'Назад');
break;
}
echo'</div>';
echo '<div class="nevb">';
echo '<a href="../"><div class="zag">Главная</div></a> <a href="./"><div class="zag">Форум</div></a></div>';
echo'</div>';
include($path . 'files/end.php');
?>