phpBB

Code Changes

File: includes/functions_content.php

  Unmodified   Added   Modified   Removed
Line 21Line 21
* make_jumpbox()
* bump_topic_allowed()
* get_context()

* make_jumpbox()
* bump_topic_allowed()
* get_context()

 
* phpbb_clean_search_string()

* decode_message()
* strip_bbcode()
* generate_text_for_display()

* decode_message()
* strip_bbcode()
* generate_text_for_display()

Line 41Line 42
/**
* Generate sort selection fields
*/

/**
* Generate sort selection fields
*/

function gen_sort_selects(&$limit_days, &$sort_by_text, &$sort_days, &$sort_key, &$sort_dir, &$s_limit_days, &$s_sort_key, &$s_sort_dir, &$u_sort_param)

function gen_sort_selects(&$limit_days, &$sort_by_text, &$sort_days, &$sort_key, &$sort_dir, &$s_limit_days, &$s_sort_key, &$s_sort_dir, &$u_sort_param, $def_st = false, $def_sk = false, $def_sd = false)

{
global $user;

$sort_dir_text = array('a' => $user->lang['ASCENDING'], 'd' => $user->lang['DESCENDING']);


{
global $user;

$sort_dir_text = array('a' => $user->lang['ASCENDING'], 'd' => $user->lang['DESCENDING']);


	// Check if the key is selectable. If not, we reset to the first key found.
// This ensures the values are always valid.
if (!isset($limit_days[$sort_days]))
{
@reset($limit_days);
$sort_days = key($limit_days);
}

	$sorts = array(
'st' => array(
'key' => 'sort_days',
'default' => $def_st,
'options' => $limit_days,
'output' => &$s_limit_days,
),





	if (!isset($sort_by_text[$sort_key]))
{
@reset($sort_by_text);
$sort_key = key($sort_by_text);
}


		'sk'	=> array(
'key' => 'sort_key',
'default' => $def_sk,
'options' => $sort_by_text,
'output' => &$s_sort_key,
),





	if (!isset($sort_dir_text[$sort_dir]))










		'sd'	=> array(
'key' => 'sort_dir',
'default' => $def_sd,
'options' => $sort_dir_text,
'output' => &$s_sort_dir,
),
);
$u_sort_param = '';

foreach ($sorts as $name => $sort_ary)

	{

	{

		@reset($sort_dir_text);
$sort_dir = key($sort_dir_text);
}

		$key = $sort_ary['key'];
$selected = $$sort_ary['key'];






	$s_limit_days = '<select name="st">';
foreach ($limit_days as $day => $text)



		// Check if the key is selectable. If not, we reset to the default or first key found.
// This ensures the values are always valid. We also set $sort_dir/sort_key/etc. to the
// correct value, else the protection is void. ;)
if (!isset($sort_ary['options'][$selected]))

	{

	{

		$selected = ($sort_days == $day) ? ' selected="selected"' : '';
$s_limit_days .= '<option value="' . $day . '"' . $selected . '>' . $text . '</option>';


			if ($sort_ary['default'] !== false)
{
$selected = $$key = $sort_ary['default'];

	}

	}

	$s_limit_days .= '</select>';

$s_sort_key = '<select name="sk">';
foreach ($sort_by_text as $key => $text)

			else




	{

	{

		$selected = ($sort_key == $key) ? ' selected="selected"' : '';
$s_sort_key .= '<option value="' . $key . '"' . $selected . '>' . $text . '</option>';


				@reset($sort_ary['options']);
$selected = $$key = key($sort_ary['options']);
}

	}

	}

	$s_sort_key .= '</select>';

 




	$s_sort_dir = '<select name="sd">';
foreach ($sort_dir_text as $key => $value)

		$sort_ary['output'] = '<select name="' . $name . '" id="' . $name . '">';
foreach ($sort_ary['options'] as $option => $text)

	{

	{

		$selected = ($sort_dir == $key) ? ' selected="selected"' : '';
$s_sort_dir .= '<option value="' . $key . '"' . $selected . '>' . $value . '</option>';

			$sort_ary['output'] .= '<option value="' . $option . '"' . (($selected == $option) ? ' selected="selected"' : '') . '>' . $text . '</option>';


	}

	}

	$s_sort_dir .= '</select>';

		$sort_ary['output'] .= '</select>';





	$u_sort_param = "st=$sort_days&amp;sk=$sort_key&amp;sd=$sort_dir";


		$u_sort_param .= ($selected !== $sort_ary['default']) ? ((strlen($u_sort_param)) ? '&amp;' : '') . "{$name}={$selected}" : '';
}


return;
}


return;
}

Line 239Line 249
function get_context($text, $words, $length = 400)
{
// first replace all whitespaces with single spaces

function get_context($text, $words, $length = 400)
{
// first replace all whitespaces with single spaces

	$text = preg_replace('/ +/', ' ', strtr($text, "\t\n\r\x0C ", '     '), $text);






	$text = preg_replace('/ +/', ' ', strtr($text, "\t\n\r\x0C ", '     '));

// we need to turn the entities back into their original form, to not cut the message in between them
$entities = array('&lt;', '&gt;', '&#91;', '&#93;', '&#46;', '&#58;', '&#058;');
$characters = array('<', '>', '[', ']', '.', ':', ':');
$text = str_replace($entities, $characters, $text);


$word_indizes = array();
if (sizeof($words))


$word_indizes = array();
if (sizeof($words))

Line 252Line 267
			{
if (preg_match('#(?:[^\w]|^)(' . $word . ')(?:[^\w]|$)#i', $text, $match))
{

			{
if (preg_match('#(?:[^\w]|^)(' . $word . ')(?:[^\w]|$)#i', $text, $match))
{

 
					if (empty($match[1]))
{
continue;
}


					$pos = utf8_strpos($text, $match[1]);
if ($pos !== false)
{

					$pos = utf8_strpos($text, $match[1]);
if ($pos !== false)
{

Line 331Line 351
					}
}
}

					}
}
}

			return $final_text;

			return str_replace($characters, $entities, $final_text);

		}
}

if (!sizeof($words) || !sizeof($word_indizes))
{

		}
}

if (!sizeof($words) || !sizeof($word_indizes))
{

		return (utf8_strlen($text) >= $length + 3) ? utf8_substr($text, 0, $length) . '...' : $text;

		return str_replace($characters, $entities, ((utf8_strlen($text) >= $length + 3) ? utf8_substr($text, 0, $length) . '...' : $text));

	}

	}

 
}

/**
* Cleans a search string by removing single wildcards from it and replacing multiple spaces with a single one.
*
* @param string $search_string The full search string which should be cleaned.
*
* @return string The cleaned search string without any wildcards and multiple spaces.
*/
function phpbb_clean_search_string($search_string)
{
// This regular expressions matches every single wildcard.
// That means one after a whitespace or the beginning of the string or one before a whitespace or the end of the string.
$search_string = preg_replace('#(?<=^|\s)\*+(?=\s|$)#', '', $search_string);
$search_string = trim($search_string);
$search_string = preg_replace(array('#\s+#u', '#\*+#u'), array(' ', '*'), $search_string);
return $search_string;

}

/**

}

/**

Line 394Line 431
{
static $bbcode;


{
static $bbcode;


	if (!$text)

	if ($text === '')

	{
return '';
}

	{
return '';
}

Line 438Line 475
	global $phpbb_root_path, $phpEx;

$uid = $bitfield = '';

	global $phpbb_root_path, $phpEx;

$uid = $bitfield = '';

 
	$flags = (($allow_bbcode) ? OPTION_FLAG_BBCODE : 0) + (($allow_smilies) ? OPTION_FLAG_SMILIES : 0) + (($allow_urls) ? OPTION_FLAG_LINKS : 0);





	if (!$text)

	if ($text === '')

	{
return;
}

	{
return;
}

Line 461Line 499
		$uid = '';
}


		$uid = '';
}


	$flags = (($allow_bbcode) ? OPTION_FLAG_BBCODE : 0) + (($allow_smilies) ? OPTION_FLAG_SMILIES : 0) + (($allow_urls) ? OPTION_FLAG_LINKS : 0);

 
	$bitfield = $message_parser->bbcode_bitfield;

return;

	$bitfield = $message_parser->bbcode_bitfield;

return;

Line 492Line 529
*/
function make_clickable_callback($type, $whitespace, $url, $relative_url, $class)
{

*/
function make_clickable_callback($type, $whitespace, $url, $relative_url, $class)
{

 
	$orig_url		= $url;
$orig_relative = $relative_url;

	$append			= '';
$url = htmlspecialchars_decode($url);
$relative_url = htmlspecialchars_decode($relative_url);

	$append			= '';
$url = htmlspecialchars_decode($url);
$relative_url = htmlspecialchars_decode($relative_url);

Line 555Line 594
			{
$url = substr($url, 0, -1);
}

			{
$url = substr($url, 0, -1);
}

 
		break;

// set last_char to empty here, so the variable can be used later to
// check whether a character was removed
default:
$last_char = '';

		break;
}

		break;
}

 

$short_url = (strlen($url) > 55) ? substr($url, 0, 39) . ' ... ' . substr($url, -10) : $url;


switch ($type)
{


switch ($type)
{

Line 564Line 611
			$tag			= 'l';
$relative_url = preg_replace('/[&?]sid=[0-9a-f]{32}$/', '', preg_replace('/([&?])sid=[0-9a-f]{32}&/', '$1', $relative_url));
$url = $url . '/' . $relative_url;

			$tag			= 'l';
$relative_url = preg_replace('/[&?]sid=[0-9a-f]{32}$/', '', preg_replace('/([&?])sid=[0-9a-f]{32}&/', '$1', $relative_url));
$url = $url . '/' . $relative_url;

			$text			= ($relative_url) ? $relative_url : $url;









			$text			= $relative_url;

// this url goes to http://domain.tld/path/to/board/ which
// would result in an empty link if treated as local so
// don't touch it and let MAGIC_URL_FULL take care of it.
if (!$relative_url)
{
return $whitespace . $orig_url . '/' . $orig_relative; // slash is taken away by relative url pattern
}

		break;

case MAGIC_URL_FULL:
$tag = 'm';

		break;

case MAGIC_URL_FULL:
$tag = 'm';

			$text	= (strlen($url) > 55) ? substr($url, 0, 39) . ' ... ' . substr($url, -10) : $url;

			$text	= $short_url;

		break;

case MAGIC_URL_WWW:
$tag = 'w';
$url = 'http://' . $url;

		break;

case MAGIC_URL_WWW:
$tag = 'w';
$url = 'http://' . $url;

			$text	= (strlen($url) > 55) ? substr($url, 0, 39) . ' ... ' . substr($url, -10) : $url;

			$text	= $short_url;

		break;

case MAGIC_URL_EMAIL:
$tag = 'e';

		break;

case MAGIC_URL_EMAIL:
$tag = 'e';

			$text	= (strlen($url) > 55) ? substr($url, 0, 39) . ' ... ' . substr($url, -10) : $url;

			$text	= $short_url;

			$url	= 'mailto:' . $url;
break;
}

			$url	= 'mailto:' . $url;
break;
}

Line 647Line 702
function censor_text($text)
{
static $censors;

function censor_text($text)
{
static $censors;

	global $cache;

 




 
	// Nothing to do?
if ($text === '')
{
return '';
}

// We moved the word censor checks in here because we call this function quite often - and then only need to do the check once

	if (!isset($censors) || !is_array($censors))
{

	if (!isset($censors) || !is_array($censors))
{

		// obtain_word_list is taking care of the users censor option and the board-wide option









		global $config, $user, $auth, $cache;

// We check here if the user is having viewing censors disabled (and also allowed to do so).
if (!$user->optionget('viewcensors') && $config['allow_nocensors'] && $auth->acl_get('u_chgcensors'))
{
$censors = array();
}
else
{

		$censors = $cache->obtain_word_list();

		$censors = $cache->obtain_word_list();

 
		}

	}

if (sizeof($censors))

	}

if (sizeof($censors))

Line 687Line 757
	}
else
{

	}
else
{

		return preg_replace('#<!\-\- s(.*?) \-\-><img src="\{SMILIES_PATH\}\/(.*?) \/><!\-\- s\1 \-\->#', '<img src="' . $phpbb_root_path . $config['smilies_path'] . '/\2 />', $text);


		$root_path = (defined('PHPBB_USE_BOARD_URL_PATH') && PHPBB_USE_BOARD_URL_PATH) ? generate_board_url() . '/' : $phpbb_root_path;
return preg_replace('#<!\-\- s(.*?) \-\-><img src="\{SMILIES_PATH\}\/(.*?) \/><!\-\- s\1 \-\->#', '<img src="' . $root_path . $config['smilies_path'] . '/\2 />', $text);

	}
}


	}
}


Line 795Line 866
		
// Some basics...
$attachment['extension'] = strtolower(trim($attachment['extension']));

		
// Some basics...
$attachment['extension'] = strtolower(trim($attachment['extension']));

		$filename = $phpbb_root_path . $config['upload_path'] . '/' . basename($attachment['physical_filename']);
$thumbnail_filename = $phpbb_root_path . $config['upload_path'] . '/thumb_' . basename($attachment['physical_filename']);

		$filename = $phpbb_root_path . $config['upload_path'] . '/' . utf8_basename($attachment['physical_filename']);
$thumbnail_filename = $phpbb_root_path . $config['upload_path'] . '/thumb_' . utf8_basename($attachment['physical_filename']);


$upload_icon = '';



$upload_icon = '';


Line 812Line 883
			}
}


			}
}


		$filesize = $attachment['filesize'];
$size_lang = ($filesize >= 1048576) ? $user->lang['MB'] : ( ($filesize >= 1024) ? $user->lang['KB'] : $user->lang['BYTES'] );
$filesize = ($filesize >= 1048576) ? round((round($filesize / 1048576 * 100) / 100), 2) : (($filesize >= 1024) ? round((round($filesize / 1024 * 100) / 100), 2) : $filesize);

		$filesize = get_formatted_filesize($attachment['filesize'], false);




$comment = bbcode_nl2br(censor_text($attachment['attach_comment']));

$block_array += array(
'UPLOAD_ICON' => $upload_icon,


$comment = bbcode_nl2br(censor_text($attachment['attach_comment']));

$block_array += array(
'UPLOAD_ICON' => $upload_icon,

			'FILESIZE'			=> $filesize,
'SIZE_LANG' => $size_lang,
'DOWNLOAD_NAME' => basename($attachment['real_filename']),

			'FILESIZE'			=> $filesize['value'],
'SIZE_LANG' => $filesize['unit'],
'DOWNLOAD_NAME' => utf8_basename($attachment['real_filename']),

			'COMMENT'			=> $comment,
);


			'COMMENT'			=> $comment,
);


Line 914Line 983
						'S_THUMBNAIL'		=> true,
'THUMB_IMAGE' => $thumbnail_link,
);

						'S_THUMBNAIL'		=> true,
'THUMB_IMAGE' => $thumbnail_link,
);

 

$update_count[] = $attachment['attach_id'];

				break;

// Windows Media Streams

				break;

// Windows Media Streams

Line 960Line 1031
						'S_FLASH_FILE'	=> true,
'WIDTH' => $width,
'HEIGHT' => $height,

						'S_FLASH_FILE'	=> true,
'WIDTH' => $width,
'HEIGHT' => $height,

 
						'U_VIEW_LINK'	=> $download_link . '&amp;view=1',

					);

// Viewed/Heared File ... update the download count

					);

// Viewed/Heared File ... update the download count

Line 1046Line 1118
/**
* Truncates string while retaining special characters if going over the max length
* The default max length is 60 at the moment

/**
* Truncates string while retaining special characters if going over the max length
* The default max length is 60 at the moment

 
* The maximum storage length is there to fit the string within the given length. The string may be further truncated due to html entities.
* For example: string given is 'a "quote"' (length: 9), would be a stored as 'a &quot;quote&quot;' (length: 19)
*
* @param string $string The text to truncate to the given length. String is specialchared.
* @param int $max_length Maximum length of string (multibyte character count as 1 char / Html entity count as 1 char)
* @param int $max_store_length Maximum character length of string (multibyte character count as 1 char / Html entity count as entity chars).
* @param bool $allow_reply Allow Re: in front of string
* NOTE: This parameter can cause undesired behavior (returning strings longer than $max_store_length) and is deprecated.
* @param string $append String to be appended

*/

*/

function truncate_string($string, $max_length = 60, $allow_reply = true, $append = '')

function truncate_string($string, $max_length = 60, $max_store_length = 255, $allow_reply = false, $append = '')

{
$chars = array();


{
$chars = array();


Line 1068Line 1149
		// Cut off the last elements from the array
$string = implode('', array_slice($chars, 0, $max_length - utf8_strlen($append)));
$stripped = true;

		// Cut off the last elements from the array
$string = implode('', array_slice($chars, 0, $max_length - utf8_strlen($append)));
$stripped = true;

 
	}

// Due to specialchars, we may not be able to store the string...
if (utf8_strlen($string) > $max_store_length)
{
// let's split again, we do not want half-baked strings where entities are split
$_chars = utf8_str_split(htmlspecialchars_decode($string));
$chars = array_map('utf8_htmlspecialchars', $_chars);

do
{
array_pop($chars);
$string = implode('', $chars);
}
while (!empty($chars) && utf8_strlen($string) > $max_store_length);

	}

if ($strip_reply)

	}

if ($strip_reply)

Line 1085Line 1181

/**
* Get username details for placing into templates.


/**
* Get username details for placing into templates.

 
* This function caches all modes on first call, except for no_profile and anonymous user - determined by $user_id.

*
* @param string $mode Can be profile (for getting an url to the profile), username (for obtaining the username), colour (for obtaining the user colour), full (for obtaining a html string representing a coloured link to the users profile) or no_profile (the same as full but forcing no profile link)
* @param int $user_id The users id

*
* @param string $mode Can be profile (for getting an url to the profile), username (for obtaining the username), colour (for obtaining the user colour), full (for obtaining a html string representing a coloured link to the users profile) or no_profile (the same as full but forcing no profile link)
* @param int $user_id The users id

Line 1094Line 1191
* @param string $custom_profile_url optional parameter to specify a profile url. The user id get appended to this url as &amp;u={user_id}
*
* @return string A string consisting of what is wanted based on $mode.

* @param string $custom_profile_url optional parameter to specify a profile url. The user id get appended to this url as &amp;u={user_id}
*
* @return string A string consisting of what is wanted based on $mode.

 
* @author BartVB, Acyd Burn

*/
function get_username_string($mode, $user_id, $username, $username_colour = '', $guest_username = false, $custom_profile_url = false)
{

*/
function get_username_string($mode, $user_id, $username, $username_colour = '', $guest_username = false, $custom_profile_url = false)
{

	global $phpbb_root_path, $phpEx, $user, $auth;

	static $_profile_cache;





	$profile_url = '';






















	// We cache some common variables we need within this function
if (empty($_profile_cache))
{
global $phpbb_root_path, $phpEx;

$_profile_cache['base_url'] = append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&amp;u={USER_ID}');
$_profile_cache['tpl_noprofile'] = '{USERNAME}';
$_profile_cache['tpl_noprofile_colour'] = '<span style="color: {USERNAME_COLOUR};" class="username-coloured">{USERNAME}</span>';
$_profile_cache['tpl_profile'] = '<a href="{PROFILE_URL}">{USERNAME}</a>';
$_profile_cache['tpl_profile_colour'] = '<a href="{PROFILE_URL}" style="color: {USERNAME_COLOUR};" class="username-coloured">{USERNAME}</a>';
}

global $user, $auth;

// This switch makes sure we only run code required for the mode
switch ($mode)
{
case 'full':
case 'no_profile':
case 'colour':

// Build correct username colour

	$username_colour = ($username_colour) ? '#' . $username_colour : '';


	$username_colour = ($username_colour) ? '#' . $username_colour : '';


 
			// Return colour
if ($mode == 'colour')
{
return $username_colour;
}

// no break;

case 'username':

// Build correct username

	if ($guest_username === false)
{
$username = ($username) ? $username : $user->lang['GUEST'];

	if ($guest_username === false)
{
$username = ($username) ? $username : $user->lang['GUEST'];

Line 1111Line 1241
		$username = ($user_id && $user_id != ANONYMOUS) ? $username : ((!empty($guest_username)) ? $guest_username : $user->lang['GUEST']);
}


		$username = ($user_id && $user_id != ANONYMOUS) ? $username : ((!empty($guest_username)) ? $guest_username : $user->lang['GUEST']);
}


	// Only show the link if not anonymous
if ($mode != 'no_profile' && $user_id && $user_id != ANONYMOUS)

			// Return username
if ($mode == 'username')

	{

	{

		// Do not show the link if the user is already logged in but do not have u_viewprofile permissions (relevant for bots mostly).
// For all others the link leads to a login page or the profile.
if ($user->data['user_id'] != ANONYMOUS && !$auth->acl_get('u_viewprofile'))
{
$profile_url = '';

				return $username;





		}

		}

		else









// no break;

case 'profile':

// Build correct profile url - only show if not anonymous and permission to view profile if registered user
// For anonymous the link leads to a login page.
if ($user_id && $user_id != ANONYMOUS && ($user->data['user_id'] == ANONYMOUS || $auth->acl_get('u_viewprofile')))

		{

		{

			$profile_url = ($custom_profile_url !== false) ? $custom_profile_url . '&amp;u=' . (int) $user_id : append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&amp;u=' . (int) $user_id);
}

				$profile_url = ($custom_profile_url !== false) ? $custom_profile_url . '&amp;u=' . (int) $user_id : str_replace(array('={USER_ID}', '=%7BUSER_ID%7D'), '=' . (int) $user_id, $_profile_cache['base_url']);


	}
else
{
$profile_url = '';
}


	}
else
{
$profile_url = '';
}


	switch ($mode)


			// Return profile
if ($mode == 'profile')

	{

	{

		case 'profile':

 
			return $profile_url;

			return $profile_url;

		break;

			}





		case 'username':
return $username;
break;

		// no break;
}






		case 'colour':
return $username_colour;
break;

case 'no_profile':
case 'full':
default:

$tpl = '';
if (!$profile_url && !$username_colour)

	if (($mode == 'full' && !$profile_url) || $mode == 'no_profile')










			{

			{

				$tpl = '{USERNAME}';
}
else if (!$profile_url && $username_colour)
{
$tpl = '<span style="color: {USERNAME_COLOUR};" class="username-coloured">{USERNAME}</span>';
}
else if ($profile_url && !$username_colour)
{
$tpl = '<a href="{PROFILE_URL}">{USERNAME}</a>';
}
else if ($profile_url && $username_colour)
{
$tpl = '<a href="{PROFILE_URL}" style="color: {USERNAME_COLOUR};" class="username-coloured">{USERNAME}</a>';

		return str_replace(array('{USERNAME_COLOUR}', '{USERNAME}'), array($username_colour, $username), (!$username_colour) ? $_profile_cache['tpl_noprofile'] : $_profile_cache['tpl_noprofile_colour']);













			}


			}


			return str_replace(array('{PROFILE_URL}', '{USERNAME_COLOUR}', '{USERNAME}'), array($profile_url, $username_colour, $username), $tpl);
break;
}

	return str_replace(array('{PROFILE_URL}', '{USERNAME_COLOUR}', '{USERNAME}'), array($profile_url, $username_colour, $username), (!$username_colour) ? $_profile_cache['tpl_profile'] : $_profile_cache['tpl_profile_colour']);



}

/**

}

/**