diff options
Diffstat (limited to 'phpBB/includes/functions_admin.php')
| -rw-r--r-- | phpBB/includes/functions_admin.php | 465 | 
1 files changed, 116 insertions, 349 deletions
| diff --git a/phpBB/includes/functions_admin.php b/phpBB/includes/functions_admin.php index a9d1db24a5..72855af5f8 100644 --- a/phpBB/includes/functions_admin.php +++ b/phpBB/includes/functions_admin.php @@ -2,9 +2,8 @@  /**  *  * @package acp -* @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  *  */ @@ -619,7 +618,7 @@ function move_posts($post_ids, $topic_id, $auto_sync = true)  */  function delete_topics($where_type, $where_ids, $auto_sync = true, $post_count_sync = true, $call_delete_posts = true)  { -	global $db, $config; +	global $db, $config, $phpbb_container;  	$approved_topics = 0;  	$forum_ids = $topic_ids = array(); @@ -716,6 +715,14 @@ function delete_topics($where_type, $where_ids, $auto_sync = true, $post_count_s  		set_config_count('num_topics', $approved_topics * (-1), true);  	} +	$phpbb_notifications = $phpbb_container->get('notification_manager'); + +	$phpbb_notifications->delete_notifications(array( +		'topic', +		'approve_topic', +		'topic_in_queue', +	), $topic_ids); +  	return $return;  } @@ -724,7 +731,7 @@ function delete_topics($where_type, $where_ids, $auto_sync = true, $post_count_s  */  function delete_posts($where_type, $where_ids, $auto_sync = true, $posted_sync = true, $post_count_sync = true, $call_delete_topics = true)  { -	global $db, $config, $phpbb_root_path, $phpEx; +	global $db, $config, $phpbb_root_path, $phpEx, $auth, $user, $phpbb_container;  	if ($where_type === 'range')  	{ @@ -848,17 +855,15 @@ function delete_posts($where_type, $where_ids, $auto_sync = true, $posted_sync =  	}  	// Remove the message from the search index -	$search_type = basename($config['search_type']); +	$search_type = $config['search_type']; -	if (!file_exists($phpbb_root_path . 'includes/search/' . $search_type . '.' . $phpEx)) +	if (!class_exists($search_type))  	{  		trigger_error('NO_SUCH_SEARCH_MODULE');  	} -	include_once("{$phpbb_root_path}includes/search/$search_type.$phpEx"); -  	$error = false; -	$search = new $search_type($error); +	$search = new $search_type($error, $phpbb_root_path, $phpEx, $auth, $config, $db, $user);  	if ($error)  	{ @@ -895,6 +900,16 @@ function delete_posts($where_type, $where_ids, $auto_sync = true, $posted_sync =  		delete_topics('topic_id', $remove_topics, $auto_sync, $post_count_sync, false);  	} +	$phpbb_notifications = $phpbb_container->get('notification_manager'); + +	$phpbb_notifications->delete_notifications(array( +		'quote', +		'bookmark', +		'post', +		'approve_post', +		'post_in_queue', +	), $post_ids); +  	return sizeof($post_ids);  } @@ -2208,6 +2223,7 @@ function prune($forum_id, $prune_mode, $prune_date, $prune_flags = 0, $auto_sync  	if (!($prune_flags & FORUM_FLAG_PRUNE_ANNOUNCE))  	{  		$sql_and .= ' AND topic_type <> ' . POST_ANNOUNCE; +		$sql_and .= ' AND topic_type <> ' . POST_GLOBAL;  	}  	if (!($prune_flags & FORUM_FLAG_PRUNE_STICKY)) @@ -2294,28 +2310,17 @@ function auto_prune($forum_id, $prune_mode, $prune_flags, $prune_days, $prune_fr  }  /** -* remove_comments will strip the sql comment lines out of an uploaded sql file -* specifically for mssql and postgres type files in the install.... +* Cache moderators. Called whenever permissions are changed +* via admin_permissions. Changes of usernames and group names +* must be carried through for the moderators table.  * -* @deprecated		Use phpbb_remove_comments() instead. +* @param phpbb_db_driver $db Database connection +* @param phpbb_cache_driver_interface Cache driver +* @param phpbb_auth $auth Authentication object +* @return null  */ -function remove_comments(&$output) -{ -	// Remove /* */ comments (http://ostermiller.org/findcomment.html) -	$output = preg_replace('#/\*(.|[\r\n])*?\*/#', "\n", $output); - -	// Return by reference and value. -	return $output; -} - -/** -* Cache moderators, called whenever permissions are changed via admin_permissions. Changes of username -* and group names must be carried through for the moderators table -*/ -function cache_moderators() +function phpbb_cache_moderators($db, $cache, $auth)  { -	global $db, $cache, $auth, $phpbb_root_path, $phpEx; -  	// Remove cached sql results  	$cache->destroy('sql', MODERATOR_CACHE_TABLE); @@ -2345,7 +2350,7 @@ function cache_moderators()  		$ug_id_ary = array_keys($hold_ary);  		// Remove users who have group memberships with DENY moderator permissions -		$sql = $db->sql_build_query('SELECT', array( +		$sql_ary_deny = array(  			'SELECT'	=> 'a.forum_id, ug.user_id, g.group_id',  			'FROM'		=> array( @@ -2358,8 +2363,8 @@ function cache_moderators()  			'LEFT_JOIN'	=> array(  				array(  					'FROM'	=> array(ACL_ROLES_DATA_TABLE => 'r'), -					'ON'	=> 'a.auth_role_id = r.role_id' -				) +					'ON'	=> 'a.auth_role_id = r.role_id', +				),  			),  			'WHERE'		=> '(o.auth_option_id = a.auth_option_id OR o.auth_option_id = r.auth_option_id) @@ -2371,7 +2376,8 @@ function cache_moderators()  				AND ' . $db->sql_in_set('ug.user_id', $ug_id_ary) . "  				AND ug.user_pending = 0  				AND o.auth_option " . $db->sql_like_expression('m_' . $db->any_char), -		)); +		); +		$sql = $db->sql_build_query('SELECT', $sql_ary_deny);  		$result = $db->sql_query($sql);  		while ($row = $db->sql_fetchrow($result)) @@ -2485,303 +2491,60 @@ function cache_moderators()  }  /** +* Cache moderators. Called whenever permissions are changed +* via admin_permissions. Changes of usernames and group names +* must be carried through for the moderators table. +* +* @deprecated 3.1 +* @return null +*/ +function cache_moderators() +{ +	global $db, $cache, $auth; +	return phpbb_cache_moderators($db, $cache, $auth); +} + +/**  * View log -* If $log_count is set to false, we will skip counting all entries in the database. +* +* @param	string	$mode			The mode defines which log_type is used and from which log the entry is retrieved +* @param	array	&$log			The result array with the logs +* @param	mixed	&$log_count		If $log_count is set to false, we will skip counting all entries in the database. +*									Otherwise an integer with the number of total matching entries is returned. +* @param	int		$limit			Limit the number of entries that are returned +* @param	int		$offset			Offset when fetching the log entries, f.e. when paginating +* @param	mixed	$forum_id		Restrict the log entries to the given forum_id (can also be an array of forum_ids) +* @param	int		$topic_id		Restrict the log entries to the given topic_id +* @param	int		$user_id		Restrict the log entries to the given user_id +* @param	int		$log_time		Only get log entries newer than the given timestamp +* @param	string	$sort_by		SQL order option, e.g. 'l.log_time DESC' +* @param	string	$keywords		Will only return log entries that have the keywords in log_operation or log_data +* +* @return	int				Returns the offset of the last valid page, if the specified offset was invalid (too high)  */  function view_log($mode, &$log, &$log_count, $limit = 0, $offset = 0, $forum_id = 0, $topic_id = 0, $user_id = 0, $limit_days = 0, $sort_by = 'l.log_time DESC', $keywords = '')  { -	global $db, $user, $auth, $phpEx, $phpbb_root_path, $phpbb_admin_path; +	global $phpbb_log; -	$topic_id_list = $reportee_id_list = $is_auth = $is_mod = array(); +	$count_logs = ($log_count !== false); -	$profile_url = (defined('IN_ADMIN')) ? append_sid("{$phpbb_admin_path}index.$phpEx", 'i=users&mode=overview') : append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile'); - -	switch ($mode) -	{ -		case 'admin': -			$log_type = LOG_ADMIN; -			$sql_forum = ''; -		break; - -		case 'mod': -			$log_type = LOG_MOD; -			$sql_forum = ''; - -			if ($topic_id) -			{ -				$sql_forum = 'AND l.topic_id = ' . (int) $topic_id; -			} -			else if (is_array($forum_id)) -			{ -				$sql_forum = 'AND ' . $db->sql_in_set('l.forum_id', array_map('intval', $forum_id)); -			} -			else if ($forum_id) -			{ -				$sql_forum = 'AND l.forum_id = ' . (int) $forum_id; -			} -		break; - -		case 'user': -			$log_type = LOG_USERS; -			$sql_forum = 'AND l.reportee_id = ' . (int) $user_id; -		break; - -		case 'users': -			$log_type = LOG_USERS; -			$sql_forum = ''; -		break; - -		case 'critical': -			$log_type = LOG_CRITICAL; -			$sql_forum = ''; -		break; - -		default: -			return; -	} - -	// Use no preg_quote for $keywords because this would lead to sole backslashes being added -	// We also use an OR connection here for spaces and the | string. Currently, regex is not supported for searching (but may come later). -	$keywords = preg_split('#[\s|]+#u', utf8_strtolower($keywords), 0, PREG_SPLIT_NO_EMPTY); -	$sql_keywords = ''; - -	if (!empty($keywords)) -	{ -		$keywords_pattern = array(); - -		// Build pattern and keywords... -		for ($i = 0, $num_keywords = sizeof($keywords); $i < $num_keywords; $i++) -		{ -			$keywords_pattern[] = preg_quote($keywords[$i], '#'); -			$keywords[$i] = $db->sql_like_expression($db->any_char . $keywords[$i] . $db->any_char); -		} - -		$keywords_pattern = '#' . implode('|', $keywords_pattern) . '#ui'; - -		$operations = array(); -		foreach ($user->lang as $key => $value) -		{ -			if (substr($key, 0, 4) == 'LOG_' && preg_match($keywords_pattern, $value)) -			{ -				$operations[] = $key; -			} -		} - -		$sql_keywords = 'AND ('; -		if (!empty($operations)) -		{ -			$sql_keywords .= $db->sql_in_set('l.log_operation', $operations) . ' OR '; -		} -		$sql_lower = $db->sql_lower_text('l.log_data'); -		$sql_keywords .= "$sql_lower " . implode(" OR $sql_lower ", $keywords) . ')'; -	} - -	if ($log_count !== false) -	{ -		$sql = 'SELECT COUNT(l.log_id) AS total_entries -			FROM ' . LOG_TABLE . ' l, ' . USERS_TABLE . " u -			WHERE l.log_type = $log_type -				AND l.user_id = u.user_id -				AND l.log_time >= $limit_days -				$sql_keywords -				$sql_forum"; -		$result = $db->sql_query($sql); -		$log_count = (int) $db->sql_fetchfield('total_entries'); -		$db->sql_freeresult($result); -	} - -	// $log_count may be false here if false was passed in for it, -	// because in this case we did not run the COUNT() query above. -	// If we ran the COUNT() query and it returned zero rows, return; -	// otherwise query for logs below. -	if ($log_count === 0) -	{ -		// Save the queries, because there are no logs to display -		return 0; -	} - -	if ($offset >= $log_count) -	{ -		$offset = ($offset - $limit < 0) ? 0 : $offset - $limit; -	} - -	$sql = "SELECT l.*, u.username, u.username_clean, u.user_colour -		FROM " . LOG_TABLE . " l, " . USERS_TABLE . " u -		WHERE l.log_type = $log_type -			AND u.user_id = l.user_id -			" . (($limit_days) ? "AND l.log_time >= $limit_days" : '') . " -			$sql_keywords -			$sql_forum -		ORDER BY $sort_by"; -	$result = $db->sql_query_limit($sql, $limit, $offset); - -	$i = 0; -	$log = array(); -	while ($row = $db->sql_fetchrow($result)) -	{ -		if ($row['topic_id']) -		{ -			$topic_id_list[] = $row['topic_id']; -		} - -		if ($row['reportee_id']) -		{ -			$reportee_id_list[] = $row['reportee_id']; -		} - -		$log[$i] = array( -			'id'				=> $row['log_id'], - -			'reportee_id'			=> $row['reportee_id'], -			'reportee_username'		=> '', -			'reportee_username_full'=> '', - -			'user_id'			=> $row['user_id'], -			'username'			=> $row['username'], -			'username_full'		=> get_username_string('full', $row['user_id'], $row['username'], $row['user_colour'], false, $profile_url), - -			'ip'				=> $row['log_ip'], -			'time'				=> $row['log_time'], -			'forum_id'			=> $row['forum_id'], -			'topic_id'			=> $row['topic_id'], - -			'viewforum'			=> ($row['forum_id'] && $auth->acl_get('f_read', $row['forum_id'])) ? append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $row['forum_id']) : false, -			'action'			=> (isset($user->lang[$row['log_operation']])) ? $user->lang[$row['log_operation']] : '{' . ucfirst(str_replace('_', ' ', $row['log_operation'])) . '}', -		); - -		if (!empty($row['log_data'])) -		{ -			$log_data_ary = @unserialize($row['log_data']); -			$log_data_ary = ($log_data_ary === false) ? array() : $log_data_ary; +	$log = $phpbb_log->get_logs($mode, $count_logs, $limit, $offset, $forum_id, $topic_id, $user_id, $limit_days, $sort_by, $keywords); +	$log_count = $phpbb_log->get_log_count(); -			if (isset($user->lang[$row['log_operation']])) -			{ -				// Check if there are more occurrences of % than arguments, if there are we fill out the arguments array -				// It doesn't matter if we add more arguments than placeholders -				if ((substr_count($log[$i]['action'], '%') - sizeof($log_data_ary)) > 0) -				{ -					$log_data_ary = array_merge($log_data_ary, array_fill(0, substr_count($log[$i]['action'], '%') - sizeof($log_data_ary), '')); -				} - -				$log[$i]['action'] = vsprintf($log[$i]['action'], $log_data_ary); - -				// If within the admin panel we do not censor text out -				if (defined('IN_ADMIN')) -				{ -					$log[$i]['action'] = bbcode_nl2br($log[$i]['action']); -				} -				else -				{ -					$log[$i]['action'] = bbcode_nl2br(censor_text($log[$i]['action'])); -				} -			} -			else if (!empty($log_data_ary)) -			{ -				$log[$i]['action'] .= '<br />' . implode('', $log_data_ary); -			} - -			/* Apply make_clickable... has to be seen if it is for good. :/ -			// Seems to be not for the moment, reconsider later... -			$log[$i]['action'] = make_clickable($log[$i]['action']); -			*/ -		} - -		$i++; -	} -	$db->sql_freeresult($result); - -	if (sizeof($topic_id_list)) -	{ -		$topic_id_list = array_unique($topic_id_list); - -		// This query is not really needed if move_topics() updates the forum_id field, -		// although it's also used to determine if the topic still exists in the database -		$sql = 'SELECT topic_id, forum_id -			FROM ' . TOPICS_TABLE . ' -			WHERE ' . $db->sql_in_set('topic_id', array_map('intval', $topic_id_list)); -		$result = $db->sql_query($sql); - -		$default_forum_id = 0; - -		while ($row = $db->sql_fetchrow($result)) -		{ -			if (!$row['forum_id']) -			{ -				if ($auth->acl_getf_global('f_read')) -				{ -					if (!$default_forum_id) -					{ -						$sql = 'SELECT forum_id -							FROM ' . FORUMS_TABLE . ' -							WHERE forum_type = ' . FORUM_POST; -						$f_result = $db->sql_query_limit($sql, 1); -						$default_forum_id = (int) $db->sql_fetchfield('forum_id', false, $f_result); -						$db->sql_freeresult($f_result); -					} - -					$is_auth[$row['topic_id']] = $default_forum_id; -				} -			} -			else -			{ -				if ($auth->acl_get('f_read', $row['forum_id'])) -				{ -					$is_auth[$row['topic_id']] = $row['forum_id']; -				} -			} - -			if ($auth->acl_gets('a_', 'm_', $row['forum_id'])) -			{ -				$is_mod[$row['topic_id']] = $row['forum_id']; -			} -		} -		$db->sql_freeresult($result); - -		foreach ($log as $key => $row) -		{ -			$log[$key]['viewtopic'] = (isset($is_auth[$row['topic_id']])) ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $is_auth[$row['topic_id']] . '&t=' . $row['topic_id']) : false; -			$log[$key]['viewlogs'] = (isset($is_mod[$row['topic_id']])) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=logs&mode=topic_logs&t=' . $row['topic_id'], true, $user->session_id) : false; -		} -	} - -	if (sizeof($reportee_id_list)) -	{ -		$reportee_id_list = array_unique($reportee_id_list); -		$reportee_names_list = array(); - -		$sql = 'SELECT user_id, username, user_colour -			FROM ' . USERS_TABLE . ' -			WHERE ' . $db->sql_in_set('user_id', $reportee_id_list); -		$result = $db->sql_query($sql); - -		while ($row = $db->sql_fetchrow($result)) -		{ -			$reportee_names_list[$row['user_id']] = $row; -		} -		$db->sql_freeresult($result); - -		foreach ($log as $key => $row) -		{ -			if (!isset($reportee_names_list[$row['reportee_id']])) -			{ -				continue; -			} - -			$log[$key]['reportee_username'] = $reportee_names_list[$row['reportee_id']]['username']; -			$log[$key]['reportee_username_full'] = get_username_string('full', $row['reportee_id'], $reportee_names_list[$row['reportee_id']]['username'], $reportee_names_list[$row['reportee_id']]['user_colour'], false, $profile_url); -		} -	} - -	return $offset; +	return $phpbb_log->get_valid_offset();  }  /** -* Update foes - remove moderators and administrators from foe lists... +* Removes moderators and administrators from foe lists. +* +* @param phpbb_db_driver $db Database connection +* @param phpbb_auth $auth Authentication object +* @param array|bool $group_id If an array, remove all members of this group from foe lists, or false to ignore +* @param array|bool $user_id If an array, remove this user from foe lists, or false to ignore +* @return null  */ -function update_foes($group_id = false, $user_id = false) +function phpbb_update_foes($db, $auth, $group_id = false, $user_id = false)  { -	global $db, $auth; -  	// update foes for some user  	if (is_array($user_id) && sizeof($user_id))  	{ @@ -2796,18 +2559,18 @@ function update_foes($group_id = false, $user_id = false)  	if (is_array($group_id) && sizeof($group_id))  	{  		// Grab group settings... -		$sql = $db->sql_build_query('SELECT', array( +		$sql_ary = array(  			'SELECT'	=> 'a.group_id',  			'FROM'		=> array(  				ACL_OPTIONS_TABLE	=> 'ao', -				ACL_GROUPS_TABLE	=> 'a' +				ACL_GROUPS_TABLE	=> 'a',  			),  			'LEFT_JOIN'	=> array(  				array(  					'FROM'	=> array(ACL_ROLES_DATA_TABLE => 'r'), -					'ON'	=> 'a.auth_role_id = r.role_id' +					'ON'	=> 'a.auth_role_id = r.role_id',  				),  			), @@ -2815,8 +2578,9 @@ function update_foes($group_id = false, $user_id = false)  				AND ' . $db->sql_in_set('a.group_id', $group_id) . "  				AND ao.auth_option IN ('a_', 'm_')", -			'GROUP_BY'	=> 'a.group_id' -		)); +			'GROUP_BY'	=> 'a.group_id', +		); +		$sql = $db->sql_build_query('SELECT', $sql_ary);  		$result = $db->sql_query($sql);  		$groups = array(); @@ -2890,6 +2654,20 @@ function update_foes($group_id = false, $user_id = false)  }  /** +* Removes moderators and administrators from foe lists. +* +* @deprecated 3.1 +* @param array|bool $group_id If an array, remove all members of this group from foe lists, or false to ignore +* @param array|bool $user_id If an array, remove this user from foe lists, or false to ignore +* @return null +*/ +function update_foes($group_id = false, $user_id = false) +{ +	global $db, $auth; +	return phpbb_update_foes($db, $auth, $group_id, $user_id); +} + +/**  * Lists inactive users  */  function view_inactive_users(&$users, &$user_count, $limit = 0, $offset = 0, $limit_days = 0, $sort_by = 'user_inactive_time DESC') @@ -3262,38 +3040,29 @@ function tidy_database()  */  function add_permission_language()  { -	global $user, $phpEx; +	global $user, $phpEx, $phpbb_extension_manager; -	// First of all, our own file. We need to include it as the first file because it presets all relevant variables. -	$user->add_lang('acp/permissions_phpbb'); +	// add permission language files from extensions +	$finder = $phpbb_extension_manager->get_finder(); -	$files_to_add = array(); +	$lang_files = $finder +		->prefix('permissions_') +		->suffix(".$phpEx") +		->core_path('language/' . $user->lang_name . '/') +		->extension_directory('/language/' . $user->lang_name) +		->find(); -	// Now search in acp and mods folder for permissions_ files. -	foreach (array('acp/', 'mods/') as $path) +	foreach ($lang_files as $lang_file => $ext_name)  	{ -		$dh = @opendir($user->lang_path . $user->lang_name . '/' . $path); - -		if ($dh) +		if ($ext_name === '/')  		{ -			while (($file = readdir($dh)) !== false) -			{ -				if ($file !== 'permissions_phpbb.' . $phpEx && strpos($file, 'permissions_') === 0 && substr($file, -(strlen($phpEx) + 1)) === '.' . $phpEx) -				{ -					$files_to_add[] = $path . substr($file, 0, -(strlen($phpEx) + 1)); -				} -			} -			closedir($dh); +			$user->add_lang($lang_file); +		} +		else +		{ +			$user->add_lang_ext($ext_name, $lang_file);  		}  	} - -	if (!sizeof($files_to_add)) -	{ -		return false; -	} - -	$user->add_lang($files_to_add); -	return true;  }  /** @@ -3354,5 +3123,3 @@ function enable_bitfield_column_flag($table_name, $column_name, $flag, $sql_more  		' . $sql_more;  	$db->sql_query($sql);  } - -?>
\ No newline at end of file | 
