mirror of
https://github.com/postgres/postgres.git
synced 2025-06-11 20:28:21 +03:00
Improve several permission-related error messages.
Mainly move some detail from errmsg to errdetail, remove explicit mention of superuser where appropriate, since that is implied in most permission checks, and make messages more uniform. Author: Nathan Bossart <nathandbossart@gmail.com> Discussion: https://www.postgresql.org/message-id/20230316234701.GA903298@nathanxps13
This commit is contained in:
@ -54,13 +54,16 @@ RESET ROLE;
|
||||
-- plain user *can't* can control replication
|
||||
SET ROLE regress_lr_normal;
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot', 'test_decoding');
|
||||
ERROR: must be superuser or replication role to use replication slots
|
||||
ERROR: permission denied to use replication slots
|
||||
DETAIL: Only roles with the REPLICATION attribute may use replication slots.
|
||||
INSERT INTO lr_test VALUES('lr_superuser_init');
|
||||
ERROR: permission denied for table lr_test
|
||||
SELECT data FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1');
|
||||
ERROR: must be superuser or replication role to use replication slots
|
||||
ERROR: permission denied to use replication slots
|
||||
DETAIL: Only roles with the REPLICATION attribute may use replication slots.
|
||||
SELECT pg_drop_replication_slot('regression_slot');
|
||||
ERROR: must be superuser or replication role to use replication slots
|
||||
ERROR: permission denied to use replication slots
|
||||
DETAIL: Only roles with the REPLICATION attribute may use replication slots.
|
||||
RESET ROLE;
|
||||
-- replication users can drop superuser created slots
|
||||
SET ROLE regress_lr_superuser;
|
||||
@ -90,7 +93,8 @@ SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot', 'test_d
|
||||
RESET ROLE;
|
||||
SET ROLE regress_lr_normal;
|
||||
SELECT pg_drop_replication_slot('regression_slot');
|
||||
ERROR: must be superuser or replication role to use replication slots
|
||||
ERROR: permission denied to use replication slots
|
||||
DETAIL: Only roles with the REPLICATION attribute may use replication slots.
|
||||
RESET ROLE;
|
||||
-- all users can see existing slots
|
||||
SET ROLE regress_lr_superuser;
|
||||
|
Reference in New Issue
Block a user