diff options
Diffstat (limited to 'phpBB/includes')
| -rw-r--r-- | phpBB/includes/mcp/mcp_post.php | 114 | 
1 files changed, 103 insertions, 11 deletions
| diff --git a/phpBB/includes/mcp/mcp_post.php b/phpBB/includes/mcp/mcp_post.php index 2dcfcd608b..b5f2bf4f02 100644 --- a/phpBB/includes/mcp/mcp_post.php +++ b/phpBB/includes/mcp/mcp_post.php @@ -24,8 +24,8 @@ if (!defined('IN_PHPBB'))  */  function mcp_post_details($id, $mode, $action)  { -	global $phpEx, $phpbb_root_path, $config; -	global $template, $db, $user, $auth, $cache; +	global $phpEx, $phpbb_root_path, $config, $request; +	global $template, $db, $user, $auth, $cache, $phpbb_container;  	global $phpbb_dispatcher;  	$user->add_lang('posting'); @@ -355,7 +355,11 @@ function mcp_post_details($id, $mode, $action)  	// Get IP  	if ($auth->acl_get('m_info', $post_info['forum_id']))  	{ -		$rdns_ip_num = request_var('rdns', ''); +		/** @var \phpbb\pagination $pagination */ +		$pagination = $phpbb_container->get('pagination'); + +		$rdns_ip_num = $request->variable('rdns', ''); +		$start_users = $request->variable('start_users', 0);  		if ($rdns_ip_num != 'all')  		{ @@ -364,23 +368,46 @@ function mcp_post_details($id, $mode, $action)  			);  		} +		$num_users = false; +		if ($start_users) +		{ +			$num_users = phpbb_get_num_posters_for_ip($db, $post_info['poster_ip']); +			$start_users = $pagination->validate_start($start_users, $config['posts_per_page'], $num_users); +		} +  		// Get other users who've posted under this IP  		$sql = 'SELECT poster_id, COUNT(poster_id) as postings  			FROM ' . POSTS_TABLE . "  			WHERE poster_ip = '" . $db->sql_escape($post_info['poster_ip']) . "' +				AND poster_id <> " . (int) $post_info['poster_id'] . "  			GROUP BY poster_id -			ORDER BY postings DESC"; -		$result = $db->sql_query($sql); +			ORDER BY postings DESC, poster_id ASC"; +		$result = $db->sql_query_limit($sql, $config['posts_per_page'], $start_users); +		$page_users = 0;  		while ($row = $db->sql_fetchrow($result))  		{ -			// Fill the user select list with users who have posted under this IP -			if ($row['poster_id'] != $post_info['poster_id']) +			$page_users++; +			$users_ary[$row['poster_id']] = $row; +		} +		$db->sql_freeresult($result); + +		if ($page_users == $config['posts_per_page'] || $start_users) +		{ +			if ($num_users === false)  			{ -				$users_ary[$row['poster_id']] = $row; +				$num_users = phpbb_get_num_posters_for_ip($db, $post_info['poster_ip']);  			} + +			$pagination->generate_template_pagination( +				$url . '&i=main&mode=post_details', +				'pagination', +				'start_users', +				$num_users, +				$config['posts_per_page'], +				$start_users +			);  		} -		$db->sql_freeresult($result);  		if (sizeof($users_ary))  		{ @@ -415,16 +442,26 @@ function mcp_post_details($id, $mode, $action)  		// A compound index on poster_id, poster_ip (posts table) would help speed up this query a lot,  		// but the extra size is only valuable if there are persons having more than a thousands posts.  		// This is better left to the really really big forums. +		$start_ips = $request->variable('start_ips', 0); + +		$num_ips = false; +		if ($start_ips) +		{ +			$num_ips = phpbb_get_num_ips_for_poster($db, $post_info['poster_id']); +			$start_ips = $pagination->validate_start($start_ips, $config['posts_per_page'], $num_ips); +		}  		$sql = 'SELECT poster_ip, COUNT(poster_ip) AS postings  			FROM ' . POSTS_TABLE . '  			WHERE poster_id = ' . $post_info['poster_id'] . "  			GROUP BY poster_ip -			ORDER BY postings DESC"; -		$result = $db->sql_query($sql); +			ORDER BY postings DESC, poster_ip ASC"; +		$result = $db->sql_query_limit($sql, $config['posts_per_page'], $start_ips); +		$page_ips = 0;  		while ($row = $db->sql_fetchrow($result))  		{ +			$page_ips++;  			$hostname = (($rdns_ip_num == $row['poster_ip'] || $rdns_ip_num == 'all') && $row['poster_ip']) ? @gethostbyaddr($row['poster_ip']) : '';  			$template->assign_block_vars('iprow', array( @@ -439,6 +476,23 @@ function mcp_post_details($id, $mode, $action)  		}  		$db->sql_freeresult($result); +		if ($page_ips == $config['posts_per_page'] || $start_ips) +		{ +			if ($num_ips === false) +			{ +				$num_ips = phpbb_get_num_ips_for_poster($db, $post_info['poster_id']); +			} + +			$pagination->generate_template_pagination( +				$url . '&i=main&mode=post_details', +				'pagination_ips', +				'start_ips', +				$num_ips, +				$config['posts_per_page'], +				$start_ips +			); +		} +  		$user_select = '';  		if (sizeof($usernames_ary)) @@ -457,6 +511,44 @@ function mcp_post_details($id, $mode, $action)  }  /** + * Get the number of posters for a given ip + * + * @param \phpbb\db\driver\driver_interface $db DBAL interface + * @param string $poster_ip IP + * @return int Number of posters + */ +function phpbb_get_num_posters_for_ip(\phpbb\db\driver\driver_interface $db, $poster_ip) +{ +	$sql = 'SELECT COUNT(DISTINCT poster_id) as num_users +		FROM ' . POSTS_TABLE . " +		WHERE poster_ip = '" . $db->sql_escape($poster_ip) . "'"; +	$result = $db->sql_query($sql); +	$num_users = (int) $db->sql_fetchfield('num_users'); +	$db->sql_freeresult($result); + +	return $num_users; +} + +/** + * Get the number of ips for a given poster + * + * @param \phpbb\db\driver\driver_interface $db + * @param int $poster_id Poster user ID + * @return int Number of IPs for given poster + */ +function phpbb_get_num_ips_for_poster(\phpbb\db\driver\driver_interface $db, $poster_id) +{ +	$sql = 'SELECT COUNT(DISTINCT poster_ip) as num_ips +		FROM ' . POSTS_TABLE . ' +		WHERE poster_id = ' . (int) $poster_id; +	$result = $db->sql_query($sql); +	$num_ips = (int) $db->sql_fetchfield('num_ips'); +	$db->sql_freeresult($result); + +	return $num_ips; +} + +/**  * Change a post's poster  */  function change_poster(&$post_info, $userdata) | 
