PostgreSQL Source Code  git master
pg_authid.h
Go to the documentation of this file.
1 /*-------------------------------------------------------------------------
2  *
3  * pg_authid.h
4  * definition of the "authorization identifier" system catalog (pg_authid)
5  *
6  * pg_shadow and pg_group are now publicly accessible views on pg_authid.
7  *
8  *
9  * Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
10  * Portions Copyright (c) 1994, Regents of the University of California
11  *
12  * src/include/catalog/pg_authid.h
13  *
14  * NOTES
15  * The Catalog.pm module reads this file and derives schema
16  * information.
17  *
18  *-------------------------------------------------------------------------
19  */
20 #ifndef PG_AUTHID_H
21 #define PG_AUTHID_H
22 
23 #include "catalog/genbki.h"
24 #include "catalog/pg_authid_d.h"
25 
26 /* ----------------
27  * pg_authid definition. cpp turns this into
28  * typedef struct FormData_pg_authid
29  * ----------------
30  */
31 CATALOG(pg_authid,1260,AuthIdRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_OID(2842,AuthIdRelation_Rowtype_Id) BKI_SCHEMA_MACRO
32 {
33  Oid oid; /* oid */
34  NameData rolname; /* name of role */
35  bool rolsuper; /* read this field via superuser() only! */
36  bool rolinherit; /* inherit privileges from other roles? */
37  bool rolcreaterole; /* allowed to create more roles? */
38  bool rolcreatedb; /* allowed to create databases? */
39  bool rolcanlogin; /* allowed to log in as session user? */
40  bool rolreplication; /* role used for streaming replication */
41  bool rolbypassrls; /* bypasses row-level security? */
42  int32 rolconnlimit; /* max connections allowed (-1=no limit) */
43 
44  /* remaining fields may be null; use heap_getattr to read them! */
45 #ifdef CATALOG_VARLEN /* variable-length fields start here */
46  text rolpassword; /* password, if any */
47  timestamptz rolvaliduntil; /* password expiration time, if any */
48 #endif
50 
51 /* ----------------
52  * Form_pg_authid corresponds to a pointer to a tuple with
53  * the format of pg_authid relation.
54  * ----------------
55  */
57 
58 DECLARE_TOAST_WITH_MACRO(pg_authid, 4175, 4176, PgAuthidToastTable, PgAuthidToastIndex);
59 
60 DECLARE_UNIQUE_INDEX(pg_authid_rolname_index, 2676, AuthIdRolnameIndexId, pg_authid, btree(rolname name_ops));
61 DECLARE_UNIQUE_INDEX_PKEY(pg_authid_oid_index, 2677, AuthIdOidIndexId, pg_authid, btree(oid oid_ops));
62 
63 MAKE_SYSCACHE(AUTHNAME, pg_authid_rolname_index, 8);
64 MAKE_SYSCACHE(AUTHOID, pg_authid_oid_index, 8);
65 
66 #endif /* PG_AUTHID_H */
signed int int32
Definition: c.h:494
#define BKI_SHARED_RELATION
Definition: genbki.h:27
#define BKI_ROWTYPE_OID(oid, oidmacro)
Definition: genbki.h:28
FormData_pg_authid
Definition: pg_authid.h:49
NameData rolname
Definition: pg_authid.h:34
bool rolcreaterole
Definition: pg_authid.h:37
MAKE_SYSCACHE(AUTHNAME, pg_authid_rolname_index, 8)
bool rolsuper
Definition: pg_authid.h:35
DECLARE_UNIQUE_INDEX_PKEY(pg_authid_oid_index, 2677, AuthIdOidIndexId, pg_authid, btree(oid oid_ops))
bool rolinherit
Definition: pg_authid.h:36
FormData_pg_authid * Form_pg_authid
Definition: pg_authid.h:56
DECLARE_TOAST_WITH_MACRO(pg_authid, 4175, 4176, PgAuthidToastTable, PgAuthidToastIndex)
AuthIdRelation_Rowtype_Id BKI_SCHEMA_MACRO
Definition: pg_authid.h:32
DECLARE_UNIQUE_INDEX(pg_authid_rolname_index, 2676, AuthIdRolnameIndexId, pg_authid, btree(rolname name_ops))
bool rolcanlogin
Definition: pg_authid.h:39
bool rolbypassrls
Definition: pg_authid.h:41
CATALOG(pg_authid, 1260, AuthIdRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_OID(2842
bool rolcreatedb
Definition: pg_authid.h:38
bool rolreplication
Definition: pg_authid.h:40
int32 rolconnlimit
Definition: pg_authid.h:42
unsigned int Oid
Definition: postgres_ext.h:31
Definition: c.h:741
Definition: c.h:687