Vergleich showthread.php - 1.8.0 - 1.8.15

  Keine Änderungen   Hinzugefügt   Modifiziert   Entfernt
Zeile 11Zeile 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,showthread_quickreply_options_close,showthread_quickreply_options_stick";
$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,showthread_multipage,postbit_reputation,postbit_quickdelete,postbit_attachments,postbit_attachments_attachment,postbit_attachments_thumbnails,postbit_attachments_images_image,postbit_attachments_images,postbit_posturl,postbit_rep_button,showthread_inlinemoderation_standard";
$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_threadedbox,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 .= ",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,postbit_warninglevel,showthread_poll_resultbit,global_moderation_notice";






$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";
$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_poll_editpoll";
$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_inlinemoderation_restore";
$templatelist .= ",forumjump_advanced,forumjump_special,forumjump_bit,postbit_attachments,postbit_attachments_attachment,postbit_attachments_thumbnails,postbit_attachments_images_image,postbit_attachments_images,showthread_quickreply_options_stick,postbit_status";
$templatelist .= ",postbit_inlinecheck,showthread_inlinemoderation,postbit_attachments_thumbnails_thumbnail,postbit_ignored,postbit_multiquote,showthread_moderationoptions_custom_tool,showthread_moderationoptions_custom,showthread_inlinemoderation_custom_tool";
$templatelist .= ",showthread_usersbrowsing,showthread_usersbrowsing_user,showthread_poll_option,showthread_poll,showthread_quickreply_options_signature,showthread_threaded_bitactive,showthread_threaded_bit,postbit_attachments_attachment_unapproved";
$templatelist .= ",showthread_moderationoptions_openclose,showthread_moderationoptions_stickunstick,showthread_moderationoptions_delete,showthread_moderationoptions_threadnotes,showthread_moderationoptions_manage,showthread_moderationoptions_deletepoll";
$templatelist .= ",postbit_userstar,postbit_reputation_formatted_link,postbit_warninglevel_formatted,postbit_quickrestore,forumdisplay_password,forumdisplay_password_wrongpass,postbit_purgespammer,showthread_inlinemoderation_approve,forumdisplay_thread_icon";
$templatelist .= ",showthread_moderationoptions_softdelete,showthread_moderationoptions_restore,post_captcha,post_captcha_recaptcha,post_captcha_recaptcha_invisible,post_captcha_nocaptcha,showthread_moderationoptions,showthread_inlinemoderation_standard,showthread_inlinemoderation_manage";
$templatelist .= ",showthread_ratethread,postbit_posturl,postbit_icon,postbit_editedby_editreason,attachment_icon,global_moderation_notice,showthread_poll_option_multiple,postbit_gotopost,postbit_rep_button,postbit_warninglevel,showthread_threadnoteslink";
$templatelist .= ",showthread_moderationoptions_approve,showthread_moderationoptions_unapprove,showthread_inlinemoderation_delete,showthread_moderationoptions_standard,showthread_quickreply_options_close,showthread_inlinemoderation_custom,showthread_search";
$templatelist .= ",postbit_profilefield_multiselect_value,postbit_profilefield_multiselect,showthread_subscription,postbit_deleted_member,postbit_away,postbit_warn,postbit_classic,postbit_reputation,postbit_deleted,postbit_offline,postbit_online,postbit_signature";
$templatelist .= ",postbit_editreason,postbit_quickdelete,showthread_threadnotes_viewnotes,showthread_threadedbox,showthread_poll_resultbit,showthread_poll_results,showthread_threadnotes,showthread_classic_header,showthread_poll_undovote,postbit_groupimage";


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 33Zeile 38
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 43Zeile 48
		$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);
}

		



		$mybb->input['tid'] = $post['tid'];

		$mybb->input['tid'] = $post['tid'];

	}
}

// Get the thread details from the database.
$thread = get_thread($mybb->get_input('tid', 1));


	}
}

// Get the thread details from the database.
$thread = get_thread($mybb->get_input('tid', MyBB::INPUT_INT));


if(!$thread || substr($thread['closed'], 0, 6) == "moved|")
{
error($lang->error_invalidthread);

if(!$thread || substr($thread['closed'], 0, 6) == "moved|")
{
error($lang->error_invalidthread);

Zeile 68Zeile 73
$thread['threadprefix'] = '';
$thread['displayprefix'] = '';
if($thread['prefix'] != 0)

$thread['threadprefix'] = '';
$thread['displayprefix'] = '';
if($thread['prefix'] != 0)

{

{

	$threadprefix = build_prefixes($thread['prefix']);

if(!empty($threadprefix['prefix']))
{

	$threadprefix = build_prefixes($thread['prefix']);

if(!empty($threadprefix['prefix']))
{

		$thread['threadprefix'] = $threadprefix['prefix'].' ';

		$thread['threadprefix'] = htmlspecialchars_uni($threadprefix['prefix']).' ';

		$thread['displayprefix'] = $threadprefix['displaystyle'].' ';
}
}

		$thread['displayprefix'] = $threadprefix['displaystyle'].' ';
}
}

Zeile 92Zeile 97
if(!$thread['username'])
{
$thread['username'] = $lang->guest;

if(!$thread['username'])
{
$thread['username'] = $lang->guest;

 
}
$thread['username'] = htmlspecialchars_uni($thread['username']);

$forumpermissions = forum_permissions($thread['fid']);

// Set here to fetch only approved/deleted posts (and then below for a moderator we change this).
if($forumpermissions['canviewdeletionnotice'] != 0)
{
$visibleonly = " AND visible IN (-1,1)";
$visibleonly2 = "AND p.visible IN (-1,1) AND t.visible IN (-1,1)";
}
else
{
$visibleonly = " AND visible=1";
$visibleonly2 = "AND p.visible=1 AND t.visible=1";

}

// Is the currently logged in user a moderator of this forum?

}

// Is the currently logged in user a moderator of this forum?

Zeile 109Zeile 129
		{
$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 127Zeile 147
{
error($lang->error_invalidthread);
}

{
error($lang->error_invalidthread);
}


$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)

Zeile 349Zeile 367
	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 363Zeile 381
		$mybb->settings['threadsperpage'] = 20;
}


		$mybb->settings['threadsperpage'] = 20;
}


	$query = $db->simple_select("forums", "threads, unapprovedthreads", "fid = '{$fid}'", array('limit' => 1));

	$query = $db->simple_select("forums", "threads, unapprovedthreads, deletedthreads", "fid = '{$fid}'", array('limit' => 1));

	$forum_threads = $db->fetch_array($query);
$threadcount = $forum_threads['threads'];


	$forum_threads = $db->fetch_array($query);
$threadcount = $forum_threads['threads'];


	if(is_moderator($fid, "canviewunapprove") == true)














if(is_moderator($fid, "canviewdeleted") == true || is_moderator($fid, "canviewunapprove") == true)
{
if(is_moderator($fid, "canviewdeleted") == true)
{
$threadcount += $forum_threads['deletedthreads'];
}
if(is_moderator($fid, "canviewunapprove") == true)
{
$threadcount += $forum_threads['unapprovedthreads'];
}
}
elseif($forumpermissions['canviewdeletionnotice'] != 0)

	{

	{

		$threadcount += $forum_threads['unapprovedthreads'];

		$threadcount += $forum_threads['deletedthreads'];

	}

// Limit to only our own threads

	}

// Limit to only our own threads

Zeile 377Zeile 407
	if(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1)
{
$uid_only = " AND uid = '".$mybb->user['uid']."'";

	if(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1)
{
$uid_only = " AND uid = '".$mybb->user['uid']."'";


$query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $visibleonly $uid_only", array('limit' => 1));
$threadcount = $db->fetch_field($query, "threads");


$query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $visibleonly $uid_only", array('limit' => 1));
$threadcount = $db->fetch_field($query, "threads");

	}

// If we have 0 threads double check there aren't any "moved" threads
if($threadcount == 0)

	}

// If we have 0 threads double check there aren't any "moved" threads
if($threadcount == 0)

	{

	{

		$query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $visibleonly $uid_only", array('limit' => 1));
$threadcount = $db->fetch_field($query, "threads");
}

		$query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $visibleonly $uid_only", array('limit' => 1));
$threadcount = $db->fetch_field($query, "threads");
}

Zeile 409Zeile 439
			break;
default:
$query = $db->simple_select("threads", "COUNT(tid) as threads", "fid = '$fid' AND (lastpost >= '".(int)$thread['lastpost']."'{$stickybit}) {$visibleonly} {$uid_only}", array('order_by' => 'lastpost', 'order_dir' => 'desc'));

			break;
default:
$query = $db->simple_select("threads", "COUNT(tid) as threads", "fid = '$fid' AND (lastpost >= '".(int)$thread['lastpost']."'{$stickybit}) {$visibleonly} {$uid_only}", array('order_by' => 'lastpost', 'order_dir' => 'desc'));

	}


	}


	$thread_position = $db->fetch_field($query, "threads");
$thread_page = ceil(($thread_position/$mybb->settings['threadsperpage']));

	$thread_position = $db->fetch_field($query, "threads");
$thread_page = ceil(($thread_position/$mybb->settings['threadsperpage']));





	$breadcrumb_multipage = array(
"num_threads" => $threadcount,
"current_page" => $thread_page

	$breadcrumb_multipage = array(
"num_threads" => $threadcount,
"current_page" => $thread_page

Zeile 423Zeile 453
// Build the navigation.
build_forum_breadcrumb($fid, $breadcrumb_multipage);
add_breadcrumb($thread['displayprefix'].$thread['subject'], get_thread_link($thread['tid']));

// Build the navigation.
build_forum_breadcrumb($fid, $breadcrumb_multipage);
add_breadcrumb($thread['displayprefix'].$thread['subject'], get_thread_link($thread['tid']));





$plugins->run_hooks("showthread_start");

// Show the entire thread (taking into account pagination).
if($mybb->input['action'] == "thread")
{
if($thread['firstpost'] == 0)

$plugins->run_hooks("showthread_start");

// Show the entire thread (taking into account pagination).
if($mybb->input['action'] == "thread")
{
if($thread['firstpost'] == 0)

	{

	{

		update_first_post($tid);
}


		update_first_post($tid);
}


Zeile 447Zeile 477
		$now = TIME_NOW;

// If the poll or the thread is closed or if the poll is expired, show the results.

		$now = TIME_NOW;

// If the poll or the thread is closed or if the poll is expired, show the results.

		if($poll['closed'] == 1 || $thread['closed'] == 1 || ($expiretime < $now && $poll['timeout'] > 0))

		if($poll['closed'] == 1 || $thread['closed'] == 1 || ($expiretime < $now && $poll['timeout'] > 0) || $forumpermissions['canvotepolls'] != 1)

		{
$showresults = 1;
}

		{
$showresults = 1;
}


// If the user is not a guest, check if he already voted.
if($mybb->user['uid'] != 0)
{
$query = $db->simple_select("pollvotes", "*", "uid='".$mybb->user['uid']."' AND pid='".$poll['pid']."'");
while($votecheck = $db->fetch_array($query))
{
$alreadyvoted = 1;
$votedfor[$votecheck['voteoption']] = 1;
}
}


if($forumpermissions['canvotepolls'] != 1)
{
$nopermission = 1;
}

// Check if the user has voted before...
if($mybb->user['uid'])
{
$user_check = "uid='{$mybb->user['uid']}'";
}

		else

		else

		{
if(isset($mybb->cookies['pollvotes'][$poll['pid']]) && $mybb->cookies['pollvotes'][$poll['pid']] !== "")
{
$alreadyvoted = 1;
}





		{
$user_check = "uid='0' AND ipaddress=".$db->escape_binary($session->packedip);
}

$query = $db->simple_select("pollvotes", "*", "{$user_check} AND pid='".$poll['pid']."'");
while($votecheck = $db->fetch_array($query))
{
$alreadyvoted = 1;
$votedfor[$votecheck['voteoption']] = 1;

		}

		}

 


		$optionsarray = explode("||~|~||", $poll['options']);
$votesarray = explode("||~|~||", $poll['votes']);
$poll['question'] = htmlspecialchars_uni($poll['question']);

		$optionsarray = explode("||~|~||", $poll['options']);
$votesarray = explode("||~|~||", $poll['votes']);
$poll['question'] = htmlspecialchars_uni($poll['question']);

Zeile 479Zeile 514
		for($i = 1; $i <= $poll['numoptions']; ++$i)
{
$poll['totvotes'] = $poll['totvotes'] + $votesarray[$i-1];

		for($i = 1; $i <= $poll['numoptions']; ++$i)
{
$poll['totvotes'] = $poll['totvotes'] + $votesarray[$i-1];

		}

		}


// Loop through the poll options.
for($i = 1; $i <= $poll['numoptions']; ++$i)


// Loop through the poll options.
for($i = 1; $i <= $poll['numoptions']; ++$i)

Zeile 519Zeile 554
			{
$optionbg = "trow1";
$votestar = "";

			{
$optionbg = "trow1";
$votestar = "";

			}

			}


// If the user already voted or if the results need to be shown, do so; else show voting screen.
if(isset($alreadyvoted) || isset($showresults))


// If the user already voted or if the results need to be shown, do so; else show voting screen.
if(isset($alreadyvoted) || isset($showresults))

Zeile 566Zeile 601
		}

// Decide what poll status to show depending on the status of the poll and whether or not the user voted already.

		}

// Decide what poll status to show depending on the status of the poll and whether or not the user voted already.

		if(isset($alreadyvoted) || isset($showresults))

		if(isset($alreadyvoted) || isset($showresults) || isset($nopermission))

		{
if($alreadyvoted)
{
$pollstatus = $lang->already_voted;


		{
if($alreadyvoted)
{
$pollstatus = $lang->already_voted;


 
				$undovote = '';

				if($mybb->usergroup['canundovotes'] == 1)
{

				if($mybb->usergroup['canundovotes'] == 1)
{

					eval("\$pollstatus .= \"".$templates->get("showthread_poll_undovote")."\";");

					eval("\$undovote = \"".$templates->get("showthread_poll_undovote")."\";");

				}

				}

 
			}
elseif($nopermission)
{
$pollstatus = $lang->no_voting_permission;

			}
else
{
$pollstatus = $lang->poll_closed;
}

			}
else
{
$pollstatus = $lang->poll_closed;
}

 


			$lang->total_votes = $lang->sprintf($lang->total_votes, $totalvotes);
eval("\$pollbox = \"".$templates->get("showthread_poll_results")."\";");
$plugins->run_hooks("showthread_poll_results");

			$lang->total_votes = $lang->sprintf($lang->total_votes, $totalvotes);
eval("\$pollbox = \"".$templates->get("showthread_poll_results")."\";");
$plugins->run_hooks("showthread_poll_results");

Zeile 737Zeile 778
	elseif($ismod && is_moderator($fid, "canviewdeleted") == true && is_moderator($fid, "canviewunapprove") == true)
{
$visible = "AND p.visible IN (-1,0,1)";

	elseif($ismod && is_moderator($fid, "canviewdeleted") == true && is_moderator($fid, "canviewunapprove") == true)
{
$visible = "AND p.visible IN (-1,0,1)";

 
	}
elseif($forumpermissions['canviewdeletionnotice'] != 0 && $ismod == false)
{
$visible = "AND p.visible IN (-1,1)";

	}
else
{

	}
else
{

Zeile 747Zeile 792
	if($forumpermissions['cansearch'] != 0)
{
eval("\$search_thread = \"".$templates->get("showthread_search")."\";");

	if($forumpermissions['cansearch'] != 0)
{
eval("\$search_thread = \"".$templates->get("showthread_search")."\";");

	}


	}


	// Fetch the ignore list for the current user if they have one
$ignored_users = array();
if($mybb->user['uid'] > 0 && $mybb->user['ignorelist'] != "")

	// Fetch the ignore list for the current user if they have one
$ignored_users = array();
if($mybb->user['uid'] > 0 && $mybb->user['ignorelist'] != "")

Zeile 757Zeile 802
		foreach($ignore_list as $uid)
{
$ignored_users[$uid] = 1;

		foreach($ignore_list as $uid)
{
$ignored_users[$uid] = 1;

		}
}

		}
}


// Fetch profile fields to display on postbit
$pfcache = $cache->read('profilefields');


// Fetch profile fields to display on postbit
$pfcache = $cache->read('profilefields');

Zeile 778Zeile 823

// Which thread mode is our user using by default?
if(!empty($mybb->user['threadmode']))


// Which thread mode is our user using by default?
if(!empty($mybb->user['threadmode']))

	{

	{

		$defaultmode = $mybb->user['threadmode'];
}
else if($mybb->settings['threadusenetstyle'] == 1)

		$defaultmode = $mybb->user['threadmode'];
}
else if($mybb->settings['threadusenetstyle'] == 1)

Zeile 831Zeile 876
		if(!$showpost['pid'])
{
error($lang->error_invalidpost);

		if(!$showpost['pid'])
{
error($lang->error_invalidpost);

		}

		}


$attachcache = array();
if($mybb->settings['enableattachments'] == 1 && $thread['attachmentcount'] > 0 || is_moderator($fid, 'caneditposts'))


$attachcache = array();
if($mybb->settings['enableattachments'] == 1 && $thread['attachmentcount'] > 0 || is_moderator($fid, 'caneditposts'))

Zeile 882Zeile 927
		// 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")
{
$page = $mybb->get_input('page', 1);
}

		if($mybb->get_input('page', MyBB::INPUT_INT) && $mybb->get_input('page') != "last")
{
$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') && $forumpermissions['canviewdeletionnotice'] == 0))
{
$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 910Zeile 959
			}
}


			}
}


		// Recount replies if user is a moderator to take into account unapproved posts.
if($ismod)

		// Recount replies if user is a moderator or can see the deletion notice to take into account unapproved/deleted posts.
if($ismod || $forumpermissions['canviewdeletionnotice'] != 0)

		{
$query = $db->simple_select("posts p", "COUNT(*) AS replies", "p.tid='$tid' $visible");
$cached_replies = $thread['replies']+$thread['unapprovedposts']+$thread['deletedposts'];

		{
$query = $db->simple_select("posts p", "COUNT(*) AS replies", "p.tid='$tid' $visible");
$cached_replies = $thread['replies']+$thread['unapprovedposts']+$thread['deletedposts'];

Zeile 924Zeile 973
				require_once MYBB_ROOT."/inc/functions_rebuild.php";
rebuild_thread_counters($thread['tid']);
}

				require_once MYBB_ROOT."/inc/functions_rebuild.php";
rebuild_thread_counters($thread['tid']);
}

 
		}
elseif($forumpermissions['canviewdeletionnotice'] != 0)
{
$thread['replies'] += $thread['deletedposts'];

		}

$postcount = (int)$thread['replies']+1;

		}

$postcount = (int)$thread['replies']+1;

Zeile 997Zeile 1050
        }

$multipage = multipage($postcount, $perpage, $page, str_replace("{tid}", $tid, THREAD_URL_PAGED.$highlight.$threadmode));

        }

$multipage = multipage($postcount, $perpage, $page, str_replace("{tid}", $tid, THREAD_URL_PAGED.$highlight.$threadmode));

		if($postcount > $perpage)
{
eval("\$threadpages = \"".$templates->get("showthread_multipage")."\";");
}

 

// Lets get the pids of the posts on this page.
$pids = "";


// Lets get the pids of the posts on this page.
$pids = "";

Zeile 1106Zeile 1155
			if($similar_thread['icon'] > 0 && $icon_cache[$similar_thread['icon']])
{
$icon = $icon_cache[$similar_thread['icon']];

			if($similar_thread['icon'] > 0 && $icon_cache[$similar_thread['icon']])
{
$icon = $icon_cache[$similar_thread['icon']];

 
				$icon['path'] = str_replace("{theme}", $theme['imgdir'], $icon['path']);
$icon['path'] = htmlspecialchars_uni($icon['path']);
$icon['name'] = htmlspecialchars_uni($icon['name']);

				eval("\$icon = \"".$templates->get("forumdisplay_thread_icon")."\";");
}
else

				eval("\$icon = \"".$templates->get("forumdisplay_thread_icon")."\";");
}
else

Zeile 1114Zeile 1166
			}
if(!$similar_thread['username'])
{

			}
if(!$similar_thread['username'])
{

				$similar_thread['username'] = $similar_thread['threadusername'];
$similar_thread['profilelink'] = $similar_thread['threadusername'];

				$similar_thread['username'] = $similar_thread['profilelink'] = htmlspecialchars_uni($similar_thread['threadusername']);


			}
else
{

			}
else
{

 
				$similar_thread['username'] = htmlspecialchars_uni($similar_thread['username']);

				$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 1212Zeile 1264
				$moderation_text = $lang->moderation_forum_posts;
eval('$moderation_notice = "'.$templates->get('global_moderation_notice').'";');
}

				$moderation_text = $lang->moderation_forum_posts;
eval('$moderation_notice = "'.$templates->get('global_moderation_notice').'";');
}

			



			if($mybb->user['moderateposts'] == 1)
{
$moderation_text = $lang->moderation_user_posts;
eval('$moderation_notice = "'.$templates->get('global_moderation_notice').'";');

			if($mybb->user['moderateposts'] == 1)
{
$moderation_text = $lang->moderation_user_posts;
eval('$moderation_notice = "'.$templates->get('global_moderation_notice').'";');

			}

			}

		}

$posthash = md5($mybb->user['uid'].random_str());

		}

$posthash = md5($mybb->user['uid'].random_str());

Zeile 1237Zeile 1289
			$thread['notes'] = nl2br(htmlspecialchars_uni($thread['notes']));

if(strlen($thread['notes']) > 200)

			$thread['notes'] = nl2br(htmlspecialchars_uni($thread['notes']));

if(strlen($thread['notes']) > 200)

			{

			{

				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}";
}

Zeile 1247Zeile 1299

if(is_moderator($forum['fid'], "canusecustomtools") && (!empty($forum_stats[-1]['modtools']) || !empty($forum_stats[$forum['fid']]['modtools'])))
{


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;
}

while($tool = $db->fetch_array($query))
{

					break;
}

while($tool = $db->fetch_array($query))
{

 
				$tool['name'] = htmlspecialchars_uni($tool['name']);

				if($tool['type'] == 'p')
{
eval("\$customposttools .= \"".$templates->get("showthread_inlinemoderation_custom_tool")."\";");

				if($tool['type'] == 'p')
{
eval("\$customposttools .= \"".$templates->get("showthread_inlinemoderation_custom_tool")."\";");

Zeile 1353Zeile 1419
		{
if($thread['visible'] == 0)
{

		{
if($thread['visible'] == 0)
{

				$approveunapprovethread = "<option value=\"approvethread\">".$lang->approve_thread."</option>";

				eval("\$approveunapprovethread = \"".$templates->get("showthread_moderationoptions_approve")."\";");

			}
else
{

			}
else
{

				$approveunapprovethread = "<option value=\"unapprovethread\">".$lang->unapprove_thread."</option>";

				eval("\$approveunapprovethread = \"".$templates->get("showthread_moderationoptions_unapprove")."\";");

			}
}


			}
}


		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))

Zeile 1403Zeile 1466
	// Subscription status
$add_remove_subscription = 'add';
$add_remove_subscription_text = $lang->subscribe_thread;

	// Subscription status
$add_remove_subscription = 'add';
$add_remove_subscription_text = $lang->subscribe_thread;





	if($mybb->user['uid'])
{
$query = $db->simple_select("threadsubscriptions", "tid", "tid='".(int)$tid."' AND uid='".(int)$mybb->user['uid']."'", array('limit' => 1));

	if($mybb->user['uid'])
{
$query = $db->simple_select("threadsubscriptions", "tid", "tid='".(int)$tid."' AND uid='".(int)$mybb->user['uid']."'", array('limit' => 1));

Zeile 1413Zeile 1476
			$add_remove_subscription = 'remove';
$add_remove_subscription_text = $lang->unsubscribe_thread;
}

			$add_remove_subscription = 'remove';
$add_remove_subscription_text = $lang->unsubscribe_thread;
}

	}





eval("\$addremovesubscription = \"".$templates->get("showthread_subscription")."\";");
}


	$classic_header = '';
if($mybb->settings['postlayout'] == "classic")
{
eval("\$classic_header = \"".$templates->get("showthread_classic_header")."\";");

	$classic_header = '';
if($mybb->settings['postlayout'] == "classic")
{
eval("\$classic_header = \"".$templates->get("showthread_classic_header")."\";");

	}


	}


	// Get users viewing this thread
if($mybb->settings['browsingthisthread'] != 0)
{

	// Get users viewing this thread
if($mybb->settings['browsingthisthread'] != 0)
{

Zeile 1454Zeile 1519

$invisiblemark = '';
if($user['invisible'] == 1)


$invisiblemark = '';
if($user['invisible'] == 1)

				{

				{

					$invisiblemark = "*";
++$inviscount;

					$invisiblemark = "*";
++$inviscount;

				}


				}


				if($user['invisible'] != 1 || $mybb->usergroup['canviewwolinvis'] == 1 || $user['uid'] == $mybb->user['uid'])
{
$user['profilelink'] = get_profile_link($user['uid']);

				if($user['invisible'] != 1 || $mybb->usergroup['canviewwolinvis'] == 1 || $user['uid'] == $mybb->user['uid'])
{
$user['profilelink'] = get_profile_link($user['uid']);

					$user['username'] = format_name($user['username'], $user['usergroup'], $user['displaygroup']);

					$user['username'] = format_name(htmlspecialchars_uni($user['username']), $user['usergroup'], $user['displaygroup']);

					$user['reading'] = my_date($mybb->settings['timeformat'], $user['time']);

eval("\$onlinemembers .= \"".$templates->get("showthread_usersbrowsing_user", 1, 0)."\";");

					$user['reading'] = my_date($mybb->settings['timeformat'], $user['time']);

eval("\$onlinemembers .= \"".$templates->get("showthread_usersbrowsing_user", 1, 0)."\";");

Zeile 1473Zeile 1538

$guestsonline = '';
if($guestcount)


$guestsonline = '';
if($guestcount)

		{

		{

			$guestsonline = $lang->sprintf($lang->users_browsing_thread_guests, $guestcount);

			$guestsonline = $lang->sprintf($lang->users_browsing_thread_guests, $guestcount);

 
		}

$invisonline = '';
if($mybb->user['invisible'] == 1)
{
// the user was counted as invisible user --> correct the inviscount
$inviscount -= 1;
}
if($inviscount && $mybb->usergroup['canviewwolinvis'] != 1)
{
$invisonline = $lang->sprintf($lang->users_browsing_forum_invis, $inviscount);

		}

$onlinesep = '';

		}

$onlinesep = '';

		if($guestcount && $onlinemembers)

		if($invisonline != '' && $onlinemembers)

		{
$onlinesep = $lang->comma;

		{
$onlinesep = $lang->comma;

		}

$invisonline = '';
if($inviscount && $mybb->usergroup['canviewwolinvis'] != 1 && ($inviscount != 1 && $mybb->user['invisible'] != 1))
{
$invisonline = $lang->sprintf($lang->users_browsing_thread_invis, $inviscount);

 
		}

$onlinesep2 = '';

		}

$onlinesep2 = '';

		if($invisonline != '' && $guestcount)

		if($invisonline != '' && $guestcount || $onlinemembers && $guestcount)

		{
$onlinesep2 = $lang->comma;
}

		{
$onlinesep2 = $lang->comma;
}

Zeile 1507Zeile 1577
/**
* Build a navigation tree for threaded display.
*

/**
* Build a navigation tree for threaded display.
*

 * @param unknown_type $replyto
* @param unknown_type $indent
* @return unknown

 * @param int $replyto
* @param int $indent
* @return string

 */

 */

function buildtree($replyto="0", $indent="0")

function buildtree($replyto=0, $indent=0)

{

{

	global $tree, $mybb, $theme, $mybb, $pid, $tid, $templates, $parser;

	global $tree, $mybb, $theme, $mybb, $pid, $tid, $templates, $parser, $lang;





	if($indent)
{
$indentsize = 13 * $indent;
}
else
{
$indentsize = 0;
}

	$indentsize = 13 * $indent;









++$indent;


++$indent;

 
	$posts = '';

	if(is_array($tree[$replyto]))
{
foreach($tree[$replyto] as $key => $post)

	if(is_array($tree[$replyto]))
{
foreach($tree[$replyto] as $key => $post)

Zeile 1537Zeile 1601
				$post['subject'] = "[".$lang->no_subject."]";
}


				$post['subject'] = "[".$lang->no_subject."]";
}


 
			$post['username'] = htmlspecialchars_uni($post['username']);

			$post['profilelink'] = build_profile_link($post['username'], $post['uid']);

if($mybb->input['pid'] == $post['pid'])

			$post['profilelink'] = build_profile_link($post['username'], $post['uid']);

if($mybb->input['pid'] == $post['pid'])