. // Post a reply to a thread. // Both input (form) and action take place here. require_once('../inc/util.inc'); require_once('../inc/forum_email.inc'); require_once('../inc/forum.inc'); require_once('../inc/bbcode_html.inc'); require_once('../inc/akismet.inc'); if (DISABLE_FORUMS) error_page("Forums are disabled"); $logged_in_user = get_logged_in_user(true); BoincForumPrefs::lookup($logged_in_user); check_banished($logged_in_user); $thread = BoincThread::lookup_id(get_int('thread')); $forum = BoincForum::lookup_id($thread->forum); $sort_style = get_str('sort', true); $filter = get_str('filter', true); $content = post_str('content', true); $preview = post_str("preview", true); $parent_post_id = get_int('post', true); $parent_post = null; if ($parent_post_id) { $parent_post = BoincPost::lookup_id($parent_post_id); if ($parent_post->thread != $thread->id) { error_page("wrong thread"); } } else { $parent_post_id = 0; } if ($filter != "false"){ $filter = true; } else { $filter = false; } check_reply_access($logged_in_user, $forum, $thread); if (!$sort_style) { $sort_style = $logged_in_user->prefs->thread_sorting; } else { $logged_in_user->prefs->update("thread_sorting=$sort_style"); } $warning = null; if ($content && (!$preview)){ if (post_str('add_signature',true)=="add_it"){ $add_signature=true; // set a flag and concatenate later } else { $add_signature=false; } check_tokens($logged_in_user->authenticator); if (!akismet_check($logged_in_user, $content)) { $warning = tra("Your post has been flagged as spam by the Akismet anti-spam system. Please modify your text and try again."); $preview = tra("Preview"); } else { $post_id = create_post( $content, $parent_post_id, $logged_in_user, $forum, $thread, $add_signature ); if ($post_id) { header("Location: forum_thread.php?id=$thread->id&postid=$post_id"); } else { error_page("Can't create post."); } } } page_head(tra("Post to thread"),'','','', $bbcode_js); show_forum_header($logged_in_user); if ($warning) { echo "$warning

"; } switch ($forum->parent_type) { case 0: $category = BoincCategory::lookup_id($forum->category); show_forum_title($category, $forum, $thread); break; case 1: show_team_forum_title($forum, $thread); break; } echo "

"; if ($preview == tra("Preview")) { $options = new output_options; echo "

".tra("Preview")."

\n"; echo "
" .output_transform($content, $options) ."
\n" ; } start_table(); show_message_row($thread, $parent_post); end_table(); if ($parent_post) { start_forum_table(array(tra("Author"), tra("Message"))); show_post( $parent_post, $thread, $forum, $logged_in_user, 0, 0, false, false ); end_table(); } else { show_posts($thread, $forum, 0, 0, CREATE_TIME_NEW, 0, $logged_in_user); } end_table(); page_tail(); function show_message_row($thread, $parent_post) { global $logged_in_user, $bbcode_html; global $content, $preview; $x1 = tra("Message:").html_info().post_warning(); $x2 = ""; if ($parent_post) { $x2 .=" ".tra("reply to %1Message ID%2:", "id.">", " ".$parent_post->id.""); } $x2 .= "
id; if ($parent_post) { $x2 .= "&post=".$parent_post->id; } $x2 .= " method=\"post\" name=\"post\" onsubmit=\"return checkForm(this)\">\n"; $x2 .= form_tokens($logged_in_user->authenticator); $x2 .= $bbcode_html."

   

"; row2($x1, $x2); } function quote_text($text) { $text = "[quote]" . $text . "[/quote]"; return $text; } $cvs_version_tracker[]="\$Id$"; ?>