Файл: forum/posting.php
Строк: 86
<?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="gameBorder">';
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']);
                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 '<b>Редактирование сообщения</b><div class="event">';
            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></div>';
        }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':
$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'].'', 'Назад');
break;
###############################################################################
##                           Форма создания темы                             ##
###############################################################################
case 'topic_add':
    echo '<b>Начать новую тему</b><div class="event">';
    echo '<form action="posting.php?act=topic_added&id='.$id.'" method="post" name="form">';
    echo 'Название(max50):<br/><input name="title" type="text" maxlength="50" /><br/>';
    echo 'Сообщение:<br/><textarea name="text" rows="4"></textarea><br/>';
    echo '<input name="submit" type="submit" value="Создать тему" /></form></div>';
    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="25" 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></div>';
include('end.php');
?>