mirror of
https://github.com/postgres/postgres.git
synced 2025-06-14 18:42:34 +03:00
Add new OID alias type regrole
The new type has the scope of whole the database cluster so it doesn't behave the same as the existing OID alias types which have database scope, concerning object dependency. To avoid confusion constants of the new type are prohibited from appearing where dependencies are made involving it. Also, add a note to the docs about possible MVCC violation and optimization issues, which are general over the all reg* types. Kyotaro Horiguchi
This commit is contained in:
@ -648,23 +648,29 @@ SetCurrentRoleId(Oid roleid, bool is_superuser)
|
||||
|
||||
|
||||
/*
|
||||
* Get user name from user oid
|
||||
* Get user name from user oid, returns NULL for nonexistent roleid if noerr
|
||||
* is true.
|
||||
*/
|
||||
char *
|
||||
GetUserNameFromId(Oid roleid)
|
||||
GetUserNameFromId(Oid roleid, bool noerr)
|
||||
{
|
||||
HeapTuple tuple;
|
||||
char *result;
|
||||
|
||||
tuple = SearchSysCache1(AUTHOID, ObjectIdGetDatum(roleid));
|
||||
if (!HeapTupleIsValid(tuple))
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_UNDEFINED_OBJECT),
|
||||
errmsg("invalid role OID: %u", roleid)));
|
||||
|
||||
result = pstrdup(NameStr(((Form_pg_authid) GETSTRUCT(tuple))->rolname));
|
||||
|
||||
ReleaseSysCache(tuple);
|
||||
{
|
||||
if (!noerr)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_UNDEFINED_OBJECT),
|
||||
errmsg("invalid role OID: %u", roleid)));
|
||||
result = NULL;
|
||||
}
|
||||
else
|
||||
{
|
||||
result = pstrdup(NameStr(((Form_pg_authid) GETSTRUCT(tuple))->rolname));
|
||||
ReleaseSysCache(tuple);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user