]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix ALTER DEFAULT PRIVILEGES with duplicated objects
authorMichael Paquier <michael@paquier.xyz>
Wed, 20 Jan 2021 02:39:24 +0000 (11:39 +0900)
committerMichael Paquier <michael@paquier.xyz>
Wed, 20 Jan 2021 02:39:24 +0000 (11:39 +0900)
commit74ee3abcfefa6e6b0756f85baa31a7ae21bb2fec
treee44e4cc9b6547aaf6ba50833481581302b1d212e
parentfac54bd5e216c18d921b7ba18b30e8f8139034b6
Fix ALTER DEFAULT PRIVILEGES with duplicated objects

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