mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 05:36:13 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			1317 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			1317 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /***************************************************************************
 | |
|  *                           admin_permissions.php
 | |
|  *                            -------------------
 | |
|  *   begin                : Saturday, Feb 13, 2001
 | |
|  *   copyright            : (C) 2001 The phpBB Group
 | |
|  *   email                : support@phpbb.com
 | |
|  *
 | |
|  *   $Id$
 | |
|  *
 | |
|  ***************************************************************************/
 | |
| 
 | |
| /***************************************************************************
 | |
|  *
 | |
|  *   This program is free software; you can redistribute it and/or modify
 | |
|  *   it under the terms of the GNU General Public License as published by
 | |
|  *   the Free Software Foundation; either version 2 of the License, or
 | |
|  *   (at your option) any later version.
 | |
|  *
 | |
|  ***************************************************************************/
 | |
| 
 | |
| if (!empty($setmodules))
 | |
| {
 | |
| 	$filename = basename(__FILE__);
 | |
| 	$module['FORUM']['PERMISSIONS'] = ($auth->acl_get('a_auth')) ? $filename . $SID . '&mode=forum' : '';
 | |
| 	$module['FORUM']['MODERATORS'] = ($auth->acl_get('a_authmods')) ? $filename . $SID . '&mode=mod' : '';
 | |
| 	$module['FORUM']['SUPER_MODERATORS'] = ($auth->acl_get('a_authmods')) ? $filename . $SID . '&mode=supermod' : '';
 | |
| 	$module['FORUM']['ADMINISTRATORS'] = ($auth->acl_get('a_authadmins')) ? $filename . $SID . '&mode=admin' : '';
 | |
| 	$module['USER']['PERMISSIONS'] = ($auth->acl_get('a_authusers')) ? $filename . $SID . '&mode=user' : '';
 | |
| 	$module['GROUP']['PERMISSIONS'] = ($auth->acl_get('a_authgroups')) ? $filename . $SID . '&mode=group' : '';
 | |
| 
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| define('IN_PHPBB', 1);
 | |
| // Include files
 | |
| $phpbb_root_path = '../';
 | |
| require($phpbb_root_path . 'extension.inc');
 | |
| require('pagestart.' . $phpEx);
 | |
| 
 | |
| 
 | |
| // Grab and set some basic parameters
 | |
| //
 | |
| // 'mode' determines what we're altering; administrators, users, deps, etc.
 | |
| // 'submit' is used to determine what we're doing ... special format
 | |
| $mode		= (isset($_REQUEST['mode'])) ? htmlspecialchars($_REQUEST['mode']) : '';
 | |
| $submode	= (isset($_REQUEST['submode'])) ? htmlspecialchars($_REQUEST['submode']) : '';
 | |
| $which_mode = (!empty($submode) && $submode != $mode) ? $submode : $mode;
 | |
| $submit		= array_values(preg_grep('#^submit_(.*)$#i', array_keys($_REQUEST)));
 | |
| $submit		= (sizeof($submit)) ? substr($submit[0], strpos($submit[0], '_') + 1) : '';
 | |
| 
 | |
| 
 | |
| // Submitted setting data
 | |
| //
 | |
| // 'auth_settings' contains the submitted option settings assigned to options, should be an 
 | |
| //   associative array with integer values
 | |
| $auth_settings = (isset($_POST['settings'])) ? $_POST['settings'] : '';
 | |
| 
 | |
| 
 | |
| // Forum, User or Group information
 | |
| //
 | |
| // 'ug_type' is either user or groups used mainly for forum/admin/mod permissions
 | |
| // 'ug_data' contains the list of usernames, user_id's or group_ids for the 'ug_type'
 | |
| // 'forum_id' contains the list of forums, 0 is used for "All forums", can be array or scalar
 | |
| $ug_type = (isset($_REQUEST['ug_type'])) ? htmlspecialchars($_REQUEST['ug_type']) : '';
 | |
| $ug_data = (isset($_POST['ug_data'])) ? $_POST['ug_data'] : '';
 | |
| 
 | |
| if (isset($_REQUEST['f']))
 | |
| {
 | |
| 	$forum_id = (is_array($_REQUEST['f'])) ? $_REQUEST['f'] : intval($_REQUEST['f']);
 | |
| }
 | |
| 
 | |
| if (!isset($forum_id[$which_mode]))
 | |
| {
 | |
| 	$forum_id[$which_mode][] = 0;
 | |
| }
 | |
| $sql_forum_id = implode(', ', array_map('intval', $forum_id[$which_mode]));
 | |
| 
 | |
| // Generate list of forum id's
 | |
| $s_forum_id = '';
 | |
| foreach ($forum_id as $forum_submode => $forum_submode_ids)
 | |
| {
 | |
| 	foreach ($forum_submode_ids as $submode_forum_id)
 | |
| 	{
 | |
| 		$s_forum_id .= '<input type="hidden" name="f[' . $forum_submode . '][]" value="' . $submode_forum_id . '" />';
 | |
| 	}
 | |
| }
 | |
| unset($forum_submode_ids);
 | |
| unset($forum_submode);
 | |
| unset($submode_forum_id);
 | |
| 
 | |
| 
 | |
| // Instantiate a new auth admin object in readiness
 | |
| $auth_admin = new auth_admin();
 | |
| 
 | |
| 
 | |
| // What mode are we running? So we can output the correct title, explanation
 | |
| // and set the sql_option_mode/acl check
 | |
| switch ($mode)
 | |
| {
 | |
| 	case 'forum':
 | |
| 		$l_title = $user->lang['PERMISSIONS'];
 | |
| 		$l_title_explain = $user->lang['PERMISSIONS_EXPLAIN'];
 | |
| 		$which_acl = 'a_auth';
 | |
| 		$sql_option_mode = 'f';
 | |
| 		break;
 | |
| 
 | |
| 	case 'mod':
 | |
| 		$l_title = $user->lang['MODERATORS'];
 | |
| 		$l_title_explain = $user->lang['MODERATORS_EXPLAIN'];
 | |
| 		$which_acl = 'a_authmods';
 | |
| 		$sql_option_mode = 'm';
 | |
| 		break;
 | |
| 
 | |
| 	case 'supermod':
 | |
| 		$l_title = $user->lang['SUPER_MODERATORS'];
 | |
| 		$l_title_explain = $user->lang['SUPER_MODERATORS_EXPLAIN'];
 | |
| 		$which_acl = 'a_authmods';
 | |
| 		$sql_option_mode = 'm';
 | |
| 		break;
 | |
| 
 | |
| 	case 'admin':
 | |
| 		$l_title = $user->lang['ADMINISTRATORS'];
 | |
| 		$l_title_explain = $user->lang['ADMINISTRATORS_EXPLAIN'];
 | |
| 		$which_acl = 'a_authadmins';
 | |
| 		$sql_option_mode = 'a';
 | |
| 		break;
 | |
| 
 | |
| 	case 'user':
 | |
| 		$l_title = $user->lang['USER_PERMISSIONS'];
 | |
| 		$l_title_explain = $user->lang['USER_PERMISSIONS_EXPLAIN'];
 | |
| 		$which_acl = 'a_authusers';
 | |
| 		$sql_option_mode = 'u';
 | |
| 		break;
 | |
| 
 | |
| 	case 'group':
 | |
| 		$l_title = $user->lang['GROUP_PERMISSIONS'];
 | |
| 		$l_title_explain = $user->lang['GROUP_PERMISSIONS_EXPLAIN'];
 | |
| 		$which_acl = 'a_authgroups';
 | |
| 		$sql_option_mode = 'u';
 | |
| 		break;
 | |
| 
 | |
| 	case 'deps':
 | |
| 		$l_title = $user->lang['DEPENDENCIES'];
 | |
| 		$l_title_explain = $user->lang['DEPENDENCIES_EXPLAIN'];
 | |
| 		$which_acl = 'a_authdeps';
 | |
| 		break;
 | |
| }
 | |
| 
 | |
| // Permission check
 | |
| if (!$auth->acl_get($which_acl))
 | |
| {
 | |
| 	trigger_error($user->lang['NO_ADMIN']);
 | |
| }
 | |
| 
 | |
| // Are we setting deps? If we are we need to re-run the mode match above for the
 | |
| // relevant 'new' mode
 | |
| if (!empty($submode))
 | |
| {
 | |
| 	switch ($submode)
 | |
| 	{
 | |
| 		case 'forum':
 | |
| 			$l_title_explain = $user->lang['PERMISSIONS_EXPLAIN'];
 | |
| 			$which_acl = 'a_auth';
 | |
| 			$sql_option_mode = 'f';
 | |
| 			break;
 | |
| 
 | |
| 		case 'mod':
 | |
| 			$l_title_explain = $user->lang['MODERATORS_EXPLAIN'];
 | |
| 			$which_acl = 'a_authmods';
 | |
| 			$sql_option_mode = 'm';
 | |
| 			break;
 | |
| 
 | |
| 		case 'supermod':
 | |
| 			$l_title_explain = $user->lang['SUPER_MODERATORS_EXPLAIN'];
 | |
| 			$which_acl = 'a_authmods';
 | |
| 			$sql_option_mode = 'm';
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	// Permission check
 | |
| 	if (!$auth->acl_get($which_acl))
 | |
| 	{
 | |
| 		trigger_error($user->lang['NO_ADMIN']);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| // Does user want to update anything? Check here to find out 
 | |
| // and act appropriately
 | |
| switch ($submit)
 | |
| {
 | |
| 	case 'update':
 | |
| 
 | |
| 		if (sizeof($auth_settings))
 | |
| 		{
 | |
| 			// Admin wants subforums to inherit permissions ... so add these
 | |
| 			// forums to the list ... since inheritance is only available for
 | |
| 			// forum and moderator primary modes we deal with '$forum_id[$mode]'
 | |
| 			if (!empty($_POST['inherit']))
 | |
| 			{
 | |
| 				$forum_id[$mode] = array_merge($forum_id[$mode], array_map('intval', $_POST['inherit']));
 | |
| 			}
 | |
| 
 | |
| 			// Update the permission set ... we loop through each auth setting array
 | |
| 			foreach ($auth_settings as $auth_submode => $auth_setting)
 | |
| 			{
 | |
| 				// Are any entries * ? If so we need to remove them since they
 | |
| 				// are options the user wishes to ignore
 | |
| 				if (in_array('*', $auth_setting))
 | |
| 				{
 | |
| 					$temp = array();
 | |
| 					foreach ($auth_setting as $option => $setting)
 | |
| 					{
 | |
| 						if ($setting != '*')
 | |
| 						{
 | |
| 							$temp[$option] = $setting;
 | |
| 						}
 | |
| 					}
 | |
| 					$auth_setting = $temp;
 | |
| 				}
 | |
| 
 | |
| 				if (sizeof($auth_setting))
 | |
| 				{
 | |
| 					// Loop through all user/group ids
 | |
| 					foreach ($ug_data as $id)
 | |
| 					{
 | |
| 						$auth_admin->acl_set($ug_type, $forum_id[$auth_submode], intval($id), $auth_setting);
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			// Do we need to recache the moderator lists? We do if the mode
 | |
| 			// was mod or auth_settings['mod'] is a non-zero size array
 | |
| 			if ($mode == 'mod' || sizeof($auth_settings['mod']))
 | |
| 			{
 | |
| 				cache_moderators();
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			// Logging ... first grab user or groupnames ...
 | |
| 			$sql = ($ug_type == 'group') ? 'SELECT group_name as name, group_type FROM ' . GROUPS_TABLE . ' WHERE group_id' : 'SELECT username as name FROM ' . USERS_TABLE . ' WHERE user_id';
 | |
| 			$sql .=  ' IN (' . implode(', ', array_map('intval', $ug_data)) . ')';
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			$l_ug_list = '';
 | |
| 			while ($row = $db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				$l_ug_list .= (($l_ug_list != '') ? ', ' : '') . ((isset($row['group_type']) && $row['group_type'] == GROUP_SPECIAL) ? '<span class="blue">' . $user->lang['G_' . $row['name']] . '</span>' : $row['name']);
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 
 | |
| 			foreach (array_keys($auth_settings) as $submode)
 | |
| 			{
 | |
| 				if (!in_array(0, $forum_id[$submode]))
 | |
| 				{
 | |
| 					// Grab the forum details if non-zero forum_id
 | |
| 					$sql = 'SELECT forum_name  
 | |
| 						FROM ' . FORUMS_TABLE . "
 | |
| 						WHERE forum_id IN ($sql_forum_id)";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					$l_forum_list = '';
 | |
| 					while ($row = $db->sql_fetchrow($result))
 | |
| 					{
 | |
| 						$l_forum_list .= (($l_forum_list != '') ? ', ' : '') . $row['forum_name'];
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					add_log('admin', 'LOG_ACL_' . strtoupper($submode) . '_ADD', $l_forum_list, $l_ug_list);
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					add_log('admin', 'LOG_ACL_' . strtoupper($submode) . '_ADD', $l_ug_list);
 | |
| 				}
 | |
| 			}
 | |
| 			unset($l_ug_list);
 | |
| 		}
 | |
| 		unset($auth_submode);
 | |
| 		unset($auth_setting);
 | |
| 
 | |
| 		trigger_error($user->lang['AUTH_UPDATED']);
 | |
| 		break;
 | |
| 
 | |
| 	case 'delete':
 | |
| 
 | |
| 		$sql = "SELECT auth_option_id
 | |
| 			FROM " . ACL_OPTIONS_TABLE . "
 | |
| 			WHERE auth_option LIKE '{$sql_option_mode}_%'";
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			$option_id_ary = array();
 | |
| 			do
 | |
| 			{
 | |
| 				$option_id_ary[] = $row['auth_option_id'];
 | |
| 			}
 | |
| 			while($row = $db->sql_fetchrow($result));
 | |
| 
 | |
| 			foreach ($ug_data as $id)
 | |
| 			{
 | |
| 				$auth_admin->acl_delete($ug_type, $forum_id[$mode], $id, $option_id_ary);
 | |
| 			}
 | |
| 			unset($option_id_ary);
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 
 | |
| 		// Do we need to recache the moderator lists? We do if the mode
 | |
| 		// was mod or auth_settings['mod'] is a non-zero size array
 | |
| 		if ($mode == 'mod' || sizeof($auth_settings['mod']))
 | |
| 		{
 | |
| 			cache_moderators();
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		// Logging ... first grab user or groupnames ...
 | |
| 		$sql = ($ug_type == 'group') ? 'SELECT group_name as name, group_type FROM ' . GROUPS_TABLE . ' WHERE group_id' : 'SELECT username as name FROM ' . USERS_TABLE . ' WHERE user_id';
 | |
| 		$sql .=  ' IN (' . implode(', ', array_map('intval', $ug_data)) . ')';
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		$l_ug_list = '';
 | |
| 		while ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			$l_ug_list .= (($l_ug_list != '') ? ', ' : '') . ((isset($row['group_type']) && $row['group_type'] == GROUP_SPECIAL) ? '<span class="blue">' . $user->lang['G_' . $row['name']] . '</span>' : $row['name']);
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 
 | |
| 		// Grab the forum details if non-zero forum_id
 | |
| 		if (!in_array(0, $forum_id[$which_mode]))
 | |
| 		{
 | |
| 			$sql = 'SELECT forum_name  
 | |
| 				FROM ' . FORUMS_TABLE . "
 | |
| 				WHERE forum_id IN ($sql_forum_id)";
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			$l_forum_list = '';
 | |
| 			while ($row = $db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				$l_forum_list .= (($l_forum_list != '') ? ', ' : '') . $row['forum_name'];
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 
 | |
| 			add_log('admin', 'LOG_ACL_' . strtoupper($which_mode) . '_DEL', $l_forum_list, $l_ug_list);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			add_log('admin', 'LOG_ACL_' . strtoupper($which_mode) . '_DEL', $l_ug_list);
 | |
| 		}
 | |
| 
 | |
| 		trigger_error($user->lang['AUTH_UPDATED']);
 | |
| 		break;
 | |
| 
 | |
| 	case 'presetsave':
 | |
| 
 | |
| 		$holding_ary = array();
 | |
| 		foreach ($auth_settings as $option => $setting)
 | |
| 		{
 | |
| 			switch ($setting)
 | |
| 			{
 | |
| 				case ACL_YES:
 | |
| 					$holding_ary['yes'][] = $option;
 | |
| 					break;
 | |
| 
 | |
| 				case ACL_NO:
 | |
| 					$holding_ary['no'][] = $option;
 | |
| 					break;
 | |
| 
 | |
| 				case ACL_UNSET:
 | |
| 					$holding_ary['unset'][] = $option;
 | |
| 					break;
 | |
| 			}
 | |
| 		}
 | |
| 		unset($option);
 | |
| 		unset($setting);
 | |
| 
 | |
| 		$sql = array(
 | |
| 			'preset_user_id'=> intval($user->data['user_id']),
 | |
| 			'preset_type'	=> $sql_option_mode,
 | |
| 			'preset_data'	=> $db->sql_escape(serialize($holding_ary))
 | |
| 		);
 | |
| 
 | |
| 		if (!empty($_POST['presetname']))
 | |
| 		{
 | |
| 			$sql['preset_name'] = $db->sql_escape($_POST['presetname']);
 | |
| 		}
 | |
| 		
 | |
| 		if (!empty($_POST['presetname']) || $_POST['presetoption'] != -1)
 | |
| 		{
 | |
| 			$sql = ($_POST['presetoption'] == -1) ? 'INSERT INTO ' . ACL_PRESETS_TABLE . ' ' . $db->sql_build_array('INSERT', $sql) : 'UPDATE ' . ACL_PRESETS_TABLE . ' SET ' . $db->sql_build_array('UPDATE', $sql) . ' WHERE preset_id =' . intval($_POST['presetoption']);
 | |
| 			$db->sql_query($sql);
 | |
| 
 | |
| 			add_log('admin', 'LOG_ACL_PRESET_ADD', $sql['preset_name']);
 | |
| 		}
 | |
| 		break;
 | |
| 
 | |
| 	case 'presetdel':
 | |
| 		if (!empty($_POST['presetoption']))
 | |
| 		{
 | |
| 			$sql = "SELECT preset_name 
 | |
| 				FROM " . ACL_PRESETS_TABLE . " 
 | |
| 				WHERE preset_id = " . intval($_POST['presetoption']);
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			$row = $db->sql_fetchrow($result);
 | |
| 			$db->sql_freeresult($result);
 | |
| 
 | |
| 			$sql = "DELETE FROM " . ACL_PRESETS_TABLE . " 
 | |
| 				WHERE preset_id = " . intval($_POST['presetoption']);
 | |
| 			$db->sql_query($sql);
 | |
| 
 | |
| 			add_log('admin', 'LOG_ACL_PRESET_DEL', $row['preset_name']);
 | |
| 			unset($row);
 | |
| 		}
 | |
| 		break;
 | |
| }
 | |
| // End update
 | |
| 
 | |
| 
 | |
| // Output page header
 | |
| adm_page_header($l_title);
 | |
| 
 | |
| 
 | |
| // First potential form ... this is for selecting forums, users
 | |
| // or groups. 
 | |
| if (in_array($mode, array('user', 'group', 'forum', 'mod')) && empty($submit))
 | |
| {
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h1><?php echo $l_title; ?></h1>
 | |
| 
 | |
| <p><?php echo $l_title_explain ?></p>
 | |
| 
 | |
| <form method="post" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode"; ?>"><table class="bg" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| <?php
 | |
| 
 | |
| 	// Mode specific markup
 | |
| 	switch ($mode)
 | |
| 	{
 | |
| 		case 'forum':
 | |
| 		case 'mod':
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<th align="center"><?php echo $user->lang['LOOK_UP_FORUM']; ?></th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1" align="center" valign="middle"> <select name="f[<?php echo $mode; ?>][]" multiple="true" size="5"><?php 
 | |
| 	
 | |
| 			echo make_forum_select(false, false, false);
 | |
| 			
 | |
| ?></select> </td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="cat" align="center"><input type="submit" name="submit_usergroups" value="<?php echo $user->lang['LOOK_UP_FORUM']; ?>" class="mainoption" />  <input type="reset" value="<?php echo $user->lang['RESET']; ?>" class="liteoption" /><input type="hidden" name="ug_type" value="forum" /><input type="hidden" name="action" value="usergroups" /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 		
 | |
| 			break;
 | |
| 
 | |
| 		case 'user':
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<th align="center"><?php echo $user->lang['LOOK_UP_USER']; ?></th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1" align="center"> <textarea cols="40" rows="4" name="ug_data[]"></textarea> </td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="cat" align="center"><input type="submit" name="submit_add_options" value="<?php echo $user->lang['SUBMIT']; ?>" class="mainoption" />  <input type="reset" value="<?php echo $user->lang['RESET']; ?>" class="liteoption" />  <input type="submit" value="<?php echo $user->lang['FIND_USERNAME']; ?>" class="liteoption" onclick="window.open('<?php echo "../memberlist.$phpEx$SID"; ?>&mode=searchuser&form=2&field=entries', '_phpbbsearch', 'HEIGHT=500,resizable=yes,scrollbars=yes,WIDTH=740');return false;" /><input type="hidden" name="ug_type" value="user" /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 			break;
 | |
| 
 | |
| 		case 'group':
 | |
| 			// Generate list of groups
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<th align="center"><?php echo $user->lang['LOOK_UP_GROUP']; ?></th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1" align="center" valign="middle"> <select name="ug_data[]" multiple="true" size="5"><?php 
 | |
| 
 | |
| 			$sql = "SELECT group_id, group_name, group_type   
 | |
| 				FROM " . GROUPS_TABLE . " 
 | |
| 				ORDER BY group_type DESC";
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			$group_options = '';
 | |
| 			if ($row = $db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				do
 | |
| 				{
 | |
| 					echo '<option' . (($row['group_type'] == GROUP_SPECIAL) ? ' class="blue"' : '') . ' value="' . $row['group_id'] . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</option>';
 | |
| 				}
 | |
| 				while ($row = $db->sql_fetchrow($result));
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 			
 | |
| ?></select> </td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="cat" align="center"><input type="submit" name="submit_edit_options" value="<?php echo $user->lang['LOOK_UP_GROUP']; ?>" class="mainoption" />  <input type="reset" value="<?php echo $user->lang['RESET']; ?>" class="liteoption" /><input type="hidden" name="ug_type" value="group" /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| </table></form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| }
 | |
| // End user, group or forum selection
 | |
| 
 | |
| 
 | |
| // Second possible form, this lists the currently enabled
 | |
| // users/groups for the given mode
 | |
| if ((in_array($submit, array('usergroups', 'delete', 'cancel'))) || (!strstr($submit, 'options') && empty($submode) && in_array($mode, array('admin', 'supermod'))))
 | |
| {
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h1><?php echo $l_title; ?></h1>
 | |
| 
 | |
| <p><?php echo $l_title_explain; ?></p>
 | |
| 
 | |
| <table width="100%" cellspacing="0" cellpadding="0" border="0">
 | |
| 	<tr>
 | |
| 		<td align="center"><h1><?php echo $user->lang['USERS']; ?></h1></td>
 | |
| 		<td align="center"><h1><?php echo $user->lang['USERGROUPS']; ?></h1></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 
 | |
| 		<td><form method="post" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode"; ?>"><table width="90%" class="bg" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th><?php echo $user->lang['MANAGE_USERS']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" align="center"><select style="width:280px" name="ug_data[]" multiple="multiple" size="5"><?php
 | |
| 			
 | |
| 	$sql = "SELECT DISTINCT u.user_id, u.username
 | |
| 		FROM " . USERS_TABLE . " u, " . ACL_USERS_TABLE . " a, " . ACL_OPTIONS_TABLE . " o
 | |
| 		WHERE o.auth_option LIKE '" . $sql_option_mode . "_%'
 | |
| 			AND a.auth_option_id = o.auth_option_id
 | |
| 			AND a.forum_id IN ($sql_forum_id)
 | |
| 			AND u.user_id = a.user_id
 | |
| 		ORDER BY u.username, u.user_regdate ASC";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$users = '';
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		echo '<option value="' . $row['user_id'] . '">' . $row['username'] . '</option>';
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 		
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" align="center"><input class="liteoption" type="submit" name="submit_delete" value="<?php echo $user->lang['DELETE']; ?>" />   <input class="liteoption" type="submit" name="submit_edit_options" value="<?php echo $user->lang['SET_OPTIONS']; ?>" /><input type="hidden" name="ug_type" value="user" /><?php echo $s_forum_id; ?></td>
 | |
| 			</tr>
 | |
| 		</table></form></td>
 | |
| 
 | |
| 		<td align="center"><form method="post" name="admingroups" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode"; ?>"><table width="90%" class="bg" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 		<tr>
 | |
| 			<th><?php echo $user->lang['MANAGE_GROUPS']; ?></th>
 | |
| 		</tr>
 | |
| 		<tr>
 | |
| 			<td class="row1" align="center"><select style="width:280px" name="ug_data[]" multiple="multiple" size="5"><?php 
 | |
| 	
 | |
| 	$sql = "SELECT DISTINCT g.group_id, g.group_name, g.group_type 
 | |
| 		FROM " . GROUPS_TABLE . " g, " . ACL_GROUPS_TABLE . " a, " . ACL_OPTIONS_TABLE . " o
 | |
| 		WHERE o.auth_option LIKE '" . $sql_option_mode . "_%'
 | |
| 			AND a.forum_id IN ($sql_forum_id)
 | |
| 			AND a.auth_option_id = o.auth_option_id
 | |
| 			AND g.group_id = a.group_id
 | |
| 		ORDER BY g.group_type DESC, g.group_name ASC";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$groups = '';
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		echo '<option' . (($row['group_type'] == GROUP_SPECIAL) ? ' class="blue"' : '') . ' value="' . $row['group_id'] . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</option>';
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| ?></select></td>
 | |
| 		</tr>
 | |
| 		<tr>
 | |
| 			<td class="cat" align="center"><input class="liteoption" type="submit" name="submit_delete" value="<?php echo $user->lang['DELETE']; ?>" />   <input class="liteoption" type="submit" name="submit_edit_options" value="<?php echo $user->lang['SET_OPTIONS']; ?>" /><input type="hidden" name="ug_type" value="group" /><?php echo $s_forum_id; ?></td>
 | |
| 		</tr>
 | |
| 	</table></form></td>
 | |
| 
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 
 | |
| 		<td><form method="post" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode"; ?>"><table class="bg" width="90%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th><?php echo $user->lang['ADD_USERS']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" align="center"><textarea cols="40" rows="4" name="ug_data[]"></textarea></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" align="center"> <input type="submit" name="submit_add_options" value="<?php echo $user->lang['SUBMIT']; ?>" class="mainoption" />  <input type="reset" value="<?php echo $user->lang['RESET']; ?>" class="liteoption" />  <input type="submit" value="<?php echo $user->lang['FIND_USERNAME']; ?>" class="liteoption" onclick="window.open('<?php echo "../memberlist.$phpEx$SID"; ?>&mode=searchuser&form=2&field=entries', '_phpbbsearch', 'HEIGHT=500,resizable=yes,scrollbars=yes,WIDTH=740');return false;" /><input type="hidden" name="ug_type" value="user" /><?php echo $s_forum_id; ?></td>
 | |
| 			</tr>
 | |
| 		</table></form></td>
 | |
| 
 | |
| 		<td><form method="post" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode"; ?>"><table width="90%" class="bg" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th><?php echo $user->lang['ADD_GROUPS']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" align="center"><select name="ug_data[]" multiple="multiple" size="4"><?php 
 | |
| 			
 | |
| 	$sql = "SELECT group_id, group_name, group_type 
 | |
| 		FROM " . GROUPS_TABLE . "
 | |
| 		ORDER BY group_type DESC, group_name";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$group_list = '';
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		echo '<option' . (($row['group_type'] == GROUP_SPECIAL) ? ' class="blue"' : '') . ' value="' . $row['group_id'] . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</option>';
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 		
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" align="center"> <input type="submit" name="submit_add_options" value="<?php echo $user->lang['SUBMIT']; ?>" class="mainoption" />  <input type="reset" value="<?php echo $user->lang['RESET']; ?>" class="liteoption" /><input type="hidden" name="ug_type" value="group" /><?php echo $s_forum_id; ?></td>
 | |
| 			</tr>
 | |
| 		</table></form></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| }
 | |
| // End user and group acl selections
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| // Third possible form, this is the major section of this script. It
 | |
| // handles the entry of permission options for all situations
 | |
| if (in_array($submit, array('add_options', 'edit_options', 'presetsave', 'presetdel', 'update')) || !empty($submode))
 | |
| {
 | |
| 
 | |
| 	// Did the user specify any users or groups?
 | |
| 	if (empty($ug_data))
 | |
| 	{
 | |
| 		$l_message = ($ug_type == 'user') ? 'NO_USER' : 'NO_GROUP';
 | |
| 		trigger_error($user->lang[$l_message]);
 | |
| 	}
 | |
| 
 | |
| 
 | |
| 	$forum_list = '';
 | |
| 	// Grab the forum details if non-zero forum_id
 | |
| 	if (!in_array(0, $forum_id[$which_mode]))
 | |
| 	{
 | |
| 		$sql = 'SELECT forum_id, forum_name, parent_id  
 | |
| 			FROM ' . FORUMS_TABLE . "
 | |
| 			WHERE forum_id IN ($sql_forum_id)";
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if (!($row = $db->sql_fetchrow($result)))
 | |
| 		{
 | |
| 			trigger_error($user->lang['NO_FORUM']);
 | |
| 		}
 | |
| 
 | |
| 		// If we have more than one forum we want a list of all their names
 | |
| 		// so loop through all results. We don't need all the data though 
 | |
| 		// since cascading/inheritance is only applicable if a single forum
 | |
| 		// was selected
 | |
| 		$forum_data = $row;
 | |
| 
 | |
| 		do
 | |
| 		{
 | |
| 			$forum_list .= (($forum_list != '') ? ', ' : '') . '<b>' . $row['forum_name'] . '</b>';
 | |
| 		}
 | |
| 		while ($row = $db->sql_fetchrow($result));
 | |
| 		$db->sql_freeresult($result);
 | |
| 	}
 | |
| 
 | |
| 
 | |
| 	// Grab relevant user or group information
 | |
| 	$ug_ids = $l_ug_list = $ug_hidden = $l_no_error = '';
 | |
| 	switch ($ug_type)
 | |
| 	{
 | |
| 		case 'user':
 | |
| 			// If we've just come from the usergroup form then user will actually
 | |
| 			// be a username rather than a user_id, so act appropriately
 | |
| 			$l_no_error = $user->lang['NO_USER'];
 | |
| 			$sql = 'SELECT user_id AS id, username AS name 
 | |
| 				FROM ' . USERS_TABLE . ' 
 | |
| 				WHERE ';
 | |
| 			$sql .= ($submit == 'add_options') ? ' username IN (' . implode(', ', array_unique(preg_replace('#^[\s]*?(.*?)[\s]*?$#', "'\\1'", explode("\n", $ug_data[0])))) . ')' : ' user_id ' . ((is_array($ug_data)) ? 'IN (' . implode(', ', $ug_data) . ')' : '= ' . $ug_data);
 | |
| 			break;
 | |
| 
 | |
| 		case 'group':
 | |
| 			$l_no_error = $user->lang['NO_GROUP'];
 | |
| 			$sql = 'SELECT group_id AS id, group_name AS name, group_type  
 | |
| 				FROM ' . GROUPS_TABLE . '
 | |
| 				WHERE group_id';
 | |
| 			$sql .= (is_array($ug_data)) ? ' IN (' . implode(', ', $ug_data) . ')' : ' = ' . $ug_data;
 | |
| 			break;
 | |
| 	}
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if (!$row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		trigger_error($l_no_error);
 | |
| 	}
 | |
| 	unset($l_no_error);
 | |
| 
 | |
| 	// Store the user_ids and names for later use
 | |
| 	do 
 | |
| 	{
 | |
| 		$l_ug_list .= (($l_ug_list != '') ? ', ' : '') . ((isset($row['group_type']) && $row['group_type'] == GROUP_SPECIAL) ? '<b class="blue">' . $user->lang['G_' . $row['name']] : '<b>' . $row['name']) . '</b>';
 | |
| 		$ug_ids .= (($ug_ids != '') ? ', ' : '') . $row['id'];
 | |
| 		$ug_hidden .= '<input type="hidden" name="ug_data[]" value="' . $row['id'] . '" />';
 | |
| 	}
 | |
| 	while ($row = $db->sql_fetchrow($result));
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 
 | |
| 	// Grab the list of options ... if we're in deps mode we want all options, 
 | |
| 	// else we skip the master options
 | |
| 	$sql_founder = ($user->data['user_founder']) ? ' AND founder_only <> 1' : '';
 | |
| 	$sql_limit_option = ($mode == 'deps') ? '' : "AND auth_option <> '" . $sql_option_mode . "_'";
 | |
| 	$sql = "SELECT auth_option_id, auth_option
 | |
| 		FROM " . ACL_OPTIONS_TABLE . "
 | |
| 		WHERE auth_option LIKE '" . $sql_option_mode . "_%' 
 | |
| 			$sql_limit_option 
 | |
| 			$sql_founder";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$auth_options = array();
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		$auth_options[] = $row;
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	unset($sql_limit_option);
 | |
| 
 | |
| 
 | |
| 	// Now we'll build a list of preset options ...
 | |
| 	$preset_options = $preset_js = $preset_update_options = '';
 | |
| 	$holding = array();
 | |
| 
 | |
| 	// Do we have a parent forum? If so offer option to inherit from that
 | |
| 	if ($forum_data['parent_id'] != 0)
 | |
| 	{
 | |
| 		switch ($ug_type)
 | |
| 		{
 | |
| 			case 'group':
 | |
| 				$sql = "SELECT o.auth_option, a.auth_setting FROM " . ACL_GROUPS_TABLE . " a, " . ACL_OPTIONS_TABLE . " o WHERE o.auth_option LIKE '" . $sql_option_mode . "_%' AND a.auth_option_id = o.auth_option_id AND a.forum_id = " . $forum_data['parent_id'] . " AND a.group_id IN ($ug_ids)";
 | |
| 				break;
 | |
| 
 | |
| 			case 'user':
 | |
| 				$sql = "SELECT o.auth_option, a.auth_setting FROM " . ACL_USERS_TABLE . " a, " . ACL_OPTIONS_TABLE . " o WHERE o.auth_option LIKE '" . $sql_option_mode . "_%' AND a.auth_option_id = o.auth_option_id AND a.forum_id = " . $forum_data['parent_id'] . " AND a.user_id IN ($ug_ids)";
 | |
| 				break;
 | |
| 		}
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			do
 | |
| 			{
 | |
| 				switch ($row['auth_setting'])
 | |
| 				{
 | |
| 					case ACL_YES:
 | |
| 						$holding['allow'] .= $row['auth_option'] . ', ';
 | |
| 						break;
 | |
| 
 | |
| 					case ACL_NO:
 | |
| 						$holding['deny'] .= $row['auth_option'] . ', ';
 | |
| 						break;
 | |
| 
 | |
| 					case ACL_UNSET:
 | |
| 						$holding['inherit'] .= $row['auth_option'] . ', ';
 | |
| 						break;
 | |
| 				}
 | |
| 			}
 | |
| 			while ($row = $db->sql_fetchrow($result));
 | |
| 
 | |
| 			$preset_options .= '<option value="preset_0">' . $user->lang['INHERIT_PARENT'] . '</option>';
 | |
| 			$preset_js .= "\tpresets['preset_0'] = new Array();" . "\n";
 | |
| 			$preset_js .= "\tpresets['preset_0'] = new preset_obj('" . $holding['allow'] . "', '" . $holding['deny'] . "', '" . $holding['inherit'] . "');\n";
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 	}
 | |
| 
 | |
| 	// Look for custom presets
 | |
| 	$sql = "SELECT preset_id, preset_name, preset_data  
 | |
| 		FROM " . ACL_PRESETS_TABLE . " 
 | |
| 		WHERE preset_type = '" . (($mode == 'deps') ? 'f' : $sql_option_mode) . "' 
 | |
| 		ORDER BY preset_id ASC";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		do
 | |
| 		{
 | |
| 			$preset_update_options .= '<option value="' . $row['preset_id'] . '">' . $row['preset_name'] . '</option>';
 | |
| 			$preset_options .= '<option value="preset_' . $row['preset_id'] . '">' . $row['preset_name'] . '</option>';
 | |
| 
 | |
| 			$preset_data = unserialize($row['preset_data']);
 | |
| 			
 | |
| 			foreach ($preset_data as $preset_type => $preset_type_ary)
 | |
| 			{
 | |
| 				$holding[$preset_type] = '';
 | |
| 				foreach ($preset_type_ary as $preset_option)
 | |
| 				{
 | |
| 					$holding[$preset_type] .= "$preset_option, ";
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			$preset_js .= "\tpresets['preset_" . $row['preset_id'] . "'] = new Array();" . "\n";
 | |
| 			$preset_js .= "\tpresets['preset_" . $row['preset_id'] . "'] = new preset_obj('" . $holding['yes'] . "', '" . $holding['no'] . "', '" . $holding['unset'] . "');\n";
 | |
| 		}
 | |
| 		while ($row = $db->sql_fetchrow($result));
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	unset($holding);
 | |
| 
 | |
| 
 | |
| 	// If we aren't looking @ deps then we try and grab existing sessions for
 | |
| 	// the given forum and user/group
 | |
| 	if (empty($auth_settings[$which_mode]))
 | |
| 	{
 | |
| 		if ($which_mode == $mode)
 | |
| 		{
 | |
| 			switch ($ug_type)
 | |
| 			{
 | |
| 				case 'group':
 | |
| 					$sql_table = ACL_GROUPS_TABLE . ' a ';
 | |
| 					$sql_join = 'a.group_id';
 | |
| 					break;
 | |
| 
 | |
| 				case 'user':
 | |
| 					$sql_table = ACL_USERS_TABLE . ' a ';
 | |
| 					$sql_join = 'a.user_id';
 | |
| 					break;
 | |
| 			}
 | |
| 		
 | |
| 			$sql = "SELECT o.auth_option, MIN(a.auth_setting) AS min_auth_setting 
 | |
| 					FROM $sql_table, " . ACL_OPTIONS_TABLE . " o 
 | |
| 					WHERE o.auth_option LIKE '" . $sql_option_mode . "_%' 
 | |
| 						AND a.auth_option_id = o.auth_option_id 
 | |
| 						AND a.forum_id IN ($sql_forum_id) 
 | |
| 						AND $sql_join IN ($ug_ids)
 | |
| 					GROUP BY o.auth_option";
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			$auth_settings[$which_mode] = array();
 | |
| 			while ($row = $db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				$auth_settings[$which_mode][$row['auth_option']] = $row['min_auth_setting'];
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			// We're looking at a view ... so we'll set all options to unset
 | |
| 			// We could be a little more clever here but the "safe side" looks
 | |
| 			// better right now
 | |
| 			$auth_settings[$which_mode] = array();
 | |
| 			foreach ($auth_options as $option)
 | |
| 			{
 | |
| 				$auth_settings[$which_mode][$option['auth_option']] = '*';
 | |
| 			}
 | |
| 			unset($option);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$view_options = '';
 | |
| 	// Should we display a dropdown for views?
 | |
| 	if (in_array($mode, array('admin', 'supermod', 'mod')))
 | |
| 	{
 | |
| 		$view_options .= '<option value="">' . $user->lang['SELECT_VIEW'] . '</option>';
 | |
| 		$view_ary = array(
 | |
| 			'admin'		=> array('admin' => 'a_', 'forum' => 'a_auth', 'supermod' => 'a_authmods', 'mod' => 'a_authmods'),
 | |
| 			'supermod'	=> array('supermod' => 'a_authmods', 'mod' => 'a_authmods', 'forum' => 'a_auth'), 
 | |
| 			'mod'		=> array('mod' => 'a_authmods', 'forum' => 'a_auth')
 | |
| 		);
 | |
| 
 | |
| 		foreach ($view_ary[$mode] as $which_submode => $which_acl)
 | |
| 		{
 | |
| 			if ($auth->acl_get($which_acl))
 | |
| 			{
 | |
| 				$view_options .= '<option value="' . $which_submode . '"' . (($which_submode == $which_mode) ? ' selected="selected"' : '') . '>' . $user->lang['ACL_VIEW_' . strtoupper($which_submode)] . '</option>';
 | |
| 			}
 | |
| 
 | |
| 		}
 | |
| 		unset($view_ary);
 | |
| 	}
 | |
| 
 | |
| 	$settings_hidden = '';
 | |
| 	// Output original settings ... needed when we jump views
 | |
| 	foreach ($auth_settings as $auth_submode => $auth_submode_settings)
 | |
| 	{
 | |
| 		if ($auth_submode != $which_mode)
 | |
| 		{
 | |
| 			foreach ($auth_submode_settings as $submode_option => $submode_setting)
 | |
| 			{
 | |
| 				$settings_hidden .= ($submode_setting != '*') ? '<input type="hidden" name="settings[' . $auth_submode . '][' . $submode_option . ']" value="' . $submode_setting . '" />' : '';
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	unset($auth_submode);
 | |
| 	unset($auth_submode_settings);
 | |
| 	unset($auth_submode_option);
 | |
| 	unset($auth_submode_setting);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <script language="Javascript" type="text/javascript">
 | |
| <!--
 | |
| 
 | |
| 	var presets = new Array();
 | |
| <?php
 | |
| 
 | |
| 	echo $preset_js;
 | |
| 
 | |
| ?>
 | |
| 
 | |
| 	function preset_obj(yes, no, unset)
 | |
| 	{
 | |
| 		this.yes = yes;
 | |
| 		this.no = no;
 | |
| 		this.unset = unset;
 | |
| 	}
 | |
| 
 | |
| 	function use_preset(option)
 | |
| 	{
 | |
| 		if (option)
 | |
| 		{
 | |
| 			document.acl.set.selectedIndex = 0;
 | |
| 			for (i = 0; i < document.acl.length; i++)
 | |
| 			{
 | |
| 				var elem = document.acl.elements[i];
 | |
| 				if (elem.name.indexOf('settings') == 0)
 | |
| 				{
 | |
| 					switch (option)
 | |
| 					{
 | |
| 						case 'all_yes':
 | |
| 							if (elem.value == <?php echo ACL_YES; ?>)
 | |
| 								elem.checked = true;
 | |
| 							break;
 | |
| 
 | |
| 						case 'all_no':
 | |
| 							if (elem.value == <?php echo ACL_NO; ?>)
 | |
| 								elem.checked = true;
 | |
| 							break;
 | |
| 
 | |
| 						case 'all_unset':
 | |
| 							if (elem.value == <?php echo ACL_UNSET; ?>)
 | |
| 								elem.checked = true;
 | |
| 							break;
 | |
| 
 | |
| 						case 'all_ignore':
 | |
| 							if (elem.value == '*')
 | |
| 								elem.checked = true;
 | |
| 							break;
 | |
| 
 | |
| 						default:
 | |
| 							option_start = elem.name.search(/\[(\w+?)\]$/);
 | |
| 							option_name = elem.name.substr(option_start + 1, elem.name.length - option_start - 2);
 | |
| 
 | |
| 							if (presets[option].yes.indexOf(option_name + ',') != -1 && elem.value == <?php echo ACL_YES; ?>)
 | |
| 								elem.checked = true;
 | |
| 							else if (presets[option].no.indexOf(option_name + ',') != -1 && elem.value == <?php echo ACL_NO; ?>)
 | |
| 								elem.checked = true;
 | |
| 							else if (presets[option].unset.indexOf(option_name + ',') != -1 && elem.value == <?php echo ACL_UNSET; ?>)
 | |
| 								elem.checked = true;
 | |
| 							break;
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	function marklist(match, status)
 | |
| 	{
 | |
| 		for (i = 0; i < document.acl.length; i++)
 | |
| 		{
 | |
| 			if (document.acl.elements[i].name.indexOf(match) == 0)
 | |
| 				document.acl.elements[i].checked = status;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	function open_win(url, width, height)
 | |
| 	{
 | |
| 		aclwin = window.open(url, '_phpbbacl', 'HEIGHT=' + height + ',resizable=yes, scrollbars=yes,WIDTH=' + width);
 | |
| 		if (window.focus)
 | |
| 			aclwin.focus();
 | |
| 	}
 | |
| //-->
 | |
| </script>
 | |
| 
 | |
| <p><?php echo $user->lang['ACL_EXPLAIN']; ?></p>
 | |
| 
 | |
| <h1><?php echo $l_title; ?></h1>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 	// Do we have a list of forums? If so, output them ... but only
 | |
| 	// if we're looking at the primary view or mode ... submodes
 | |
| 	// output their own list of forums as and where applicable so this
 | |
| 	// is unnecessary
 | |
| 	if ($forum_list != '' && $which_mode == $mode)
 | |
| 	{
 | |
| 		$l_selected_forums = (sizeof($forum_id[$which_mode]) == 1) ? 'SELECTED_FORUM' : 'SELECTED_FORUMS';
 | |
| 
 | |
| 		echo '<p>' . $user->lang[$l_selected_forums] . ': ' . $forum_list . '</p>';
 | |
| 
 | |
| 		unset($forum_list);
 | |
| 		unset($l_selected_forums);
 | |
| 	}
 | |
| 
 | |
| 	// Now output the list of users or groups ... these will always exist
 | |
| 	$l_selected_users = ($ug_type == 'user') ? ((sizeof($ug_data) == 1) ? 'SELECTED_USER' : 'SELECTED_USERS') : ((sizeof($ug_data) == 1) ? 'SELECTED_GROUP' : 'SELECTED_GROUPS'); 
 | |
| 
 | |
| 	echo '<p>' . $user->lang[$l_selected_users] . ': ' . $l_ug_list . '</p>';
 | |
| 
 | |
| 	unset($l_selected_users);
 | |
| 	unset($ug_data);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <p><?php echo $l_title_explain; ?></p>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 	if ($settings_hidden != '')
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h2 style="color:red"><?php echo $user->lang['WARNING']; ?></h2>
 | |
| 
 | |
| <p><?php echo $user->lang['WARNING_EXPLAIN']; ?></p>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <form method="post" name="acl" action="<?php echo "admin_permissions.$phpEx$SID&mode=$mode&submode=$submode"; ?>"><table cellspacing="2" cellpadding="0" border="0" align="center">
 | |
| <?php
 | |
| 
 | |
| 	// This is the main listing of options
 | |
| 
 | |
| 	// We output this for both deps and when update is requested where
 | |
| 	// deps exist
 | |
| 	if (($mode == 'admin' || $mode == 'supermod') && in_array($submode, array('forum', 'mod')))
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td colspan="2" align="right"><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0">
 | |
| 			<tr>
 | |
| 				<th colspan="2"><?php echo $user->lang['SELECT_FORUM']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="150"><?php echo $user->lang['WILL_SET_OPTIONS']; ?>:</td>
 | |
| 				<td class="row2"><select name="f[<?php echo $which_mode; ?>][]" multiple="4"><?php 
 | |
| 		
 | |
| 		echo make_forum_select($forum_id[$which_mode], false, true); 
 | |
| 		
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| 		</table><br /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 	// End deps output
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td align="left"><?php
 | |
| 	
 | |
| 	if ($view_options != '')
 | |
| 	{
 | |
| 	
 | |
| ?><select name="submode" onchange="if (this.options[this.selectedIndex].value != '') this.form.submit();"><?php echo $view_options; ?></select><?php
 | |
| 	
 | |
| 	}
 | |
| 	
 | |
| ?></td>
 | |
| 		<td align="right"><?php echo $user->lang['PRESETS']; ?>: <select name="set" onchange="use_preset(this.options[this.selectedIndex].value);"><option class="sep"><?php echo $user->lang['SELECT'] . ' ->'; ?></option><option value="all_yes"><?php echo $user->lang['ALL_YES']; ?></option><option value="all_no"><?php echo $user->lang['ALL_NO']; ?></option><option value="all_unset"><?php echo $user->lang['ALL_UNSET']; ?></option><?php 
 | |
| 
 | |
| 	$colspan = 4;
 | |
| 	if ($which_mode != $mode)
 | |
| 	{
 | |
| 		$colspan = 5;
 | |
| 		echo '<option value="all_ignore">' . $user->lang['ALL_IGNORE'] . '</option>';
 | |
| 	}
 | |
| 
 | |
| 	// Output user preset options ... if any
 | |
| 	echo ($preset_options) ? '<option class="sep">' . $user->lang['USER_PRESETS'] . ' ->' . '</option>' . $preset_options : ''; 
 | |
| 
 | |
| ?></select></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td colspan="2"><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th> <?php echo $user->lang['OPTION']; ?> </th>
 | |
| 				<th width="50"> <?php echo $user->lang['YES']; ?> </th>
 | |
| 				<th width="50"> <?php echo $user->lang['UNSET']; ?> </th>
 | |
| 				<th width="50"> <?php echo $user->lang['NO']; ?> </th>
 | |
| <?php
 | |
| 
 | |
| 	if ($which_mode != $mode)
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 				<th width="50"> <?php echo $user->lang['IGNORE']; ?> </th>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 	for($i = 0; $i < sizeof($auth_options); $i++)
 | |
| 	{
 | |
| 		$row_class = ($row_class == 'row1') ? 'row2' : 'row1';
 | |
| 
 | |
| 		// Try and output correct language strings, else output prettyfied auth_option
 | |
| 		$l_auth_option = (!empty($user->lang['acl_' . $auth_options[$i]['auth_option']])) ? $user->lang['acl_' . $auth_options[$i]['auth_option']] : ucfirst(preg_replace('#.*?_#', '', $auth_options[$i]['auth_option']));
 | |
| 		$s_auth_option = '[' . $which_mode . '][' . $auth_options[$i]['auth_option'] . ']';
 | |
| 
 | |
| 		
 | |
| 		// Which option should we select?
 | |
| 		$selected_yes = (isset($auth_settings[$which_mode][$auth_options[$i]['auth_option']]) && $auth_settings[$which_mode][$auth_options[$i]['auth_option']] == ACL_YES) ? ' checked="checked"' : '';
 | |
| 		$selected_no = (isset($auth_settings[$which_mode][$auth_options[$i]['auth_option']]) && $auth_settings[$which_mode][$auth_options[$i]['auth_option']] == ACL_NO) ? ' checked="checked"' : '';
 | |
| 		$selected_unset = (!isset($auth_settings[$which_mode][$auth_options[$i]['auth_option']]) || $auth_settings[$which_mode][$auth_options[$i]['auth_option']] == ACL_UNSET) ? ' checked="checked"' : '';
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="<?php echo $row_class; ?>" nowrap="nowrap"><?php echo $l_auth_option; ?> </td>
 | |
| 				<td class="<?php echo $row_class; ?>" align="center"><input type="radio" name="settings<?php echo $s_auth_option ;?>" value="<?php echo ACL_YES; ?>"<?php echo $selected_yes; ?> /></td>
 | |
| 				<td class="<?php echo $row_class; ?>" align="center"><input type="radio" name="settings<?php echo $s_auth_option ;?>" value="<?php echo ACL_UNSET; ?>"<?php echo $selected_unset; ?> /></td>
 | |
| 				<td class="<?php echo $row_class; ?>" align="center"><input type="radio" name="settings<?php echo $s_auth_option ;?>" value="<?php echo ACL_NO; ?>"<?php echo $selected_no; ?> /></td>
 | |
| <?php
 | |
| 
 | |
| 		if ($which_mode != $mode)
 | |
| 		{
 | |
| 			$selected_ignore = (isset($auth_settings[$which_mode][$auth_options[$i]['auth_option']]) && $auth_settings[$which_mode][$auth_options[$i]['auth_option']] == '*') ? ' checked="checked"' : '';
 | |
| 
 | |
| ?>
 | |
| 				<td class="<?php echo $row_class; ?>" align="center"><input type="radio" name="settings<?php echo $s_auth_option ;?>" value="*"<?php echo $selected_ignore; ?> /></td>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 
 | |
| ?>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| 
 | |
| 	// If we're setting forum or moderator options and a single forum has
 | |
| 	// been selected then look to see if any subforums exist. If they do
 | |
| 	// give user the option of cascading permissions to them
 | |
| 	if (($mode == 'forum' || $mode == 'mod') && empty($submode) && sizeof($forum_id[$which_mode]) == 1)
 | |
| 	{
 | |
| 		$children = get_forum_branch($forum_id[$which_mode][0], 'children', 'descending', false);
 | |
| 
 | |
| 		if (!empty($children))
 | |
| 		{
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<th colspan="<?php echo $colspan; ?>"><?php echo $user->lang['ACL_SUBFORUMS']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" colspan="<?php echo $colspan; ?>"><table width="100%" cellspacing="1" cellpadding="0" border="0">
 | |
| 					<tr>
 | |
| 						<td class="gensmall" colspan="4" height="16" align="center"><?php echo $user->lang['ACL_SUBFORUMS_EXPLAIN']; ?></td>
 | |
| 					</tr>
 | |
| <?php
 | |
| 
 | |
| 			foreach ($children as $row)
 | |
| 			{
 | |
| 
 | |
| ?>
 | |
| 					<tr>
 | |
| 						<td><input type="checkbox" name="inherit[]" value="<?php echo $row['forum_id']; ?>" /> <?php echo $row['forum_name']; ?></td>
 | |
| 					</tr>
 | |
| <?php
 | |
| 
 | |
| 			}
 | |
| 
 | |
| ?>
 | |
| 					<tr>
 | |
| 						<td height="16" align="center"><a class="gensmall" href="javascript:marklist('inherit', true);"><?php echo $user->lang['MARK_ALL']; ?></a> :: <a href="javascript:marklist('inherit', false);" class="gensmall"><?php echo $user->lang['UNMARK_ALL']; ?></a></td>
 | |
| 					</tr>
 | |
| 				</table></td>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Display event/cron radio buttons
 | |
| 	if ($auth->acl_gets('a_events', 'a_cron') && $mode != 'deps' && $submit != 'update')
 | |
| 	{
 | |
| 		$row_class = ($row_class == 'row1') ? 'row2' : 'row1';
 | |
| 
 | |
| ?>
 | |
| 			<!-- tr>
 | |
| 				<th colspan="<?php echo $colspan; ?>"><?php echo $user->lang['RUN_HOW']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="<?php echo $row_class; ?>" colspan="4" align="center"><input type="radio" name="runas" value="now" checked="checked" /> <?php echo $user->lang['RUN_AS_NOW']; ?><?php 
 | |
| 	
 | |
| 			if ($auth->acl_get('a_events'))
 | |
| 			{ 
 | |
| 
 | |
| ?>  <input type="radio" name="runas" value="evt" /> <?php 
 | |
| 	
 | |
| 				echo $user->lang['RUN_AS_EVT'];  
 | |
| 			}
 | |
| 			
 | |
| 			if ($auth->acl_get('a_cron'))
 | |
| 			{
 | |
| 
 | |
| ?>  <input type="radio" name="runas" value="crn" /> <?php 
 | |
| 	
 | |
| 				echo $user->lang['RUN_AS_CRN']; 
 | |
| 				
 | |
| 			}
 | |
| 
 | |
| ?></td>
 | |
| 			</tr -->
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="cat" colspan="<?php echo $colspan; ?>" align="center"><input class="mainoption" type="submit" name="submit_update" value="<?php echo $user->lang['UPDATE']; ?>" />  <input class="liteoption" type="submit" name="submit_cancel" value="<?php echo $user->lang['CANCEL']; ?>" /><input type="hidden" name="ug_type" value="<?php echo $ug_type; ?>" /><?php echo $ug_hidden; ?><?php 
 | |
| 
 | |
| 	// Output forum id data
 | |
| 	echo $s_forum_id;
 | |
| 
 | |
| 	// Output settings generated from other views
 | |
| 	echo $settings_hidden;
 | |
| 	unset($settings_hidden);
 | |
| 	
 | |
| ?></td>
 | |
| 			</tr>
 | |
| 		</table>
 | |
| 
 | |
| 		<br clear="all" />
 | |
| 
 | |
| 		<table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th colspan="4"><?php echo $user->lang['PRESETS']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" colspan="4"><table width="100%" cellspacing="1" cellpadding="0" border="0">
 | |
| 					<tr>
 | |
| 						<td colspan="2" height="16"><span class="gensmall"><?php echo $user->lang['PRESETS_EXPLAIN']; ?></span></td>
 | |
| 					</tr>
 | |
| 					<tr>
 | |
| 						<td nowrap="nowrap"><?php echo $user->lang['SELECT_PRESET']; ?>: </td>
 | |
| 						<td><select name="presetoption"><option class="sep" value="-1"><?php echo $user->lang['SELECT'] . ' ->'; ?></option><?php 
 | |
| 
 | |
| 	echo $preset_update_options;
 | |
| 			
 | |
| 		?></select></td>
 | |
| 					</tr>
 | |
| 					<tr>
 | |
| 						<td nowrap="nowrap"><?php echo $user->lang['PRESET_NAME']; ?>: </td>
 | |
| 						<td><input type="text" name="presetname" maxlength="25" /> </td>
 | |
| 					</tr>
 | |
| 				</table></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" colspan="4" align="center"><input class="liteoption" type="submit" name="submit_presetsave" value="<?php echo $user->lang['SAVE']; ?>" />  <input class="liteoption" type="submit" name="submit_presetdel" value="<?php echo $user->lang['DELETE']; ?>" /></td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| }
 | |
| 
 | |
| // Output page footer
 | |
| adm_page_footer();
 | |
| 
 | |
| ?>
 |