diff options
Diffstat (limited to 'phpBB')
84 files changed, 627 insertions, 417 deletions
| diff --git a/phpBB/adm/style/install_update.html b/phpBB/adm/style/install_update.html index b5fa46dbf6..57e2c8ffea 100644 --- a/phpBB/adm/style/install_update.html +++ b/phpBB/adm/style/install_update.html @@ -109,27 +109,14 @@  	<!-- ENDIF -->  	</fieldset> -	<!-- IF not S_UP_TO_DATE --> - -		<form id="install_dbupdate" method="post" action="{U_DB_UPDATE_ACTION}"> - -		<fieldset class="submit-buttons"> -			<p>{L_UPDATE_DATABASE_EXPLAIN}</p> -			<input class="button1" type="submit" name="db_update" value="{L_UPDATE_DATABASE}" /> -		</fieldset> - -		</form> - -	<!-- ELSE --> -		<form id="install_update" method="post" action="{U_ACTION}"> +	<form id="install_update" method="post" action="{U_ACTION}"> -		<fieldset class="submit-buttons"> -			<p>{L_CHECK_FILES_UP_TO_DATE}</p> -			<input class="button1" type="submit" name="submit" value="{L_CHECK_FILES}" /> -		</fieldset> +	<fieldset class="submit-buttons"> +		<p>{L_CHECK_FILES_EXPLAIN}</p> +		<input class="button1" type="submit" name="submit" value="{L_CHECK_FILES}" /> +	</fieldset> -		</form> -	<!-- ENDIF --> +	</form>  <!-- ELSEIF S_DB_UPDATE --> @@ -155,29 +142,29 @@  	<!-- ELSE --> -		<h1>{L_UPDATE_DB_SUCCESS}</h1> +		<div class="successbox"> +			<h3>{L_UPDATE_SUCCESS}</h3> +			<p>{L_EVERYTHING_UP_TO_DATE}</p> +		</div> -		<br /><br /> +	<!-- ENDIF --> -		<form id="install_update" method="post" action="{U_ACTION}"> +<!-- ELSEIF S_FILE_CHECK --> -		<fieldset class="submit-buttons"> -			<p>{L_CHECK_FILES_EXPLAIN}</p> -			<input class="button1" type="submit" name="submit" value="{L_CHECK_FILES}" /> -		</fieldset> +	<!-- IF S_ALL_UP_TO_DATE --> -		</form> +		<h1>{L_UPDATE_FILE_SUCCESS}</h1> +		<p>{L_ALL_FILES_UP_TO_DATE}</p> -	<!-- ENDIF --> +		<p>{L_UPDATE_DATABASE_EXPLAIN}</p> -<!-- ELSEIF S_FILE_CHECK --> +		<form id="install_dbupdate" method="post" action="{U_DB_UPDATE_ACTION}"> -	<!-- IF S_ALL_UP_TO_DATE --> +		<fieldset class="submit-buttons"> +			<input class="button1" type="submit" name="db_update" value="{L_UPDATE_DATABASE}" /> +		</fieldset> -		<div class="successbox"> -			<h3>{L_UPDATE_SUCCESS}</h3> -			<p>{L_ALL_FILES_UP_TO_DATE}</p> -		</div> +		</form>  	<!-- ELSE -->  		<h1>{L_COLLECTED_INFORMATION}</h1> diff --git a/phpBB/develop/blank.gif b/phpBB/develop/blank.gif new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/phpBB/develop/blank.gif diff --git a/phpBB/develop/blank.jpg b/phpBB/develop/blank.jpg new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/phpBB/develop/blank.jpg diff --git a/phpBB/develop/mysql_upgrader.php b/phpBB/develop/mysql_upgrader.php index 597dd5e932..f5e7e97400 100644 --- a/phpBB/develop/mysql_upgrader.php +++ b/phpBB/develop/mysql_upgrader.php @@ -149,7 +149,8 @@ foreach ($schema_data as $table_name => $table_data)  			list($orig_column_type, $column_length) = explode(':', $column_data[0]);  			$column_type = sprintf($dbms_type_map['mysql_41'][$orig_column_type . ':'], $column_length); -			if (isset($dbms_type_map['mysql_40'][$orig_column_type . ':']['limit'][0])) +			if (isset($dbms_type_map['mysql_40'][$orig_column_type . ':']['limit']) && +				isset($dbms_type_map['mysql_40'][$orig_column_type . ':']['limit'][0]))  			{  				switch ($dbms_type_map['mysql_40'][$orig_column_type . ':']['limit'][0])  				{ @@ -698,6 +699,24 @@ function get_schema_struct()  		),  	); +	$schema_data['phpbb_login_attempts'] = array( +		'COLUMNS'		=> array( +			'attempt_ip'			=> array('VCHAR:40', ''), +			'attempt_browser'		=> array('VCHAR:150', ''), +			'attempt_forwarded_for'	=> array('VCHAR:255', ''), +			'attempt_time'			=> array('TIMESTAMP', 0), +			'user_id'				=> array('UINT', 0), +			'username'				=> array('VCHAR_UNI:255', 0), +			'username_clean'		=> array('VCHAR_CI', 0), +		), +		'KEYS'			=> array( +			'att_ip'				=> array('INDEX', array('attempt_ip', 'attempt_time')), +			'att_for'		=> array('INDEX', array('attempt_forwarded_for', 'attempt_time')), +			'att_time'				=> array('INDEX', array('attempt_time')), +			'user_id'					=> array('INDEX', 'user_id'), +		), +	); +  	$schema_data['phpbb_moderator_cache'] = array(  		'COLUMNS'		=> array(  			'forum_id'				=> array('UINT', 0), @@ -901,6 +920,7 @@ function get_schema_struct()  			'field_default_value'	=> array('VCHAR_UNI', ''),  			'field_validation'		=> array('VCHAR_UNI:20', ''),  			'field_required'		=> array('BOOL', 0), +			'field_show_novalue'	=> array('BOOL', 0),  			'field_show_on_reg'		=> array('BOOL', 0),  			'field_show_on_vt'		=> array('BOOL', 0),  			'field_show_profile'	=> array('BOOL', 0), diff --git a/phpBB/docs/CHANGELOG.html b/phpBB/docs/CHANGELOG.html index 97f8c40383..bb42736daf 100644 --- a/phpBB/docs/CHANGELOG.html +++ b/phpBB/docs/CHANGELOG.html @@ -183,6 +183,8 @@  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11662">PHPBB3-11662</a>] - "occured" should be "occurred"</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11670">PHPBB3-11670</a>] - Replace trademark ™ with ® on "Welcome to phpBB" install page</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11674">PHPBB3-11674</a>] - Do not include vendor folder if there are no dependencies.</li> +<li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11524">PHPBB3-11524</a>] - MySQL Upgrader throws warnings on PHP 5.4</li> +<li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11720">PHPBB3-11720</a>] - Reporting posts leads to white page error</li>  </ul>  <h4>Improvement</h4>  <ul> @@ -206,6 +208,7 @@  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11294">PHPBB3-11294</a>] - Update extension list in running tests doc</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11368">PHPBB3-11368</a>] - Latest pm reports row count</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11583">PHPBB3-11583</a>] - InnoDB supports FULLTEXT index since MySQL 5.6.4.</li> +<li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11740">PHPBB3-11740</a>] - Update link in FAQ to Ideas Centre</li>  </ul>  <h4>Sub-task</h4>  <ul> @@ -231,6 +234,8 @@  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11529">PHPBB3-11529</a>] - Rename RUNNING_TESTS file to .md file to render it on GitHub</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11576">PHPBB3-11576</a>] - Make phpBB Test Suite MySQL behave at least as strict as phpBB MySQL driver</li>  <li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11671">PHPBB3-11671</a>] - Add phing/phing to composer.json</li> +<li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11752">PHPBB3-11752</a>] - Update phpBB.com URLs to https in email templates</li> +<li>[<a href="http://tracker.phpbb.com/browse/PHPBB3-11753">PHPBB3-11753</a>] - Upgrade mysql_upgrader.php schema data.</li>  </ul>  	<a name="v3010"></a><h3>1.ii. Changes since 3.0.10</h3> diff --git a/phpBB/docs/events.md b/phpBB/docs/events.md index 3723bf7b3f..af6e6bdb1c 100644 --- a/phpBB/docs/events.md +++ b/phpBB/docs/events.md @@ -52,6 +52,36 @@ index_body_stat_blocks_before      + styles/subsilver2/template/index_body.html  * Purpose: Add new statistic blocks above the Who Is Online and Board Statistics blocks +memberlist_body_username_append +=== +* Locations: +    + styles/prosilver/template/memberlist_body.html +    + styles/subsilver2/template/memberlist_body.html +* Purpose: Add information after every username in the memberlist. Works in +all display modes (leader, group and normal memberlist). + +memberlist_body_username_prepend +=== +* Locations: +    + styles/prosilver/template/memberlist_body.html +    + styles/subsilver2/template/memberlist_body.html +* Purpose: Add information before every username in the memberlist. Works in +all display modes (leader, group and normal memberlist). + +memberlist_view_user_statistics_after +=== +* Locations: +    + styles/prosilver/template/memberlist_view.html +    + styles/subsilver2/template/memberlist_view.html +* Purpose: Add entries after the user statistics part of any user profile + +memberlist_view_user_statistics_before +=== +* Locations: +    + styles/prosilver/template/memberlist_view.html +    + styles/subsilver2/template/memberlist_view.html +* Purpose: Add entries before the user statistics part of any user profile +  overall_footer_after  ===  * Locations: @@ -114,6 +144,36 @@ simple_footer_after  * Location: styles/prosilver/template/simple_footer.html  * Purpose: Add content directly prior to the `</body>` tag of the simple footer +topiclist_row_prepend +=== +* Locations: +    + styles/prosilver/template/search_results.html +    + styles/prosilver/template/viewforum_body.html +    + styles/subsilver2/template/search_results.html +    + styles/subsilver2/template/viewforum_body.html +* Purpose: Add content into topic rows (inside the elements containing topic titles) + +topiclist_row_append +=== +* Locations: +    + styles/prosilver/template/search_results.html +    + styles/prosilver/template/viewforum_body.html +    + styles/subsilver2/template/search_results.html +    + styles/subsilver2/template/viewforum_body.html +* Purpose: Add content into topic rows (inside the elements containing topic titles) + +ucp_pm_viewmessage_custom_fields_after +=== +* Location: styles/prosilver/template/ucp_pm_viewmessage.html +* Purpose: Add data after the custom fields on the user profile when viewing +a private message + +ucp_pm_viewmessage_custom_fields_before +=== +* Location: styles/prosilver/template/ucp_pm_viewmessage.html +* Purpose: Add data before the custom fields on the user profile when viewing +a private message +  ucp_pm_viewmessage_print_head_append  ===  * Location: styles/prosilver/template/ucp_pm_viewmessage_print.html @@ -133,6 +193,38 @@ viewtopic_body_footer_before  and quick reply, directly before the jumpbox in Prosilver, breadcrumbs in  Subsilver2. +viewtopic_body_post_buttons_after +=== +* Locations: +    + styles/prosilver/template/viewtopic_body.html +    + styles/subsilver2/template/viewtopic_body.html +* Purpose: Add post button to posts (next to edit, quote etc), at the end of +the list. + +viewtopic_body_post_buttons_before +=== +* Locations: +    + styles/prosilver/template/viewtopic_body.html +    + styles/subsilver2/template/viewtopic_body.html +* Purpose: Add post button to posts (next to edit, quote etc), at the start of +the list. + +viewtopic_body_postrow_custom_fields_after +=== +* Locations: +    + styles/prosilver/template/viewtopic_body.html +    + styles/subsilver2/template/viewtopic_body.html +* Purpose: Add data after the custom fields on the user profile when viewing +a post + +viewtopic_body_postrow_custom_fields_before +=== +* Locations: +    + styles/prosilver/template/viewtopic_body.html +    + styles/subsilver2/template/viewtopic_body.html +* Purpose: Add data before the custom fields on the user profile when viewing +a post +  viewtopic_topic_title_prepend  ===  * Locations: diff --git a/phpBB/includes/functions_container.php b/phpBB/includes/functions_container.php index f63dde0614..7cbfa17a0e 100644 --- a/phpBB/includes/functions_container.php +++ b/phpBB/includes/functions_container.php @@ -118,7 +118,10 @@ function phpbb_create_container(array $extensions, $phpbb_root_path, $php_ext)  */  function phpbb_create_install_container($phpbb_root_path, $php_ext)  { -	$core = new phpbb_di_extension_core($phpbb_root_path); +	$other_config_path = $phpbb_root_path . 'install/update/new/config/'; +	$config_path = file_exists($other_config_path . 'services.yml') ? $other_config_path : $phpbb_root_path . 'config/'; + +	$core = new phpbb_di_extension_core($config_path);  	$container = phpbb_create_container(array($core), $phpbb_root_path, $php_ext);  	$container->setParameter('core.root_path', $phpbb_root_path); @@ -136,6 +139,32 @@ function phpbb_create_install_container($phpbb_root_path, $php_ext)  }  /** +* Create updater container +* +* @param string $phpbb_root_path Root path +* @param string $php_ext PHP Extension +* @param array $config_path Path to config directory +* @return ContainerBuilder object (compiled) +*/ +function phpbb_create_update_container($phpbb_root_path, $php_ext, $config_path) +{ +	$config_file = $phpbb_root_path . 'config.' . $php_ext; +	return phpbb_create_compiled_container( +		$config_file, +		array( +			new phpbb_di_extension_config($config_file), +			new phpbb_di_extension_core($config_path), +		), +		array( +			new phpbb_di_pass_collection_pass(), +			new phpbb_di_pass_kernel_pass(), +		), +		$phpbb_root_path, +		$php_ext +	); +} + +/**  * Create a compiled ContainerBuilder object  *  * @param array $extensions Array of Container extension objects @@ -146,11 +175,6 @@ function phpbb_create_install_container($phpbb_root_path, $php_ext)  */  function phpbb_create_compiled_container($config_file, array $extensions, array $passes, $phpbb_root_path, $php_ext)  { -	$installed_exts = phpbb_bootstrap_enabled_exts($config_file, $phpbb_root_path); - -	// Now pass the enabled extension paths into the ext compiler extension -	$extensions[] = new phpbb_di_extension_ext($installed_exts); -  	// Create the final container to be compiled and cached  	$container = phpbb_create_container($extensions, $phpbb_root_path, $php_ext); @@ -231,11 +255,14 @@ function phpbb_create_dumped_container_unless_debug($config_file, array $extensi  function phpbb_create_default_container($phpbb_root_path, $php_ext)  {  	$config_file = $phpbb_root_path . 'config.' . $php_ext; +	$installed_exts = phpbb_bootstrap_enabled_exts($config_file, $phpbb_root_path); +  	return phpbb_create_dumped_container_unless_debug(  		$config_file,  		array(  			new phpbb_di_extension_config($config_file), -			new phpbb_di_extension_core($phpbb_root_path), +			new phpbb_di_extension_core($phpbb_root_path . 'config'), +			new phpbb_di_extension_ext($installed_exts),  		),  		array(  			new phpbb_di_pass_collection_pass(), diff --git a/phpBB/includes/functions_content.php b/phpBB/includes/functions_content.php index c54cc25f34..05d3c5fde2 100644 --- a/phpBB/includes/functions_content.php +++ b/phpBB/includes/functions_content.php @@ -413,7 +413,7 @@ function generate_text_for_display($text, $uid, $bitfield, $flags, $censor_text  	static $bbcode;  	global $phpbb_dispatcher; -	if (!$text) +	if ($text === '')  	{  		return '';  	} @@ -505,7 +505,7 @@ function generate_text_for_storage(&$text, &$uid, &$bitfield, &$flags, $allow_bb  	$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;  	} diff --git a/phpBB/includes/functions_posting.php b/phpBB/includes/functions_posting.php index 103cc81205..6e62c0c6e4 100644 --- a/phpBB/includes/functions_posting.php +++ b/phpBB/includes/functions_posting.php @@ -1095,25 +1095,20 @@ function topic_review($topic_id, $forum_id, $mode = 'topic_review', $cur_post_id  		$poster_id		= $row['user_id'];  		$post_subject	= $row['post_subject']; -		$message		= censor_text($row['post_text']);  		$decoded_message = false;  		if ($show_quote_button && $auth->acl_get('f_reply', $forum_id))  		{ -			$decoded_message = $message; +			$decoded_message = censor_text($row['post_text']);  			decode_message($decoded_message, $row['bbcode_uid']);  			$decoded_message = bbcode_nl2br($decoded_message);  		} -		if ($row['bbcode_bitfield']) -		{ -			$bbcode->bbcode_second_pass($message, $row['bbcode_uid'], $row['bbcode_bitfield']); -		} - -		$message = bbcode_nl2br($message); -		$message = smiley_text($message, !$row['enable_smilies']); +		$parse_flags = ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0); +		$parse_flags |= ($row['enable_smilies'] ? OPTION_FLAG_SMILIES : 0); +		$message = generate_text_for_display($row['post_text'], $row['bbcode_uid'], $row['bbcode_bitfield'], $parse_flags, true);  		if (!empty($attachments[$row['post_id']]))  		{ diff --git a/phpBB/includes/functions_privmsgs.php b/phpBB/includes/functions_privmsgs.php index 14278a2529..5fc6de8e02 100644 --- a/phpBB/includes/functions_privmsgs.php +++ b/phpBB/includes/functions_privmsgs.php @@ -2018,14 +2018,11 @@ function message_history($msg_id, $user_id, $message_row, $folder, $in_post_mode  			$decoded_message = bbcode_nl2br($decoded_message);  		} - -		if ($row['bbcode_bitfield']) -		{ -			$bbcode->bbcode_second_pass($message, $row['bbcode_uid'], $row['bbcode_bitfield']); -		} - -		$message = bbcode_nl2br($message); -		$message = smiley_text($message, !$row['enable_smilies']); +		 +		$parse_flags = ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0); +		$parse_flags |= ($row['enable_smilies'] ? OPTION_FLAG_SMILIES : 0); +		 +		$message = generate_text_for_display($message, $row['bbcode_uid'], $row['bbcode_bitfield'], $parse_flags, false);  		$subject = censor_text($subject); diff --git a/phpBB/includes/mcp/mcp_pm_reports.php b/phpBB/includes/mcp/mcp_pm_reports.php index 99ff397a66..cb61b25174 100644 --- a/phpBB/includes/mcp/mcp_pm_reports.php +++ b/phpBB/includes/mcp/mcp_pm_reports.php @@ -115,17 +115,9 @@ class mcp_pm_reports  				}  				// Process message, leave it uncensored -				$message = $pm_info['message_text']; +				$parse_flags = ($pm_info['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +				$message = generate_text_for_display($pm_info['message_text'], $pm_info['bbcode_uid'], $pm_info['bbcode_bitfield'], $parse_flags, false); -				if ($pm_info['bbcode_bitfield']) -				{ -					include_once($phpbb_root_path . 'includes/bbcode.' . $phpEx); -					$bbcode = new bbcode($pm_info['bbcode_bitfield']); -					$bbcode->bbcode_second_pass($message, $pm_info['bbcode_uid'], $pm_info['bbcode_bitfield']); -				} - -				$message = bbcode_nl2br($message); -				$message = smiley_text($message);  				$report['report_text'] = make_clickable(bbcode_nl2br($report['report_text']));  				if ($pm_info['message_attachment'] && $auth->acl_get('u_pm_download')) diff --git a/phpBB/includes/mcp/mcp_post.php b/phpBB/includes/mcp/mcp_post.php index 734fa96a78..06f27655ae 100644 --- a/phpBB/includes/mcp/mcp_post.php +++ b/phpBB/includes/mcp/mcp_post.php @@ -125,17 +125,8 @@ function mcp_post_details($id, $mode, $action)  	$post_unread = (isset($topic_tracking_info[$post_info['topic_id']]) && $post_info['post_time'] > $topic_tracking_info[$post_info['topic_id']]) ? true : false;  	// Process message, leave it uncensored -	$message = $post_info['post_text']; - -	if ($post_info['bbcode_bitfield']) -	{ -		include_once($phpbb_root_path . 'includes/bbcode.' . $phpEx); -		$bbcode = new bbcode($post_info['bbcode_bitfield']); -		$bbcode->bbcode_second_pass($message, $post_info['bbcode_uid'], $post_info['bbcode_bitfield']); -	} - -	$message = bbcode_nl2br($message); -	$message = smiley_text($message); +	$parse_flags = ($post_info['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +	$message = generate_text_for_display($post_info['post_text'], $post_info['bbcode_uid'], $post_info['bbcode_bitfield'], $parse_flags, false);  	if ($post_info['post_attachment'] && $auth->acl_get('u_download') && $auth->acl_get('f_download', $post_info['forum_id']))  	{ diff --git a/phpBB/includes/mcp/mcp_queue.php b/phpBB/includes/mcp/mcp_queue.php index 8a9390212f..1fa89af8e1 100644 --- a/phpBB/includes/mcp/mcp_queue.php +++ b/phpBB/includes/mcp/mcp_queue.php @@ -206,17 +206,8 @@ class mcp_queue  				$post_unread = (isset($topic_tracking_info[$post_info['topic_id']]) && $post_info['post_time'] > $topic_tracking_info[$post_info['topic_id']]) ? true : false;  				// Process message, leave it uncensored -				$message = $post_info['post_text']; - -				if ($post_info['bbcode_bitfield']) -				{ -					include_once($phpbb_root_path . 'includes/bbcode.' . $phpEx); -					$bbcode = new bbcode($post_info['bbcode_bitfield']); -					$bbcode->bbcode_second_pass($message, $post_info['bbcode_uid'], $post_info['bbcode_bitfield']); -				} - -				$message = bbcode_nl2br($message); -				$message = smiley_text($message); +				$parse_flags = ($post_info['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +				$message = generate_text_for_display($post_info['post_text'], $post_info['bbcode_uid'], $post_info['bbcode_bitfield'], $parse_flags, false);  				if ($post_info['post_attachment'] && $auth->acl_get('u_download') && $auth->acl_get('f_download', $post_info['forum_id']))  				{ diff --git a/phpBB/includes/mcp/mcp_reports.php b/phpBB/includes/mcp/mcp_reports.php index 72400ce623..3f48c58073 100644 --- a/phpBB/includes/mcp/mcp_reports.php +++ b/phpBB/includes/mcp/mcp_reports.php @@ -187,7 +187,7 @@ class mcp_reports  					'S_CLOSE_ACTION'		=> append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=reports&mode=report_details&f=' . $post_info['forum_id'] . '&p=' . $post_id),  					'S_CAN_VIEWIP'			=> $auth->acl_get('m_info', $post_info['forum_id']),  					'S_POST_REPORTED'		=> $post_info['post_reported'], -					'S_POST_UNAPPROVED'		=> ($post_info['post_visibility'] == POST_UNAPPROVED), +					'S_POST_UNAPPROVED'		=> ($post_info['post_visibility'] == ITEM_UNAPPROVED),  					'S_POST_LOCKED'			=> $post_info['post_edit_locked'],  					'S_USER_NOTES'			=> true, diff --git a/phpBB/includes/mcp/mcp_topic.php b/phpBB/includes/mcp/mcp_topic.php index d0e4a2e057..b282258c08 100644 --- a/phpBB/includes/mcp/mcp_topic.php +++ b/phpBB/includes/mcp/mcp_topic.php @@ -207,13 +207,8 @@ function mcp_topic_view($id, $mode, $action)  		$message = $row['post_text'];  		$post_subject = ($row['post_subject'] != '') ? $row['post_subject'] : $topic_info['topic_title']; -		if ($row['bbcode_bitfield']) -		{ -			$bbcode->bbcode_second_pass($message, $row['bbcode_uid'], $row['bbcode_bitfield']); -		} - -		$message = bbcode_nl2br($message); -		$message = smiley_text($message); +		$parse_flags = ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +		$message = generate_text_for_display($message, $row['bbcode_uid'], $row['bbcode_bitfield'], $parse_flags, false);  		if (!empty($attachments[$row['post_id']]))  		{ diff --git a/phpBB/includes/mcp/mcp_warn.php b/phpBB/includes/mcp/mcp_warn.php index 4ef477775d..bb21d3d377 100644 --- a/phpBB/includes/mcp/mcp_warn.php +++ b/phpBB/includes/mcp/mcp_warn.php @@ -289,19 +289,8 @@ class mcp_warn  		// We want to make the message available here as a reminder  		// Parse the message and subject -		$message = censor_text($user_row['post_text']); - -		// Second parse bbcode here -		if ($user_row['bbcode_bitfield']) -		{ -			include_once($phpbb_root_path . 'includes/bbcode.' . $phpEx); - -			$bbcode = new bbcode($user_row['bbcode_bitfield']); -			$bbcode->bbcode_second_pass($message, $user_row['bbcode_uid'], $user_row['bbcode_bitfield']); -		} - -		$message = bbcode_nl2br($message); -		$message = smiley_text($message); +		$parse_flags = OPTION_FLAG_SMILIES | ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0); +		$message = generate_text_for_display($user_row['post_text'], $user_row['bbcode_uid'], $user_row['bbcode_bitfield'], $parse_flags, true);  		// Generate the appropriate user information for the user we are looking at  		if (!function_exists('phpbb_get_user_avatar')) diff --git a/phpBB/includes/ucp/ucp_pm_viewmessage.php b/phpBB/includes/ucp/ucp_pm_viewmessage.php index b7d2dd6821..c7b4489daf 100644 --- a/phpBB/includes/ucp/ucp_pm_viewmessage.php +++ b/phpBB/includes/ucp/ucp_pm_viewmessage.php @@ -76,17 +76,8 @@ function view_message($id, $mode, $folder_id, $msg_id, $folder, $message_row)  	$user_info = get_user_information($author_id, $message_row);  	// Parse the message and subject -	$message = censor_text($message_row['message_text']); - -	// Second parse bbcode here -	if ($message_row['bbcode_bitfield']) -	{ -		$bbcode->bbcode_second_pass($message, $message_row['bbcode_uid'], $message_row['bbcode_bitfield']); -	} - -	// Always process smilies after parsing bbcodes -	$message = bbcode_nl2br($message); -	$message = smiley_text($message); +	$parse_flags = ($message_row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +	$message = generate_text_for_display($message_row['message_text'], $message_row['bbcode_uid'], $message_row['bbcode_bitfield'], $parse_flags, true);  	// Replace naughty words such as farty pants  	$message_row['message_subject'] = censor_text($message_row['message_subject']); @@ -160,21 +151,8 @@ function view_message($id, $mode, $folder_id, $msg_id, $folder, $message_row)  	// End signature parsing, only if needed  	if ($signature)  	{ -		$signature = censor_text($signature); - -		if ($user_info['user_sig_bbcode_bitfield']) -		{ -			if ($bbcode === false) -			{ -				include($phpbb_root_path . 'includes/bbcode.' . $phpEx); -				$bbcode = new bbcode($user_info['user_sig_bbcode_bitfield']); -			} - -			$bbcode->bbcode_second_pass($signature, $user_info['user_sig_bbcode_uid'], $user_info['user_sig_bbcode_bitfield']); -		} - -		$signature = bbcode_nl2br($signature); -		$signature = smiley_text($signature); +		$parse_flags = ($user_info['user_sig_bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +		$signature = generate_text_for_display($signature, $user_info['user_sig_bbcode_uid'], $user_info['user_sig_bbcode_bitfield'], $parse_flags, true);  	}  	$url = append_sid("{$phpbb_root_path}ucp.$phpEx", 'i=pm'); diff --git a/phpBB/includes/ucp/ucp_profile.php b/phpBB/includes/ucp/ucp_profile.php index 55df5f610c..e55569fdd5 100644 --- a/phpBB/includes/ucp/ucp_profile.php +++ b/phpBB/includes/ucp/ucp_profile.php @@ -546,6 +546,9 @@ class ucp_profile  				// Build custom bbcodes array  				display_custom_bbcodes(); +				// Generate smiley listing +				generate_smilies('inline', 0); +  			break;  			case 'avatar': diff --git a/phpBB/includes/ucp/ucp_register.php b/phpBB/includes/ucp/ucp_register.php index 70fbfe46fb..7bc7ac8191 100644 --- a/phpBB/includes/ucp/ucp_register.php +++ b/phpBB/includes/ucp/ucp_register.php @@ -38,7 +38,7 @@ class ucp_register  		include($phpbb_root_path . 'includes/functions_profile_fields.' . $phpEx);  		$coppa			= $request->is_set('coppa') ? (int) $request->variable('coppa', false) : false; -		$agreed			= (int) $request->variable('agreed', false); +		$agreed			= $request->variable('agreed', false);  		$submit			= $request->is_set_post('submit');  		$change_lang	= request_var('change_lang', '');  		$user_lang		= request_var('lang', $user->lang_name); @@ -63,7 +63,7 @@ class ucp_register  					$submit = false;  					// Setting back agreed to let the user view the agreement in his/her language -					$agreed = ($request->variable('change_lang', false)) ? 0 : $agreed; +					$agreed = false;  				}  				$user->lang_name = $user_lang = $use_lang; @@ -89,7 +89,7 @@ class ucp_register  			$add_coppa = ($coppa !== false) ? '&coppa=' . $coppa : '';  			$s_hidden_fields = array( -				'change_lang'	=> $change_lang, +				'change_lang'	=> '',  			);  			// If we change the language, we want to pass on some more possible parameter. diff --git a/phpBB/install/database_update.php b/phpBB/install/database_update.php index cd6fb7931b..3be5ea659c 100644 --- a/phpBB/install/database_update.php +++ b/phpBB/install/database_update.php @@ -21,26 +21,6 @@ define('IN_INSTALL', true);  $phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './../';  $phpEx = substr(strrchr(__FILE__, '.'), 1); -if (!function_exists('phpbb_require_updated')) -{ -	function phpbb_require_updated($path, $optional = false) -	{ -		global $phpbb_root_path; - -		$new_path = $phpbb_root_path . 'install/update/new/' . $path; -		$old_path = $phpbb_root_path . $path; - -		if (file_exists($new_path)) -		{ -			require($new_path); -		} -		else if (!$optional || file_exists($old_path)) -		{ -			require($old_path); -		} -	} -} -  function phpbb_end_update($cache, $config)  {  	$cache->purge(); @@ -69,7 +49,7 @@ function phpbb_end_update($cache, $config)  	exit_handler();  } -phpbb_require_updated('includes/startup.' . $phpEx); +require($phpbb_root_path . 'includes/startup.' . $phpEx);  include($phpbb_root_path . 'config.' . $phpEx);  if (!defined('PHPBB_INSTALLED') || empty($dbms) || empty($acm_type)) @@ -88,7 +68,9 @@ require($phpbb_root_path . 'includes/functions.' . $phpEx);  require($phpbb_root_path . 'includes/functions_content.' . $phpEx);  require($phpbb_root_path . 'includes/functions_container.' . $phpEx); +require($phpbb_root_path . 'config.' . $phpEx);  require($phpbb_root_path . 'includes/constants.' . $phpEx); +include($phpbb_root_path . 'includes/utf/utf_normalizer.' . $phpEx);  require($phpbb_root_path . 'includes/utf/utf_tools.' . $phpEx);  // Set PHP error handler to ours @@ -101,11 +83,10 @@ $phpbb_class_loader->register();  // Set up container (must be done here because extensions table may not exist)  $container_extensions = array(  	new phpbb_di_extension_config($phpbb_root_path . 'config.' . $phpEx), -	new phpbb_di_extension_core($phpbb_root_path), +	new phpbb_di_extension_core($phpbb_root_path . 'config/'),  );  $container_passes = array(  	new phpbb_di_pass_collection_pass(), -	//new phpbb_di_pass_kernel_pass(),  );  $phpbb_container = phpbb_create_container($container_extensions, $phpbb_root_path, $phpEx); @@ -263,8 +244,8 @@ while (!$migrator->finished())  	// Are we approaching the time limit? If so we want to pause the update and continue after refreshing  	if ((time() - $update_start_time) >= $safe_time_limit)  	{ -		echo $user->lang['DATABASE_UPDATE_NOT_COMPLETED'] . '<br />'; -		echo '<a href="' . append_sid($phpbb_root_path . 'install/database_update.' . $phpEx, 'type=' . $request->variable('type', 0) . '&language=' . $user->lang['USER_LANG']) . '">' . $user->lang['DATABASE_UPDATE_CONTINUE'] . '</a>'; +		echo '<br />' . $user->lang['DATABASE_UPDATE_NOT_COMPLETED'] . '<br /><br />'; +		echo '<a href="' . append_sid($phpbb_root_path . 'install/database_update.' . $phpEx, 'type=' . $request->variable('type', 0) . '&language=' . $request->variable('language', 'en')) . '" class="button1">' . $user->lang['DATABASE_UPDATE_CONTINUE'] . '</a>';  		phpbb_end_update($cache, $config);  	} @@ -280,7 +261,7 @@ echo $user->lang['DATABASE_UPDATE_COMPLETE'] . '<br />';  if ($request->variable('type', 0))  {  	echo $user->lang['INLINE_UPDATE_SUCCESSFUL'] . '<br /><br />'; -	echo '<a href="' . append_sid($phpbb_root_path . 'install/index.' . $phpEx, 'mode=update&sub=file_check&language=' . $user->lang['USER_LANG']) . '" class="button1">' . $user->lang['CONTINUE_UPDATE_NOW'] . '</a>'; +	echo '<a href="' . append_sid($phpbb_root_path . 'install/index.' . $phpEx, 'mode=update&sub=update_db&language=' . $request->variable('language', 'en')) . '" class="button1">' . $user->lang['CONTINUE_UPDATE_NOW'] . '</a>';  }  else  { diff --git a/phpBB/install/index.php b/phpBB/install/index.php index 45e5777e36..bd39e231f4 100644 --- a/phpBB/install/index.php +++ b/phpBB/install/index.php @@ -28,7 +28,7 @@ if (version_compare(PHP_VERSION, '5.3.3') < 0)  function phpbb_require_updated($path, $optional = false)  { -	global $phpbb_root_path; +	global $phpbb_root_path, $table_prefix;  	$new_path = $phpbb_root_path . 'install/update/new/' . $path;  	$old_path = $phpbb_root_path . $path; @@ -43,6 +43,23 @@ function phpbb_require_updated($path, $optional = false)  	}  } +function phpbb_include_updated($path, $optional = false) +{ +	global $phpbb_root_path; + +	$new_path = $phpbb_root_path . 'install/update/new/' . $path; +	$old_path = $phpbb_root_path . $path; + +	if (file_exists($new_path)) +	{ +		include($new_path); +	} +	else if (!$optional || file_exists($old_path)) +	{ +		include($old_path); +	} +} +  phpbb_require_updated('includes/startup.' . $phpEx);  // Try to override some limits - maybe it helps some... @@ -78,18 +95,21 @@ $phpbb_adm_relative_path = (isset($phpbb_adm_relative_path)) ? $phpbb_adm_relati  $phpbb_admin_path = (defined('PHPBB_ADMIN_PATH')) ? PHPBB_ADMIN_PATH : $phpbb_root_path . $phpbb_adm_relative_path;  // Include essential scripts -require($phpbb_root_path . 'phpbb/class_loader.' . $phpEx); +phpbb_require_updated('phpbb/class_loader.' . $phpEx); -require($phpbb_root_path . 'includes/functions.' . $phpEx); -require($phpbb_root_path . 'includes/functions_container.' . $phpEx); +phpbb_require_updated('includes/functions.' . $phpEx); +phpbb_require_updated('includes/functions_container.' . $phpEx);  phpbb_require_updated('includes/functions_content.' . $phpEx, true); -include($phpbb_root_path . 'includes/functions_admin.' . $phpEx); -include($phpbb_root_path . 'includes/utf/utf_tools.' . $phpEx); -require($phpbb_root_path . 'includes/functions_install.' . $phpEx); +phpbb_include_updated('includes/functions_admin.' . $phpEx); +phpbb_include_updated('includes/utf/utf_normalizer.' . $phpEx); +phpbb_include_updated('includes/utf/utf_tools.' . $phpEx); +phpbb_require_updated('includes/functions_install.' . $phpEx);  // Setup class loader first +$phpbb_class_loader_new = new phpbb_class_loader('phpbb_', "{$phpbb_root_path}install/update/new/phpbb/", $phpEx); +$phpbb_class_loader_new->register();  $phpbb_class_loader = new phpbb_class_loader('phpbb_', "{$phpbb_root_path}phpbb/", $phpEx);  $phpbb_class_loader->register();  $phpbb_class_loader_ext = new phpbb_class_loader('phpbb_ext_', "{$phpbb_root_path}ext/", $phpEx); @@ -108,7 +128,7 @@ $request	= $phpbb_container->get('request');  request_var('', 0, false, false, $request); // "dependency injection" for a function  // Try and load an appropriate language if required -$language = basename(request_var('language', '')); +$language = basename($request->variable('language', ''));  if ($request->header('Accept-Language') && !$language)  { @@ -167,11 +187,23 @@ if (!file_exists($phpbb_root_path . 'language/' . $language) || !is_dir($phpbb_r  }  // And finally, load the relevant language files -include($phpbb_root_path . 'language/' . $language . '/common.' . $phpEx); -include($phpbb_root_path . 'language/' . $language . '/acp/common.' . $phpEx); -include($phpbb_root_path . 'language/' . $language . '/acp/board.' . $phpEx); -include($phpbb_root_path . 'language/' . $language . '/install.' . $phpEx); -include($phpbb_root_path . 'language/' . $language . '/posting.' . $phpEx); +$load_lang_files = array('common', 'acp/common', 'acp/board', 'install', 'posting'); +$new_path = $phpbb_root_path . 'install/update/new/language/' . $language . '/'; +$old_path = $phpbb_root_path . 'language/' . $language . '/'; + +// NOTE: we can not use "phpbb_include_updated" as the files uses vars which would be required +// to be global while loading. +foreach ($load_lang_files as $lang_file) +{ +	if (file_exists($new_path . $lang_file . '.' . $phpEx)) +	{ +		include($new_path . $lang_file . '.' . $phpEx); +	} +	else +	{ +		include($old_path . $lang_file . '.' . $phpEx); +	} +}  // usually we would need every single constant here - and it would be consistent. For 3.0.x, use a dirty hack... :( @@ -181,8 +213,8 @@ define('CHMOD_READ', 4);  define('CHMOD_WRITE', 2);  define('CHMOD_EXECUTE', 1); -$mode = request_var('mode', 'overview'); -$sub = request_var('sub', ''); +$mode = $request->variable('mode', 'overview'); +$sub = $request->variable('sub', '');  // Set PHP error handler to ours  set_error_handler(defined('PHPBB_MSG_HANDLER') ? PHPBB_MSG_HANDLER : 'msg_handler'); @@ -217,7 +249,11 @@ $phpbb_style_path_provider = new phpbb_style_path_provider();  $template = new phpbb_template_twig($phpbb_root_path, $phpEx, $config, $user, new phpbb_template_context());  $phpbb_style = new phpbb_style($phpbb_root_path, $phpEx, $config, $user, $phpbb_style_resource_locator, $phpbb_style_path_provider, $template);  $phpbb_style->set_ext_dir_prefix('adm/'); -$phpbb_style->set_custom_style('admin', $phpbb_admin_path . 'style', array(), ''); + +$paths = array($phpbb_root_path . 'install/update/new/adm/style', $phpbb_admin_path . 'style'); +$paths = array_filter($paths, 'is_dir'); +$phpbb_style->set_custom_style('admin', $paths, array(), ''); +  $template->assign_var('T_ASSETS_PATH', '../assets');  $template->assign_var('T_TEMPLATE_PATH', $phpbb_admin_path . 'style'); diff --git a/phpBB/install/install_update.php b/phpBB/install/install_update.php index df9b6c1c7e..4ae39f202f 100644 --- a/phpBB/install/install_update.php +++ b/phpBB/install/install_update.php @@ -39,7 +39,7 @@ if (!empty($setmodules))  		'module_filename'	=> substr(basename(__FILE__), 0, -strlen($phpEx)-1),  		'module_order'		=> 30,  		'module_subs'		=> '', -		'module_stages'		=> array('INTRO', 'VERSION_CHECK', 'UPDATE_DB', 'FILE_CHECK', 'UPDATE_FILES'), +		'module_stages'		=> array('INTRO', 'VERSION_CHECK', 'FILE_CHECK', 'UPDATE_FILES', 'UPDATE_DB'),  		'module_reqs'		=> ''  	);  } @@ -57,7 +57,6 @@ class install_update extends module  	var $new_location;  	var $latest_version;  	var $current_version; -	var $unequal_version;  	var $update_to_version; @@ -74,15 +73,19 @@ class install_update extends module  		global $phpbb_style, $template, $phpEx, $phpbb_root_path, $user, $db, $config, $cache, $auth, $language;  		global $request, $phpbb_admin_path, $phpbb_adm_relative_path, $phpbb_container; +		// We must enable super globals, otherwise creating a new instance of the request class, +		// using the new container with a dbal connection will fail with the following PHP Notice: +		// Object of class phpbb_request_deactivated_super_global could not be converted to int +		$request->enable_super_globals(); +  		// Create a normal container now -		$phpbb_container = phpbb_create_default_container($phpbb_root_path, $phpEx); +		$phpbb_container = phpbb_create_update_container($phpbb_root_path, $phpEx, $phpbb_root_path . 'install/update/new/config');  		// Writes into global $cache  		$cache = $phpbb_container->get('cache');  		$this->tpl_name = 'install_update';  		$this->page_title = 'UPDATE_INSTALLATION'; -		$this->unequal_version = false;  		$this->old_location = $phpbb_root_path . 'install/update/old/';  		$this->new_location = $phpbb_root_path . 'install/update/new/'; @@ -125,7 +128,7 @@ class install_update extends module  		$config['default_lang'] = $language;  		$user->data['user_lang'] = $language; -		$user->setup(array('common', 'acp/common', 'acp/board', 'install', 'posting')); +		$user->add_lang(array('common', 'acp/common', 'acp/board', 'install', 'posting'));  		// Reset the default_lang  		$config['default_lang'] = $config_default_lang; @@ -138,7 +141,9 @@ class install_update extends module  		}  		// Set custom template again. ;) -		$phpbb_style->set_custom_style('admin', $phpbb_admin_path . 'style', array(), ''); +		$paths = array($phpbb_root_path . 'install/update/new/adm/style', $phpbb_admin_path . 'style'); +		$paths = array_filter($paths, 'is_dir'); +		$phpbb_style->set_custom_style('admin', $paths, array(), '');  		$template->assign_vars(array(  			'S_USER_LANG'			=> $user->lang['USER_LANG'], @@ -192,8 +197,6 @@ class install_update extends module  		// Check if the update files are actually meant to update from the current version  		if ($this->current_version != $this->update_info['version']['from'])  		{ -			$this->unequal_version = true; -  			$template->assign_vars(array(  				'S_ERROR'	=> true,  				'ERROR_MSG'	=> sprintf($user->lang['INCOMPATIBLE_UPDATE_FILES'], $this->current_version, $this->update_info['version']['from'], $this->update_info['version']['to']), @@ -201,10 +204,8 @@ class install_update extends module  		}  		// Check if the update files stored are for the latest version... -		if ($this->latest_version != $this->update_info['version']['to']) +		if (version_compare(strtolower($this->latest_version), strtolower($this->update_info['version']['to']), '>'))  		{ -			$this->unequal_version = true; -  			$template->assign_vars(array(  				'S_WARNING'		=> true,  				'WARNING_MSG'	=> sprintf($user->lang['OLD_UPDATE_FILES'], $this->update_info['version']['from'], $this->update_info['version']['to'], $this->latest_version)) @@ -222,14 +223,15 @@ class install_update extends module  		if ($this->test_update === false)  		{ -			// Got the updater template itself updated? If so, we are able to directly use it - but only if all three files are present -			if (in_array($phpbb_adm_relative_path . 'style/install_update.html', $this->update_info['files'])) +			// What about the language file? Got it updated? +			if (in_array('language/' . $language . '/install.' . $phpEx, $this->update_info['files']))  			{ -				$this->tpl_name = '../../install/update/new/adm/style/install_update'; +				$lang = array(); +				include($this->new_location . 'language/' . $language . '/install.' . $phpEx); +				// this is the user's language.. just merge it +				$user->lang = array_merge($user->lang, $lang);  			} - -			// What about the language file? Got it updated? -			if (in_array('language/en/install.' . $phpEx, $this->update_info['files'])) +			if ($language != 'en' && in_array('language/en/install.' . $phpEx, $this->update_info['files']))  			{  				$lang = array();  				include($this->new_location . 'language/en/install.' . $phpEx); @@ -273,18 +275,17 @@ class install_update extends module  				$this->page_title = 'STAGE_VERSION_CHECK';  				$template->assign_vars(array( -					'S_UP_TO_DATE'		=> $up_to_date,  					'S_VERSION_CHECK'	=> true, -					'U_ACTION'				=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=file_check"), -					'U_DB_UPDATE_ACTION'	=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=update_db"), +					'U_ACTION'			=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=file_check"), +					'S_UP_TO_DATE'		=> $up_to_date,  					'LATEST_VERSION'	=> $this->latest_version, -					'CURRENT_VERSION'	=> $this->current_version) -				); +					'CURRENT_VERSION'	=> $this->current_version, +				));  				// Print out version the update package updates to -				if ($this->unequal_version) +				if ($this->latest_version != $this->update_info['version']['to'])  				{  					$template->assign_var('PACKAGE_VERSION', $this->update_info['version']['to']);  				} @@ -302,30 +303,6 @@ class install_update extends module  			break;  			case 'update_db': - -				// Make sure the database update is valid for the latest version -				$valid = false; -				$updates_to_version = ''; - -				if (file_exists($phpbb_root_path . 'install/database_update.' . $phpEx)) -				{ -					include_once($phpbb_root_path . 'install/database_update.' . $phpEx); - -					if ($updates_to_version === $this->update_info['version']['to']) -					{ -						$valid = true; -					} -				} - -				// Should not happen at all -				if (!$valid) -				{ -					trigger_error($user->lang['DATABASE_UPDATE_INFO_OLD'], E_USER_ERROR); -				} - -				// Just a precaution -				$cache->purge(); -  				// Redirect the user to the database update script with some explanations...  				$template->assign_vars(array(  					'S_DB_UPDATE'			=> true, @@ -333,8 +310,14 @@ class install_update extends module  					'U_DB_UPDATE'			=> append_sid($phpbb_root_path . 'install/database_update.' . $phpEx, 'type=1&language=' . $user->data['user_lang']),  					'U_DB_UPDATE_ACTION'	=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=update_db"),  					'U_ACTION'				=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=file_check"), +					'L_EVERYTHING_UP_TO_DATE'	=> $user->lang('EVERYTHING_UP_TO_DATE', append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login'), append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login&redirect=' . $phpbb_adm_relative_path . 'index.php%3Fi=send_statistics%26mode=send_statistics')),  				)); +				// Do not display incompatible package note after successful update +				if ($config['version'] == $this->update_info['version']['to']) +				{ +					$template->assign_var('S_ERROR', false); +				}  			break;  			case 'file_check': @@ -500,17 +483,30 @@ class install_update extends module  				$template->assign_vars(array(  					'S_FILE_CHECK'			=> true,  					'S_ALL_UP_TO_DATE'		=> $all_up_to_date, -					'L_ALL_FILES_UP_TO_DATE'	=> $user->lang('ALL_FILES_UP_TO_DATE', append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login'), append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login&redirect=' . $phpbb_adm_relative_path . 'index.php%3Fi=send_statistics%26mode=send_statistics')),  					'S_VERSION_UP_TO_DATE'	=> $up_to_date, +					'S_UP_TO_DATE'			=> $up_to_date,  					'U_ACTION'				=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=file_check"),  					'U_UPDATE_ACTION'		=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=update_files"),  					'U_DB_UPDATE_ACTION'	=> append_sid($this->p_master->module_url, "language=$language&mode=$mode&sub=update_db"),  				)); +				// Since some people try to update to RC releases, but phpBB.com tells them the last version is the version they currently run +				// we are faced with the updater thinking the database schema is up-to-date; which it is, but should be updated none-the-less +				// We now try to cope with this by triggering the update process +				if (version_compare(str_replace('rc', 'RC', strtolower($this->current_version)), str_replace('rc', 'RC', strtolower($this->update_info['version']['to'])), '<')) +				{ +					$template->assign_vars(array( +						'S_UP_TO_DATE'		=> false, +					)); +				} +  				if ($all_up_to_date)  				{ +					global $phpbb_container; +					$phpbb_log = $phpbb_container->get('log'); +  					// Add database update to log -					add_log('admin', 'LOG_UPDATE_PHPBB', $this->current_version, $this->update_to_version); +					$phpbb_log->add('admin', $user->data['user_id'], $user->ip, 'LOG_UPDATE_PHPBB', time(), array($this->current_version, $this->update_to_version));  					$db->sql_return_on_error(true);  					$db->sql_query('DELETE FROM ' . CONFIG_TABLE . " WHERE config_name = 'version_update_from'"); @@ -1089,12 +1085,6 @@ class install_update extends module  		$this->tpl_name = 'install_update_diff'; -		// Got the diff template itself updated? If so, we are able to directly use it -		if (in_array($phpbb_adm_relative_path . 'style/install_update_diff.html', $this->update_info['files'])) -		{ -			$this->tpl_name = '../../install/update/new/adm/style/install_update_diff'; -		} -  		$this->page_title = 'VIEWING_FILE_DIFF';  		$status = request_var('status', ''); diff --git a/phpBB/install/schemas/schema_data.sql b/phpBB/install/schemas/schema_data.sql index d03fdf9de4..0a31b89aab 100644 --- a/phpBB/install/schemas/schema_data.sql +++ b/phpBB/install/schemas/schema_data.sql @@ -170,7 +170,7 @@ INSERT INTO phpbb_config (config_name, config_value) VALUES ('limit_search_load'  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_anon_lastread', '0');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_birthdays', '1');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_cpf_memberlist', '0'); -INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_cpf_profile', '0'); +INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_cpf_pm', '0');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_cpf_viewprofile', '1');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_cpf_viewtopic', '0');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('load_db_lastread', '1'); diff --git a/phpBB/language/en/acp/permissions_phpbb.php b/phpBB/language/en/acp/permissions_phpbb.php index d0128db34a..5ea151f6ea 100644 --- a/phpBB/language/en/acp/permissions_phpbb.php +++ b/phpBB/language/en/acp/permissions_phpbb.php @@ -102,6 +102,17 @@ $lang = array_merge($lang, array(  // Forum Permissions  $lang = array_merge($lang, array( +	'ACL_F_LIST'		=> 'Can see forum', +	'ACL_F_READ'		=> 'Can read forum', +	'ACL_F_SEARCH'		=> 'Can search the forum', +	'ACL_F_SUBSCRIBE'	=> 'Can subscribe forum', +	'ACL_F_PRINT'		=> 'Can print topics', +	'ACL_F_EMAIL'		=> 'Can email topics', +	'ACL_F_BUMP'		=> 'Can bump topics', +	'ACL_F_USER_LOCK'	=> 'Can lock own topics', +	'ACL_F_DOWNLOAD'	=> 'Can download files', +	'ACL_F_REPORT'		=> 'Can report posts', +  	'ACL_F_POST'		=> 'Can start new topics',  	'ACL_F_STICKY'		=> 'Can post stickies',  	'ACL_F_ANNOUNCE'	=> 'Can post announcements', diff --git a/phpBB/language/en/email/installed.txt b/phpBB/language/en/email/installed.txt index 9ec93484e1..8f63d07635 100644 --- a/phpBB/language/en/email/installed.txt +++ b/phpBB/language/en/email/installed.txt @@ -12,7 +12,7 @@ Username: {USERNAME}  Board URL: {U_BOARD}  ---------------------------- -Useful information regarding the phpBB software can be found in the docs folder of your installation and on phpBB.com's support page - http://www.phpbb.com/support/ +Useful information regarding the phpBB software can be found in the docs folder of your installation and on phpBB.com's support page - https://www.phpbb.com/support/  In order to keep your board safe and secure, we highly recommended keeping current with software releases. For your convenience, a mailing list is available at the page referenced above. diff --git a/phpBB/language/en/help_faq.php b/phpBB/language/en/help_faq.php index 68dc05f992..94e6622685 100644 --- a/phpBB/language/en/help_faq.php +++ b/phpBB/language/en/help_faq.php @@ -332,7 +332,7 @@ $help = array(  	),  	array(  		0 => 'Why isn’t X feature available?', -		1 => 'This software was written by and licensed through phpBB Group. If you believe a feature needs to be added, or you want to report a bug, please visit the phpBB <a href="http://area51.phpbb.com/">Area51</a> website, where you will find resources to do so.' +		1 => 'This software was written by and licensed through phpBB Group. If you believe a feature needs to be added please visit the <a href="https://www.phpbb.com/ideas/">phpBB Ideas Centre</a>, where you can upvote existing ideas or suggest new features.'  	),  	array(  		0 => 'Who do I contact about abusive and/or legal matters related to this board?', diff --git a/phpBB/language/en/install.php b/phpBB/language/en/install.php index be45047861..03c9562983 100644 --- a/phpBB/language/en/install.php +++ b/phpBB/language/en/install.php @@ -374,7 +374,7 @@ $lang = array_merge($lang, array(  // Updater  $lang = array_merge($lang, array( -	'ALL_FILES_UP_TO_DATE'		=> 'All files are up to date with the latest phpBB version. You should now <a href="%1$s">login to your board</a> and check if everything is working fine. Do not forget to delete, rename or move your install directory! Please send us updated information about your server and board configurations from the <a href="%2$s">Send statistics</a> module in your ACP.', +	'ALL_FILES_UP_TO_DATE'		=> 'All files are up to date with the latest phpBB version.',  	'ARCHIVE_FILE'				=> 'Source file within archive',  	'BACK'				=> 'Back', @@ -398,7 +398,7 @@ $lang = array_merge($lang, array(  	'DATABASE_TYPE'						=> 'Database type',  	'DATABASE_UPDATE_COMPLETE'			=> 'Database updater has completed!', -	'DATABASE_UPDATE_CONTINUE'			=> 'Continue database update.', +	'DATABASE_UPDATE_CONTINUE'			=> 'Continue database update',  	'DATABASE_UPDATE_INFO_OLD'			=> 'The database update file within the install directory is outdated. Please make sure you uploaded the correct version of the file.',  	'DATABASE_UPDATE_NOT_COMPLETED'		=> 'The database update has not yet completed.',  	'DELETE_USER_REMOVE'				=> 'Delete user and remove posts', @@ -419,8 +419,9 @@ $lang = array_merge($lang, array(  	'DOWNLOAD_UPDATE_METHOD'			=> 'Download modified files archive',  	'DOWNLOAD_UPDATE_METHOD_EXPLAIN'	=> 'Once downloaded you should unpack the archive. You will find the modified files you need to upload to your phpBB root directory within it. Please upload the files to their respective locations then. After you have uploaded all files, please check the files again with the other button below.', -	'ERROR'			=> 'Error',  	'EDIT_USERNAME'	=> 'Edit username', +	'ERROR'			=> 'Error', +	'EVERYTHING_UP_TO_DATE'		=> 'Everything is up to date with the latest phpBB version. You should now <a href="%1$s">login to your board</a> and check if everything is working fine. Do not forget to delete, rename or move your install directory! Please send us updated information about your server and board configurations from the <a href="%2$s">Send statistics</a> module in your ACP.',  	'FILE_ALREADY_UP_TO_DATE'		=> 'File is already up to date.',  	'FILE_DIFF_NOT_ALLOWED'			=> 'File not allowed to be diffed.', @@ -570,6 +571,7 @@ $lang = array_merge($lang, array(  	'UPLOAD_METHOD'					=> 'Upload method',  	'UPDATE_DB_SUCCESS'				=> 'Database update was successful.', +	'UPDATE_FILE_SUCCESS'			=> 'File update was successful.',  	'USER_ACTIVE'					=> 'Active user',  	'USER_INACTIVE'					=> 'Inactive user', diff --git a/phpBB/memberlist.php b/phpBB/memberlist.php index 46136dbdd4..26f920fe5a 100644 --- a/phpBB/memberlist.php +++ b/phpBB/memberlist.php @@ -561,17 +561,8 @@ switch ($mode)  		if ($member['user_sig'])  		{ -			$member['user_sig'] = censor_text($member['user_sig']); - -			if ($member['user_sig_bbcode_bitfield']) -			{ -				include_once($phpbb_root_path . 'includes/bbcode.' . $phpEx); -				$bbcode = new bbcode(); -				$bbcode->bbcode_second_pass($member['user_sig'], $member['user_sig_bbcode_uid'], $member['user_sig_bbcode_bitfield']); -			} - -			$member['user_sig'] = bbcode_nl2br($member['user_sig']); -			$member['user_sig'] = smiley_text($member['user_sig']); +			$parse_flags = ($member['user_sig_bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +			$member['user_sig'] = generate_text_for_display($member['user_sig'], $member['user_sig_bbcode_uid'], $member['user_sig_bbcode_bitfield'], $parse_flags, true);  		}  		$poster_avatar = phpbb_get_user_avatar($member); diff --git a/phpBB/phpbb/cache/driver/file.php b/phpBB/phpbb/cache/driver/file.php index 85decbe3e8..944dfd6541 100644 --- a/phpBB/phpbb/cache/driver/file.php +++ b/phpBB/phpbb/cache/driver/file.php @@ -205,28 +205,34 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  	function purge()  	{  		// Purge all phpbb cache files -		$dir = @opendir($this->cache_dir); - -		if (!$dir) +		try  +		{ +			$iterator = new DirectoryIterator($this->cache_dir); +		} +		catch (Exception $e)  		{  			return;  		} -		while (($entry = readdir($dir)) !== false) +		foreach ($iterator as $fileInfo)  		{ -			if (strpos($entry, 'container_') !== 0 && -				strpos($entry, 'url_matcher') !== 0 && -				strpos($entry, 'sql_') !== 0 && -				strpos($entry, 'data_') !== 0 && -				strpos($entry, 'ctpl_') !== 0 && -				strpos($entry, 'tpl_') !== 0) +			if ($fileInfo->isDot())  			{  				continue;  			} - -			$this->remove_file($this->cache_dir . $entry); +			$filename = $fileInfo->getFilename(); +			if ($fileInfo->isDir()) +			{ +				$this->remove_dir($fileInfo->getPathname()); +			} +			elseif (strpos($filename, 'container_') === 0 || +				strpos($filename, 'url_matcher') === 0 || +				strpos($filename, 'sql_') === 0 || +				strpos($filename, 'data_') === 0) +			{ +				$this->remove_file($fileInfo->getPathname()); +			}  		} -		closedir($dir);  		unset($this->vars);  		unset($this->var_expires); @@ -242,6 +248,44 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  	}  	/** +	* Remove directory +	* +	* @param string $dir Directory to remove +	* +	* @return null +	*/ +	protected function remove_dir($dir) +	{ +		try  +		{ +			$iterator = new DirectoryIterator($dir); +		} +		catch (Exception $e) +		{ +			return; +		} + +		foreach ($iterator as $fileInfo) +		{ +			if ($fileInfo->isDot()) +			{ +				continue; +			} + +			if ($fileInfo->isDir()) +			{ +				$this->remove_dir($fileInfo->getPathname()); +			} +			else +			{ +				$this->remove_file($fileInfo->getPathname()); +			} +		} + +		@rmdir($dir); +	} + +	/**  	* Destroy cache data  	*/  	function destroy($var_name, $table = '') diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc1.php index 0ed05812dc..459b423736 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.10-rc1', '>='); +		return version_compare($this->config['version'], '3.0.10-RC1', '>=');  	}  	static public function depends_on() @@ -24,7 +24,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc1 extends phpbb_db_migration  		return array(  			array('config.add', array('email_max_chunk_size', 50)), -			array('config.update', array('version', '3.0.10-rc1')), +			array('config.update', array('version', '3.0.10-RC1')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc2.php index b14b3b00aa..8d21cab45d 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.10-rc2', '>='); +		return version_compare($this->config['version'], '3.0.10-RC2', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.10-rc2')), +			array('config.update', array('version', '3.0.10-RC2')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc3.php b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc3.php index 473057d65d..296c3c40af 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_10_rc3.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_10_rc3.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc3 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.10-rc3', '>='); +		return version_compare($this->config['version'], '3.0.10-RC3', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_10_rc3 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.10-rc3')), +			array('config.update', array('version', '3.0.10-RC3')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_11_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_11_rc1.php index dddfc0e0e7..3a3908258f 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_11_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_11_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_11_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.11-rc1', '>='); +		return version_compare($this->config['version'], '3.0.11-RC1', '>=');  	}  	static public function depends_on() @@ -25,7 +25,7 @@ class phpbb_db_migration_data_30x_3_0_11_rc1 extends phpbb_db_migration  			array('custom', array(array(&$this, 'cleanup_deactivated_styles'))),  			array('custom', array(array(&$this, 'delete_orphan_private_messages'))), -			array('config.update', array('version', '3.0.11-rc1')), +			array('config.update', array('version', '3.0.11-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_11_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_11_rc2.php index fac8523e8c..4b1b5642ce 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_11_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_11_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_11_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.11-rc2', '>='); +		return version_compare($this->config['version'], '3.0.11-RC2', '>=');  	}  	static public function depends_on() @@ -44,7 +44,7 @@ class phpbb_db_migration_data_30x_3_0_11_rc2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.11-rc2')), +			array('config.update', array('version', '3.0.11-RC2')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_12_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_12_rc1.php index 6a31a51201..1338d48006 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_12_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_12_rc1.php @@ -13,7 +13,7 @@ class phpbb_db_migration_data_30x_3_0_12_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.12-rc1', '>='); +		return version_compare($this->config['version'], '3.0.12-RC1', '>=');  	}   	static public function depends_on() @@ -28,7 +28,7 @@ class phpbb_db_migration_data_30x_3_0_12_rc1 extends phpbb_db_migration  			array('custom', array(array(&$this, 'update_bots'))),  			array('custom', array(array(&$this, 'disable_bots_from_receiving_pms'))), -			array('config.update', array('version', '3.0.12-rc1')), +			array('config.update', array('version', '3.0.12-RC1')),  		);  	} @@ -108,7 +108,7 @@ class phpbb_db_migration_data_30x_3_0_12_rc1 extends phpbb_db_migration  						WHERE user_id = $bot_user_id";  					$this->sql_query($sql); -					user_delete('remove', $bot_user_id); +					user_delete('retain', $bot_user_id);  				}  				else  				{ diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_1_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_1_rc1.php index 562ccf077c..761ed5d2ec 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_1_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_1_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_1_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.1-rc1', '>='); +		return version_compare($this->config['version'], '3.0.1-RC1', '>=');  	}  	public function update_schema() @@ -74,7 +74,7 @@ class phpbb_db_migration_data_30x_3_0_1_rc1 extends phpbb_db_migration  			array('custom', array(array(&$this, 'fix_unset_last_view_time'))),  			array('custom', array(array(&$this, 'reset_smiley_size'))), -			array('config.update', array('version', '3.0.1-rc1')), +			array('config.update', array('version', '3.0.1-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_2_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_2_rc1.php index a960e90765..a84f3c2d92 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_2_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_2_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_2_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.2-rc1', '>='); +		return version_compare($this->config['version'], '3.0.2-RC1', '>=');  	}  	static public function depends_on() @@ -26,7 +26,7 @@ class phpbb_db_migration_data_30x_3_0_2_rc1 extends phpbb_db_migration  			array('config.add', array('check_attachment_content', '1')),  			array('config.add', array('mime_triggers', 'body|head|html|img|plaintext|a href|pre|script|table|title')), -			array('config.update', array('version', '3.0.2-rc1')), +			array('config.update', array('version', '3.0.2-RC1')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_2_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_2_rc2.php index 8917dfea77..33bacc077f 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_2_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_2_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_2_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.2-rc2', '>='); +		return version_compare($this->config['version'], '3.0.2-RC2', '>=');  	}  	static public function depends_on() @@ -74,7 +74,7 @@ class phpbb_db_migration_data_30x_3_0_2_rc2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.2-rc2')), +			array('config.update', array('version', '3.0.2-RC2')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_3_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_3_rc1.php index 4b102e1a2e..69433f386e 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_3_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_3_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_3_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.3-rc1', '>='); +		return version_compare($this->config['version'], '3.0.3-RC1', '>=');  	}  	static public function depends_on() @@ -60,7 +60,7 @@ class phpbb_db_migration_data_30x_3_0_3_rc1 extends phpbb_db_migration  			array('permission.add', array('u_masspm_group', true, 'u_masspm')),  			array('custom', array(array(&$this, 'correct_acp_email_permissions'))), -			array('config.update', array('version', '3.0.3-rc1')), +			array('config.update', array('version', '3.0.3-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_4_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_4_rc1.php index 8ad75a557b..e45bd3eeee 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_4_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_4_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_4_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.4-rc1', '>='); +		return version_compare($this->config['version'], '3.0.4-RC1', '>=');  	}  	static public function depends_on() @@ -76,7 +76,7 @@ class phpbb_db_migration_data_30x_3_0_4_rc1 extends phpbb_db_migration  		return array(  			array('custom', array(array(&$this, 'update_custom_profile_fields'))), -			array('config.update', array('version', '3.0.4-rc1')), +			array('config.update', array('version', '3.0.4-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1.php index ea17cc1e31..62ae7bff1a 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_5_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.5-rc1', '>='); +		return version_compare($this->config['version'], '3.0.5-RC1', '>=');  	}  	static public function depends_on() diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1part2.php b/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1part2.php index 8538347b1a..d72176489b 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1part2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_5_rc1part2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_5_rc1part2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.5-rc1', '>='); +		return version_compare($this->config['version'], '3.0.5-RC1', '>=');  	}  	static public function depends_on() @@ -36,7 +36,7 @@ class phpbb_db_migration_data_30x_3_0_5_rc1part2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.5-rc1')), +			array('config.update', array('version', '3.0.5-RC1')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc1.php index 38c282ebf0..25f4995b0e 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.6-rc1', '>='); +		return version_compare($this->config['version'], '3.0.6-RC1', '>=');  	}  	static public function depends_on() @@ -185,7 +185,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc1 extends phpbb_db_migration  			array('custom', array(array(&$this, 'add_newly_registered_group'))),  			array('custom', array(array(&$this, 'set_user_options_default'))), -			array('config.update', array('version', '3.0.6-rc1')), +			array('config.update', array('version', '3.0.6-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc2.php index a939dbd489..d5d14ab05d 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.6-rc2', '>='); +		return version_compare($this->config['version'], '3.0.6-RC2', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.6-rc2')), +			array('config.update', array('version', '3.0.6-RC2')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc3.php b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc3.php index b3f09d8ab8..f3f1fb42f4 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc3.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc3.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc3 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.6-rc3', '>='); +		return version_compare($this->config['version'], '3.0.6-RC3', '>=');  	}  	static public function depends_on() @@ -24,7 +24,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc3 extends phpbb_db_migration  		return array(  			array('custom', array(array(&$this, 'update_cp_fields'))), -			array('config.update', array('version', '3.0.6-rc3')), +			array('config.update', array('version', '3.0.6-RC3')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc4.php b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc4.php index fc2923f99b..6138ef351d 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_6_rc4.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_6_rc4.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc4 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.6-rc4', '>='); +		return version_compare($this->config['version'], '3.0.6-RC4', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_6_rc4 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.6-rc4')), +			array('config.update', array('version', '3.0.6-RC4')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_7_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_7_rc1.php index ffebf66f2d..be8f9045f4 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_7_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_7_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_7_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.7-rc1', '>='); +		return version_compare($this->config['version'], '3.0.7-RC1', '>=');  	}  	static public function depends_on() @@ -62,7 +62,7 @@ class phpbb_db_migration_data_30x_3_0_7_rc1 extends phpbb_db_migration  			array('config.add', array('feed_topics_active', $this->config['feed_overall_topics'])),  			array('custom', array(array(&$this, 'delete_text_templates'))), -			array('config.update', array('version', '3.0.7-rc1')), +			array('config.update', array('version', '3.0.7-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_7_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_7_rc2.php index 55bc2bc679..0e43229f13 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_7_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_7_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_7_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.7-rc2', '>='); +		return version_compare($this->config['version'], '3.0.7-RC2', '>=');  	}  	static public function depends_on() @@ -24,7 +24,7 @@ class phpbb_db_migration_data_30x_3_0_7_rc2 extends phpbb_db_migration  		return array(  			array('custom', array(array(&$this, 'update_email_hash'))), -			array('config.update', array('version', '3.0.7-rc2')), +			array('config.update', array('version', '3.0.7-RC2')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_8_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_8_rc1.php index aeff35333e..ff7824fa3b 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_8_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_8_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_8_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.8-rc1', '>='); +		return version_compare($this->config['version'], '3.0.8-RC1', '>=');  	}  	static public function depends_on() @@ -38,7 +38,7 @@ class phpbb_db_migration_data_30x_3_0_8_rc1 extends phpbb_db_migration  			array('config.update_if_equals', array(600, 'queue_interval', 60)),  			array('config.update_if_equals', array(50, 'email_package_size', 20)), -			array('config.update', array('version', '3.0.8-rc1')), +			array('config.update', array('version', '3.0.8-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc1.php b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc1.php index 4c345b429b..d3beda63b7 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc1.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc1.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc1 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.9-rc1', '>='); +		return version_compare($this->config['version'], '3.0.9-RC1', '>=');  	}  	static public function depends_on() @@ -74,7 +74,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc1 extends phpbb_db_migration  			array('custom', array(array(&$this, 'update_file_extension_group_names'))),  			array('custom', array(array(&$this, 'fix_firebird_qa_captcha'))), -			array('config.update', array('version', '3.0.9-rc1')), +			array('config.update', array('version', '3.0.9-RC1')),  		);  	} diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc2.php b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc2.php index c0e662aa45..beb8873da7 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc2.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc2.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc2 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.9-rc2', '>='); +		return version_compare($this->config['version'], '3.0.9-RC2', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc2 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.9-rc2')), +			array('config.update', array('version', '3.0.9-RC2')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc3.php b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc3.php index d6d1f14b2e..56e04e7235 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc3.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc3.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc3 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.9-rc3', '>='); +		return version_compare($this->config['version'], '3.0.9-RC3', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc3 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.9-rc3')), +			array('config.update', array('version', '3.0.9-RC3')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc4.php b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc4.php index e673249343..5be1124287 100644 --- a/phpBB/phpbb/db/migration/data/30x/3_0_9_rc4.php +++ b/phpBB/phpbb/db/migration/data/30x/3_0_9_rc4.php @@ -11,7 +11,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc4 extends phpbb_db_migration  {  	public function effectively_installed()  	{ -		return version_compare($this->config['version'], '3.0.9-rc4', '>='); +		return version_compare($this->config['version'], '3.0.9-RC4', '>=');  	}  	static public function depends_on() @@ -22,7 +22,7 @@ class phpbb_db_migration_data_30x_3_0_9_rc4 extends phpbb_db_migration  	public function update_data()  	{  		return array( -			array('config.update', array('version', '3.0.9-rc4')), +			array('config.update', array('version', '3.0.9-RC4')),  		);  	}  } diff --git a/phpBB/phpbb/db/migration/data/310/signature_module_auth.php b/phpBB/phpbb/db/migration/data/310/signature_module_auth.php index e4fbb27bcb..02cd70059a 100644 --- a/phpBB/phpbb/db/migration/data/310/signature_module_auth.php +++ b/phpBB/phpbb/db/migration/data/310/signature_module_auth.php @@ -17,7 +17,7 @@ class phpbb_db_migration_data_310_signature_module_auth extends phpbb_db_migrati  				AND module_basename = 'ucp_profile'  				AND module_mode = 'signature'";  		$result = $this->db->sql_query($sql); -		$module_auth = $this->db_sql_fetchfield('module_auth'); +		$module_auth = $this->db->sql_fetchfield('module_auth');  		$this->db->sql_freeresult($result);  		return $module_auth === 'acl_u_sig' || $module_auth === false; diff --git a/phpBB/phpbb/di/extension/core.php b/phpBB/phpbb/di/extension/core.php index 9c36ba2fc4..9d59a24b7e 100644 --- a/phpBB/phpbb/di/extension/core.php +++ b/phpBB/phpbb/di/extension/core.php @@ -26,19 +26,19 @@ use Symfony\Component\Config\FileLocator;  class phpbb_di_extension_core extends Extension  {  	/** -	* phpBB Root path +	* Config path  	* @var string  	*/ -	protected $root_path; +	protected $config_path;  	/**  	* Constructor  	* -	* @param string $root_path Root path +	* @param string $config_path Config path  	*/ -	public function __construct($root_path) +	public function __construct($config_path)  	{ -		$this->root_path = $root_path; +		$this->config_path = $config_path;  	}  	/** @@ -51,7 +51,7 @@ class phpbb_di_extension_core extends Extension  	*/  	public function load(array $config, ContainerBuilder $container)  	{ -		$loader = new YamlFileLoader($container, new FileLocator(phpbb_realpath($this->root_path . 'config'))); +		$loader = new YamlFileLoader($container, new FileLocator(phpbb_realpath($this->config_path)));  		$loader->load('services.yml');  	} diff --git a/phpBB/phpbb/template/twig/node/includeasset.php b/phpBB/phpbb/template/twig/node/includeasset.php index 990b1c984f..1cab416c79 100644 --- a/phpBB/phpbb/template/twig/node/includeasset.php +++ b/phpBB/phpbb/template/twig/node/includeasset.php @@ -7,7 +7,7 @@  *  */ -class phpbb_template_twig_node_includeasset extends Twig_Node +abstract class phpbb_template_twig_node_includeasset extends Twig_Node  {  	/** @var Twig_Environment */  	protected $environment; @@ -57,4 +57,19 @@ class phpbb_template_twig_node_includeasset extends Twig_Node  			->raw("\n');\n")  		;  	} + +	/** +	* Get the definition name +	* +	* @return string (e.g. 'SCRIPTS') +	*/ +	abstract public function get_definition_name(); + +	/** +	* Append the output code for the asset +	* +	* @param Twig_Compiler A Twig_Compiler instance +	* @return null +	*/ +	abstract protected function append_asset(Twig_Compiler $compiler);  } diff --git a/phpBB/phpbb/template/twig/node/includecss.php b/phpBB/phpbb/template/twig/node/includecss.php index 01fda44aad..a9d9b46d69 100644 --- a/phpBB/phpbb/template/twig/node/includecss.php +++ b/phpBB/phpbb/template/twig/node/includecss.php @@ -9,16 +9,17 @@  class phpbb_template_twig_node_includecss extends phpbb_template_twig_node_includeasset  { +	/** +	* {@inheritdoc} +	*/  	public function get_definition_name()  	{  		return 'STYLESHEETS';  	}  	/** -	 * Compiles the node to PHP. -	 * -	 * @param Twig_Compiler A Twig_Compiler instance -	 */ +	* {@inheritdoc} +	*/  	public function append_asset(Twig_Compiler $compiler)  	{  		$compiler diff --git a/phpBB/phpbb/template/twig/node/includejs.php b/phpBB/phpbb/template/twig/node/includejs.php index fdf2bea3ed..2b4b55fb0a 100644 --- a/phpBB/phpbb/template/twig/node/includejs.php +++ b/phpBB/phpbb/template/twig/node/includejs.php @@ -9,16 +9,17 @@  class phpbb_template_twig_node_includejs extends phpbb_template_twig_node_includeasset  { +	/** +	* {@inheritdoc} +	*/  	public function get_definition_name()  	{  		return 'SCRIPTS';  	}  	/** -	 * Compiles the node to PHP. -	 * -	 * @param Twig_Compiler A Twig_Compiler instance -	 */ +	* {@inheritdoc} +	*/  	protected function append_asset(Twig_Compiler $compiler)  	{  		$config = $this->environment->get_phpbb_config(); diff --git a/phpBB/phpbb/user.php b/phpBB/phpbb/user.php index 5530fe3f03..b39438e315 100644 --- a/phpBB/phpbb/user.php +++ b/phpBB/phpbb/user.php @@ -590,6 +590,13 @@ class phpbb_user extends phpbb_session  				$language_filename = $lang_path . $this->lang_name . '/' . $filename . '.' . $phpEx;  			} +			// If we are in install, try to use the updated version, when available +			$install_language_filename = str_replace('language/', 'install/update/new/language/', $language_filename); +			if (defined('IN_INSTALL') && file_exists($install_language_filename)) +			{ +				$language_filename = $install_language_filename; +			} +  			if (!file_exists($language_filename))  			{  				global $config; diff --git a/phpBB/report.php b/phpBB/report.php index c9ca57ecbe..5081f90ad1 100644 --- a/phpBB/report.php +++ b/phpBB/report.php @@ -139,9 +139,10 @@ else  	$reported_post_text 				= $report_data['message_text'];  	$reported_post_bitfield				= $report_data['bbcode_bitfield']; -	$reported_post_enable_bbcode		= $report_data['reported_post_enable_bbcode']; -	$reported_post_enable_smilies		= $report_data['reported_post_enable_smilies']; -	$reported_post_enable_magic_url		= $report_data['reported_post_enable_magic_url']; +	$reported_post_uid					= $report_data['bbcode_uid']; +	$reported_post_enable_bbcode		= $report_data['enable_bbcode']; +	$reported_post_enable_smilies		= $report_data['enable_smilies']; +	$reported_post_enable_magic_url		= $report_data['enable_magic_url'];  }  if ($config['enable_post_confirm'] && !$user->data['is_registered']) diff --git a/phpBB/search.php b/phpBB/search.php index 8bcbfc498b..40c0b9a8ce 100644 --- a/phpBB/search.php +++ b/phpBB/search.php @@ -687,6 +687,18 @@ if ($keywords || $author || $author_id || $search_id || $submit)  				$tracking_topics = ($tracking_topics) ? tracking_unserialize($tracking_topics) : array();  			} +			/** +			* Event to modify the SQL query before the topic data is retrieved +			* +			* @event core.search_get_topic_data +			* @var	string	sql_select		The SQL SELECT string used by search to get topic data +			* @var	string	sql_from		The SQL FROM string used by search to get topic data +			* @var	string	sql_where		The SQL WHERE string used by search to get topic data +			* @since 3.1-A1 +			*/ +			$vars = array('sql_select', 'sql_from', 'sql_where'); +			extract($phpbb_dispatcher->trigger_event('core.search_get_topic_data', compact($vars))); +  			$sql = "SELECT $sql_select  				FROM $sql_from  				WHERE $sql_where"; @@ -989,7 +1001,7 @@ if ($keywords || $author || $author_id || $search_id || $submit)  				);  			} -			$template->assign_block_vars('searchresults', array_merge($tpl_ary, array( +			$tpl_ary = array_merge($tpl_ary, array(  				'FORUM_ID'			=> $forum_id,  				'TOPIC_ID'			=> $result_topic_id,  				'POST_ID'			=> ($show_results == 'posts') ? $row['post_id'] : false, @@ -1001,9 +1013,22 @@ if ($keywords || $author || $author_id || $search_id || $submit)  				'U_VIEW_TOPIC'		=> $view_topic_url,  				'U_VIEW_FORUM'		=> append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $forum_id), -				'U_VIEW_POST'		=> (!empty($row['post_id'])) ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=" . $row['topic_id'] . '&p=' . $row['post_id'] . (($u_hilit) ? '&hilit=' . $u_hilit : '')) . '#p' . $row['post_id'] : '') +				'U_VIEW_POST'		=> (!empty($row['post_id'])) ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=" . $row['topic_id'] . '&p=' . $row['post_id'] . (($u_hilit) ? '&hilit=' . $u_hilit : '')) . '#p' . $row['post_id'] : '',  			)); +			/** +			* Modify the topic data before it is assigned to the template +			* +			* @event core.search_modify_tpl_ary +			* @var	array	row			Array with topic data +			* @var	array	tpl_ary		Template block array with topic data +			* @since 3.1-A1 +			*/ +			$vars = array('row', 'tpl_ary'); +			extract($phpbb_dispatcher->trigger_event('core.search_modify_tpl_ary', compact($vars))); + +			$template->assign_block_vars('searchresults', $tpl_ary); +  			if ($show_results == 'topics')  			{  				phpbb_generate_template_pagination($template, $view_topic_url, 'searchresults.pagination', 'start', $replies + 1, $config['posts_per_page'], 1, true, true); diff --git a/phpBB/styles/prosilver/template/bbcode.html b/phpBB/styles/prosilver/template/bbcode.html index c0c0a2da46..909c09df5a 100644 --- a/phpBB/styles/prosilver/template/bbcode.html +++ b/phpBB/styles/prosilver/template/bbcode.html @@ -12,8 +12,8 @@  <!-- BEGIN quote_open --><blockquote class="uncited"><div><!-- END quote_open -->  <!-- BEGIN quote_close --></div></blockquote><!-- END quote_close --> -<!-- BEGIN code_open --><dl class="codebox"><dt>{L_CODE}{L_COLON} <a href="#" onclick="selectCode(this); return false;">{L_SELECT_ALL_CODE}</a></dt><dd><code><!-- END code_open --> -<!-- BEGIN code_close --></code></dd></dl><!-- END code_close --> +<!-- BEGIN code_open --><div class="codebox"><p>{L_CODE}{L_COLON} <a href="#" onclick="selectCode(this); return false;">{L_SELECT_ALL_CODE}</a></p><code><!-- END code_open --> +<!-- BEGIN code_close --></code></div><!-- END code_close -->  <!-- BEGIN inline_attachment_open --><div class="inline-attachment"><!-- END inline_attachment_open -->  <!-- BEGIN inline_attachment_close --></div><!-- END inline_attachment_close --> diff --git a/phpBB/styles/prosilver/template/memberlist_body.html b/phpBB/styles/prosilver/template/memberlist_body.html index 07a7e2e182..459c3f6bc6 100644 --- a/phpBB/styles/prosilver/template/memberlist_body.html +++ b/phpBB/styles/prosilver/template/memberlist_body.html @@ -109,7 +109,7 @@  			<!-- ENDIF -->  	<tr class="<!-- IF memberrow.S_ROW_COUNT is even -->bg1<!-- ELSE -->bg2<!-- ENDIF -->"> -		<td><!-- IF memberrow.RANK_IMG --><span class="rank-img">{memberrow.RANK_IMG}</span><!-- ELSE --><span class="rank-img">{memberrow.RANK_TITLE}</span><!-- ENDIF --><!-- IF S_IN_SEARCH_POPUP and not S_SELECT_SINGLE --><input type="checkbox" name="user" value="{memberrow.USERNAME}" /> <!-- ENDIF -->{memberrow.USERNAME_FULL}<!-- IF S_SELECT_SINGLE --><br />[ <a href="#" onclick="insert_single('{memberrow.A_USERNAME}'); return false;">{L_SELECT}</a> ]<!-- ENDIF --></td> +		<td><!-- IF memberrow.RANK_IMG --><span class="rank-img">{memberrow.RANK_IMG}</span><!-- ELSE --><span class="rank-img">{memberrow.RANK_TITLE}</span><!-- ENDIF --><!-- IF S_IN_SEARCH_POPUP and not S_SELECT_SINGLE --><input type="checkbox" name="user" value="{memberrow.USERNAME}" /> <!-- ENDIF --><!-- EVENT memberlist_body_username_prepend -->{memberrow.USERNAME_FULL}<!-- EVENT memberlist_body_username_append --><!-- IF S_SELECT_SINGLE --><br />[ <a href="#" onclick="insert_single('{memberrow.A_USERNAME}'); return false;">{L_SELECT}</a> ]<!-- ENDIF --></td>  		<td class="posts"><!-- IF memberrow.POSTS and S_DISPLAY_SEARCH --><a href="{memberrow.U_SEARCH_USER}" title="{L_SEARCH_USER_POSTS}">{memberrow.POSTS}</a><!-- ELSE -->{memberrow.POSTS}<!-- ENDIF --></td>  		<td class="info"><!-- IF memberrow.U_WWW or memberrow.LOCATION --><!-- IF memberrow.U_WWW --><div><a href="{memberrow.U_WWW}" title="{L_VISIT_WEBSITE}{L_COLON} {memberrow.U_WWW}">{memberrow.U_SHORT_WWW}</a></div><!-- ENDIF --><!-- IF memberrow.LOCATION --><div>{memberrow.LOCATION}</div><!-- ENDIF --><!-- ELSE --> <!-- ENDIF --></td>  		<td>{memberrow.JOINED}</td> diff --git a/phpBB/styles/prosilver/template/memberlist_view.html b/phpBB/styles/prosilver/template/memberlist_view.html index 57cfcb86d9..0d103b5914 100644 --- a/phpBB/styles/prosilver/template/memberlist_view.html +++ b/phpBB/styles/prosilver/template/memberlist_view.html @@ -77,6 +77,7 @@  	<div class="column2">  		<h3>{L_USER_FORUM}</h3>  		<dl class="details"> +			<!-- EVENT memberlist_view_user_statistics_before -->  			<dt>{L_JOINED}{L_COLON}</dt> <dd>{JOINED}</dd>  			<dt>{L_VISITED}{L_COLON}</dt> <dd>{VISITED}</dd>  			<!-- IF S_WARNINGS --> @@ -92,6 +93,7 @@  				<dt>{L_ACTIVE_IN_FORUM}{L_COLON}</dt> <dd><!-- IF ACTIVE_FORUM != '' --><strong><a href="{U_ACTIVE_FORUM}">{ACTIVE_FORUM}</a></strong><br />({ACTIVE_FORUM_POSTS} / {ACTIVE_FORUM_PCT})<!-- ELSE --> - <!-- ENDIF --></dd>  				<dt>{L_ACTIVE_IN_TOPIC}{L_COLON}</dt> <dd><!-- IF ACTIVE_TOPIC != '' --><strong><a href="{U_ACTIVE_TOPIC}">{ACTIVE_TOPIC}</a></strong><br />({ACTIVE_TOPIC_POSTS} / {ACTIVE_TOPIC_PCT})<!-- ELSE --> - <!-- ENDIF --></dd>  			<!-- ENDIF --> +			<!-- EVENT memberlist_view_user_statistics_after -->  		</dl>  	</div>  	<span class="clear"></span></div> diff --git a/phpBB/styles/prosilver/template/posting_smilies.html b/phpBB/styles/prosilver/template/posting_smilies.html index 01b74c710c..3d56a932b7 100644 --- a/phpBB/styles/prosilver/template/posting_smilies.html +++ b/phpBB/styles/prosilver/template/posting_smilies.html @@ -2,8 +2,8 @@  <script type="text/javascript">  // <![CDATA[ -	var form_name = 'postform'; -	var text_name = 'message'; +	var form_name = opener.form_name; +	var text_name = opener.text_name;  // ]]>  </script>  <script type="text/javascript" src="{T_SUPER_TEMPLATE_PATH}/editor.js"></script> diff --git a/phpBB/styles/prosilver/template/search_results.html b/phpBB/styles/prosilver/template/search_results.html index f0424c45db..54e8867526 100644 --- a/phpBB/styles/prosilver/template/search_results.html +++ b/phpBB/styles/prosilver/template/search_results.html @@ -63,6 +63,7 @@  					<dt <!-- IF searchresults.TOPIC_ICON_IMG -->style="background-image: url({T_ICONS_PATH}{searchresults.TOPIC_ICON_IMG}); background-repeat: no-repeat;"<!-- ENDIF --> title="{searchresults.TOPIC_FOLDER_IMG_ALT}">  						<div class="list-inner"> +							<!-- EVENT topiclist_row_prepend -->  							<!-- IF searchresults.S_UNREAD_TOPIC --><a href="{searchresults.U_NEWEST_POST}">{NEWEST_POST_IMG}</a> <!-- ENDIF -->  							<a href="{searchresults.U_VIEW_TOPIC}" class="topictitle">{searchresults.TOPIC_TITLE}</a> {searchresults.ATTACH_ICON_IMG}  							<!-- IF searchresults.S_TOPIC_UNAPPROVED or searchresults.S_POSTS_UNAPPROVED --><a href="{searchresults.U_MCP_QUEUE}">{searchresults.UNAPPROVED_IMG}</a> <!-- ENDIF --> @@ -83,6 +84,7 @@  							</div>  							<!-- ENDIF -->  							{L_POST_BY_AUTHOR} {searchresults.TOPIC_AUTHOR_FULL} » {searchresults.FIRST_POST_TIME} » {L_IN} <a href="{searchresults.U_VIEW_FORUM}">{searchresults.FORUM_TITLE}</a> +							<!-- EVENT topiclist_row_append -->  						</div>  					</dt> diff --git a/phpBB/styles/prosilver/template/ucp_pm_viewmessage.html b/phpBB/styles/prosilver/template/ucp_pm_viewmessage.html index 22149c8b80..4f2531d3a6 100644 --- a/phpBB/styles/prosilver/template/ucp_pm_viewmessage.html +++ b/phpBB/styles/prosilver/template/ucp_pm_viewmessage.html @@ -85,9 +85,11 @@  		<!-- IF AUTHOR_JOINED --><dd><strong>{L_JOINED}{L_COLON}</strong> {AUTHOR_JOINED}</dd><!-- ENDIF -->  		<!-- IF AUTHOR_FROM --><dd><strong>{L_LOCATION}{L_COLON}</strong> {AUTHOR_FROM}</dd><!-- ENDIF --> +		<!-- EVENT ucp_pm_viewmessage_custom_fields_before -->  		<!-- BEGIN custom_fields -->  			<dd><strong>{custom_fields.PROFILE_FIELD_NAME}{L_COLON}</strong> {custom_fields.PROFILE_FIELD_VALUE}</dd>  		<!-- END custom_fields --> +		<!-- EVENT ucp_pm_viewmessage_custom_fields_after -->  		<!-- IF U_PM or U_EMAIL or U_WWW or U_MSN or U_ICQ or U_YIM or U_AIM or U_JABBER --> diff --git a/phpBB/styles/prosilver/template/viewforum_body.html b/phpBB/styles/prosilver/template/viewforum_body.html index 69b0608a64..ecd993d7fb 100644 --- a/phpBB/styles/prosilver/template/viewforum_body.html +++ b/phpBB/styles/prosilver/template/viewforum_body.html @@ -144,6 +144,7 @@  			<dl class="icon {topicrow.TOPIC_IMG_STYLE}">  				<dt<!-- IF topicrow.TOPIC_ICON_IMG and S_TOPIC_ICONS --> style="background-image: url({T_ICONS_PATH}{topicrow.TOPIC_ICON_IMG}); background-repeat: no-repeat;"<!-- ENDIF --> title="{topicrow.TOPIC_FOLDER_IMG_ALT}">  					<div class="list-inner"> +						<!-- EVENT topiclist_row_prepend -->  						<!-- IF topicrow.S_UNREAD_TOPIC --><a href="{topicrow.U_NEWEST_POST}">{NEWEST_POST_IMG}</a> <!-- ENDIF --><a href="{topicrow.U_VIEW_TOPIC}" class="topictitle">{topicrow.TOPIC_TITLE}</a>  						<!-- IF topicrow.S_TOPIC_UNAPPROVED or topicrow.S_POSTS_UNAPPROVED --><a href="{topicrow.U_MCP_QUEUE}">{topicrow.UNAPPROVED_IMG}</a> <!-- ENDIF -->  						<!-- IF topicrow.S_TOPIC_DELETED --><a href="{topicrow.U_MCP_QUEUE}">{DELETED_IMG}</a> <!-- ENDIF --> @@ -164,6 +165,7 @@  						<!-- ENDIF -->  						<!-- IF topicrow.ATTACH_ICON_IMG -->{topicrow.ATTACH_ICON_IMG} <!-- ENDIF -->{L_POST_BY_AUTHOR} {topicrow.TOPIC_AUTHOR_FULL} » {topicrow.FIRST_POST_TIME}  						<!-- IF topicrow.S_POST_GLOBAL and FORUM_ID != topicrow.FORUM_ID --> » {L_IN} <a href="{topicrow.U_VIEW_FORUM}">{topicrow.FORUM_NAME}</a><!-- ENDIF --> +						<!-- EVENT topiclist_row_append -->  					</div>  				</dt>  				<dd class="posts">{topicrow.REPLIES} <dfn>{L_REPLIES}</dfn></dd> diff --git a/phpBB/styles/prosilver/template/viewtopic_body.html b/phpBB/styles/prosilver/template/viewtopic_body.html index a8bac42842..c8a99b18e4 100644 --- a/phpBB/styles/prosilver/template/viewtopic_body.html +++ b/phpBB/styles/prosilver/template/viewtopic_body.html @@ -136,12 +136,14 @@  		<!-- IF not S_IS_BOT -->  			<!-- IF postrow.U_EDIT or postrow.U_DELETE or postrow.U_REPORT or postrow.U_WARN or postrow.U_INFO or postrow.U_QUOTE -->  				<ul class="profile-icons"> +					<!-- EVENT viewtopic_body_post_buttons_before -->  					<!-- IF postrow.U_EDIT --><li class="edit-icon"><a href="{postrow.U_EDIT}" title="{L_EDIT_POST}"><span>{L_EDIT_POST}</span></a></li><!-- ENDIF -->  					<!-- IF postrow.U_DELETE --><li class="delete-icon"><a href="{postrow.U_DELETE}" title="{L_DELETE_POST}"><span>{L_DELETE_POST}</span></a></li><!-- ENDIF -->  					<!-- IF postrow.U_REPORT --><li class="report-icon"><a href="{postrow.U_REPORT}" title="{L_REPORT_POST}"><span>{L_REPORT_POST}</span></a></li><!-- ENDIF -->  					<!-- IF postrow.U_WARN --><li class="warn-icon"><a href="{postrow.U_WARN}" title="{L_WARN_USER}"><span>{L_WARN_USER}</span></a></li><!-- ENDIF -->  					<!-- IF postrow.U_INFO --><li class="info-icon"><a href="{postrow.U_INFO}" title="{L_INFORMATION}"><span>{L_INFORMATION}</span></a></li><!-- ENDIF -->  					<!-- IF postrow.U_QUOTE --><li class="quote-icon"><a href="{postrow.U_QUOTE}" title="{L_REPLY_WITH_QUOTE}"><span>{L_REPLY_WITH_QUOTE}</span></a></li><!-- ENDIF --> +					<!-- EVENT viewtopic_body_post_buttons_after -->  				</ul>  			<!-- ENDIF -->  		<!-- ENDIF --> @@ -237,9 +239,11 @@  			<dd><strong>{postrow.PROFILE_FIELD1_NAME}{L_COLON}</strong> {postrow.PROFILE_FIELD1_VALUE}</dd>  		<!-- ENDIF --> +		<!-- EVENT viewtopic_body_postrow_custom_fields_before -->  		<!-- BEGIN custom_fields -->  			<dd><strong>{postrow.custom_fields.PROFILE_FIELD_NAME}{L_COLON}</strong> {postrow.custom_fields.PROFILE_FIELD_VALUE}</dd>  		<!-- END custom_fields --> +		<!-- EVENT viewtopic_body_postrow_custom_fields_after -->  		<!-- IF not S_IS_BOT -->  		<!-- IF postrow.U_PM or postrow.U_EMAIL or postrow.U_WWW or postrow.U_MSN or postrow.U_ICQ or postrow.U_YIM or postrow.U_AIM or postrow.U_JABBER --> diff --git a/phpBB/styles/prosilver/theme/bidi.css b/phpBB/styles/prosilver/theme/bidi.css index f617428565..a921805327 100644 --- a/phpBB/styles/prosilver/theme/bidi.css +++ b/phpBB/styles/prosilver/theme/bidi.css @@ -422,7 +422,7 @@  	margin-left: 0;  } -.rtl blockquote dl.codebox { +.rtl blockquote .codebox {  	margin-right: 0;  } diff --git a/phpBB/styles/prosilver/theme/colours.css b/phpBB/styles/prosilver/theme/colours.css index 7d0462be1b..5548905ede 100644 --- a/phpBB/styles/prosilver/theme/colours.css +++ b/phpBB/styles/prosilver/theme/colours.css @@ -470,16 +470,16 @@ blockquote blockquote blockquote {  }  /* Code block */ -dl.codebox { +.codebox {  	background-color: #FFFFFF;  	border-color: #C9D2D8;  } -dl.codebox dt { +.codebox p {  	border-bottom-color:  #CCCCCC;  } -dl.codebox code { +.codebox code {  	color: #2E8B57;  } diff --git a/phpBB/styles/prosilver/theme/content.css b/phpBB/styles/prosilver/theme/content.css index 4b8c972697..c56c7f9ef8 100644 --- a/phpBB/styles/prosilver/theme/content.css +++ b/phpBB/styles/prosilver/theme/content.css @@ -472,13 +472,13 @@ blockquote.uncited {  }  /* Code block */ -dl.codebox { +.codebox {  	padding: 3px;  	border: 1px solid transparent;  	font-size: 1em;  } -dl.codebox dt { +.codebox p {  	text-transform: uppercase;  	border-bottom: 1px solid transparent;  	margin-bottom: 3px; @@ -487,11 +487,11 @@ dl.codebox dt {  	display: block;  } -blockquote dl.codebox { +blockquote .codebox {  	margin-left: 0;  } -dl.codebox code { +.codebox code {  	/* Also see tweaks.css */  	overflow: auto;  	display: block; diff --git a/phpBB/styles/prosilver/theme/print.css b/phpBB/styles/prosilver/theme/print.css index bc3ca80fdc..88de620493 100644 --- a/phpBB/styles/prosilver/theme/print.css +++ b/phpBB/styles/prosilver/theme/print.css @@ -136,4 +136,4 @@ div.spacer { clear: both; }  /* Accessibility tweaks: Mozilla.org */  .skip_link { display: none; } -dl.codebox dt { display: none; } +.codebox p { display: none; } diff --git a/phpBB/styles/subsilver2/template/bbcode.html b/phpBB/styles/subsilver2/template/bbcode.html index efcf5e1acb..5558716cad 100644 --- a/phpBB/styles/subsilver2/template/bbcode.html +++ b/phpBB/styles/subsilver2/template/bbcode.html @@ -21,11 +21,11 @@  <!-- END quote_close -->  <!-- BEGIN code_open --> -<div class="codetitle"><b>{L_CODE}{L_COLON}</b></div><div class="codecontent"> +<div class="codetitle"><b>{L_CODE}{L_COLON}</b></div><pre class="codecontent">  <!-- END code_open -->  <!-- BEGIN code_close --> -</div> +</pre>  <!-- END code_close -->  <!-- BEGIN inline_attachment_open --> diff --git a/phpBB/styles/subsilver2/template/memberlist_body.html b/phpBB/styles/subsilver2/template/memberlist_body.html index 09336fb8a3..7c4d301de7 100644 --- a/phpBB/styles/subsilver2/template/memberlist_body.html +++ b/phpBB/styles/subsilver2/template/memberlist_body.html @@ -66,7 +66,7 @@  	<!-- IF memberrow.S_ROW_COUNT is even --><tr class="row2"><!-- ELSE -->	<tr class="row1"><!-- ENDIF -->  		<td class="gen" align="center"> {memberrow.ROW_NUMBER} </td> -		<td class="genmed" align="{S_CONTENT_FLOW_BEGIN}">{memberrow.USERNAME_FULL}<!-- IF S_SELECT_SINGLE --> [ <a href="#" onclick="insert_single('{memberrow.A_USERNAME}'); return false;">{L_SELECT}</a> ]<!-- ENDIF --></td> +		<td class="genmed" align="{S_CONTENT_FLOW_BEGIN}"><!-- EVENT memberlist_body_username_prepend -->{memberrow.USERNAME_FULL}<!-- EVENT memberlist_body_username_append --><!-- IF S_SELECT_SINGLE --> [ <a href="#" onclick="insert_single('{memberrow.A_USERNAME}'); return false;">{L_SELECT}</a> ]<!-- ENDIF --></td>  		<td class="genmed" align="center" nowrap="nowrap"> {memberrow.JOINED} </td>  		<td class="gen" align="center">{memberrow.POSTS}</td>  		<td class="gen" align="center"><!-- IF memberrow.RANK_IMG -->{memberrow.RANK_IMG}<!-- ELSE -->{memberrow.RANK_TITLE}<!-- ENDIF --></td> diff --git a/phpBB/styles/subsilver2/template/memberlist_view.html b/phpBB/styles/subsilver2/template/memberlist_view.html index 464369a7a8..3ffdb1ce70 100644 --- a/phpBB/styles/subsilver2/template/memberlist_view.html +++ b/phpBB/styles/subsilver2/template/memberlist_view.html @@ -66,6 +66,7 @@  		</td>  		<td class="row1">  			<table width="100%" cellspacing="1" cellpadding="2" border="0"> +			<!-- EVENT memberlist_view_user_statistics_before -->  			<tr>  				<td class="gen" align="{S_CONTENT_FLOW_END}" nowrap="nowrap">{L_JOINED}{L_COLON} </td>  				<td width="100%"><b class="gen">{JOINED}</b></td> @@ -96,6 +97,7 @@  					<td><!-- IF ACTIVE_TOPIC != '' --><b><a class="gen" href="{U_ACTIVE_TOPIC}">{ACTIVE_TOPIC}</a></b><br /><span class="genmed">[ {ACTIVE_TOPIC_POSTS} / {ACTIVE_TOPIC_PCT} ]</span><!-- ELSE --><span class="gen">-</span><!-- ENDIF --></td>  				</tr>  			<!-- ENDIF --> +			<!-- EVENT memberlist_view_user_statistics_after -->  			</table>  		</td>  	</tr> diff --git a/phpBB/styles/subsilver2/template/overall_header.html b/phpBB/styles/subsilver2/template/overall_header.html index bc2307154b..b0d7ce6fab 100644 --- a/phpBB/styles/subsilver2/template/overall_header.html +++ b/phpBB/styles/subsilver2/template/overall_header.html @@ -154,8 +154,8 @@ function marklist(id, name, state)  		<table width="100%" cellspacing="0">  		<tr>  			<td class="genmed"> -				<!-- IF S_NOTIFICATIONS_DISPLAY --> -					[ <a href="{U_VIEW_ALL_NOTIFICATIONS}" id="notification_list_button">{NOTIFICATIONS_COUNT}</a> ] • +				<!-- IF S_NOTIFICATIONS_DISPLAY and not S_IS_BOT and S_USER_LOGGED_IN --> +					[ <a href="{U_VIEW_ALL_NOTIFICATIONS}" id="notification_list_button">{NOTIFICATIONS_COUNT}</a> ]   					<div id="notification_list" class="notification_list">  						<div class="row1 header">  							{L_NOTIFICATIONS} diff --git a/phpBB/styles/subsilver2/template/posting_smilies.html b/phpBB/styles/subsilver2/template/posting_smilies.html index 30a80e26ab..d0ced9ff12 100644 --- a/phpBB/styles/subsilver2/template/posting_smilies.html +++ b/phpBB/styles/subsilver2/template/posting_smilies.html @@ -2,8 +2,8 @@  <script type="text/javascript">  // <![CDATA[ -	var form_name = 'postform'; -	var text_name = 'message'; +	var form_name = opener.form_name; +	var text_name = opener.text_name;  // ]]>  </script>  <script type="text/javascript" src="{T_SUPER_TEMPLATE_PATH}/editor.js"></script> diff --git a/phpBB/styles/subsilver2/template/search_results.html b/phpBB/styles/subsilver2/template/search_results.html index d98079de20..19ba0b196a 100644 --- a/phpBB/styles/subsilver2/template/search_results.html +++ b/phpBB/styles/subsilver2/template/search_results.html @@ -34,6 +34,7 @@  			<!-- ENDIF -->  			</td>  			<td class="row1"> +				<!-- EVENT topiclist_row_prepend -->  				<!-- IF searchresults.S_UNREAD_TOPIC --><a href="{searchresults.U_NEWEST_POST}" class="imageset">{NEWEST_POST_IMG}</a><!-- ENDIF -->  				{searchresults.ATTACH_ICON_IMG} <a href="{searchresults.U_VIEW_TOPIC}" class="topictitle">{searchresults.TOPIC_TITLE}</a>  				<!-- IF searchresults.S_TOPIC_UNAPPROVED or searchresults.S_POSTS_UNAPPROVED --> @@ -58,6 +59,7 @@  					] </p>  				<!-- ENDIF -->  				<p class="gensmall">{L_IN} <a href="{searchresults.U_VIEW_FORUM}">{searchresults.FORUM_TITLE}</a></p> +				<!-- EVENT topiclist_row_append -->  			</td>  			<td class="row2" width="100" align="center"><p class="topicauthor">{searchresults.TOPIC_AUTHOR_FULL}</p></td>  			<td class="row1" width="50" align="center"><p class="topicdetails">{searchresults.TOPIC_REPLIES}</p></td> diff --git a/phpBB/styles/subsilver2/template/ucp_profile_signature.html b/phpBB/styles/subsilver2/template/ucp_profile_signature.html index 467018dd1c..85c8b0f616 100644 --- a/phpBB/styles/subsilver2/template/ucp_profile_signature.html +++ b/phpBB/styles/subsilver2/template/ucp_profile_signature.html @@ -1,13 +1,22 @@  <!-- INCLUDE ucp_header.html --> +<script type="text/javascript"> +// <![CDATA[ +	var form_name = 'ucp'; +	var text_name = 'signature'; +// ]]> +</script> +  <!-- DEFINE $S_SIGNATURE = 1 -->  <table class="tablebg" width="100%" cellspacing="1">  <tr>  	<th colspan="2">{L_TITLE}</th>  </tr> +<!-- IF not S_SMILIES_ALLOWED -->  <tr>  	<td colspan="2" class="row1">{L_SIGNATURE_EXPLAIN}</td>  </tr> +<!-- ENDIF -->  <!-- IF ERROR -->  	<tr> @@ -16,14 +25,32 @@  <!-- ENDIF -->  <tr> -	<td colspan="2" class="row2"> -		<script type="text/javascript"> -		// <![CDATA[ -			var form_name = 'ucp'; -			var text_name = 'signature'; -		// ]]> -		</script> -		 +	<!-- IF S_SMILIES_ALLOWED --> +	<td class="row1" width="22%" valign="top"> +		{L_SIGNATURE_EXPLAIN} +		<table width="100%" cellspacing="5" cellpadding="0" border="0" align="center"> +			<tr> +				<td class="gensmall" align="center"><b>{L_SMILIES}</b></td> +			</tr> +			<tr> +				<td align="center"> +				<!-- BEGIN smiley --> +					<a href="#" onclick="insert_text('{smiley.A_SMILEY_CODE}', true); return false;" style="line-height: 20px;"><img src="{smiley.SMILEY_IMG}" width="{smiley.SMILEY_WIDTH}" height="{smiley.SMILEY_HEIGHT}" alt="{smiley.SMILEY_CODE}" title="{smiley.SMILEY_DESC}" hspace="2" vspace="2" /></a> +				<!-- END smiley --> +				</td> +			</tr> +			<!-- IF S_SHOW_SMILEY_LINK --> +			<tr> +				<td align="center"><a class="nav" href="{U_MORE_SMILIES}" onclick="popup(this.href, 300, 350, '_phpbbsmilies'); return false;">{L_MORE_SMILIES}</a></td> +			</tr> +			<!-- ENDIF --> +		</table> +	</td> +	<td class="row2"> +	<!-- ELSE --> +	<td class="row2" colspan="2"> +	<!-- ENDIF --> +  		<table cellspacing="0" cellpadding="2" border="0" width="99%">  		<!-- INCLUDE posting_buttons.html -->  		<tr> diff --git a/phpBB/styles/subsilver2/template/viewforum_body.html b/phpBB/styles/subsilver2/template/viewforum_body.html index d07e9a1372..dfbe0a605b 100644 --- a/phpBB/styles/subsilver2/template/viewforum_body.html +++ b/phpBB/styles/subsilver2/template/viewforum_body.html @@ -40,6 +40,7 @@  				<td class="row1" width="25" align="center"><!-- IF topicrow.TOPIC_ICON_IMG --><img src="{T_ICONS_PATH}{topicrow.TOPIC_ICON_IMG}" width="{topicrow.TOPIC_ICON_IMG_WIDTH}" height="{topicrow.TOPIC_ICON_IMG_HEIGHT}" alt="" title="" /><!-- ENDIF --></td>  			<!-- ENDIF -->  			<td class="row1"> +				<!-- EVENT topiclist_row_prepend -->  				<!-- IF topicrow.S_UNREAD_TOPIC --><a href="{topicrow.U_NEWEST_POST}" class="imageset">{NEWEST_POST_IMG}</a><!-- ENDIF -->  				{topicrow.ATTACH_ICON_IMG} <!-- IF topicrow.S_HAS_POLL or topicrow.S_TOPIC_MOVED --><b>{topicrow.TOPIC_TYPE}</b> <!-- ENDIF --><a title="{L_POSTED}{L_COLON} {topicrow.FIRST_POST_TIME}" href="{topicrow.U_VIEW_TOPIC}"class="topictitle">{topicrow.TOPIC_TITLE}</a>  				<!-- IF topicrow.S_TOPIC_UNAPPROVED or topicrow.S_POSTS_UNAPPROVED --> @@ -63,6 +64,7 @@  					<!-- END pagination -->  					] </p>  				<!-- ENDIF --> +				<!-- EVENT topiclist_row_append -->  			</td>  			<td class="row2" width="130" align="center"><p class="topicauthor">{topicrow.TOPIC_AUTHOR_FULL}</p></td>  			<td class="row1" width="50" align="center"><p class="topicdetails">{topicrow.REPLIES}</p></td> @@ -203,6 +205,7 @@  					<td class="row1" width="25" align="center"><!-- IF topicrow.TOPIC_ICON_IMG --><img src="{T_ICONS_PATH}{topicrow.TOPIC_ICON_IMG}" width="{topicrow.TOPIC_ICON_IMG_WIDTH}" height="{topicrow.TOPIC_ICON_IMG_HEIGHT}" alt="" title="" /><!-- ENDIF --></td>  				<!-- ENDIF -->  				<td class="row1"> +					<!-- EVENT topiclist_row_prepend -->  					<!-- IF topicrow.S_UNREAD_TOPIC --><a href="{topicrow.U_NEWEST_POST}" class="imageset">{NEWEST_POST_IMG}</a><!-- ENDIF -->  					{topicrow.ATTACH_ICON_IMG} <!-- IF topicrow.S_HAS_POLL or topicrow.S_TOPIC_MOVED --><b>{topicrow.TOPIC_TYPE}</b> <!-- ENDIF --><a title="{L_POSTED}{L_COLON} {topicrow.FIRST_POST_TIME}" href="{topicrow.U_VIEW_TOPIC}" class="topictitle">{topicrow.TOPIC_TITLE}</a>  					<!-- IF topicrow.S_TOPIC_UNAPPROVED or topicrow.S_POSTS_UNAPPROVED --> @@ -227,6 +230,7 @@  						] </p>  					<!-- ENDIF -->  					<!-- IF topicrow.S_POST_GLOBAL and FORUM_ID != topicrow.FORUM_ID --><p class="gensmall">{L_IN} <a href="{topicrow.U_VIEW_FORUM}">{topicrow.FORUM_NAME}</a></p><!-- ENDIF --> +					<!-- EVENT topiclist_row_append -->  				</td>  				<td class="row2" width="130" align="center"><p class="topicauthor">{topicrow.TOPIC_AUTHOR_FULL}</p></td>  				<td class="row1" width="50" align="center"><p class="topicdetails">{topicrow.REPLIES}</p></td> diff --git a/phpBB/styles/subsilver2/template/viewtopic_body.html b/phpBB/styles/subsilver2/template/viewtopic_body.html index 299b8219eb..26e74b8c38 100644 --- a/phpBB/styles/subsilver2/template/viewtopic_body.html +++ b/phpBB/styles/subsilver2/template/viewtopic_body.html @@ -208,9 +208,11 @@  						<br /><b>{postrow.PROFILE_FIELD1_NAME}{L_COLON}</b> {postrow.PROFILE_FIELD1_VALUE}  					<!-- ENDIF --> +					<!-- EVENT viewtopic_body_postrow_custom_fields_before -->  					<!-- BEGIN custom_fields -->  						<br /><b>{postrow.custom_fields.PROFILE_FIELD_NAME}{L_COLON}</b> {postrow.custom_fields.PROFILE_FIELD_VALUE}  					<!-- END custom_fields --> +					<!-- EVENT viewtopic_body_postrow_custom_fields_after -->  				</span>  			</td> @@ -315,7 +317,21 @@  		<!-- IF postrow.S_ROW_COUNT is even --><tr class="row1"><!-- ELSE --><tr class="row2"><!-- ENDIF -->  			<td class="profile"><strong><a href="#wrapheader">{L_BACK_TO_TOP}</a></strong></td> -			<td><div class="gensmall" style="float: {S_CONTENT_FLOW_BEGIN};"> <!-- IF postrow.U_POST_AUTHOR --><a href="{postrow.U_POST_AUTHOR}" class="imageset">{PROFILE_IMG}</a> <!-- ENDIF --> <!-- IF postrow.U_PM --><a href="{postrow.U_PM}" class="imageset">{PM_IMG}</a> <!-- ENDIF --> <!-- IF postrow.U_EMAIL --><a href="{postrow.U_EMAIL}" class="imageset">{EMAIL_IMG}</a> <!-- ENDIF --> </div> <div class="gensmall" style="float: {S_CONTENT_FLOW_END};"><!-- IF not S_IS_BOT --><!-- IF postrow.U_EDIT --><a href="{postrow.U_EDIT}" class="imageset">{EDIT_IMG}</a> <!-- ENDIF --> <!-- IF postrow.U_QUOTE --><a href="{postrow.U_QUOTE}" class="imageset">{QUOTE_IMG}</a> <!-- ENDIF --> <!-- ENDIF --> </div></td> +			<td> +				<div class="gensmall" style="float: {S_CONTENT_FLOW_BEGIN};"> +					 <!-- IF postrow.U_POST_AUTHOR --><a href="{postrow.U_POST_AUTHOR}" class="imageset">{PROFILE_IMG}</a><!-- ENDIF --> +					<!-- IF postrow.U_PM --><a href="{postrow.U_PM}" class="imageset">{PM_IMG}</a><!-- ENDIF --> +					<!-- IF postrow.U_EMAIL --><a href="{postrow.U_EMAIL}" class="imageset">{EMAIL_IMG}</a><!-- ENDIF --> +				 </div> +				<div class="gensmall" style="float: {S_CONTENT_FLOW_END};"> +					<!-- EVENT viewtopic_body_post_buttons_before --> +					<!-- IF not S_IS_BOT --> +						<!-- IF postrow.U_EDIT --><a href="{postrow.U_EDIT}" class="imageset">{EDIT_IMG}</a><!-- ENDIF --> +						<!-- IF postrow.U_QUOTE --><a href="{postrow.U_QUOTE}" class="imageset">{QUOTE_IMG}</a><!-- ENDIF --> +					<!-- ENDIF --> +					<!-- EVENT viewtopic_body_post_buttons_after --> +				 </div> +			</td>  	<!-- ENDIF -->  		</tr> diff --git a/phpBB/viewforum.php b/phpBB/viewforum.php index 5a59e021b3..1fa2030671 100644 --- a/phpBB/viewforum.php +++ b/phpBB/viewforum.php @@ -372,6 +372,16 @@ $sql_array = array(  	'LEFT_JOIN'	=> array(),  ); +/** +* Event to modify the SQL query before the topic data is retrieved +* +* @event core.viewforum_get_topic_data +* @var	array	sql_array		The SQL array to get the data of all topics +* @since 3.1-A1 +*/ +$vars = array('sql_array'); +extract($phpbb_dispatcher->trigger_event('core.viewforum_get_topic_data', compact($vars))); +  $sql_approved = ' AND ' . $phpbb_content_visibility->get_visibility_sql('topic', $forum_id, 't.');  if ($user->data['is_registered']) @@ -554,6 +564,17 @@ if (sizeof($shadow_topic_list))  	$sql = 'SELECT *  		FROM ' . TOPICS_TABLE . '  		WHERE ' . $db->sql_in_set('topic_id', array_keys($shadow_topic_list)); + +	/** +	* Event to modify the SQL query before the shadowtopic data is retrieved +	* +	* @event core.viewforum_get_shadowtopic_data +	* @var	string	sql		The SQL string to get the data of any shadowtopics +	* @since 3.1-A1 +	*/ +	$vars = array('sql'); +	extract($phpbb_dispatcher->trigger_event('core.viewforum_get_shadowtopic_data', compact($vars))); +  	$result = $db->sql_query($sql);  	while ($row = $db->sql_fetchrow($result)) diff --git a/phpBB/viewtopic.php b/phpBB/viewtopic.php index 1e444f47ad..bc54a249a9 100644 --- a/phpBB/viewtopic.php +++ b/phpBB/viewtopic.php @@ -832,39 +832,14 @@ if (!empty($topic_data['poll_start']))  		$poll_total += $poll_option['poll_option_total'];  	} -	if ($poll_info[0]['bbcode_bitfield']) -	{ -		$poll_bbcode = new bbcode(); -	} -	else -	{ -		$poll_bbcode = false; -	} +	$parse_flags = ($poll_info[0]['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES;  	for ($i = 0, $size = sizeof($poll_info); $i < $size; $i++)  	{ -		$poll_info[$i]['poll_option_text'] = censor_text($poll_info[$i]['poll_option_text']); - -		if ($poll_bbcode !== false) -		{ -			$poll_bbcode->bbcode_second_pass($poll_info[$i]['poll_option_text'], $poll_info[$i]['bbcode_uid'], $poll_option['bbcode_bitfield']); -		} - -		$poll_info[$i]['poll_option_text'] = bbcode_nl2br($poll_info[$i]['poll_option_text']); -		$poll_info[$i]['poll_option_text'] = smiley_text($poll_info[$i]['poll_option_text']); -	} - -	$topic_data['poll_title'] = censor_text($topic_data['poll_title']); - -	if ($poll_bbcode !== false) -	{ -		$poll_bbcode->bbcode_second_pass($topic_data['poll_title'], $poll_info[0]['bbcode_uid'], $poll_info[0]['bbcode_bitfield']); +		$poll_info[$i]['poll_option_text'] = generate_text_for_display($poll_info[$i]['poll_option_text'], $poll_info[$i]['bbcode_uid'], $poll_option['bbcode_bitfield'], $parse_flags, true);  	} -	$topic_data['poll_title'] = bbcode_nl2br($topic_data['poll_title']); -	$topic_data['poll_title'] = smiley_text($topic_data['poll_title']); - -	unset($poll_bbcode); +	$topic_data['poll_title'] = generate_text_for_display($topic_data['poll_title'], $poll_info[0]['bbcode_uid'], $poll_info[0]['bbcode_bitfield'], $parse_flags, true);  	foreach ($poll_info as $poll_option)  	{ @@ -1406,29 +1381,13 @@ for ($i = 0, $end = sizeof($post_list); $i < $end; ++$i)  	// End signature parsing, only if needed  	if ($user_cache[$poster_id]['sig'] && $row['enable_sig'] && empty($user_cache[$poster_id]['sig_parsed']))  	{ -		$user_cache[$poster_id]['sig'] = censor_text($user_cache[$poster_id]['sig']); - -		if ($user_cache[$poster_id]['sig_bbcode_bitfield']) -		{ -			$bbcode->bbcode_second_pass($user_cache[$poster_id]['sig'], $user_cache[$poster_id]['sig_bbcode_uid'], $user_cache[$poster_id]['sig_bbcode_bitfield']); -		} - -		$user_cache[$poster_id]['sig'] = bbcode_nl2br($user_cache[$poster_id]['sig']); -		$user_cache[$poster_id]['sig'] = smiley_text($user_cache[$poster_id]['sig']); -		$user_cache[$poster_id]['sig_parsed'] = true; +		$parse_flags = ($user_cache[$poster_id]['sig_bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +		$user_cache[$poster_id]['sig'] = generate_text_for_display($user_cache[$poster_id]['sig'], $user_cache[$poster_id]['sig_bbcode_uid'], $user_cache[$poster_id]['sig_bbcode_bitfield'],  $parse_flags, true);  	}  	// Parse the message and subject -	$message = censor_text($row['post_text']); - -	// Second parse bbcode here -	if ($row['bbcode_bitfield']) -	{ -		$bbcode->bbcode_second_pass($message, $row['bbcode_uid'], $row['bbcode_bitfield']); -	} - -	$message = bbcode_nl2br($message); -	$message = smiley_text($message); +	$parse_flags = ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES; +	$message = generate_text_for_display($row['post_text'], $row['bbcode_uid'], $row['bbcode_bitfield'], $parse_flags, true);  	if (!empty($attachments[$row['post_id']]))  	{ | 
