diff options
Diffstat (limited to 'phpBB/includes')
| -rw-r--r-- | phpBB/includes/acp/acp_attachments.php | 2 | ||||
| -rw-r--r-- | phpBB/includes/acp/acp_bbcodes.php | 36 | ||||
| -rw-r--r-- | phpBB/includes/functions.php | 29 | ||||
| -rw-r--r-- | phpBB/includes/functions_content.php | 44 | ||||
| -rw-r--r-- | phpBB/includes/functions_messenger.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/functions_posting.php | 8 | ||||
| -rw-r--r-- | phpBB/includes/functions_user.php | 6 | ||||
| -rw-r--r-- | phpBB/includes/ucp/ucp_main.php | 42 | ||||
| -rw-r--r-- | phpBB/includes/ucp/ucp_pm_compose.php | 24 | 
9 files changed, 170 insertions, 25 deletions
| diff --git a/phpBB/includes/acp/acp_attachments.php b/phpBB/includes/acp/acp_attachments.php index dc4eb66cf8..6c2df8d999 100644 --- a/phpBB/includes/acp/acp_attachments.php +++ b/phpBB/includes/acp/acp_attachments.php @@ -1270,7 +1270,7 @@ class acp_attachments  					$row['extension'] = strtolower(trim((string) $row['extension']));  					$comment = ($row['attach_comment'] && !$row['in_message']) ? str_replace(array("\n", "\r"), array('<br />', "\n"), $row['attach_comment']) : ''; -					$display_cat = $extensions[$row['extension']]['display_cat']; +					$display_cat = isset($extensions[$row['extension']]['display_cat']) ? $extensions[$row['extension']]['display_cat'] : ATTACHMENT_CATEGORY_NONE;  					$l_downloaded_viewed = ($display_cat == ATTACHMENT_CATEGORY_NONE) ? 'DOWNLOAD_COUNTS' : 'VIEWED_COUNTS';  					$template->assign_block_vars('attachments', array( diff --git a/phpBB/includes/acp/acp_bbcodes.php b/phpBB/includes/acp/acp_bbcodes.php index 2634ae1874..1f7374a07f 100644 --- a/phpBB/includes/acp/acp_bbcodes.php +++ b/phpBB/includes/acp/acp_bbcodes.php @@ -295,6 +295,22 @@ class acp_bbcodes  					$phpbb_log->add('admin', $user->data['user_id'], $user->ip, $log_action, false, array($data['bbcode_tag'])); +					/** +					* Event after a BBCode has been added or updated +					* +					* @event core.acp_bbcodes_modify_create_after +					* @var	string	action		Type of the action: modify|create +					* @var	int		bbcode_id	The id of the added or updated bbcode +					* @var	array	sql_ary		Array with bbcode data (read only) +					* @since 3.2.4-RC1 +					*/ +					$vars = array( +						'action', +						'bbcode_id', +						'sql_ary', +					); +					extract($phpbb_dispatcher->trigger_event('core.acp_bbcodes_modify_create_after', compact($vars))); +  					trigger_error($user->lang[$lang] . adm_back_link($this->u_action));  				}  				else @@ -325,10 +341,28 @@ class acp_bbcodes  				{  					if (confirm_box(true))  					{ +						$bbcode_tag = $row['bbcode_tag']; +  						$db->sql_query('DELETE FROM ' . BBCODES_TABLE . " WHERE bbcode_id = $bbcode_id");  						$cache->destroy('sql', BBCODES_TABLE);  						$phpbb_container->get('text_formatter.cache')->invalidate(); -						$phpbb_log->add('admin', $user->data['user_id'], $user->ip, 'LOG_BBCODE_DELETE', false, array($row['bbcode_tag'])); +						$phpbb_log->add('admin', $user->data['user_id'], $user->ip, 'LOG_BBCODE_DELETE', false, array($bbcode_tag)); + +						/** +						* Event after a BBCode has been deleted +						* +						* @event core.acp_bbcodes_delete_after +						* @var	string	action		Type of the action: delete +						* @var	int		bbcode_id	The id of the deleted bbcode +						* @var	string	bbcode_tag	The tag of the deleted bbcode +						* @since 3.2.4-RC1 +						*/ +						$vars = array( +							'action', +							'bbcode_id', +							'bbcode_tag', +						); +						extract($phpbb_dispatcher->trigger_event('core.acp_bbcodes_delete_after', compact($vars)));  						if ($request->is_ajax())  						{ diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index cbea7afe6e..1457888c9f 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -73,8 +73,17 @@ function set_var(&$result, $var, $type, $multibyte = false)  */  function gen_rand_string($num_chars = 8)  { -	// [a, z] + [0, 9] = 36 -	return substr(strtoupper(base_convert(bin2hex(random_bytes($num_chars + 1)), 16, 36)), 0, $num_chars); +	$range = array_merge(range('A', 'Z'), range(0, 9)); +	$size = count($range); + +	$output = ''; +	for ($i = 0; $i < $num_chars; $i++) +	{ +		$rand = random_int(0, $size-1); +		$output .= $range[$rand]; +	} + +	return $output;  }  /** @@ -88,13 +97,17 @@ function gen_rand_string($num_chars = 8)  */  function gen_rand_string_friendly($num_chars = 8)  { -	$rand_str = bin2hex(random_bytes($num_chars + 1)); +	$range = array_merge(range('A', 'N'), range('P', 'Z'), range(1, 9)); +	$size = count($range); -	// Remove Z and Y from the base_convert(), replace 0 with Z and O with Y -	// [a, z] + [0, 9] - {z, y} = [a, z] + [0, 9] - {0, o} = 34 -	$rand_str = str_replace(array('0', 'O'), array('Z', 'Y'), strtoupper(base_convert($rand_str, 16, 34))); +	$output = ''; +	for ($i = 0; $i < $num_chars; $i++) +	{ +		$rand = random_int(0, $size-1); +		$output .= $range[$rand]; +	} -	return substr($rand_str, 0, $num_chars); +	return $output;  }  /** @@ -102,7 +115,7 @@ function gen_rand_string_friendly($num_chars = 8)  */  function unique_id()  { -	return bin2hex(random_bytes(8)); +	return gen_rand_string(32);  }  /** diff --git a/phpBB/includes/functions_content.php b/phpBB/includes/functions_content.php index 40d44cfe7b..e124bd46e6 100644 --- a/phpBB/includes/functions_content.php +++ b/phpBB/includes/functions_content.php @@ -1758,3 +1758,47 @@ class bitfield  		$this->data = $this->data | $bitfield->get_blob();  	}  } + +/** + * Formats the quote according to the given BBCode status setting + * + * @param bool 						$bbcode_status The status of the BBCode setting + * @param array 					$quote_attributes The attributes of the quoted post + * @param phpbb\textformatter\utils $text_formatter_utils Text formatter utilities + * @param parse_message 			$message_parser Message parser class + * @param string 					$message_link Link of the original quoted post + */ +function phpbb_format_quote($bbcode_status, $quote_attributes, $text_formatter_utils, $message_parser, $message_link = '') +{ +	if ($bbcode_status) +	{ +		$quote_text = $text_formatter_utils->generate_quote( +			censor_text($message_parser->message), +			$quote_attributes +		); + +		$message_parser->message = $quote_text . "\n\n"; +	} +	else +	{ +		$offset = 0; +		$quote_string = "> "; +		$message = censor_text(trim($message_parser->message)); +		// see if we are nesting. It's easily tricked but should work for one level of nesting +		if (strpos($message, ">") !== false) +		{ +			$offset = 10; +		} +		$message = utf8_wordwrap($message, 75 + $offset, "\n"); + +		$message = $quote_string . $message; +		$message = str_replace("\n", "\n" . $quote_string, $message); + +		$message_parser->message = $quote_attributes['author'] . " " . $user->lang['WROTE'] . ":\n" . $message . "\n"; +	} + +	if ($message_link) +	{ +		$message_parser->message = $message_link . $message_parser->message; +	} +} diff --git a/phpBB/includes/functions_messenger.php b/phpBB/includes/functions_messenger.php index a85a3b67c5..fdd1dc6e32 100644 --- a/phpBB/includes/functions_messenger.php +++ b/phpBB/includes/functions_messenger.php @@ -327,6 +327,7 @@ class messenger  		$subject = $this->subject;  		$message = $this->msg; +		$template  = $this->template;  		/**  		* Event to modify notification message text before parsing  		* @@ -336,13 +337,16 @@ class messenger  		*						and the message without sending it  		* @var	string	subject	The message subject  		* @var	string	message	The message text +		* @var	\phpbb\template\template	template	Template object  		* @since 3.1.11-RC1 +		* @changed 3.2.4-RC1 Added template  		*/  		$vars = array(  			'method',  			'break',  			'subject',  			'message', +			'template',  		);  		extract($phpbb_dispatcher->trigger_event('core.modify_notification_message', compact($vars)));  		$this->subject = $subject; diff --git a/phpBB/includes/functions_posting.php b/phpBB/includes/functions_posting.php index 78c66ac6b8..73a2e0be0c 100644 --- a/phpBB/includes/functions_posting.php +++ b/phpBB/includes/functions_posting.php @@ -2309,8 +2309,14 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll_ary, &$data  			case 'edit_first_post':  			case 'edit':  			case 'edit_last_post': +				if ($user->data['user_id'] == $poster_id) +				{ +					$phpbb_notifications->update_notifications(array( +						'notification.type.quote', +					), $notification_data); +				} +  				$phpbb_notifications->update_notifications(array( -					'notification.type.quote',  					'notification.type.bookmark',  					'notification.type.topic',  					'notification.type.post', diff --git a/phpBB/includes/functions_user.php b/phpBB/includes/functions_user.php index 245d263720..f4b60d7ad4 100644 --- a/phpBB/includes/functions_user.php +++ b/phpBB/includes/functions_user.php @@ -461,9 +461,11 @@ function user_delete($mode, $user_ids, $retain_username = true)  	* @var	array	user_ids	IDs of the deleted user  	* @var	mixed	retain_username	True if username should be retained  	*				or false if not +	* @var	array	user_rows	Array containing data of the deleted users  	* @since 3.1.0-a1 +	* @changed 3.2.4-RC1 Added user_rows  	*/ -	$vars = array('mode', 'user_ids', 'retain_username'); +	$vars = array('mode', 'user_ids', 'retain_username', 'user_rows');  	extract($phpbb_dispatcher->trigger_event('core.delete_user_before', compact($vars)));  	// Before we begin, we will remove the reports the user issued. @@ -664,7 +666,7 @@ function user_delete($mode, $user_ids, $retain_username = true)  		delete_posts('poster_id', $user_ids);  	} -	$table_ary = array(USERS_TABLE, USER_GROUP_TABLE, TOPICS_WATCH_TABLE, FORUMS_WATCH_TABLE, ACL_USERS_TABLE, TOPICS_TRACK_TABLE, TOPICS_POSTED_TABLE, FORUMS_TRACK_TABLE, PROFILE_FIELDS_DATA_TABLE, MODERATOR_CACHE_TABLE, DRAFTS_TABLE, BOOKMARKS_TABLE, SESSIONS_KEYS_TABLE, PRIVMSGS_FOLDER_TABLE, PRIVMSGS_RULES_TABLE); +	$table_ary = array(USERS_TABLE, USER_GROUP_TABLE, TOPICS_WATCH_TABLE, FORUMS_WATCH_TABLE, ACL_USERS_TABLE, TOPICS_TRACK_TABLE, TOPICS_POSTED_TABLE, FORUMS_TRACK_TABLE, PROFILE_FIELDS_DATA_TABLE, MODERATOR_CACHE_TABLE, DRAFTS_TABLE, BOOKMARKS_TABLE, SESSIONS_KEYS_TABLE, PRIVMSGS_FOLDER_TABLE, PRIVMSGS_RULES_TABLE, $phpbb_container->getParameter('tables.auth_provider_oauth_token_storage'), $phpbb_container->getParameter('tables.auth_provider_oauth_states'), $phpbb_container->getParameter('tables.auth_provider_oauth_account_assoc'));  	// Delete the miscellaneous (non-post) data for the user  	foreach ($table_ary as $table) diff --git a/phpBB/includes/ucp/ucp_main.php b/phpBB/includes/ucp/ucp_main.php index cd75eead1e..f8a80b3324 100644 --- a/phpBB/includes/ucp/ucp_main.php +++ b/phpBB/includes/ucp/ucp_main.php @@ -77,6 +77,22 @@ class ucp_main  				// If the user can't see any forums, he can't read any posts because fid of 0 is invalid  				if (!empty($forum_ary))  				{ +					/** +					 * Modify sql variables before query is processed +					 * +					 * @event core.ucp_main_front_modify_sql +					 * @var string	sql_select	SQL select +					 * @var string  sql_from	SQL from +					 * @var array   forum_ary	Forum array +					 * @since 3.2.4-RC1 +					 */ +					$vars = array( +						'sql_select', +						'sql_from', +						'forum_ary', +					); +					extract($phpbb_dispatcher->trigger_event('core.ucp_main_front_modify_sql', compact($vars))); +  					$sql = "SELECT t.* $sql_select  						FROM $sql_from  						WHERE t.topic_type = " . POST_GLOBAL . ' @@ -144,7 +160,7 @@ class ucp_main  						$folder_img .= '_mine';  					} -					$template->assign_block_vars('topicrow', array( +					$topicrow = array(  						'FORUM_ID'					=> $forum_id,  						'TOPIC_ID'					=> $topic_id,  						'TOPIC_AUTHOR'				=> get_username_string('username', $row['topic_poster'], $row['topic_first_poster_name'], $row['topic_first_poster_colour']), @@ -171,8 +187,30 @@ class ucp_main  						'U_LAST_POST'			=> append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id&p=" . $row['topic_last_post_id']) . '#p' . $row['topic_last_post_id'],  						'U_LAST_POST_AUTHOR'	=> get_username_string('profile', $row['topic_last_poster_id'], $row['topic_last_poster_name'], $row['topic_last_poster_colour']),  						'U_NEWEST_POST'			=> append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id&view=unread") . '#unread', -						'U_VIEW_TOPIC'			=> append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id")) +						'U_VIEW_TOPIC'			=> append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id"),  					); + +					/** +					 * Add template variables to a front topics row. +					 * +					 * @event core.ucp_main_front_modify_template_vars +					 * @var array	topicrow		Array containing the template variables for the row +					 * @var array   row    	        Array containing the subscribed forum row data +					 * @var int     forum_id        Forum ID +					 * @var string  folder_img		Folder image +					 * @var string  folder_alt      Alt text for the folder image +					 * @since 3.2.4-RC1 +					 */ +					$vars = array( +						'topicrow', +						'row', +						'forum_id', +						'folder_img', +						'folder_alt', +					); +					extract($phpbb_dispatcher->trigger_event('core.ucp_main_front_modify_template_vars', compact($vars))); + +					$template->assign_block_vars('topicrow', $topicrow);  				}  				if ($config['load_user_activity']) diff --git a/phpBB/includes/ucp/ucp_pm_compose.php b/phpBB/includes/ucp/ucp_pm_compose.php index bc43b5d1fe..91cd7680ca 100644 --- a/phpBB/includes/ucp/ucp_pm_compose.php +++ b/phpBB/includes/ucp/ucp_pm_compose.php @@ -48,7 +48,6 @@ function compose_pm($id, $mode, $action, $user_folders = array())  	$to_group_id	= $request->variable('g', 0);  	$msg_id			= $request->variable('p', 0);  	$draft_id		= $request->variable('d', 0); -	$lastclick		= $request->variable('lastclick', 0);  	// Reply to all triggered (quote/reply)  	$reply_to_all	= $request->variable('reply_to_all', 0); @@ -80,7 +79,7 @@ function compose_pm($id, $mode, $action, $user_folders = array())  	$group_helper = $phpbb_container->get('group_helper');  	// Was cancel pressed? If so then redirect to the appropriate page -	if ($cancel || ($current_time - $lastclick < 2 && $submit)) +	if ($cancel)  	{  		if ($msg_id)  		{ @@ -957,7 +956,16 @@ function compose_pm($id, $mode, $action, $user_folders = array())  			$post_id = $request->variable('p', 0);  			if ($config['allow_post_links'])  			{ -				$message_link = "[url=" . generate_board_url() . "/viewtopic.$phpEx?p={$post_id}#p{$post_id}]{$user->lang['SUBJECT']}{$user->lang['COLON']} {$message_subject}[/url]\n\n"; +				$message_link = generate_board_url() . "/viewtopic.$phpEx?p={$post_id}#p{$post_id}"; +				$message_link_subject = "{$user->lang['SUBJECT']}{$user->lang['COLON']} {$message_subject}"; +				if ($bbcode_status) +				{ +					$message_link = "[url=" . $message_link . "]" . $message_link_subject . "[/url]\n\n"; +				} +				else +				{ +					$message_link = $message_link . " - " . $message_link_subject . "\n\n"; +				}  			}  			else  			{ @@ -977,11 +985,8 @@ function compose_pm($id, $mode, $action, $user_folders = array())  		{  			$quote_attributes['post_id'] = $post['msg_id'];  		} -		$quote_text = $phpbb_container->get('text_formatter.utils')->generate_quote( -			censor_text($message_parser->message), -			$quote_attributes -		); -		$message_parser->message = $message_link . $quote_text . "\n\n"; + +		phpbb_format_quote($bbcode_status, $quote_attributes, $phpbb_container->get('text_formatter.utils'), $message_parser, $message_link);  	}  	if (($action == 'reply' || $action == 'quote' || $action == 'quotepost') && !$preview && !$refresh) @@ -1177,8 +1182,7 @@ function compose_pm($id, $mode, $action, $user_folders = array())  		break;  	} -	$s_hidden_fields = '<input type="hidden" name="lastclick" value="' . $current_time . '" />'; -	$s_hidden_fields .= (isset($check_value)) ? '<input type="hidden" name="status_switch" value="' . $check_value . '" />' : ''; +	$s_hidden_fields = (isset($check_value)) ? '<input type="hidden" name="status_switch" value="' . $check_value . '" />' : '';  	$s_hidden_fields .= ($draft_id || isset($_REQUEST['draft_loaded'])) ? '<input type="hidden" name="draft_loaded" value="' . ((isset($_REQUEST['draft_loaded'])) ? $request->variable('draft_loaded', 0) : $draft_id) . '" />' : '';  	$form_enctype = (@ini_get('file_uploads') == '0' || strtolower(@ini_get('file_uploads')) == 'off' || !$config['allow_pm_attach'] || !$auth->acl_get('u_pm_attach')) ? '' : ' enctype="multipart/form-data"'; | 
