Файл: posting.php
Строк: 689
<?php
/***************************************************************************
 *                                posting.php
 *                            -------------------
 *      Разработка: phpBB Group.
 ***************************************************************************/
define('IN_PHPBB', true);
$phpbb_root_path = './';
include($phpbb_root_path . 'extension.inc');
include($phpbb_root_path . 'common.'.$phpEx);
include($phpbb_root_path . 'includes/bbcode.'.$phpEx);
include($phpbb_root_path . 'includes/functions_post.'.$phpEx);
include($phpbb_root_path . 'includes/functions_translit.'.$phpEx);
include($phpbb_root_path . 'includes/functions_antispam.'.$phpEx);
$params = array('submit' => 'post', 'preview' => 'preview', 'delete' => 'delete', 'translit' => 'translit', 'poll_delete' => 'poll_delete', 'poll_add' => 'add_poll_option', 'poll_edit' => 'edit_poll_option', 'mode' => 'mode', 'lock_subject' => 'lock_subject');
while( list($var, $param) = @each($params) )
{
    if ( !empty($HTTP_POST_VARS[$param]) || !empty($HTTP_GET_VARS[$param]) )
    {
        $$var = ( !empty($HTTP_POST_VARS[$param]) ) ? htmlspecialchars($HTTP_POST_VARS[$param]) : htmlspecialchars($HTTP_GET_VARS[$param]);
    }
    else
    {
        $$var = '';
    }
}
$confirm = isset($HTTP_POST_VARS['confirm']) ? true : false;
$sid = (isset($HTTP_POST_VARS['sid'])) ? $HTTP_POST_VARS['sid'] : 0;
$params = array('forum_id' => POST_FORUM_URL, 'topic_id' => POST_TOPIC_URL, 'post_id' => POST_POST_URL);
while( list($var, $param) = @each($params) )
{
    if ( !empty($HTTP_POST_VARS[$param]) || !empty($HTTP_GET_VARS[$param]) )
    {
        $$var = ( !empty($HTTP_POST_VARS[$param]) ) ? intval($HTTP_POST_VARS[$param]) : intval($HTTP_GET_VARS[$param]);
    }
    else
    {
        $$var = '';
    }
}
$refresh = $preview || $poll_add || $poll_edit || $poll_delete;
$orig_word = $replacement_word = array();
$topic_type = ( !empty($HTTP_POST_VARS['topictype']) ) ? intval($HTTP_POST_VARS['topictype']) : POST_NORMAL;
$topic_type = ( in_array($topic_type, array(POST_NORMAL, POST_STICKY, POST_ANNOUNCE)) ) ? $topic_type : POST_NORMAL;
if ( $mode == 'smilies' )
{
    generate_smilies('window', PAGE_POSTING);
    exit;
}
$userdata = session_pagestart($user_ip, PAGE_POSTING);
init_userprefs($userdata);
$ban_information = session_userban($user_ip, $userdata['user_id']);
if ($ban_information)
{
    message_die(CRITICAL_MESSAGE, 'Вы не можете создавать новые темы и отвечать на старые, т.к. ваш '.$ban_information);
}
if ( isset($HTTP_POST_VARS['cancel']) )
{
        if ( $postreport )
        {
            $redirect = 'viewtopic.$phpEx?' . POST_POST_URL . '=$postreport';
            $post_append = '';
        }        
        else if ( $post_id )
    {
        $redirect = "viewtopic.$phpEx?" . POST_POST_URL . "=$post_id";
        $post_append = "#$post_id";
    }
    else if ( $topic_id )
    {
        $redirect = "viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id";
        $post_append = '';
    }
    else if ( $forum_id )
    {
        $redirect = "viewforum.$phpEx?" . POST_FORUM_URL . "=$forum_id";
        $post_append = '';
    }
    else
    {
        $redirect = "index.$phpEx";
        $post_append = '';
    }
    redirect(append_sid($redirect, true) . $post_append);
}
$is_auth = array();
switch( $mode )
{
    case 'newtopic':
        if ( $topic_type == POST_ANNOUNCE )
        {
            $is_auth_type = 'auth_announce';
        }
        else if ( $topic_type == POST_STICKY )
        {
            $is_auth_type = 'auth_sticky';
        }
        else
        {
            $is_auth_type = 'auth_post';
        }
        break;
    case 'reply':
    case 'quote':
    case 'reply_to_user':
              $is_auth_type = 'auth_reply';
              break;
    case 'editpost':
        $is_auth_type = 'auth_edit';
        break;
    case 'delete':
    case 'poll_delete':
        $is_auth_type = 'auth_delete';
        break;
    case 'vote':
        $is_auth_type = 'auth_vote';
        break;
    case 'topicreview':
    case 'thank':
        $is_auth_type = 'auth_read';
        break;
    default:
        message_die(GENERAL_MESSAGE, $lang['No_post_mode']);
        break;
}
$error_msg = '';
$post_data = array();
switch ( $mode )
{
    case 'newtopic':
        if ( empty($forum_id) )
        {
            message_die(GENERAL_MESSAGE, $lang['Forum_not_exist']);
        }
        $sql = "SELECT * 
            FROM " . FORUMS_TABLE . " 
            WHERE forum_id = $forum_id";
        break;
        
        case 'thank':
    case 'reply':
    case 'vote':
        if ( empty( $topic_id) )
        {
            message_die(GENERAL_MESSAGE, $lang['No_topic_id']);
        }
        $sql = "SELECT f.*, t.topic_status, t.topic_title, t.topic_type  
            FROM " . FORUMS_TABLE . " f, " . TOPICS_TABLE . " t
            WHERE t.topic_id = $topic_id
            AND f.forum_id = t.forum_id";
        break;
    case 'quote':
    case 'reply_to_user':
    case 'editpost':
    case 'delete':
    case 'poll_delete':
        if ( empty($post_id) )
        {
            message_die(GENERAL_MESSAGE, $lang['No_post_id']);
        }
        $select_sql = (!$submit) ? ', t.topic_title, p.enable_bbcode, p.enable_html, p.enable_smilies, p.enable_sig, p.post_username, pt.post_subject, pt.post_text, pt.bbcode_uid, u.username, u.user_id, u.user_sig, u.user_sig_bbcode_uid, u.admin_allow_points' : '';
        $from_sql = ( !$submit ) ? ", " . POSTS_TEXT_TABLE . " pt, " . USERS_TABLE . " u" : '';
        $where_sql = ( !$submit ) ? "AND pt.post_id = p.post_id AND u.user_id = p.poster_id" : '';
        $sql = "SELECT f.*, t.topic_id, t.topic_status, t.topic_type, t.topic_first_post_id, t.topic_last_post_id, t.topic_vote, p.post_id, p.poster_id" . $select_sql . " 
            FROM " . POSTS_TABLE . " p, " . TOPICS_TABLE . " t, " . FORUMS_TABLE . " f" . $from_sql . " 
            WHERE p.post_id = $post_id 
            AND t.topic_id = p.topic_id 
            AND f.forum_id = p.forum_id
            $where_sql";
        break;
    default:
    message_die(GENERAL_MESSAGE, $lang['No_valid_mode']);
}
if ( ($result = $db->sql_query($sql)) && ($post_info = $db->sql_fetchrow($result)) )
{
    $db->sql_freeresult($result);
    $forum_id = $post_info['forum_id'];
    $forum_name = $post_info['forum_name'];       
        
    $is_auth = auth(AUTH_ALL, $forum_id, $userdata, $post_info);
    if ( $post_info['forum_status'] == FORUM_LOCKED && !$is_auth['auth_mod']) 
    { 
       message_die(GENERAL_MESSAGE, $lang['Forum_locked']); 
    } 
    else if ( $mode != 'newtopic' &&  $mode != 'thank' && $post_info['topic_status'] == TOPIC_LOCKED && !$is_auth['auth_mod']) 
    { 
       message_die(GENERAL_MESSAGE, $lang['Topic_locked']); 
    } 
    if ( $mode == 'editpost' || $mode == 'delete' || $mode == 'poll_delete' )
    {
        $topic_id = $post_info['topic_id'];
        $post_data['poster_post'] = ( $post_info['poster_id'] == $userdata['user_id'] ) ? true : false;
        $post_data['first_post'] = ( $post_info['topic_first_post_id'] == $post_id ) ? true : false;
        $post_data['last_post'] = ( $post_info['topic_last_post_id'] == $post_id ) ? true : false;
        $post_data['last_topic'] = ( $post_info['forum_last_post_id'] == $post_id ) ? true : false;
        $post_data['has_poll'] = ( $post_info['topic_vote'] ) ? true : false; 
        $post_data['topic_type'] = $post_info['topic_type'];
        $post_data['poster_id'] = $post_info['poster_id'];
        if ( $post_data['first_post'] && $post_data['has_poll'] )
        {
            $sql = "SELECT * 
                FROM " . VOTE_DESC_TABLE . " vd, " . VOTE_RESULTS_TABLE . " vr 
                WHERE vd.topic_id = $topic_id 
                AND vr.vote_id = vd.vote_id 
                ORDER BY vr.vote_option_id";
            if ( !($result = $db->sql_query($sql)) )
            {
                message_die(GENERAL_ERROR, 'Could not obtain vote data for this topic', '', __LINE__, __FILE__, $sql);
            }
            $poll_options = array();
            $poll_results_sum = 0;
            if ( $row = $db->sql_fetchrow($result) )
            {
                $poll_title = $row['vote_text'];
                $poll_id = $row['vote_id'];
                $poll_length = $row['vote_length'] / 86400;
                do
                {
                    $poll_options[$row['vote_option_id']] = $row['vote_option_text']; 
                    $poll_results_sum += $row['vote_result'];
                }
                while ( $row = $db->sql_fetchrow($result) );
            }
            $db->sql_freeresult($result);
            $post_data['edit_poll'] = ( ( !$poll_results_sum || $is_auth['auth_mod'] ) && $post_data['first_post'] ) ? true : 0;
        }
        else 
        {
            $post_data['edit_poll'] = ($post_data['first_post'] && $is_auth['auth_pollcreate']) ? true : false;
        }
        if ( $post_info['poster_id'] != $userdata['user_id'] && !$is_auth['auth_mod'] )
        {
            $message = ( $delete || $mode == 'delete' ) ? $lang['Delete_own_posts'] : $lang['Edit_own_posts'];
            $message .= '<br /><br />' . sprintf($lang['Click_return_topic'], '<a href="' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">', '</a>');
            message_die(GENERAL_MESSAGE, $message);
        }
        else if ( !$post_data['last_post'] && !$is_auth['auth_mod'] && ( $mode == 'delete' || $delete ) )
        {
            message_die(GENERAL_MESSAGE, $lang['Cannot_delete_replied']);
        }
        else if ( !$post_data['edit_poll'] && !$is_auth['auth_mod'] && ( $mode == 'poll_delete' || $poll_delete ) )
        {
            message_die(GENERAL_MESSAGE, $lang['Cannot_delete_poll']);
        }
    }
    else
    {
        if (( $mode == 'quote' )||( $mode == 'reply_to_user' ))
        {
            $topic_id = $post_info['topic_id'];
        }
        if ( $mode == 'newtopic' )
        {
            $post_data['topic_type'] = POST_NORMAL;
        }
        $post_data['first_post'] = ( $mode == 'newtopic' ) ? true : 0;
        $post_data['last_post'] = false;
        $post_data['has_poll'] = false;
        $post_data['edit_poll'] = false;
    }
    if ( $mode == 'poll_delete' && !isset($poll_id) )
    {
        message_die(GENERAL_MESSAGE, $lang['No_such_post']);
    }
}
else
{
    message_die(GENERAL_MESSAGE, $lang['No_such_post']);
}
if ( !$is_auth[$is_auth_type] )
{
    if ( $userdata['session_logged_in'] )
    {
        message_die(GENERAL_MESSAGE, sprintf($lang['Sorry_' . $is_auth_type], $is_auth[$is_auth_type . "_type"]));
    }
    switch( $mode )
    {
        case 'newtopic':
            $redirect = "mode=newtopic&" . POST_FORUM_URL . "=" . $forum_id;
            break;
        case 'thank':
        case 'reply':
        case 'topicreview':
            $redirect = "mode=reply&" . POST_TOPIC_URL . "=" . $topic_id;
            break;
        case 'quote':
        case 'editpost':
            $redirect = "mode=quote&" . POST_POST_URL ."=" . $post_id;
            break;
    }
$redirect .= ($post_reportid) ? '&post_reportid=$post_reportid' : ''; 
    redirect(append_sid("login.$phpEx?redirect=posting.$phpEx&" . $redirect, true));
}
if ( !$board_config['allow_html'] )
{
    $html_on = 0;
}
else
{
    $html_on = ( $submit || $refresh ) ? ( ( !empty($HTTP_POST_VARS['disable_html']) ) ? 0 : TRUE ) : ( ( $userdata['user_id'] == ANONYMOUS ) ? $board_config['allow_html'] : $userdata['user_allowhtml'] );
}
if ( !$board_config['allow_bbcode'] )
{
    $bbcode_on = 0;
}
else
{
    $bbcode_on = ( $submit || $refresh ) ? ( ( !empty($HTTP_POST_VARS['disable_bbcode']) ) ? 0 : TRUE ) : ( ( $userdata['user_id'] == ANONYMOUS ) ? $board_config['allow_bbcode'] : $userdata['user_allowbbcode'] );
}
if ( !$board_config['allow_smilies'] )
{
    $smilies_on = 0;
}
else
{
    $smilies_on = ( $submit || $refresh ) ? ( ( !empty($HTTP_POST_VARS['disable_smilies']) ) ? 0 : TRUE ) : ( ( $userdata['user_id'] == ANONYMOUS ) ? $board_config['allow_smilies'] : $userdata['user_allowsmile'] );
}
if ( ($submit || $refresh) && $is_auth['auth_read'])
{
    $notify_user = ( !empty($HTTP_POST_VARS['notify']) ) ? TRUE : 0;
}
else
{
    if ( $mode != 'newtopic' && $userdata['session_logged_in'] && $is_auth['auth_read'] )
    {
        $sql = "SELECT topic_id 
            FROM " . TOPICS_WATCH_TABLE . "
            WHERE topic_id = $topic_id 
            AND user_id = " . $userdata['user_id'];
        if ( !($result = $db->sql_query($sql)) )
        {
            message_die(GENERAL_ERROR, 'Could not obtain topic watch information', '', __LINE__, __FILE__, $sql);
        }
        $notify_user = ( $db->sql_fetchrow($result) ) ? TRUE : $userdata['user_notify'];
        $db->sql_freeresult($result);
    }
    else
    {
        $notify_user = ( $userdata['session_logged_in'] && $is_auth['auth_read'] ) ? $userdata['user_notify'] : 0;
    }
}
$attach_sig = ( $submit || $refresh ) ? ( ( !empty($HTTP_POST_VARS['attach_sig']) ) ? TRUE : 0 ) : ( ( $userdata['user_id'] == ANONYMOUS ) ? 0 : $userdata['user_attachsig'] );
    if (!empty($HTTP_SERVER_VARS['HTTP_USER_AGENT'])) 
    {
        $HTTP_USER_AGENT = $HTTP_SERVER_VARS['HTTP_USER_AGENT'];
    }
    else if (!isset($HTTP_USER_AGENT))
    {
        $HTTP_USER_AGENT = '';
    }
    if (ereg('Opera(/| )([0-9].[0-9]{1,2})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'opera';
    } 
    else if (ereg('MSIE ([0-9].[0-9]{1,2})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'ie';
    } 
    else if (ereg('OmniWeb/([0-9].[0-9]{1,2})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'omniweb';
    } 
    else if (ereg('Netscape([0-9]{1})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'netscape';
    } 
    else if (ereg('Mozilla/([0-9].[0-9]{1,2})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'mozilla';
    } 
    else if (ereg('Konqueror/([0-9].[0-9]{1,2})', $HTTP_USER_AGENT)) 
    {
        $browser_agent = 'konqueror';
    } 
    else 
    {
        $browser_agent = 'other';
    }
execute_posting_attachment_handling();
if ( ( $delete || $poll_delete || $mode == 'delete' ) && !$confirm )
{
    $s_hidden_fields = '<input type="hidden" name="' . POST_POST_URL . '" value="' . $post_id . '" />';
    $s_hidden_fields .= ( $delete || $mode == "delete" ) ? '<input type="hidden" name="mode" value="delete" />' : '<input type="hidden" name="mode" value="poll_delete" />';
    $s_hidden_fields .= '<input type="hidden" name="sid" value="' . $userdata['session_id'] . '" />';
    $l_confirm = ( $delete || $mode == 'delete' ) ? $lang['Confirm_delete'] : $lang['Confirm_delete_poll'];
        
        $page_title = $lang['Information']; 
    include($phpbb_root_path . 'includes/page_header.'.$phpEx);
    $template->set_filenames(array(
        'confirm_body' => 'confirm_body.tpl')
    );
    $template->assign_vars(array(
        'MESSAGE_TITLE' => $lang['Information'],
        'MESSAGE_TEXT' => $l_confirm,
        'L_YES' => $lang['Yes'],
        'L_NO' => $lang['No'],
        'S_CONFIRM_ACTION' => append_sid("posting.$phpEx"),
        'S_HIDDEN_FIELDS' => $s_hidden_fields)
    );
    $template->pparse('confirm_body');
    include($phpbb_root_path . 'includes/page_tail.'.$phpEx);
}
else if ( $mode == 'thank' ) 
{
    $topic_id = intval($HTTP_GET_VARS[POST_TOPIC_URL]);
        if ( !($userdata['session_logged_in']) )
        {
            $message = $lang['thanks_not_logged'];
            $message .=  '<br /><br />' . sprintf($lang['Click_return_topic'], '<a href="' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">', '</a>');
            message_die(GENERAL_MESSAGE, $message);
        }
        if ( empty($topic_id) )
        {
            message_die(GENERAL_MESSAGE, 'No topic Selected');
        }
        $userid = $userdata['user_id'];
        $thanks_date = time();
        $sql = "SELECT `topic_poster`
                FROM " . TOPICS_TABLE . " 
                WHERE topic_id = $topic_id
                AND topic_poster = $userid";
        if ( !($result = $db->sql_query($sql)) )
        {
            message_die(GENERAL_ERROR, "Couldn't check for topic starter", '', __LINE__, __FILE__, $sql);
                    
        }
        if ( ($topic_starter_check = $db->sql_fetchrow($result)) )
        {
            $message = $lang['t_starter'];
            $message .=  '<br /><br />' . sprintf($lang['Click_return_topic'], '<a href="' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">', '</a>');
            message_die(GENERAL_MESSAGE, $message);
        }
        $sql = "SELECT `topic_id`
                FROM " . THANKS_TABLE . " 
                WHERE topic_id = $topic_id
                AND user_id = $userid";
        if ( !($result = $db->sql_query($sql)) )
        {
            message_die(GENERAL_ERROR, "Couldn't check for previous thanks", '', __LINE__, __FILE__, $sql);
                    
        }
        if ( !($thankfull_check = $db->sql_fetchrow($result)) )
        {
            $sql = "INSERT INTO " . THANKS_TABLE . " (topic_id, user_id, thanks_time) 
            VALUES ('" . $topic_id . "', '" . $userid . "', " . $thanks_date . ") ";
            if ( !($result = $db->sql_query($sql)) )
            {
                message_die(GENERAL_ERROR, "Could not insert thanks information", '', __LINE__, __FILE__, $sql);
                    
            }
            $message = $lang['thanks_add'];
        }
        else
        {
            $message = $lang['thanked_before'];
        }
        $template->assign_vars(array(
            'META' => '<meta http-equiv="refresh" content="3;url=' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">')
        );
        $message .=  '<br /><br />' . sprintf($lang['Click_return_topic'], '<a href="' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">', '</a>');
        
        message_die(GENERAL_MESSAGE, $message);    
}
else if ( $mode == 'vote' )
{
    if ( !empty($HTTP_POST_VARS['vote_id']) )
    {
        $vote_option_id = intval($HTTP_POST_VARS['vote_id']);
        $sql = "SELECT vd.vote_id    
            FROM " . VOTE_DESC_TABLE . " vd, " . VOTE_RESULTS_TABLE . " vr
            WHERE vd.topic_id = $topic_id 
                AND vr.vote_id = vd.vote_id 
                AND vr.vote_option_id = $vote_option_id
            GROUP BY vd.vote_id";
        if ( !($result = $db->sql_query($sql)) )
        {
            message_die(GENERAL_ERROR, 'Could not obtain vote data for this topic', '', __LINE__, __FILE__, $sql);
        }
        if ( $vote_info = $db->sql_fetchrow($result) )
        {
            $vote_id = $vote_info['vote_id'];
            $sql = "SELECT * 
                FROM " . VOTE_USERS_TABLE . "  
                WHERE vote_id = $vote_id 
                    AND vote_user_id = " . $userdata['user_id'];
            if ( !($result2 = $db->sql_query($sql)) )
            {
                message_die(GENERAL_ERROR, 'Could not obtain user vote data for this topic', '', __LINE__, __FILE__, $sql);
            }
            if ( !($row = $db->sql_fetchrow($result2)) )
            {
                $sql = "UPDATE " . VOTE_RESULTS_TABLE . " 
                    SET vote_result = vote_result + 1 
                    WHERE vote_id = $vote_id 
                        AND vote_option_id = $vote_option_id";
                if ( !$db->sql_query($sql, BEGIN_TRANSACTION) )
                {
                    message_die(GENERAL_ERROR, 'Could not update poll result', '', __LINE__, __FILE__, $sql);
                }
                $sql = "INSERT INTO " . VOTE_USERS_TABLE . " (vote_id, vote_user_id, vote_user_ip) 
                    VALUES ($vote_id, " . $userdata['user_id'] . ", '$user_ip')";
                if ( !$db->sql_query($sql, END_TRANSACTION) )
                {
                    message_die(GENERAL_ERROR, "Could not insert user_id for poll", "", __LINE__, __FILE__, $sql);
                }
                $message = $lang['Vote_cast'];
                if ($board_config['points_poll'] && !$post_info['points_disabled'] )
                {
                    if (($userdata['user_id'] !=ANONYMOUS)/* && ($userdata['admin_allow_points'])*/)
                    {
                        add_points($userdata['user_id'], $board_config['points_vote']);
                    }
                }
            }
            else
            {
                $message = $lang['Already_voted'];
            }
            $db->sql_freeresult($result2);
        }
        else
        {
            $message = $lang['No_vote_option'];
        }
        $db->sql_freeresult($result);
        $template->assign_vars(array(
            'META' => '<meta http-equiv="refresh" content="0;url=' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">')
        );
        $message .=  '<br /><br />' . sprintf($lang['Click_view_message'], '<a href="' . append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id") . '">', '</a>');
        message_die(GENERAL_MESSAGE, $message);
    }
    else
    {
        redirect(append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id", true));
    }
}
else if ( $submit || $confirm )
{
    $return_message = '';
    $return_meta = '';
    if ($sid == '' || $sid != $userdata['session_id'])
    {
        $error_msg .= (!empty($error_msg)) ? '<br />' . $lang['Session_invalid'] : $lang['Session_invalid'];
    }
        $translit = ( isset($HTTP_POST_VARS['translit']) ) ? TRUE : FALSE; 
        if ( $translit )
        {
        switch ( $mode )
        {
        case 'editpost':
        case 'newtopic':
        case 'reply':
            $username = ( !empty($HTTP_POST_VARS['username']) ) ? $HTTP_POST_VARS['username'] : '';
            $subject = ( !empty($HTTP_POST_VARS['subject']) ) ? trim($HTTP_POST_VARS['subject']) : '';
            $subject = ( $mode == 'reply' ) ? $template_name . ': ' . $subject : $subject;
            $message = ( !empty($HTTP_POST_VARS['message']) ) ?  '[rus]' . $HTTP_POST_VARS['message'] . '[/rus]' : '';
            $poll_title = ( isset($HTTP_POST_VARS['poll_title']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_title'] : '';
            $poll_options = ( isset($HTTP_POST_VARS['poll_option_text']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_option_text'] : '';
            $poll_length = ( isset($HTTP_POST_VARS['poll_length']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_length'] : '';
            $bbcode_uid = '';
                        
            prepare_post($mode, $post_data, $bbcode_on, $html_on, $smilies_on, $error_msg, $username, $bbcode_uid, $subject, $message, $poll_title, $poll_options, $poll_length);
                        spam_hook('', $error_msg, $username, $subject, $message);
                        
            if ( $error_msg == '' )
            {
                $topic_type = ( $topic_type != $post_data['topic_type'] && !$is_auth['auth_sticky'] && !$is_auth['auth_announce'] ) ? $post_data['topic_type'] : $topic_type;
                                if ($lock_subject)
                                {
                                   $url = "<a href='viewtopic.$phpEx?" . POST_POST_URL . "=" .$lock_subject."#".$lock_subject."'> ";
                                   $message = addslashes(sprintf($lang['Link_to_post'],$url,"</a>")).$message;    
                                }
                submit_post($mode, $post_data, $return_message, $return_meta, $forum_id, $topic_id, $post_id, $poll_id, $topic_type, $bbcode_on, $html_on, $smilies_on, $attach_sig, $bbcode_uid, str_replace("'", "''", $username), str_replace("'", "''", $subject), str_replace("'", "''", $message), str_replace("'", "''", $poll_title), $poll_options, $poll_length);
            }
            break;
        case 'delete':
        case 'poll_delete':
            if ($error_msg != '')
            {
                message_die(GENERAL_MESSAGE, $error_msg);
            }
            delete_post($mode, $post_data, $return_message, $return_meta, $forum_id, $topic_id, $post_id, $poll_id);
            break;
          }
         } 
         else 
         {
        switch ( $mode )
        {
        case 'editpost':
        case 'newtopic':
        case 'reply':
            $username = ( !empty($HTTP_POST_VARS['username']) ) ? $HTTP_POST_VARS['username'] : '';
            $subject = ( !empty($HTTP_POST_VARS['subject']) ) ? trim($HTTP_POST_VARS['subject']) : '';
            $subject = ( $mode == 'reply' ) ? $template_name . ': ' . $subject : $subject;
            $message = ( !empty($HTTP_POST_VARS['message']) ) ?  $HTTP_POST_VARS['message'] : '';
            $poll_title = ( isset($HTTP_POST_VARS['poll_title']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_title'] : '';
            $poll_options = ( isset($HTTP_POST_VARS['poll_option_text']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_option_text'] : '';
            $poll_length = ( isset($HTTP_POST_VARS['poll_length']) && $is_auth['auth_pollcreate'] ) ? $HTTP_POST_VARS['poll_length'] : '';
            $bbcode_uid = '';
            
            prepare_post($mode, $post_data, $bbcode_on, $html_on, $smilies_on, $error_msg, $username, $bbcode_uid, $subject, $message, $poll_title, $poll_options, $poll_length);
                        spam_hook('', $error_msg, $username, $subject, $message);
            
            if ( $error_msg == '' )
            {
                $topic_type = ( $topic_type != $post_data['topic_type'] && !$is_auth['auth_sticky'] && !$is_auth['auth_announce'] ) ? $post_data['topic_type'] : $topic_type;
                                if ($lock_subject)
                                {
                                   $url = "<a href='viewtopic.$phpEx?" . POST_POST_URL . "=" .$lock_subject."#".$lock_subject."'> ";
                                   $message = addslashes(sprintf($lang['Link_to_post'],$url,"</a>")).$message;    
                                }
                submit_post($mode, $post_data, $return_message, $return_meta, $forum_id, $topic_id, $post_id, $poll_id, $topic_type, $bbcode_on, $html_on, $smilies_on, $attach_sig, $bbcode_uid, str_replace("'", "''", $username), str_replace("'", "''", $subject), str_replace("'", "''", $message), str_replace("'", "''", $poll_title), $poll_options, $poll_length);
            }
            break;
        case 'delete':
        case 'poll_delete':
            if ($error_msg != '')
            {
                message_die(GENERAL_MESSAGE, $error_msg);
            }
            delete_post($mode, $post_data, $return_message, $return_meta, $forum_id, $topic_id, $post_id, $poll_id);
            break;
          }
         }
         if ( $error_msg == '' )
         {
        if ( $mode != 'editpost' )
        {
            $user_id = ( $mode == 'reply' || $mode == 'newtopic' ) ? $userdata['user_id'] : $post_data['poster_id'];
            $post_data['points_disabled'] = $post_info['points_disabled'];
            /*$post_data['admin_allow_points'] = ( $mode == 'reply' || $mode == 'newtopic' ) ? $userdata['admin_allow_points'] : $post_info['admin_allow_points'];*/
            update_post_stats($mode, $post_data, $forum_id, $topic_id, $post_id, $user_id);                      
        }
                $attachment_mod['posting']->insert_attachment($post_id);
                
        if ($error_msg == '' && $mode != 'poll_delete')
        {
            user_notification($mode, $post_data, $post_info['topic_title'], $forum_id, $topic_id, $post_id, $notify_user);
        }
                if ($lock_subject) 
                { 
                   $url = "<a href='".append_sid("viewtopic.$phpEx?" . POST_POST_URL . "=" .$lock_subject."#".$lock_subject)."'> ";
                   $return_message = $lang['Report_stored']."<br/><br/>".sprintf($lang['Send_report'],$url,"</a>");    
                   $return_meta = str_replace($post_id,$lock_subject,$return_meta); 
                } 
        if ( $mode == 'newtopic' || $mode == 'reply' )
        {
            $tracking_topics = ( !empty($HTTP_COOKIE_VARS[$board_config['cookie_name'] . '_t']) ) ? unserialize($HTTP_COOKIE_VARS[$board_config['cookie_name'] . '_t']) : array();
            $tracking_forums = ( !empty($HTTP_COOKIE_VARS[$board_config['cookie_name'] . '_f']) ) ? unserialize($HTTP_COOKIE_VARS[$board_config['cookie_name'] . '_f']) : array();
            if ( count($tracking_topics) + count($tracking_forums) == 100 && empty($tracking_topics[$topic_id]) )
            {
                asort($tracking_topics);
                unset($tracking_topics[key($tracking_topics)]);
            }
            $tracking_topics[$topic_id] = time();
            setcookie($board_config['cookie_name'] . '_t', serialize($tracking_topics), 0, $board_config['cookie_path'], $board_config['cookie_domain'], $board_config['cookie_secure']);
        }
        $template->assign_vars(array(
            'META' => $return_meta)
        );
        message_die(GENERAL_MESSAGE, $return_message);
     }
}
if( $refresh || isset($HTTP_POST_VARS['del_poll_option']) || $error_msg != '' )
{
    $username = ( !empty($HTTP_POST_VARS['username']) ) ? htmlspecialchars(trim(stripslashes($HTTP_POST_VARS['username']))) : '';
    $subject = ( !empty($HTTP_POST_VARS['subject']) ) ? htmlspecialchars(trim(stripslashes($HTTP_POST_VARS['subject']))) : '';
    $message = ( !empty($HTTP_POST_VARS['message']) ) ? htmlspecialchars(trim(stripslashes($HTTP_POST_VARS['message']))) : '';
    $poll_title = ( !empty($HTTP_POST_VARS['poll_title']) ) ? htmlspecialchars(trim(stripslashes($HTTP_POST_VARS['poll_title']))) : '';
    $poll_length = ( isset($HTTP_POST_VARS['poll_length']) ) ? max(0, intval($HTTP_POST_VARS['poll_length'])) : 0;
    $poll_options = array();
    if ( !empty($HTTP_POST_VARS['poll_option_text']) )
    {
        while( list($option_id, $option_text) = @each($HTTP_POST_VARS['poll_option_text']) )
        {
            if( isset($HTTP_POST_VARS['del_poll_option'][$option_id]) )
            {
                unset($poll_options[$option_id]);
            }
            else if ( !empty($option_text) ) 
            {
                $poll_options[intval($option_id)] = htmlspecialchars(trim(stripslashes($option_text)));
            }
        }
    }
    if ( isset($poll_add) && !empty($HTTP_POST_VARS['add_poll_option_text']) )
    {
        $poll_options[] = htmlspecialchars(trim(stripslashes($HTTP_POST_VARS['add_poll_option_text'])));
    }
    if ( $mode == 'newtopic' || $mode == 'reply')
    {
        $user_sig = ( $userdata['user_sig'] != '' && $board_config['allow_sig'] ) ? $userdata['user_sig'] : '';
    }
    else if ( $mode == 'editpost' )
    {
        $user_sig = ( $post_info['user_sig'] != '' && $board_config['allow_sig'] ) ? $post_info['user_sig'] : '';
        $userdata['user_sig_bbcode_uid'] = $post_info['user_sig_bbcode_uid'];
    }
    spam_hook('', $error_msg, $username, $subject, $message);   
         
        if($error_msg != '')        
    {
        $template->set_filenames(array(
            'reg_header' => 'error_body.tpl')
        );
        $template->assign_vars(array(
            'ERROR_MESSAGE' => $error_msg)
        );
        $template->assign_var_from_handle('ERROR_BOX', 'reg_header');
    }
}
else
{
        $postreport=(isset($HTTP_GET_VARS['postreport']))? intval( $HTTP_GET_VARS['postreport']) : 0;
        if ($postreport)
        {
           $sql = 'SELECT topic_id 
                   FROM ' . POSTS_TABLE . ' 
                   WHERE post_id = "'.$postreport.'"';        
           if( !($result = $db->sql_query($sql) ))
           {
                   message_die(GENERAL_ERROR, "Couldn't get post subject information");
           }         
           $post_details = $db->sql_fetchrow($result);
           $post_topic_id = $post_details['topic_id'];
           
           $sql = 'SELECT pt.post_subject 
                   FROM ' . POSTS_TEXT_TABLE . ' pt, ' . POSTS_TABLE . ' p 
                   WHERE p.topic_id = "' . $post_topic_id . '" 
                   AND pt.post_id = p.post_id 
                   ORDER BY p.post_time ASC LIMIT 1';
           if( !($result = $db->sql_query($sql) )) 
           {
               message_die(GENERAL_ERROR, "Couldn't get topic subject information".$sql); 
           }       
           $post_details = $db->sql_fetchrow($result);
           $subject = '(' . $postreport . ')' . $post_details['post_subject'];
           $lock_subject = $postreport;
        } 
        else
        {
           $subject = '';
           $lock_subject='';
        }              
    if ( $mode == 'newtopic' )
    {
        $user_sig = ( $userdata['user_sig'] != '' ) ? $userdata['user_sig'] : '';
                $subject = '';
        $message = '';
    }
    else if ( $mode == 'reply' )
    {
        $user_sig = ( $userdata['user_sig'] != '' ) ? $userdata['user_sig'] : '';
        $username = ( $userdata['session_logged_in'] ) ? $userdata['username'] : '';
        $subject = $post_info['topic_title'];
        $message = '';
    }
    else if ( $mode == 'quote' || $mode == 'reply_to_user' || $mode == 'editpost' )
    {
        $subject = ( $post_data['first_post'] || !$post_info['post_subject'] ) ? $post_info['topic_title'] : $post_info['post_subject'];
        if ((preg_match('/^wap:/', $subject) || preg_match('/^web:/', $subject)) && strlen($subject) > 0 && $mode != 'editpost')
        {
                $parrent = (preg_match('/^wap:/', $subject)) ? 'wap: ' : 'web: ';
                $subject = str_replace($parrent, '', $subject);
        }  
        $message = $post_info['post_text'];
        if ( $mode == 'editpost' )
        {
            $attach_sig = ( $post_info['enable_sig'] && $post_info['user_sig'] != '' ) ? TRUE : 0; 
            $user_sig = $post_info['user_sig'];
            $html_on = ( $post_info['enable_html'] ) ? true : false;
            $bbcode_on = ( $post_info['enable_bbcode'] ) ? true : false;
            $smilies_on = ( $post_info['enable_smilies'] ) ? true : false;
        }
        else
        {
            $attach_sig = ( $userdata['user_attachsig'] ) ? TRUE : 0;
            $user_sig = $userdata['user_sig'];
        }
        if ( $post_info['bbcode_uid'] != '' )
        {
            $message = preg_replace('/:(([a-z0-9]:)?)' . $post_info['bbcode_uid'] . '/s', '', $message);
        }
        $message = str_replace('<', '<', $message);
        $message = str_replace('>', '>', $message);
        $message = str_replace('<br />', "n", $message);
        
        if (( $mode == 'quote' )||( $mode == 'reply_to_user' ))
        {
            $orig_word = array();
            $replacement_word = array();
            obtain_word_list($orig_word, $replace_word);
            $msg_date =  create_date($board_config['default_dateformat'], $postrow['post_time'], $board_config['board_timezone']);
            $quote_username = ( trim($post_info['post_username']) != '' ) ? $post_info['post_username'] : $post_info['username'];
            
            if ( $mode == 'quote' )
                        {
                    $message = '[quote="' . $quote_username . '"]' . $message . '[/quote]';
                        }
                        if ( $mode == 'reply_to_user' )
                        {
                                $message = $quote_username . ', ' ;
                        }
            if ( !empty($orig_word) )
            {
                $subject = ( !empty($subject) ) ? str_replace($orig_word, $replace_word, $subject) : '';
                $message = ( !empty($message) ) ? str_replace($orig_word, $replace_word, $message) : '';
            }
            if ( !preg_match('/^Re:/', $subject) && strlen($subject) > 0 )
            {
                $subject = 'Re: ' . $subject;
            }
            $mode = 'reply';
        }
        else
        {
            $username = ( $post_info['user_id'] == ANONYMOUS && !empty($post_info['post_username']) ) ? $post_info['post_username'] : '';
        }      
    }
}
if( $user_sig != '' )
{
    $template->assign_block_vars('switch_signature_checkbox', array());
}
if ( $board_config['allow_html'] )
{
    $html_status = $lang['HTML_is_ON'];
    $template->assign_block_vars('switch_html_checkbox', array());
}
else
{
    $html_status = $lang['HTML_is_OFF'];
}
if ( $board_config['allow_bbcode'] )
{
    $bbcode_status = $lang['BBCode_is_ON'];
    $template->assign_block_vars('switch_bbcode_checkbox', array());
}
else
{
    $bbcode_status = $lang['BBCode_is_OFF'];
}
if ( $board_config['allow_smilies'] )
{
    $smilies_status = $lang['Smilies_are_ON'];
    $template->assign_block_vars('switch_smilies_checkbox', array());
}
else
{
    $smilies_status = $lang['Smilies_are_OFF'];
}
if( !$userdata['session_logged_in'] || ( $mode == 'editpost' && $post_info['poster_id'] == ANONYMOUS ) )
{
    $template->assign_block_vars('switch_username_select', array());
}
if ( $userdata['session_logged_in'] && $is_auth['auth_read'] )
{
    if ( $mode != 'editpost' || ( $mode == 'editpost' && $post_info['poster_id'] != ANONYMOUS ) )
    {
        $template->assign_block_vars('switch_notify_checkbox', array());
    }
}
if ( $mode == 'editpost' && ( ( $is_auth['auth_delete'] && $post_data['last_post'] && ( !$post_data['has_poll'] || $post_data['edit_poll'] ) ) || $is_auth['auth_mod'] ) )
{
    $template->assign_block_vars('switch_delete_checkbox', array());
}
$topic_type_toggle = '';
if ( $mode == 'newtopic' || ( $mode == 'editpost' && $post_data['first_post'] ) )
{
    $template->assign_block_vars('switch_allow_subject_on', array()); 
    if( $is_auth['auth_sticky'] )
    {
        $topic_type_toggle .= '<input type="radio" name="topictype" value="' . POST_STICKY . '"';
        if ( $post_data['topic_type'] == POST_STICKY || $topic_type == POST_STICKY )
        {
            $topic_type_toggle .= ' checked="checked"';
        }
        $topic_type_toggle .= ' />' . $lang['Post_Sticky'];
    }
    if( $is_auth['auth_announce'] )
    {
        $topic_type_toggle .= '<input type="radio" name="topictype" value="' . POST_ANNOUNCE . '"';
        if ( $post_data['topic_type'] == POST_ANNOUNCE || $topic_type == POST_ANNOUNCE )
        {
            $topic_type_toggle .= ' checked="checked"';
        }
        $topic_type_toggle .= ' />' . $lang['Post_Announcement'];
    }
    if ( $topic_type_toggle != '' )
    {
        $template->assign_block_vars('switch_type_toggle', array());
        $topic_type_toggle = $lang['Post_topic_as'] . ':<br/><input type="radio" name="topictype" value="' . POST_NORMAL .'"' . ( ( $post_data['topic_type'] == POST_NORMAL || $topic_type == POST_NORMAL ) ? ' checked="checked"' : '' ) . ' />' . $lang['Post_Normal'] . '' . $topic_type_toggle;
    }
}
$hidden_form_fields = '<input type="hidden" name="mode" value="' . $mode . '" />';
$hidden_form_fields .= '<input type="hidden" name="sid" value="' . $userdata['session_id'] . '" />';
$hidden_form_fields .= ($lock_subject) ? '<input type="hidden" name="lock_subject" value="'.$lock_subject.'" />':'';
switch( $mode )
{
    case 'newtopic':
        $page_title = $lang['Post_a_new_topic'];
        $hidden_form_fields .= '<input type="hidden" name="' . POST_FORUM_URL . '" value="' . $forum_id . '" />';
        break;
    case 'reply':
        $page_title = $lang['Post_a_reply'];
        $hidden_form_fields .= '<input type="hidden" name="' . POST_TOPIC_URL . '" value="' . $topic_id . '" />';
        break;
    case 'editpost':
        $page_title = $lang['Edit_Post'];
        $hidden_form_fields .= '<input type="hidden" name="' . POST_POST_URL . '" value="' . $post_id . '" />';
        break;
}
generate_smilies('inline', PAGE_POSTING);
include($phpbb_root_path . 'includes/page_header.'.$phpEx);
$template->set_filenames(array(
    'body' => 'posting_body.tpl', 
    'pollbody' => 'posting_poll_body.tpl')
);
$template->assign_vars(array(
    'FORUM_NAME' => $forum_name,
    'L_POST_A' => $page_title,
    'L_POST_SUBJECT' => $lang['Post_subject'], 
    'U_VIEW_FORUM' => append_sid("viewforum.$phpEx?" . POST_FORUM_URL . "=$forum_id"))
);
$template->assign_block_vars('switch_not_privmsg', array());
$template->assign_vars(array(
    'USERNAME' => $username,
    'SUBJECT' => $subject,
    'MESSAGE' => $message,
    'HTML_STATUS' => $html_status,
    'SMILIES_STATUS' => $smilies_status, 
    'L_SUBJECT' => $lang['Subject'],
    'L_MESSAGE_BODY' => $lang['Message_body'],
    'L_OPTIONS' => $lang['Options'],
    'L_PREVIEW' => $lang['Preview'],
    'L_SPELLCHECK' => $lang['Spellcheck'],
    'L_SUBMIT' => $lang['Submit'],
    
    'L_CANCEL' => $lang['Cancel'],
    'L_CONFIRM_DELETE' => $lang['Confirm_delete'],
    'L_DISABLE_HTML' => $lang['Disable_HTML_post'], 
    'L_DISABLE_BBCODE' => $lang['Disable_BBCode_post'], 
    'L_DISABLE_SMILIES' => $lang['Disable_Smilies_post'], 
    'L_ATTACH_SIGNATURE' => $lang['Attach_signature'], 
    'L_NOTIFY_ON_REPLY' => $lang['Notify'], 
    'L_DELETE_POST' => $lang['Delete_post'],
    'U_VIEWTOPIC' => ( $mode == 'reply' ) ? append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id&postorder=desc") : '', 
    'U_REVIEW_TOPIC' => ( $mode == 'reply' ) ? append_sid("posting.$phpEx?mode=topicreview&" . POST_TOPIC_URL . "=$topic_id") : '', 
    'S_HTML_CHECKED' => ( !$html_on ) ? 'checked="checked"' : '', 
    'S_BBCODE_CHECKED' => ( !$bbcode_on ) ? 'checked="checked"' : '', 
    'S_SMILIES_CHECKED' => ( !$smilies_on ) ? 'checked="checked"' : '', 
    'S_SIGNATURE_CHECKED' => ( $attach_sig ) ? 'checked="checked"' : '', 
 
    'S_TYPE_TOGGLE' => $topic_type_toggle, 
    'S_TOPIC_ID' => $topic_id, 
    'S_POST_ACTION' => append_sid("posting.$phpEx"),
    'S_HIDDEN_FORM_FIELDS' => $hidden_form_fields)
);
if( ( $mode == 'newtopic' || ( $mode == 'editpost' && $post_data['edit_poll']) ) && $is_auth['auth_pollcreate'] )
{
    $template->assign_vars(array(
        'L_ADD_A_POLL' => $lang['Add_poll'],  
        'L_ADD_POLL_EXPLAIN' => $lang['Add_poll_explain'],   
        'L_POLL_QUESTION' => $lang['Poll_question'],   
        'L_POLL_OPTION' => $lang['Poll_option'],  
        'L_ADD_OPTION' => $lang['Add_option'],
        'L_UPDATE_OPTION' => $lang['Update'],
        'L_DELETE_OPTION' => $lang['Delete'], 
        'L_POLL_LENGTH' => $lang['Poll_for'],  
        'L_DAYS' => $lang['Days'], 
        'L_POLL_LENGTH_EXPLAIN' => $lang['Poll_for_explain'], 
        'L_POLL_DELETE' => $lang['Delete_poll'],
        
        'POLL_TITLE' => $poll_title,
        'POLL_LENGTH' => $poll_length)
    );
    if( $mode == 'editpost' && $post_data['edit_poll'] && $post_data['has_poll'])
    {
        $template->assign_block_vars('switch_poll_delete_toggle', array());
    }
    if( !empty($poll_options) )
    {
        while( list($option_id, $option_text) = each($poll_options) )
        {
            $template->assign_block_vars('poll_option_rows', array(
                'POLL_OPTION' => str_replace('"', '"', $option_text), 
                'S_POLL_OPTION_NUM' => $option_id)
            );
        }
    }
    $template->assign_var_from_handle('POLLBOX', 'pollbody');
}
$template->pparse('body');
include($phpbb_root_path . 'includes/page_tail.'.$phpEx);
?>