mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 14:18:52 +00:00
Almost but not quite ... wouldn't update user levels for former mods who've been removed from auth_access ... doh
git-svn-id: file:///svn/phpbb/trunk@2229 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
parent
81fc6e2d22
commit
33a6fbcda0
1 changed files with 43 additions and 8 deletions
|
@ -417,13 +417,48 @@ if ( isset($HTTP_POST_VARS['submit']) && ( ( $mode == "user" && $user_id ) || (
|
||||||
//
|
//
|
||||||
// Update user level to user for appropriate users
|
// Update user level to user for appropriate users
|
||||||
//
|
//
|
||||||
$sql = "SELECT u.user_id, SUM(aa.auth_mod) AS mod
|
switch ( SQL_LAYER )
|
||||||
FROM " . AUTH_ACCESS_TABLE . " aa, " . USER_GROUP_TABLE . " ug, " . USERS_TABLE . " u
|
{
|
||||||
WHERE ug.group_id = aa.group_id
|
case 'postgresql':
|
||||||
AND u.user_id = ug.user_id
|
$sql = "SELECT u.user_id
|
||||||
AND u.user_level NOT IN (" . USER . ", " . ADMIN . ")
|
FROM " . USERS_TABLE . " u, " . USER_GROUP_TABLE . " ug, " . AUTH_ACCESS_TABLE . " aa
|
||||||
GROUP BY u.user_id
|
WHERE ug.user_id = u.user_id
|
||||||
HAVING mod = 0";
|
AND aa.group_id = ug.group_id
|
||||||
|
AND u.user_level NOT IN (" . USER . ", " . ADMIN . ")
|
||||||
|
GROUP BY u.user_id
|
||||||
|
HAVING SUM(aa.auth_mod) = 0
|
||||||
|
UNION (
|
||||||
|
SELECT u.user_id
|
||||||
|
FROM " . USERS_TABLE . " u
|
||||||
|
WHERE NOT EXISTS (
|
||||||
|
SELECT aa.auth_mod
|
||||||
|
FROM " . USER_GROUP_TABLE . " ug, " . AUTH_ACCESS_TABLE . " aa
|
||||||
|
WHERE ug.user_id = u.user_id
|
||||||
|
AND aa.group_id = ug.group_id
|
||||||
|
)
|
||||||
|
AND u.user_level NOT IN (" . USER . ", " . ADMIN . ")
|
||||||
|
GROUP BY u.user_id
|
||||||
|
)";
|
||||||
|
break;
|
||||||
|
case 'oracle':
|
||||||
|
$sql = "SELECT u.user_id, SUM(aa.auth_mod) AS mod
|
||||||
|
FROM " . USERS_TABLE . " u, " . USER_GROUP_TABLE . " ug, " . AUTH_ACCESS_TABLE . " aa
|
||||||
|
WHERE ug.user_id = u.user_id(+)
|
||||||
|
AND aa.group_id = ug.group_id(+)
|
||||||
|
AND u.user_level NOT IN (" . USER . ", " . ADMIN . ")
|
||||||
|
GROUP BY u.user_id
|
||||||
|
HAVING mod = 0";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$sql = "SELECT u.user_id, SUM(aa.auth_mod) AS mod
|
||||||
|
FROM ( ( " . USERS_TABLE . " u
|
||||||
|
LEFT JOIN " . USER_GROUP_TABLE . " ug ON ug.user_id = u.user_id )
|
||||||
|
LEFT JOIN " . AUTH_ACCESS_TABLE . " aa ON aa.group_id = ug.group_id )
|
||||||
|
WHERE u.user_level NOT IN (" . USER . ", " . ADMIN . ")
|
||||||
|
GROUP BY u.user_id
|
||||||
|
HAVING mod = 0";
|
||||||
|
break;
|
||||||
|
}
|
||||||
if ( !($result = $db->sql_query($sql)) )
|
if ( !($result = $db->sql_query($sql)) )
|
||||||
{
|
{
|
||||||
message_die(GENERAL_ERROR, "Couldn't obtain user/group permissions", "", __LINE__, __FILE__, $sql);
|
message_die(GENERAL_ERROR, "Couldn't obtain user/group permissions", "", __LINE__, __FILE__, $sql);
|
||||||
|
@ -432,7 +467,7 @@ if ( isset($HTTP_POST_VARS['submit']) && ( ( $mode == "user" && $user_id ) || (
|
||||||
$unset_mod = "";
|
$unset_mod = "";
|
||||||
while( $row = $db->sql_fetchrow($result) )
|
while( $row = $db->sql_fetchrow($result) )
|
||||||
{
|
{
|
||||||
$unset_mod .= ( ( $unset_mod != "" ) ? ", " : "" ) . $row['user_id'];
|
echo $unset_mod .= ( ( $unset_mod != "" ) ? ", " : "" ) . $row['user_id'];
|
||||||
}
|
}
|
||||||
$db->sql_freeresult($result);
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue