mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-09-27 22:22:05 +02:00
9b1a6f50b9
Add a new genbki macros MAKE_SYSCACHE that specifies the syscache ID macro, the underlying index, and the number of buckets. From that, we can generate the existing tables in syscache.h and syscache.c via genbki.pl. Reviewed-by: John Naylor <johncnaylorls@gmail.com> Discussion: https://www.postgresql.org/message-id/flat/75ae5875-3abc-dafc-8aec-73247ed41cde@eisentraut.org
75 lines
2.4 KiB
C
75 lines
2.4 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* pg_default_acl.h
|
|
* definition of the system catalog for default ACLs of new objects
|
|
* (pg_default_acl)
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/catalog/pg_default_acl.h
|
|
*
|
|
* NOTES
|
|
* The Catalog.pm module reads this file and derives schema
|
|
* information.
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef PG_DEFAULT_ACL_H
|
|
#define PG_DEFAULT_ACL_H
|
|
|
|
#include "catalog/genbki.h"
|
|
#include "catalog/pg_default_acl_d.h"
|
|
|
|
/* ----------------
|
|
* pg_default_acl definition. cpp turns this into
|
|
* typedef struct FormData_pg_default_acl
|
|
* ----------------
|
|
*/
|
|
CATALOG(pg_default_acl,826,DefaultAclRelationId)
|
|
{
|
|
Oid oid; /* oid */
|
|
Oid defaclrole BKI_LOOKUP(pg_authid); /* OID of role owning this
|
|
* ACL */
|
|
Oid defaclnamespace BKI_LOOKUP_OPT(pg_namespace); /* OID of namespace, or
|
|
* 0 for all */
|
|
char defaclobjtype; /* see DEFACLOBJ_xxx constants below */
|
|
|
|
#ifdef CATALOG_VARLEN /* variable-length fields start here */
|
|
aclitem defaclacl[1] BKI_FORCE_NOT_NULL; /* permissions to add at
|
|
* CREATE time */
|
|
#endif
|
|
} FormData_pg_default_acl;
|
|
|
|
/* ----------------
|
|
* Form_pg_default_acl corresponds to a pointer to a tuple with
|
|
* the format of pg_default_acl relation.
|
|
* ----------------
|
|
*/
|
|
typedef FormData_pg_default_acl *Form_pg_default_acl;
|
|
|
|
DECLARE_TOAST(pg_default_acl, 4143, 4144);
|
|
|
|
DECLARE_UNIQUE_INDEX(pg_default_acl_role_nsp_obj_index, 827, DefaultAclRoleNspObjIndexId, pg_default_acl, btree(defaclrole oid_ops, defaclnamespace oid_ops, defaclobjtype char_ops));
|
|
DECLARE_UNIQUE_INDEX_PKEY(pg_default_acl_oid_index, 828, DefaultAclOidIndexId, pg_default_acl, btree(oid oid_ops));
|
|
|
|
MAKE_SYSCACHE(DEFACLROLENSPOBJ, pg_default_acl_role_nsp_obj_index, 8);
|
|
|
|
#ifdef EXPOSE_TO_CLIENT_CODE
|
|
|
|
/*
|
|
* Types of objects for which the user is allowed to specify default
|
|
* permissions through pg_default_acl. These codes are used in the
|
|
* defaclobjtype column.
|
|
*/
|
|
#define DEFACLOBJ_RELATION 'r' /* table, view */
|
|
#define DEFACLOBJ_SEQUENCE 'S' /* sequence */
|
|
#define DEFACLOBJ_FUNCTION 'f' /* function */
|
|
#define DEFACLOBJ_TYPE 'T' /* type */
|
|
#define DEFACLOBJ_NAMESPACE 'n' /* namespace */
|
|
|
|
#endif /* EXPOSE_TO_CLIENT_CODE */
|
|
|
|
#endif /* PG_DEFAULT_ACL_H */
|