diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2005-11-04 17:25:15 +0000 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2005-11-04 17:25:15 +0000 |
commit | c3d8de0907b53e3ce8988c71181edb6bcecd5aa6 (patch) | |
tree | a1042b32888fa0bd6486d3fd6c00fa5e5a317ef2 /src/backend/commands/user.c | |
parent | e47ea0566c58e9a7f3a592e9f44d57c4a1823447 (diff) |
Disregard superuserness when checking to see if a role GRANT would
create circularity of role memberships. This is a minimum-impact fix
for the problem reported by Florian Pflug. I thought about removing
the superuser_arg test from is_member_of_role() altogether, as it seems
redundant for many of the callers --- but not all, and it's way too late
in the 8.1 cycle to be making large changes. Perhaps reconsider this
later.
Diffstat (limited to 'src/backend/commands/user.c')
-rw-r--r-- | src/backend/commands/user.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/backend/commands/user.c b/src/backend/commands/user.c index d26b3f8c8cb..91befbc6aba 100644 --- a/src/backend/commands/user.c +++ b/src/backend/commands/user.c @@ -6,7 +6,7 @@ * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $PostgreSQL: pgsql/src/backend/commands/user.c,v 1.163 2005/10/29 00:31:51 petere Exp $ + * $PostgreSQL: pgsql/src/backend/commands/user.c,v 1.164 2005/11/04 17:25:15 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -1214,9 +1214,10 @@ AddRoleMems(const char *rolename, Oid roleid, * Refuse creation of membership loops, including the trivial case * where a role is made a member of itself. We do this by checking to * see if the target role is already a member of the proposed member - * role. + * role. We have to ignore possible superuserness, however, else we + * could never grant membership in a superuser-privileged role. */ - if (is_member_of_role(roleid, memberid)) + if (is_member_of_role_nosuper(roleid, memberid)) ereport(ERROR, (errcode(ERRCODE_INVALID_GRANT_OPERATION), (errmsg("role \"%s\" is a member of role \"%s\"", |