diff options
Diffstat (limited to 'phpBB/mcp.php')
| -rw-r--r-- | phpBB/mcp.php | 87 | 
1 files changed, 44 insertions, 43 deletions
| diff --git a/phpBB/mcp.php b/phpBB/mcp.php index 48cd68500f..24a7bebeba 100644 --- a/phpBB/mcp.php +++ b/phpBB/mcp.php @@ -2,9 +2,8 @@  /**  *  * @package mcp -* @version $Id$  * @copyright (c) 2005 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ @@ -31,15 +30,8 @@ $template->assign_var('S_IN_MCP', true);  // Basic parameter data  $id = request_var('i', ''); -if (isset($_REQUEST['mode']) && is_array($_REQUEST['mode'])) -{ -	$mode = request_var('mode', array('')); -	list($mode, ) = each($mode); -} -else -{ -	$mode = request_var('mode', ''); -} +$mode = request_var('mode', array('')); +$mode = sizeof($mode) ? array_shift($mode) : request_var('mode', '');  // Only Moderators can go beyond this point  if (!$user->data['is_registered']) @@ -57,7 +49,7 @@ $action = request_var('action', '');  $action_ary = request_var('action', array('' => 0));  $forum_action = request_var('forum_action', ''); -if ($forum_action !== '' && !empty($_POST['sort'])) +if ($forum_action !== '' && $request->variable('sort', false, false, \phpbb\request\request_interface::POST))  {  	$action = $forum_action;  } @@ -92,7 +84,7 @@ if ($post_id)  	$db->sql_freeresult($result);  	$topic_id = (int) $row['topic_id']; -	$forum_id = (int) ($row['forum_id']) ? $row['forum_id'] : $forum_id; +	$forum_id = (int) $row['forum_id'];  }  else if ($topic_id)  { @@ -166,6 +158,7 @@ if ($quickmod)  		case 'move':  		case 'delete_post':  		case 'delete_topic': +		case 'restore_topic':  			$module->load('mcp', 'main', 'quickmod');  			return;  		break; @@ -174,7 +167,7 @@ if ($quickmod)  			// Reset start parameter if we jumped from the quickmod dropdown  			if (request_var('start', 0))  			{ -				$_REQUEST['start'] = 0; +				$request->overwrite('start', 0);  			}  			$module->set_active('logs', 'topic_logs'); @@ -190,7 +183,26 @@ if ($quickmod)  		break;  		default: -			trigger_error("$action not allowed as quickmod", E_USER_ERROR); +			// If needed, the flag can be set to true within event listener +			// to indicate that the action was handled properly +			// and to pass by the trigger_error() call below +			$is_valid_action = false; + +			/** +			* This event allows you to add custom quickmod options +			* +			* @event core.modify_quickmod_options +			* @var	object	module			Instance of module system class +			* @var	string	action			Quickmod option +			* @var	bool	is_valid_action	Flag indicating if the action was handled properly +			* @since 3.1.0-a4 +			*/ +			extract($phpbb_dispatcher->trigger_event('core.modify_quickmod_options', compact(array('module', 'action', 'is_valid_action')))); + +			if (!$is_valid_action) +			{ +				trigger_error($user->lang('QUICKMOD_ACTION_NOT_ALLOWED', $action), E_USER_ERROR); +			}  		break;  	}  } @@ -207,7 +219,7 @@ if (!$post_id)  	$module->set_display('warn', 'warn_post', false);  } -if ($mode == '' || $mode == 'unapproved_topics' || $mode == 'unapproved_posts') +if ($mode == '' || $mode == 'unapproved_topics' || $mode == 'unapproved_posts' || $mode == 'deleted_topics' || $mode == 'deleted_posts')  {  	$module->set_display('queue', 'approve_details', false);  } @@ -407,12 +419,6 @@ function get_topic_data($topic_ids, $acl_list = false, $read_tracking = false)  		while ($row = $db->sql_fetchrow($result))  		{ -			if (!$row['forum_id']) -			{ -				// Global Announcement? -				$row['forum_id'] = request_var('f', 0); -			} -  			$rowset[$row['topic_id']] = $row;  			if ($acl_list && !$auth->acl_gets($acl_list, $row['forum_id'])) @@ -492,18 +498,12 @@ function get_post_data($post_ids, $acl_list = false, $read_tracking = false)  	while ($row = $db->sql_fetchrow($result))  	{ -		if (!$row['forum_id']) -		{ -			// Global Announcement? -			$row['forum_id'] = request_var('f', 0); -		} -  		if ($acl_list && !$auth->acl_gets($acl_list, $row['forum_id']))  		{  			continue;  		} -		if (!$row['post_approved'] && !$auth->acl_get('m_approve', $row['forum_id'])) +		if ($row['post_visibility'] != ITEM_APPROVED && !$auth->acl_get('m_approve', $row['forum_id']))  		{  			// Moderators without the permission to approve post should at least not see them. ;)  			continue; @@ -521,7 +521,7 @@ function get_post_data($post_ids, $acl_list = false, $read_tracking = false)  */  function get_forum_data($forum_id, $acl_list = 'f_list', $read_tracking = false)  { -	global $auth, $db, $user, $config; +	global $auth, $db, $user, $config, $phpbb_container;  	$rowset = array(); @@ -551,6 +551,8 @@ function get_forum_data($forum_id, $acl_list = 'f_list', $read_tracking = false)  		WHERE " . $db->sql_in_set('f.forum_id', $forum_id);  	$result = $db->sql_query($sql); +	$phpbb_content_visibility = $phpbb_container->get('content.visibility'); +  	while ($row = $db->sql_fetchrow($result))  	{  		if ($acl_list && !$auth->acl_gets($acl_list, $row['forum_id'])) @@ -558,10 +560,7 @@ function get_forum_data($forum_id, $acl_list = 'f_list', $read_tracking = false)  			continue;  		} -		if ($auth->acl_get('m_approve', $row['forum_id'])) -		{ -			$row['forum_topics'] = $row['forum_topics_real']; -		} +		$row['forum_topics_approved'] = $phpbb_content_visibility->get_count('forum_topics', $row, $row['forum_id']);  		$rowset[$row['forum_id']] = $row;  	} @@ -639,7 +638,7 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  			if (!$auth->acl_get('m_approve', $forum_id))  			{ -				$sql .= 'AND topic_approved = 1'; +				$sql .= 'AND topic_visibility = ' . ITEM_APPROVED;  			}  		break; @@ -655,11 +654,13 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  			if (!$auth->acl_get('m_approve', $forum_id))  			{ -				$sql .= 'AND post_approved = 1'; +				$sql .= 'AND post_visibility = ' . ITEM_APPROVED;  			}  		break;  		case 'unapproved_posts': +		case 'deleted_posts': +			$visibility_const = ($mode == 'unapproved_posts') ? ITEM_UNAPPROVED : ITEM_DELETED;  			$type = 'posts';  			$default_key = 't';  			$default_dir = 'd'; @@ -668,9 +669,9 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  			$sql = 'SELECT COUNT(p.post_id) AS total  				FROM ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . " t  				$where_sql " . $db->sql_in_set('p.forum_id', ($forum_id) ? array($forum_id) : array_intersect(get_forum_list('f_read'), get_forum_list('m_approve'))) . ' -					AND p.post_approved = 0 +					AND p.post_visibility = ' . $visibility_const . '  					AND t.topic_id = p.topic_id -					AND t.topic_first_post_id <> p.post_id'; +					AND t.topic_visibility <> p.post_visibility';  			if ($min_time)  			{ @@ -679,6 +680,8 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  		break;  		case 'unapproved_topics': +		case 'deleted_topics': +			$visibility_const = ($mode == 'unapproved_topics') ? ITEM_UNAPPROVED : ITEM_DELETED;  			$type = 'topics';  			$default_key = 't';  			$default_dir = 'd'; @@ -686,7 +689,7 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  			$sql = 'SELECT COUNT(topic_id) AS total  				FROM ' . TOPICS_TABLE . "  				$where_sql " . $db->sql_in_set('forum_id', ($forum_id) ? array($forum_id) : array_intersect(get_forum_list('f_read'), get_forum_list('m_approve'))) . ' -					AND topic_approved = 0'; +					AND topic_visibility = ' . $visibility_const;  			if ($min_time)  			{ @@ -768,7 +771,7 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  			$limit_days = array(0 => $user->lang['ALL_TOPICS'], 1 => $user->lang['1_DAY'], 7 => $user->lang['7_DAYS'], 14 => $user->lang['2_WEEKS'], 30 => $user->lang['1_MONTH'], 90 => $user->lang['3_MONTHS'], 180 => $user->lang['6_MONTHS'], 365 => $user->lang['1_YEAR']);  			$sort_by_text = array('a' => $user->lang['AUTHOR'], 't' => $user->lang['POST_TIME'], 'tt' => $user->lang['TOPIC_TIME'], 'r' => $user->lang['REPLIES'], 's' => $user->lang['SUBJECT'], 'v' => $user->lang['VIEWS']); -			$sort_by_sql = array('a' => 't.topic_first_poster_name', 't' => 't.topic_last_post_time', 'tt' => 't.topic_time', 'r' => (($auth->acl_get('m_approve', $forum_id)) ? 't.topic_replies_real' : 't.topic_replies'), 's' => 't.topic_title', 'v' => 't.topic_views'); +			$sort_by_sql = array('a' => 't.topic_first_poster_name', 't' => 't.topic_last_post_time', 'tt' => 't.topic_time', 'r' => (($auth->acl_get('m_approve', $forum_id)) ? 't.topic_posts_approved + t.topic_posts_unapproved + t.topic_posts_softdeleted' : 't.topic_posts_approved'), 's' => 't.topic_title', 'v' => 't.topic_views');  			$limit_time_sql = ($min_time) ? "AND t.topic_last_post_time >= $min_time" : '';  		break; @@ -816,7 +819,7 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,  		'S_SELECT_SORT_DAYS'	=> $s_limit_days)  	); -	if (($sort_days && $mode != 'viewlogs') || in_array($mode, array('reports', 'unapproved_topics', 'unapproved_posts')) || $where_sql != 'WHERE') +	if (($sort_days && $mode != 'viewlogs') || in_array($mode, array('reports', 'unapproved_topics', 'unapproved_posts', 'deleted_topics', 'deleted_posts')) || $where_sql != 'WHERE')  	{  		$result = $db->sql_query($sql);  		$total = (int) $db->sql_fetchfield('total'); @@ -911,5 +914,3 @@ function check_ids(&$ids, $table, $sql_id, $acl_list = false, $single_forum = fa  	return ($single_forum === false) ? true : (int) $forum_id;  } - -?>
\ No newline at end of file | 
