Zeile 11 | Zeile 11 |
---|
define("IN_MYBB", 1); define('THIS_SCRIPT', 'showthread.php');
|
define("IN_MYBB", 1); define('THIS_SCRIPT', 'showthread.php');
|
$templatelist = "showthread,postbit,postbit_author_user,postbit_author_guest,showthread_newthread,showthread_newreply,showthread_newreply_closed,postbit_avatar,postbit_find,postbit_pm,postbit_www,postbit_email,postbit_edit,postbit_quote,postbit_report,postbit_signature,postbit_online,postbit_offline,postbit_away,postbit_gotopost,showthread_ratethread"; $templatelist .= ",multipage,multipage_breadcrumb,multipage_end,multipage_jump_page,multipage_nextpage,multipage_page,multipage_page_current,multipage_page_link_current,multipage_prevpage,multipage_start,showthread_inlinemoderation_softdelete,showthread_inlinemoderation_restore,showthread_inlinemoderation_delete,showthread_inlinemoderation_manage"; $templatelist .= ",postbit_editedby,showthread_similarthreads,showthread_similarthreads_bit,postbit_iplogged_show,postbit_iplogged_hiden,postbit_profilefield,showthread_quickreply,showthread_add_poll,showthread_send_thread,showthread_poll_editpoll,showthread_poll_undovote,showthread_moderationoptions_standard,postbit_editedby_editreason,postbit_warninglevel"; $templatelist .= ",forumjump_advanced,forumjump_special,forumjump_bit,postbit_reputation,postbit_quickdelete,postbit_attachments,postbit_attachments_attachment,postbit_attachments_thumbnails,postbit_attachments_images_image,postbit_attachments_images,showthread_inlinemoderation_standard,showthread_quickreply_options_stick,showthread_quickreply_options_close"; $templatelist .= ",postbit_inlinecheck,showthread_inlinemoderation,postbit_attachments_thumbnails_thumbnail,postbit_ignored,postbit_groupimage,postbit_multiquote,showthread_search,showthread_moderationoptions_custom_tool,showthread_moderationoptions_custom,showthread_inlinemoderation_custom_tool,showthread_inlinemoderation_custom,postbit_posturl,postbit_rep_button"; $templatelist .= ",showthread_usersbrowsing,showthread_usersbrowsing_user,showthread_poll_option_multiple,showthread_poll_option,showthread_poll,showthread_threadedbox,showthread_quickreply_options_signature,showthread_threaded_bitactive,showthread_threaded_bit,postbit_attachments_attachment_unapproved,showthread_threadnotes,showthread_threadnotes_viewnotes";
| $templatelist = "showthread,postbit,postbit_author_user,postbit_author_guest,showthread_newthread,showthread_newreply,showthread_newreply_closed,postbit_avatar,postbit_find,postbit_pm,postbit_www,postbit_email,postbit_edit,postbit_quote,postbit_report,postbit_signature,postbit_online,postbit_offline,postbit_away,showthread_ratethread"; $templatelist .= ",multipage,multipage_breadcrumb,multipage_end,multipage_jump_page,multipage_nextpage,multipage_page,multipage_page_current,multipage_page_link_current,multipage_prevpage,multipage_start,showthread_inlinemoderation_softdelete,showthread_inlinemoderation_restore,showthread_inlinemoderation_delete,postbit_posturl,postbit_icon"; $templatelist .= ",postbit_editedby,showthread_similarthreads,showthread_similarthreads_bit,postbit_iplogged_show,postbit_iplogged_hiden,postbit_profilefield,showthread_quickreply,showthread_add_poll,showthread_send_thread,showthread_poll_editpoll,showthread_poll_undovote,showthread_moderationoptions_standard,postbit_editedby_editreason"; $templatelist .= ",forumjump_advanced,forumjump_special,forumjump_bit,postbit_reputation,postbit_quickdelete,postbit_attachments,postbit_attachments_attachment,postbit_attachments_thumbnails,postbit_attachments_images_image,postbit_attachments_images,showthread_quickreply_options_stick,showthread_quickreply_options_close,attachment_icon"; $templatelist .= ",postbit_inlinecheck,showthread_inlinemoderation,postbit_attachments_thumbnails_thumbnail,postbit_ignored,postbit_groupimage,postbit_multiquote,showthread_search,showthread_moderationoptions_custom_tool,showthread_moderationoptions_custom,showthread_inlinemoderation_custom_tool,showthread_inlinemoderation_custom"; $templatelist .= ",showthread_usersbrowsing,showthread_usersbrowsing_user,showthread_poll_option_multiple,showthread_poll_option,showthread_poll,showthread_quickreply_options_signature,showthread_threaded_bitactive,showthread_threaded_bit,postbit_attachments_attachment_unapproved,showthread_threadnotes,showthread_threadnotes_viewnotes";
|
$templatelist .= ",showthread_moderationoptions_openclose,showthread_moderationoptions_stickunstick,showthread_moderationoptions_delete,showthread_moderationoptions_threadnotes,showthread_moderationoptions_manage,showthread_moderationoptions_deletepoll,showthread_threadnoteslink,showthread_poll_results,showthread_classic_header,postbit_warn";
|
$templatelist .= ",showthread_moderationoptions_openclose,showthread_moderationoptions_stickunstick,showthread_moderationoptions_delete,showthread_moderationoptions_threadnotes,showthread_moderationoptions_manage,showthread_moderationoptions_deletepoll,showthread_threadnoteslink,showthread_poll_results,showthread_classic_header,postbit_warn";
|
$templatelist .= ",postbit_userstar,postbit_reputation_formatted_link,postbit_warninglevel_formatted,postbit_quickrestore,forumdisplay_password,forumdisplay_password_wrongpass,postbit_classic,postbit_purgespammer,showthread_inlinemoderation_approve,showthread_moderationoptions,forumdisplay_thread_icon,showthread_poll_resultbit,global_moderation_notice";
| $templatelist .= ",postbit_userstar,postbit_reputation_formatted_link,postbit_warninglevel_formatted,postbit_quickrestore,forumdisplay_password,forumdisplay_password_wrongpass,postbit_classic,postbit_purgespammer,showthread_inlinemoderation_approve,forumdisplay_thread_icon,showthread_poll_resultbit,postbit_warninglevel,postbit_gotopost"; $templatelist .= ",showthread_moderationoptions_softdelete,showthread_moderationoptions_restore,post_captcha,post_captcha_recaptcha,post_captcha_nocaptcha,post_captcha_ayah,showthread_moderationoptions,showthread_inlinemoderation_standard,showthread_threadedbox,postbit_rep_button,showthread_inlinemoderation_manage,global_moderation_notice";
|
require_once "./global.php"; require_once MYBB_ROOT."inc/functions_post.php";
| require_once "./global.php"; require_once MYBB_ROOT."inc/functions_post.php";
|
Zeile 33 | Zeile 34 |
---|
if(!empty($mybb->input['pid']) && !isset($mybb->input['tid'])) { // see if we already have the post information
|
if(!empty($mybb->input['pid']) && !isset($mybb->input['tid'])) { // see if we already have the post information
|
if(isset($style) && $style['pid'] == $mybb->get_input('pid', 1) && $style['tid'])
| if(isset($style) && $style['pid'] == $mybb->get_input('pid', MyBB::INPUT_INT) && $style['tid'])
|
{ $mybb->input['tid'] = $style['tid']; unset($style['tid']); // stop the thread caching code from being tricked
| { $mybb->input['tid'] = $style['tid']; unset($style['tid']); // stop the thread caching code from being tricked
|
Zeile 43 | Zeile 44 |
---|
$options = array( "limit" => 1 );
|
$options = array( "limit" => 1 );
|
$query = $db->simple_select("posts", "tid", "pid=".$mybb->get_input('pid', 1), $options);
| $query = $db->simple_select("posts", "fid,tid,visible", "pid=".$mybb->get_input('pid', MyBB::INPUT_INT), $options);
|
$post = $db->fetch_array($query);
|
$post = $db->fetch_array($query);
|
if(empty($post))
| if(empty($post) || ($post['visible'] == 0 && !is_moderator($post['fid'], 'canviewunapprove')) || ($post['visible'] == -1 && !is_moderator($post['fid'], 'canviewdeleted')))
|
{ // post does not exist --> show corresponding error error($lang->error_invalidpost);
| { // post does not exist --> show corresponding error error($lang->error_invalidpost);
|
Zeile 57 | Zeile 58 |
---|
}
// Get the thread details from the database.
|
}
// Get the thread details from the database.
|
$thread = get_thread($mybb->get_input('tid', 1));
| $thread = get_thread($mybb->get_input('tid', MyBB::INPUT_INT));
|
if(!$thread || substr($thread['closed'], 0, 6) == "moved|") {
| if(!$thread || substr($thread['closed'], 0, 6) == "moved|") {
|
Zeile 73 | Zeile 74 |
---|
if(!empty($threadprefix['prefix'])) {
|
if(!empty($threadprefix['prefix'])) {
|
$thread['threadprefix'] = $threadprefix['prefix'].' ';
| $thread['threadprefix'] = htmlspecialchars_uni($threadprefix['prefix']).' ';
|
$thread['displayprefix'] = $threadprefix['displaystyle'].' '; } }
| $thread['displayprefix'] = $threadprefix['displaystyle'].' '; } }
|
Zeile 88 | Zeile 89 |
---|
$reply_subject = htmlspecialchars_uni($reply_subject); $tid = $thread['tid']; $fid = $thread['fid'];
|
$reply_subject = htmlspecialchars_uni($reply_subject); $tid = $thread['tid']; $fid = $thread['fid'];
|
|
|
if(!$thread['username'])
|
if(!$thread['username'])
|
{
| {
|
$thread['username'] = $lang->guest; }
| $thread['username'] = $lang->guest; }
|
Zeile 101 | Zeile 102 |
---|
if(is_moderator($fid, "canviewdeleted") == true || is_moderator($fid, "canviewunapprove") == true) { if(is_moderator($fid, "canviewunapprove") == true && is_moderator($fid, "canviewdeleted") == false)
|
if(is_moderator($fid, "canviewdeleted") == true || is_moderator($fid, "canviewunapprove") == true) { if(is_moderator($fid, "canviewunapprove") == true && is_moderator($fid, "canviewdeleted") == false)
|
{
| {
|
$visibleonly = " AND visible IN (0,1)"; $visibleonly2 = "AND p.visible IN (0,1) AND t.visible IN (0,1)"; }
| $visibleonly = " AND visible IN (0,1)"; $visibleonly2 = "AND p.visible IN (0,1) AND t.visible IN (0,1)"; }
|
Zeile 109 | Zeile 110 |
---|
{ $visibleonly = " AND visible IN (-1,1)"; $visibleonly2 = "AND p.visible IN (-1,1) AND t.visible IN (-1,1)";
|
{ $visibleonly = " AND visible IN (-1,1)"; $visibleonly2 = "AND p.visible IN (-1,1) AND t.visible IN (-1,1)";
|
}
| }
|
else { $visibleonly = " AND visible IN (-1,0,1)";
| else { $visibleonly = " AND visible IN (-1,0,1)";
|
Zeile 120 | Zeile 121 |
---|
else { $ismod = false;
|
else { $ismod = false;
|
}
| $visibleonly = " AND visible=1"; $visibleonly2 = "AND p.visible=1 AND t.visible=1"; }
|
// Make sure we are looking at a real thread here. if(($thread['visible'] != 1 && $ismod == false) || ($thread['visible'] == 0 && !is_moderator($fid, "canviewunapprove")) || ($thread['visible'] == -1 && !is_moderator($fid, "canviewdeleted"))) { error($lang->error_invalidthread);
|
// Make sure we are looking at a real thread here. if(($thread['visible'] != 1 && $ismod == false) || ($thread['visible'] == 0 && !is_moderator($fid, "canviewunapprove")) || ($thread['visible'] == -1 && !is_moderator($fid, "canviewdeleted"))) { error($lang->error_invalidthread);
|
}
$forumpermissions = forum_permissions($thread['fid']);
| }
$forumpermissions = forum_permissions($thread['fid']);
|
// Does the user have permission to view this thread? if($forumpermissions['canview'] != 1 || $forumpermissions['canviewthreads'] != 1)
|
// Does the user have permission to view this thread? if($forumpermissions['canview'] != 1 || $forumpermissions['canviewthreads'] != 1)
|
{ error_no_permission(); }
| { error_no_permission(); }
|
if(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1 && $thread['uid'] != $mybb->user['uid'])
|
if(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1 && $thread['uid'] != $mybb->user['uid'])
|
{
| {
|
error_no_permission(); }
| error_no_permission(); }
|
Zeile 148 | Zeile 151 |
---|
if(!$forum || $forum['type'] != "f") { error($lang->error_invalidforum);
|
if(!$forum || $forum['type'] != "f") { error($lang->error_invalidforum);
|
}
| }
|
$threadnoteslink = ''; if(is_moderator($fid, "canmanagethreads") && !empty($thread['notes'])) {
| $threadnoteslink = ''; if(is_moderator($fid, "canmanagethreads") && !empty($thread['notes'])) {
|
Zeile 211 | Zeile 214 |
---|
if($readcookie > $forum_read) { $lastread = $readcookie;
|
if($readcookie > $forum_read) { $lastread = $readcookie;
|
}
| }
|
else { $lastread = $forum_read;
| else { $lastread = $forum_read;
|
Zeile 349 | Zeile 352 |
---|
exit; }
|
exit; }
|
$pid = $mybb->input['pid'] = $mybb->get_input('pid', 1);
| $pid = $mybb->input['pid'] = $mybb->get_input('pid', MyBB::INPUT_INT);
|
// Forumdisplay cache $forum_stats = $cache->read("forumsdisplay");
| // Forumdisplay cache $forum_stats = $cache->read("forumsdisplay");
|
Zeile 540 | Zeile 543 |
---|
if($poll['multiple'] == 1) { eval("\$polloptions .= \"".$templates->get("showthread_poll_option_multiple")."\";");
|
if($poll['multiple'] == 1) { eval("\$polloptions .= \"".$templates->get("showthread_poll_option_multiple")."\";");
|
}
| }
|
else { eval("\$polloptions .= \"".$templates->get("showthread_poll_option")."\";");
| else { eval("\$polloptions .= \"".$templates->get("showthread_poll_option")."\";");
|
Zeile 882 | Zeile 885 |
---|
// Figure out if we need to display multiple pages. $page = 1; $perpage = $mybb->settings['postsperpage'];
|
// Figure out if we need to display multiple pages. $page = 1; $perpage = $mybb->settings['postsperpage'];
|
if($mybb->get_input('page', 1) && $mybb->get_input('page') != "last")
| if($mybb->get_input('page', MyBB::INPUT_INT) && $mybb->get_input('page') != "last")
|
{
|
{
|
$page = $mybb->get_input('page', 1);
| $page = $mybb->get_input('page', MyBB::INPUT_INT);
|
}
if(!empty($mybb->input['pid'])) { $post = get_post($mybb->input['pid']);
|
}
if(!empty($mybb->input['pid'])) { $post = get_post($mybb->input['pid']);
|
if($post)
| if(empty($post) || ($post['visible'] == 0 && !is_moderator($post['fid'], 'canviewunapprove')) || ($post['visible'] == -1 && !is_moderator($post['fid'], 'canviewdeleted'))) { $footer .= '<script type="text/javascript">$(document).ready(function() { $.jGrowl(\''.$lang->error_invalidpost.'\', {theme: \'jgrowl_error\'}); });</script>'; } else
|
{ $query = $db->query(" SELECT COUNT(p.dateline) AS count FROM ".TABLE_PREFIX."posts p
| { $query = $db->query(" SELECT COUNT(p.dateline) AS count FROM ".TABLE_PREFIX."posts p
|
Zeile 906 | Zeile 913 |
---|
else { $page = (int)($result / $perpage) + 1;
|
else { $page = (int)($result / $perpage) + 1;
|
} } }
| } } }
|
// Recount replies if user is a moderator to take into account unapproved posts. if($ismod) {
| // Recount replies if user is a moderator to take into account unapproved posts. if($ismod) {
|
Zeile 943 | Zeile 950 |
---|
if($page) { $start = ($page-1) * $perpage;
|
if($page) { $start = ($page-1) * $perpage;
|
} else {
| } else {
|
$start = 0; $page = 1; }
| $start = 0; $page = 1; }
|
Zeile 1034 | Zeile 1041 |
---|
{ // If there are no pid's the thread is probably awaiting approval. error($lang->error_invalidthread);
|
{ // If there are no pid's the thread is probably awaiting approval. error($lang->error_invalidthread);
|
}
| }
|
// Get the actual posts from the database here. $posts = ''; $query = $db->query("
| // Get the actual posts from the database here. $posts = ''; $query = $db->query("
|
Zeile 1115 | Zeile 1122 |
---|
{ $similar_thread['username'] = $similar_thread['threadusername']; $similar_thread['profilelink'] = $similar_thread['threadusername'];
|
{ $similar_thread['username'] = $similar_thread['threadusername']; $similar_thread['profilelink'] = $similar_thread['threadusername'];
|
} else {
| } else {
|
$similar_thread['profilelink'] = build_profile_link($similar_thread['username'], $similar_thread['uid']); }
| $similar_thread['profilelink'] = build_profile_link($similar_thread['username'], $similar_thread['uid']); }
|
Zeile 1158 | Zeile 1165 |
---|
eval("\$similarthreads = \"".$templates->get("showthread_similarthreads")."\";"); } }
|
eval("\$similarthreads = \"".$templates->get("showthread_similarthreads")."\";"); } }
|
|
|
// Decide whether or not to show quick reply. $quickreply = ''; if($forumpermissions['canpostreplys'] != 0 && $mybb->user['suspendposting'] != 1 && ($thread['closed'] != 1 || is_moderator($fid, "canpostclosedthreads")) && $mybb->settings['quickreply'] != 0 && $mybb->user['showquickreply'] != '0' && $forum['open'] != 0 && ($thread['uid'] == $mybb->user['uid'] || $forumpermissions['canonlyreplyownthreads'] != 1))
| // Decide whether or not to show quick reply. $quickreply = ''; if($forumpermissions['canpostreplys'] != 0 && $mybb->user['suspendposting'] != 1 && ($thread['closed'] != 1 || is_moderator($fid, "canpostclosedthreads")) && $mybb->settings['quickreply'] != 0 && $mybb->user['showquickreply'] != '0' && $forum['open'] != 0 && ($thread['uid'] == $mybb->user['uid'] || $forumpermissions['canonlyreplyownthreads'] != 1))
|
Zeile 1199 | Zeile 1206 |
---|
$trow = alt_trow(); if($thread['closed'] == 1)
|
$trow = alt_trow(); if($thread['closed'] == 1)
|
{
| {
|
$trow = 'trow_shaded'; }
| $trow = 'trow_shaded'; }
|
Zeile 1239 | Zeile 1246 |
---|
{ eval("\$viewnotes = \"".$templates->get("showthread_threadnotes_viewnotes")."\";"); $thread['notes'] = my_substr($thread['notes'], 0, 200)."... {$viewnotes}";
|
{ eval("\$viewnotes = \"".$templates->get("showthread_threadnotes_viewnotes")."\";"); $thread['notes'] = my_substr($thread['notes'], 0, 200)."... {$viewnotes}";
|
}
| }
|
eval("\$threadnotesbox = \"".$templates->get("showthread_threadnotes")."\";"); }
if(is_moderator($forum['fid'], "canusecustomtools") && (!empty($forum_stats[-1]['modtools']) || !empty($forum_stats[$forum['fid']]['modtools']))) {
|
eval("\$threadnotesbox = \"".$templates->get("showthread_threadnotes")."\";"); }
if(is_moderator($forum['fid'], "canusecustomtools") && (!empty($forum_stats[-1]['modtools']) || !empty($forum_stats[$forum['fid']]['modtools']))) {
|
| $gids = explode(',', $mybb->user['additionalgroups']); $gids[] = $mybb->user['usergroup']; $gids = array_filter(array_unique($gids));
|
switch($db->type) { case "pgsql": case "sqlite":
|
switch($db->type) { case "pgsql": case "sqlite":
|
$query = $db->simple_select("modtools", "tid, name, type", "','||forums||',' LIKE '%,$fid,%' OR ','||forums||',' LIKE '%,-1,%' OR forums=''");
| foreach($gids as $gid) { $gid = (int)$gid; $gidswhere .= " OR ','||groups||',' LIKE '%,{$gid},%'"; } $query = $db->simple_select("modtools", 'tid, name, type', "(','||forums||',' LIKE '%,$fid,%' OR ','||forums||',' LIKE '%,-1,%' OR forums='') AND (groups='' OR ','||groups||',' LIKE '%,-1,%'{$gidswhere})");
|
break; default:
|
break; default:
|
$query = $db->simple_select("modtools", "tid, name, type", "CONCAT(',',forums,',') LIKE '%,$fid,%' OR CONCAT(',',forums,',') LIKE '%,-1,%' OR forums=''");
| foreach($gids as $gid) { $gid = (int)$gid; $gidswhere .= " OR CONCAT(',',groups,',') LIKE '%,{$gid},%'"; } $query = $db->simple_select("modtools", 'tid, name, type', "(CONCAT(',',forums,',') LIKE '%,$fid,%' OR CONCAT(',',forums,',') LIKE '%,-1,%' OR forums='') AND (groups='' OR CONCAT(',',groups,',') LIKE '%,-1,%'{$gidswhere})");
|
break; }
| break; }
|
Zeile 1304 | Zeile 1324 |
---|
}
if(!empty($inlinemodsoftdelete) || !empty($inlinemodrestore) || !empty($inlinemoddelete) || !empty($inlinemodmanage) || !empty($inlinemodapprove))
|
}
if(!empty($inlinemodsoftdelete) || !empty($inlinemodrestore) || !empty($inlinemoddelete) || !empty($inlinemodmanage) || !empty($inlinemodapprove))
|
{
| {
|
eval("\$standardposttools = \"".$templates->get("showthread_inlinemoderation_standard")."\";"); }
| eval("\$standardposttools = \"".$templates->get("showthread_inlinemoderation_standard")."\";"); }
|
Zeile 1360 | Zeile 1380 |
---|
} }
|
} }
|
if(is_moderator($forum['fid'], "cansoftdeletethreads"))
| if(is_moderator($forum['fid'], "cansoftdeletethreads") && $thread['visible'] != -1)
|
{
|
{
|
if($thread['visible'] == -1) { $softdeletethread = "<option value=\"restorethread\">".$lang->restore_thread."</option>"; } else { $softdeletethread = "<option value=\"softdeletethread\">".$lang->soft_delete_thread."</option>"; }
| eval("\$softdeletethread = \"".$templates->get("showthread_moderationoptions_softdelete")."\";"); } elseif(is_moderator($forum['fid'], "canrestorethreads") && $thread['visible'] == -1) { eval("\$softdeletethread = \"".$templates->get("showthread_moderationoptions_restore")."\";");
|
}
if(!empty($openclosethread) || !empty($stickunstickthread) || !empty($deletethread) || !empty($managethread) || !empty($adminpolloptions) || !empty($approveunapprovethread) || !empty($softdeletethread))
| }
if(!empty($openclosethread) || !empty($stickunstickthread) || !empty($deletethread) || !empty($managethread) || !empty($adminpolloptions) || !empty($approveunapprovethread) || !empty($softdeletethread))
|