1 /*------------------------------------------------------------------------- 2 * 3 * pg_default_acl.h 4 * definition of the system catalog for default ACLs of new objects 5 * (pg_default_acl) 6 * 7 * 8 * Portions Copyright (c) 1996-2018, PostgreSQL Global Development Group 9 * Portions Copyright (c) 1994, Regents of the University of California 10 * 11 * src/include/catalog/pg_default_acl.h 12 * 13 * NOTES 14 * The Catalog.pm module reads this file and derives schema 15 * information. 16 * 17 *------------------------------------------------------------------------- 18 */ 19 #ifndef PG_DEFAULT_ACL_H 20 #define PG_DEFAULT_ACL_H 21 22 #include "catalog/genbki.h" 23 #include "catalog/pg_default_acl_d.h" 24 25 /* ---------------- 26 * pg_default_acl definition. cpp turns this into 27 * typedef struct FormData_pg_default_acl 28 * ---------------- 29 */ 30 CATALOG(pg_default_acl,826,DefaultAclRelationId) 31 { 32 Oid defaclrole; /* OID of role owning this ACL */ 33 Oid defaclnamespace; /* OID of namespace, or 0 for all */ 34 char defaclobjtype; /* see DEFACLOBJ_xxx constants below */ 35 36 #ifdef CATALOG_VARLEN /* variable-length fields start here */ 37 aclitem defaclacl[1]; /* permissions to add at CREATE time */ 38 #endif 39 } FormData_pg_default_acl; 40 41 /* ---------------- 42 * Form_pg_default_acl corresponds to a pointer to a tuple with 43 * the format of pg_default_acl relation. 44 * ---------------- 45 */ 46 typedef FormData_pg_default_acl *Form_pg_default_acl; 47 48 #ifdef EXPOSE_TO_CLIENT_CODE 49 50 /* 51 * Types of objects for which the user is allowed to specify default 52 * permissions through pg_default_acl. These codes are used in the 53 * defaclobjtype column. 54 */ 55 #define DEFACLOBJ_RELATION 'r' /* table, view */ 56 #define DEFACLOBJ_SEQUENCE 'S' /* sequence */ 57 #define DEFACLOBJ_FUNCTION 'f' /* function */ 58 #define DEFACLOBJ_TYPE 'T' /* type */ 59 #define DEFACLOBJ_NAMESPACE 'n' /* namespace */ 60 61 #endif /* EXPOSE_TO_CLIENT_CODE */ 62 63 #endif /* PG_DEFAULT_ACL_H */ 64