]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix ALTER DEFAULT PRIVILEGES with duplicated objects
authorMichael Paquier <michael@paquier.xyz>
Wed, 20 Jan 2021 02:39:17 +0000 (11:39 +0900)
committerMichael Paquier <michael@paquier.xyz>
Wed, 20 Jan 2021 02:39:17 +0000 (11:39 +0900)
Specifying duplicated objects in this command would lead to unique
constraint violations in pg_default_acl or "tuple already updated by
self" errors.  Similarly to GRANT/REVOKE, increment the command ID after
each subcommand processing to allow this case to work transparently.

A regression test is added by tweaking one of the existing queries of
privileges.sql to stress this case.

Reported-by: Andrus
Author: Michael Paquier
Reviewed-by: Álvaro Herrera
Discussion: https://postgr.es/m/ae2a7dc1-9d71-8cba-3bb9-e4cb7eb1f44e@hot.ee
Backpatch-through: 9.5

src/backend/catalog/aclchk.c
src/test/regress/expected/privileges.out
src/test/regress/sql/privileges.sql

index 2797af35c3d48259e737246bb3a439731f7b2473..e2970bfb005f1c617e1525402e62328aa8ed4246 100644 (file)
@@ -1391,6 +1391,9 @@ SetDefaultACL(InternalDefaultACL *iacls)
                ReleaseSysCache(tuple);
 
        table_close(rel, RowExclusiveLock);
+
+       /* prevent error when processing duplicate objects */
+       CommandCounterIncrement();
 }
 
 
index 534f0f63e0e03b2a96b98534f7e864d83f0556b7..1dcc2031ed82daa66e5312022c05a9e94635a5b4 100644 (file)
@@ -1617,7 +1617,8 @@ SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'INSERT'); -
  f
 (1 row)
 
-ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT SELECT ON TABLES TO public;
+-- placeholder for test with duplicated schema and role names
+ALTER DEFAULT PRIVILEGES IN SCHEMA testns,testns GRANT SELECT ON TABLES TO public,public;
 SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'SELECT'); -- no
  has_table_privilege 
 ---------------------
index 393b7090eb74f9faefbe26d1f9bd12350e030c9a..3e94477cd5038d063a612bfcf5738a867cd80b05 100644 (file)
@@ -961,7 +961,8 @@ CREATE TABLE testns.acltest1 (x int);
 SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'SELECT'); -- no
 SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'INSERT'); -- no
 
-ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT SELECT ON TABLES TO public;
+-- placeholder for test with duplicated schema and role names
+ALTER DEFAULT PRIVILEGES IN SCHEMA testns,testns GRANT SELECT ON TABLES TO public,public;
 
 SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'SELECT'); -- no
 SELECT has_table_privilege('regress_priv_user1', 'testns.acltest1', 'INSERT'); -- no