Add USER SET parameter values for pg_db_role_setting
authorAlexander Korotkov <[email protected]>
Fri, 9 Dec 2022 10:12:20 +0000 (13:12 +0300)
committerAlexander Korotkov <[email protected]>
Fri, 9 Dec 2022 10:12:20 +0000 (13:12 +0300)
commit096dd80f3ccc103c8e078fca05e6ccfb2071aa91
treebfcd25f09b535b52d0e0373c9f8909b030f3a537
parent5defdef8aa0535b8e9365ea9cceee60d5731395f
Add USER SET parameter values for pg_db_role_setting

The USER SET flag specifies that the variable should be set on behalf of an
ordinary role.  That lets ordinary roles set placeholder variables, which
permission requirements are not known yet.  Such a value wouldn't be used if
the variable finally appear to require superuser privileges.

The new flags are stored in the pg_db_role_setting.setuser array.  Catversion
is bumped.

This commit is inspired by the previous work by Steve Chavez.

Discussion: https://postgr.es/m/CAPpHfdsLd6E--epnGqXENqLP6dLwuNZrPMcNYb3wJ87WR7UBOQ%40mail.gmail.com
Author: Alexander Korotkov, Steve Chavez
Reviewed-by: Pavel Borisov, Steve Chavez
34 files changed:
doc/src/sgml/catalogs.sgml
doc/src/sgml/ref/alter_database.sgml
doc/src/sgml/ref/alter_role.sgml
doc/src/sgml/ref/alter_user.sgml
doc/src/sgml/ref/psql-ref.sgml
src/backend/catalog/pg_db_role_setting.c
src/backend/catalog/pg_proc.c
src/backend/commands/functioncmds.c
src/backend/parser/gram.y
src/backend/utils/adt/arrayfuncs.c
src/backend/utils/fmgr/fmgr.c
src/backend/utils/misc/guc.c
src/backend/utils/misc/guc_funcs.c
src/bin/pg_dump/dumputils.c
src/bin/pg_dump/dumputils.h
src/bin/pg_dump/pg_dump.c
src/bin/pg_dump/pg_dumpall.c
src/bin/psql/describe.c
src/bin/psql/tab-complete.c
src/include/catalog/catversion.h
src/include/catalog/pg_db_role_setting.h
src/include/nodes/parsenodes.h
src/include/utils/guc.h
src/test/modules/Makefile
src/test/modules/meson.build
src/test/modules/test_pg_db_role_setting/.gitignore [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/Makefile [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/expected/test_pg_db_role_setting.out [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/meson.build [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/sql/test_pg_db_role_setting.sql [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/test_pg_db_role_setting--1.0.sql [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/test_pg_db_role_setting.c [new file with mode: 0644]
src/test/modules/test_pg_db_role_setting/test_pg_db_role_setting.control [new file with mode: 0644]
src/test/regress/expected/psql.out