mirror of
https://github.com/postgres/postgres.git
synced 2025-07-07 00:36:50 +03:00
Wrap calls to SearchSysCache and related functions using macros.
The purpose of this change is to eliminate the need for every caller of SearchSysCache, SearchSysCacheCopy, SearchSysCacheExists, GetSysCacheOid, and SearchSysCacheList to know the maximum number of allowable keys for a syscache entry (currently 4). This will make it far easier to increase the maximum number of keys in a future release should we choose to do so, and it makes the code shorter, too. Design and review by Tom Lane.
This commit is contained in:
@ -6,7 +6,7 @@
|
||||
* Portions Copyright (c) 1996-2010, PostgreSQL Global Development Group
|
||||
* Portions Copyright (c) 1994, Regents of the University of California
|
||||
*
|
||||
* $PostgreSQL: pgsql/src/backend/commands/user.c,v 1.191 2010/01/02 16:57:39 momjian Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/commands/user.c,v 1.192 2010/02/14 18:42:14 rhaas Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -61,9 +61,7 @@ have_createrole_privilege(void)
|
||||
if (superuser())
|
||||
return true;
|
||||
|
||||
utup = SearchSysCache(AUTHOID,
|
||||
ObjectIdGetDatum(GetUserId()),
|
||||
0, 0, 0);
|
||||
utup = SearchSysCache1(AUTHOID, ObjectIdGetDatum(GetUserId()));
|
||||
if (HeapTupleIsValid(utup))
|
||||
{
|
||||
result = ((Form_pg_authid) GETSTRUCT(utup))->rolcreaterole;
|
||||
@ -295,9 +293,7 @@ CreateRole(CreateRoleStmt *stmt)
|
||||
pg_authid_rel = heap_open(AuthIdRelationId, RowExclusiveLock);
|
||||
pg_authid_dsc = RelationGetDescr(pg_authid_rel);
|
||||
|
||||
tuple = SearchSysCache(AUTHNAME,
|
||||
PointerGetDatum(stmt->role),
|
||||
0, 0, 0);
|
||||
tuple = SearchSysCache1(AUTHNAME, PointerGetDatum(stmt->role));
|
||||
if (HeapTupleIsValid(tuple))
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_DUPLICATE_OBJECT),
|
||||
@ -576,9 +572,7 @@ AlterRole(AlterRoleStmt *stmt)
|
||||
pg_authid_rel = heap_open(AuthIdRelationId, RowExclusiveLock);
|
||||
pg_authid_dsc = RelationGetDescr(pg_authid_rel);
|
||||
|
||||
tuple = SearchSysCache(AUTHNAME,
|
||||
PointerGetDatum(stmt->role),
|
||||
0, 0, 0);
|
||||
tuple = SearchSysCache1(AUTHNAME, PointerGetDatum(stmt->role));
|
||||
if (!HeapTupleIsValid(tuple))
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_UNDEFINED_OBJECT),
|
||||
@ -765,9 +759,7 @@ AlterRoleSet(AlterRoleSetStmt *stmt)
|
||||
HeapTuple roletuple;
|
||||
Oid databaseid = InvalidOid;
|
||||
|
||||
roletuple = SearchSysCache(AUTHNAME,
|
||||
PointerGetDatum(stmt->role),
|
||||
0, 0, 0);
|
||||
roletuple = SearchSysCache1(AUTHNAME, PointerGetDatum(stmt->role));
|
||||
|
||||
if (!HeapTupleIsValid(roletuple))
|
||||
ereport(ERROR,
|
||||
@ -849,9 +841,7 @@ DropRole(DropRoleStmt *stmt)
|
||||
SysScanDesc sscan;
|
||||
Oid roleid;
|
||||
|
||||
tuple = SearchSysCache(AUTHNAME,
|
||||
PointerGetDatum(role),
|
||||
0, 0, 0);
|
||||
tuple = SearchSysCache1(AUTHNAME, PointerGetDatum(role));
|
||||
if (!HeapTupleIsValid(tuple))
|
||||
{
|
||||
if (!stmt->missing_ok)
|
||||
@ -1005,9 +995,7 @@ RenameRole(const char *oldname, const char *newname)
|
||||
rel = heap_open(AuthIdRelationId, RowExclusiveLock);
|
||||
dsc = RelationGetDescr(rel);
|
||||
|
||||
oldtuple = SearchSysCache(AUTHNAME,
|
||||
CStringGetDatum(oldname),
|
||||
0, 0, 0);
|
||||
oldtuple = SearchSysCache1(AUTHNAME, CStringGetDatum(oldname));
|
||||
if (!HeapTupleIsValid(oldtuple))
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_UNDEFINED_OBJECT),
|
||||
@ -1033,9 +1021,7 @@ RenameRole(const char *oldname, const char *newname)
|
||||
errmsg("current user cannot be renamed")));
|
||||
|
||||
/* make sure the new name doesn't exist */
|
||||
if (SearchSysCacheExists(AUTHNAME,
|
||||
CStringGetDatum(newname),
|
||||
0, 0, 0))
|
||||
if (SearchSysCacheExists1(AUTHNAME, CStringGetDatum(newname)))
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_DUPLICATE_OBJECT),
|
||||
errmsg("role \"%s\" already exists", newname)));
|
||||
@ -1326,10 +1312,9 @@ AddRoleMems(const char *rolename, Oid roleid,
|
||||
* Check if entry for this role/member already exists; if so, give
|
||||
* warning unless we are adding admin option.
|
||||
*/
|
||||
authmem_tuple = SearchSysCache(AUTHMEMROLEMEM,
|
||||
ObjectIdGetDatum(roleid),
|
||||
ObjectIdGetDatum(memberid),
|
||||
0, 0);
|
||||
authmem_tuple = SearchSysCache2(AUTHMEMROLEMEM,
|
||||
ObjectIdGetDatum(roleid),
|
||||
ObjectIdGetDatum(memberid));
|
||||
if (HeapTupleIsValid(authmem_tuple) &&
|
||||
(!admin_opt ||
|
||||
((Form_pg_auth_members) GETSTRUCT(authmem_tuple))->admin_option))
|
||||
@ -1440,10 +1425,9 @@ DelRoleMems(const char *rolename, Oid roleid,
|
||||
/*
|
||||
* Find entry for this role/member
|
||||
*/
|
||||
authmem_tuple = SearchSysCache(AUTHMEMROLEMEM,
|
||||
ObjectIdGetDatum(roleid),
|
||||
ObjectIdGetDatum(memberid),
|
||||
0, 0);
|
||||
authmem_tuple = SearchSysCache2(AUTHMEMROLEMEM,
|
||||
ObjectIdGetDatum(roleid),
|
||||
ObjectIdGetDatum(memberid));
|
||||
if (!HeapTupleIsValid(authmem_tuple))
|
||||
{
|
||||
ereport(WARNING,
|
||||
|
Reference in New Issue
Block a user