mirror of
https://github.com/postgres/postgres.git
synced 2025-11-06 07:49:08 +03:00
Support user mappings in get_object_address
Since commit 72dd233d3e we were trying to obtain object addressing
information in sql_drop event triggers, but that caused failures when
the drops involved user mappings. This addition enables that to work
again. Naturally, pg_get_object_address can work with these objects
now, too.
I toyed with the idea of removing DropUserMappingStmt as a node and
using DropStmt instead in the DropUserMappingStmt grammar production,
but that didn't go very well: for one thing the messages thrown by the
specific code are specialized (you get "server not found" if you specify
the wrong server, instead of a generic "user mapping for ... not found"
which you'd get it we were to merge this with RemoveObjects --- unless
we added even more special cases). For another thing, it would require
to pass RoleSpec nodes through the objname/objargs representation used
by RemoveObjects, which works in isolation, but gets messy when
pg_get_object_address is involved. So I dropped this part for now.
Reviewed by Stephen Frost.
This commit is contained in:
@@ -1268,6 +1268,7 @@ typedef enum ObjectType
|
||||
OBJECT_TSPARSER,
|
||||
OBJECT_TSTEMPLATE,
|
||||
OBJECT_TYPE,
|
||||
OBJECT_USER_MAPPING,
|
||||
OBJECT_VIEW
|
||||
} ObjectType;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user