PostgreSQL Source Code  git master
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros
event_trigger.h File Reference
Include dependency graph for event_trigger.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  EventTriggerData
 

Macros

#define AT_REWRITE_ALTER_PERSISTENCE   0x01
 
#define AT_REWRITE_DEFAULT_VAL   0x02
 
#define AT_REWRITE_COLUMN_REWRITE   0x04
 
#define AT_REWRITE_ALTER_OID   0x08
 
#define CALLED_AS_EVENT_TRIGGER(fcinfo)   ((fcinfo)->context != NULL && IsA((fcinfo)->context, EventTriggerData))
 

Typedefs

typedef struct EventTriggerData EventTriggerData
 

Functions

Oid CreateEventTrigger (CreateEventTrigStmt *stmt)
 
void RemoveEventTriggerById (Oid ctrigOid)
 
Oid get_event_trigger_oid (const char *trigname, bool missing_ok)
 
Oid AlterEventTrigger (AlterEventTrigStmt *stmt)
 
ObjectAddress AlterEventTriggerOwner (const char *name, Oid newOwnerId)
 
void AlterEventTriggerOwner_oid (Oid, Oid newOwnerId)
 
bool EventTriggerSupportsObjectType (ObjectType obtype)
 
bool EventTriggerSupportsObjectClass (ObjectClass objclass)
 
bool EventTriggerSupportsGrantObjectType (GrantObjectType objtype)
 
void EventTriggerDDLCommandStart (Node *parsetree)
 
void EventTriggerDDLCommandEnd (Node *parsetree)
 
void EventTriggerSQLDrop (Node *parsetree)
 
void EventTriggerTableRewrite (Node *parsetree, Oid tableOid, int reason)
 
bool EventTriggerBeginCompleteQuery (void)
 
void EventTriggerEndCompleteQuery (void)
 
bool trackDroppedObjectsNeeded (void)
 
void EventTriggerSQLDropAddObject (const ObjectAddress *object, bool original, bool normal)
 
void EventTriggerInhibitCommandCollection (void)
 
void EventTriggerUndoInhibitCommandCollection (void)
 
void EventTriggerCollectSimpleCommand (ObjectAddress address, ObjectAddress secondaryObject, Node *parsetree)
 
void EventTriggerAlterTableStart (Node *parsetree)
 
void EventTriggerAlterTableRelid (Oid objectId)
 
void EventTriggerCollectAlterTableSubcmd (Node *subcmd, ObjectAddress address)
 
void EventTriggerAlterTableEnd (void)
 
void EventTriggerCollectGrant (InternalGrant *istmt)
 
void EventTriggerCollectAlterOpFam (AlterOpFamilyStmt *stmt, Oid opfamoid, List *operators, List *procedures)
 
void EventTriggerCollectCreateOpClass (CreateOpClassStmt *stmt, Oid opcoid, List *operators, List *procedures)
 
void EventTriggerCollectAlterTSConfig (AlterTSConfigurationStmt *stmt, Oid cfgId, Oid *dictIds, int ndicts)
 
void EventTriggerCollectAlterDefPrivs (AlterDefaultPrivilegesStmt *stmt)
 

Macro Definition Documentation

#define AT_REWRITE_ALTER_OID   0x08

Definition at line 34 of file event_trigger.h.

Referenced by ATExecAddColumn(), and ATExecDropColumn().

#define AT_REWRITE_ALTER_PERSISTENCE   0x01

Definition at line 31 of file event_trigger.h.

Referenced by ATPrepCmd().

#define AT_REWRITE_COLUMN_REWRITE   0x04

Definition at line 33 of file event_trigger.h.

Referenced by ATPrepAlterColumnType().

#define AT_REWRITE_DEFAULT_VAL   0x02

Definition at line 32 of file event_trigger.h.

Referenced by ATExecAddColumn().

#define CALLED_AS_EVENT_TRIGGER (   fcinfo)    ((fcinfo)->context != NULL && IsA((fcinfo)->context, EventTriggerData))

Typedef Documentation

Function Documentation

Oid AlterEventTrigger ( AlterEventTrigStmt stmt)

Definition at line 499 of file event_trigger.c.

References ACL_KIND_EVENT_TRIGGER, aclcheck_error(), ACLCHECK_NOT_OWNER, CatalogTupleUpdate(), CStringGetDatum, ereport, errcode(), errmsg(), ERROR, EVENTTRIGGERNAME, EventTriggerRelationId, GETSTRUCT, GetUserId(), heap_close, heap_freetuple(), heap_open(), HeapTupleGetOid, HeapTupleIsValid, InvokeObjectPostAlterHook, pg_event_trigger_ownercheck(), RowExclusiveLock, SearchSysCacheCopy1, HeapTupleData::t_self, AlterEventTrigStmt::tgenabled, and AlterEventTrigStmt::trigname.

Referenced by standard_ProcessUtility().

500 {
501  Relation tgrel;
502  HeapTuple tup;
503  Oid trigoid;
504  Form_pg_event_trigger evtForm;
505  char tgenabled = stmt->tgenabled;
506 
508 
510  CStringGetDatum(stmt->trigname));
511  if (!HeapTupleIsValid(tup))
512  ereport(ERROR,
513  (errcode(ERRCODE_UNDEFINED_OBJECT),
514  errmsg("event trigger \"%s\" does not exist",
515  stmt->trigname)));
516 
517  trigoid = HeapTupleGetOid(tup);
518 
519  if (!pg_event_trigger_ownercheck(trigoid, GetUserId()))
521  stmt->trigname);
522 
523  /* tuple is a copy, so we can modify it below */
524  evtForm = (Form_pg_event_trigger) GETSTRUCT(tup);
525  evtForm->evtenabled = tgenabled;
526 
527  CatalogTupleUpdate(tgrel, &tup->t_self, tup);
528 
530  trigoid, 0);
531 
532  /* clean up */
533  heap_freetuple(tup);
535 
536  return trigoid;
537 }
#define GETSTRUCT(TUP)
Definition: htup_details.h:656
Oid GetUserId(void)
Definition: miscinit.c:283
int errcode(int sqlerrcode)
Definition: elog.c:575
#define heap_close(r, l)
Definition: heapam.h:97
void heap_freetuple(HeapTuple htup)
Definition: heaptuple.c:1374
unsigned int Oid
Definition: postgres_ext.h:31
#define ERROR
Definition: elog.h:43
bool pg_event_trigger_ownercheck(Oid et_oid, Oid roleid)
Definition: aclchk.c:4937
ItemPointerData t_self
Definition: htup.h:65
void aclcheck_error(AclResult aclerr, AclObjectKind objectkind, const char *objectname)
Definition: aclchk.c:3399
#define RowExclusiveLock
Definition: lockdefs.h:38
#define CStringGetDatum(X)
Definition: postgres.h:584
#define ereport(elevel, rest)
Definition: elog.h:122
#define InvokeObjectPostAlterHook(classId, objectId, subId)
Definition: objectaccess.h:163
Relation heap_open(Oid relationId, LOCKMODE lockmode)
Definition: heapam.c:1284
FormData_pg_event_trigger * Form_pg_event_trigger
#define HeapTupleIsValid(tuple)
Definition: htup.h:77
#define EventTriggerRelationId
void CatalogTupleUpdate(Relation heapRel, ItemPointer otid, HeapTuple tup)
Definition: indexing.c:210
#define SearchSysCacheCopy1(cacheId, key1)
Definition: syscache.h:161
int errmsg(const char *fmt,...)
Definition: elog.c:797
#define HeapTupleGetOid(tuple)
Definition: htup_details.h:695
ObjectAddress AlterEventTriggerOwner ( const char *  name,
Oid  newOwnerId 
)

Definition at line 543 of file event_trigger.c.

References AlterEventTriggerOwner_internal(), CStringGetDatum, ereport, errcode(), errmsg(), ERROR, EVENTTRIGGERNAME, EventTriggerRelationId, heap_close, heap_freetuple(), heap_open(), HeapTupleGetOid, HeapTupleIsValid, ObjectAddressSet, RowExclusiveLock, and SearchSysCacheCopy1.

Referenced by ExecAlterOwnerStmt().

544 {
545  Oid evtOid;
546  HeapTuple tup;
547  Relation rel;
548  ObjectAddress address;
549 
551 
553 
554  if (!HeapTupleIsValid(tup))
555  ereport(ERROR,
556  (errcode(ERRCODE_UNDEFINED_OBJECT),
557  errmsg("event trigger \"%s\" does not exist", name)));
558 
559  evtOid = HeapTupleGetOid(tup);
560 
561  AlterEventTriggerOwner_internal(rel, tup, newOwnerId);
562 
563  ObjectAddressSet(address, EventTriggerRelationId, evtOid);
564 
565  heap_freetuple(tup);
566 
568 
569  return address;
570 }
int errcode(int sqlerrcode)
Definition: elog.c:575
#define heap_close(r, l)
Definition: heapam.h:97
void heap_freetuple(HeapTuple htup)
Definition: heaptuple.c:1374
unsigned int Oid
Definition: postgres_ext.h:31
static void AlterEventTriggerOwner_internal(Relation rel, HeapTuple tup, Oid newOwnerId)
#define ERROR
Definition: elog.h:43
#define RowExclusiveLock
Definition: lockdefs.h:38
#define CStringGetDatum(X)
Definition: postgres.h:584
#define ereport(elevel, rest)
Definition: elog.h:122
Relation heap_open(Oid relationId, LOCKMODE lockmode)
Definition: heapam.c:1284
#define HeapTupleIsValid(tuple)
Definition: htup.h:77
#define EventTriggerRelationId
const char * name
Definition: encode.c:521
#define ObjectAddressSet(addr, class_id, object_id)
Definition: objectaddress.h:40
#define SearchSysCacheCopy1(cacheId, key1)
Definition: syscache.h:161
int errmsg(const char *fmt,...)
Definition: elog.c:797
#define HeapTupleGetOid(tuple)
Definition: htup_details.h:695
void AlterEventTriggerOwner_oid ( Oid  ,
Oid  newOwnerId 
)

Definition at line 576 of file event_trigger.c.

References AlterEventTriggerOwner_internal(), ereport, errcode(), errmsg(), ERROR, EVENTTRIGGEROID, EventTriggerRelationId, heap_close, heap_freetuple(), heap_open(), HeapTupleIsValid, ObjectIdGetDatum, RowExclusiveLock, and SearchSysCacheCopy1.

Referenced by shdepReassignOwned().

577 {
578  HeapTuple tup;
579  Relation rel;
580 
582 
584 
585  if (!HeapTupleIsValid(tup))
586  ereport(ERROR,
587  (errcode(ERRCODE_UNDEFINED_OBJECT),
588  errmsg("event trigger with OID %u does not exist", trigOid)));
589 
590  AlterEventTriggerOwner_internal(rel, tup, newOwnerId);
591 
592  heap_freetuple(tup);
593 
595 }
int errcode(int sqlerrcode)
Definition: elog.c:575
#define heap_close(r, l)
Definition: heapam.h:97
void heap_freetuple(HeapTuple htup)
Definition: heaptuple.c:1374
static void AlterEventTriggerOwner_internal(Relation rel, HeapTuple tup, Oid newOwnerId)
#define ObjectIdGetDatum(X)
Definition: postgres.h:513
#define ERROR
Definition: elog.h:43
#define RowExclusiveLock
Definition: lockdefs.h:38
#define ereport(elevel, rest)
Definition: elog.h:122
Relation heap_open(Oid relationId, LOCKMODE lockmode)
Definition: heapam.c:1284
#define HeapTupleIsValid(tuple)
Definition: htup.h:77
#define EventTriggerRelationId
#define SearchSysCacheCopy1(cacheId, key1)
Definition: syscache.h:161
int errmsg(const char *fmt,...)
Definition: elog.c:797
Oid CreateEventTrigger ( CreateEventTrigStmt stmt)

Definition at line 167 of file event_trigger.c.

References DefElem::arg, CStringGetDatum, DefElem::defname, ereport, errcode(), ERRCODE_DUPLICATE_OBJECT, errhint(), errmsg(), ERROR, error_duplicate_filter_variable(), CreateEventTrigStmt::eventname, EVENTTRIGGERNAME, EVTTRIGGEROID, CreateEventTrigStmt::funcname, get_func_rettype(), GetUserId(), HeapTupleIsValid, insert_event_trigger_tuple(), lfirst, LookupFuncName(), NameListToString(), NULL, SearchSysCache1, superuser(), CreateEventTrigStmt::trigname, validate_ddl_tags(), validate_table_rewrite_tags(), and CreateEventTrigStmt::whenclause.

Referenced by standard_ProcessUtility().

168 {
169  HeapTuple tuple;
170  Oid funcoid;
171  Oid funcrettype;
172  Oid fargtypes[1]; /* dummy */
173  Oid evtowner = GetUserId();
174  ListCell *lc;
175  List *tags = NULL;
176 
177  /*
178  * It would be nice to allow database owners or even regular users to do
179  * this, but there are obvious privilege escalation risks which would have
180  * to somehow be plugged first.
181  */
182  if (!superuser())
183  ereport(ERROR,
184  (errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),
185  errmsg("permission denied to create event trigger \"%s\"",
186  stmt->trigname),
187  errhint("Must be superuser to create an event trigger.")));
188 
189  /* Validate event name. */
190  if (strcmp(stmt->eventname, "ddl_command_start") != 0 &&
191  strcmp(stmt->eventname, "ddl_command_end") != 0 &&
192  strcmp(stmt->eventname, "sql_drop") != 0 &&
193  strcmp(stmt->eventname, "table_rewrite") != 0)
194  ereport(ERROR,
195  (errcode(ERRCODE_SYNTAX_ERROR),
196  errmsg("unrecognized event name \"%s\"",
197  stmt->eventname)));
198 
199  /* Validate filter conditions. */
200  foreach(lc, stmt->whenclause)
201  {
202  DefElem *def = (DefElem *) lfirst(lc);
203 
204  if (strcmp(def->defname, "tag") == 0)
205  {
206  if (tags != NULL)
208  tags = (List *) def->arg;
209  }
210  else
211  ereport(ERROR,
212  (errcode(ERRCODE_SYNTAX_ERROR),
213  errmsg("unrecognized filter variable \"%s\"", def->defname)));
214  }
215 
216  /* Validate tag list, if any. */
217  if ((strcmp(stmt->eventname, "ddl_command_start") == 0 ||
218  strcmp(stmt->eventname, "ddl_command_end") == 0 ||
219  strcmp(stmt->eventname, "sql_drop") == 0)
220  && tags != NULL)
221  validate_ddl_tags("tag", tags);
222  else if (strcmp(stmt->eventname, "table_rewrite") == 0
223  && tags != NULL)
224  validate_table_rewrite_tags("tag", tags);
225 
226  /*
227  * Give user a nice error message if an event trigger of the same name
228  * already exists.
229  */
231  if (HeapTupleIsValid(tuple))
232  ereport(ERROR,
234  errmsg("event trigger \"%s\" already exists",
235  stmt->trigname)));
236 
237  /* Find and validate the trigger function. */
238  funcoid = LookupFuncName(stmt->funcname, 0, fargtypes, false);
239  funcrettype = get_func_rettype(funcoid);
240  if (funcrettype != EVTTRIGGEROID)
241  ereport(ERROR,
242  (errcode(ERRCODE_INVALID_OBJECT_DEFINITION),
243  errmsg("function %s must return type %s",
244  NameListToString(stmt->funcname), "event_trigger")));
245 
246  /* Insert catalog entries. */
247  return insert_event_trigger_tuple(stmt->trigname, stmt->eventname,
248  evtowner, funcoid, tags);
249 }
static void validate_ddl_tags(const char *filtervar, List *taglist)
int errhint(const char *fmt,...)
Definition: elog.c:987
Oid GetUserId(void)
Definition: miscinit.c:283
static Oid insert_event_trigger_tuple(char *trigname, char *eventname, Oid evtOwner, Oid funcoid, List *tags)
int errcode(int sqlerrcode)
Definition: elog.c:575
bool superuser(void)
Definition: superuser.c:47
unsigned int Oid
Definition: postgres_ext.h:31
#define SearchSysCache1(cacheId, key1)
Definition: syscache.h:152
Oid get_func_rettype(Oid funcid)
Definition: lsyscache.c:1459
#define ERROR
Definition: elog.h:43
static void validate_table_rewrite_tags(const char *filtervar, List *taglist)
static void error_duplicate_filter_variable(const char *defname)
#define CStringGetDatum(X)
Definition: postgres.h:584
#define ereport(elevel, rest)
Definition: elog.h:122
Node * arg
Definition: parsenodes.h:721
char * NameListToString(List *names)
Definition: namespace.c:2953
#define HeapTupleIsValid(tuple)
Definition: htup.h:77
#define EVTTRIGGEROID
Definition: pg_type.h:694
#define NULL
Definition: c.h:229
#define lfirst(lc)
Definition: pg_list.h:106
Oid LookupFuncName(List *funcname, int nargs, const Oid *argtypes, bool noError)
Definition: parse_func.c:1910
int errmsg(const char *fmt,...)
Definition: elog.c:797
char * defname
Definition: parsenodes.h:720
#define ERRCODE_DUPLICATE_OBJECT
Definition: streamutil.c:31
Definition: pg_list.h:45
void EventTriggerAlterTableEnd ( void  )

Definition at line 1780 of file event_trigger.c.

References CollectedCommand::alterTable, EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, EventTriggerQueryState::currentCommand, CollectedCommand::d, lappend(), list_length(), NULL, and pfree().

Referenced by AlterTableMoveAll(), and ProcessUtilitySlow().

1781 {
1782  /* ignore if event trigger context not set, or collection disabled */
1783  if (!currentEventTriggerState ||
1785  return;
1786 
1787  /* If no subcommands, don't collect */
1789  {
1793  }
1794  else
1796 
1798 }
union CollectedCommand::@102 d
struct CollectedCommand::@102::@104 alterTable
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
void pfree(void *pointer)
Definition: mcxt.c:950
CollectedCommand * currentCommand
Definition: event_trigger.c:66
List * lappend(List *list, void *datum)
Definition: list.c:128
#define NULL
Definition: c.h:229
static int list_length(const List *l)
Definition: pg_list.h:89
void EventTriggerAlterTableRelid ( Oid  objectId)

Definition at line 1728 of file event_trigger.c.

References CollectedCommand::alterTable, EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::currentCommand, and CollectedCommand::d.

Referenced by AlterTableInternal(), and ProcessUtilitySlow().

1729 {
1730  if (!currentEventTriggerState ||
1732  return;
1733 
1734  currentEventTriggerState->currentCommand->d.alterTable.objectId = objectId;
1735 }
union CollectedCommand::@102 d
struct CollectedCommand::@102::@104 alterTable
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
CollectedCommand * currentCommand
Definition: event_trigger.c:66
void EventTriggerAlterTableStart ( Node parsetree)

Definition at line 1695 of file event_trigger.c.

References CollectedCommand::alterTable, EventTriggerQueryState::commandCollectionInhibited, copyObject, creating_extension, EventTriggerQueryState::currentCommand, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::in_extension, InvalidOid, MemoryContextSwitchTo(), NIL, palloc(), CollectedCommand::parsetree, RelationRelationId, SCT_AlterTable, and CollectedCommand::type.

Referenced by AlterTableMoveAll(), and ProcessUtilitySlow().

1696 {
1697  MemoryContext oldcxt;
1698  CollectedCommand *command;
1699 
1700  /* ignore if event trigger context not set, or collection disabled */
1701  if (!currentEventTriggerState ||
1703  return;
1704 
1706 
1707  command = palloc(sizeof(CollectedCommand));
1708 
1709  command->type = SCT_AlterTable;
1710  command->in_extension = creating_extension;
1711 
1712  command->d.alterTable.classId = RelationRelationId;
1713  command->d.alterTable.objectId = InvalidOid;
1714  command->d.alterTable.subcmds = NIL;
1715  command->parsetree = copyObject(parsetree);
1716 
1718 
1719  MemoryContextSwitchTo(oldcxt);
1720 }
union CollectedCommand::@102 d
#define NIL
Definition: pg_list.h:69
struct CollectedCommand::@102::@104 alterTable
#define RelationRelationId
Definition: pg_class.h:29
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
CollectedCommand * currentCommand
Definition: event_trigger.c:66
#define InvalidOid
Definition: postgres_ext.h:36
bool creating_extension
Definition: extension.c:67
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
bool EventTriggerBeginCompleteQuery ( void  )

Definition at line 1220 of file event_trigger.c.

References ALLOCSET_DEFAULT_SIZES, AllocSetContextCreate(), EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, EventTriggerQueryState::currentCommand, currentEventTriggerState, EventTriggerQueryState::cxt, EventTriggerQueryState::in_sql_drop, InvalidOid, MemoryContextAlloc(), NIL, NULL, EventTriggerQueryState::previous, slist_init(), EventTriggerQueryState::SQLDropList, EventTriggerQueryState::table_rewrite_oid, TopMemoryContext, and trackDroppedObjectsNeeded().

Referenced by ProcessUtilitySlow().

1221 {
1223  MemoryContext cxt;
1224 
1225  /*
1226  * Currently, sql_drop, table_rewrite, ddl_command_end events are the only
1227  * reason to have event trigger state at all; so if there are none, don't
1228  * install one.
1229  */
1231  return false;
1232 
1234  "event trigger state",
1236  state = MemoryContextAlloc(cxt, sizeof(EventTriggerQueryState));
1237  state->cxt = cxt;
1238  slist_init(&(state->SQLDropList));
1239  state->in_sql_drop = false;
1240  state->table_rewrite_oid = InvalidOid;
1241 
1244  state->currentCommand = NULL;
1245  state->commandList = NIL;
1247  currentEventTriggerState = state;
1248 
1249  return true;
1250 }
#define NIL
Definition: pg_list.h:69
bool trackDroppedObjectsNeeded(void)
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
static void slist_init(slist_head *head)
Definition: ilist.h:554
#define ALLOCSET_DEFAULT_SIZES
Definition: memutils.h:165
CollectedCommand * currentCommand
Definition: event_trigger.c:66
struct EventTriggerQueryState * previous
Definition: event_trigger.c:69
MemoryContext TopMemoryContext
Definition: mcxt.c:43
MemoryContext AllocSetContextCreate(MemoryContext parent, const char *name, Size minContextSize, Size initBlockSize, Size maxBlockSize)
Definition: aset.c:322
#define InvalidOid
Definition: postgres_ext.h:36
#define NULL
Definition: c.h:229
Definition: regguts.h:298
void * MemoryContextAlloc(MemoryContext context, Size size)
Definition: mcxt.c:707
void EventTriggerCollectAlterDefPrivs ( AlterDefaultPrivilegesStmt stmt)

Definition at line 1954 of file event_trigger.c.

References AlterDefaultPrivilegesStmt::action, EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::defprivs, CollectedCommand::in_extension, lappend(), MemoryContextSwitchTo(), GrantStmt::objtype, palloc0(), CollectedCommand::parsetree, SCT_AlterDefaultPrivileges, and CollectedCommand::type.

Referenced by ProcessUtilitySlow().

1955 {
1956  MemoryContext oldcxt;
1957  CollectedCommand *command;
1958 
1959  /* ignore if event trigger context not set, or collection disabled */
1960  if (!currentEventTriggerState ||
1962  return;
1963 
1965 
1966  command = palloc0(sizeof(CollectedCommand));
1967  command->type = SCT_AlterDefaultPrivileges;
1968  command->d.defprivs.objtype = stmt->action->objtype;
1969  command->in_extension = creating_extension;
1970  command->parsetree = (Node *) copyObject(stmt);
1971 
1974  MemoryContextSwitchTo(oldcxt);
1975 }
union CollectedCommand::@102 d
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
Definition: nodes.h:509
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
List * lappend(List *list, void *datum)
Definition: list.c:128
void * palloc0(Size size)
Definition: mcxt.c:878
bool creating_extension
Definition: extension.c:67
GrantObjectType objtype
Definition: parsenodes.h:1826
struct CollectedCommand::@102::@109 defprivs
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerCollectAlterOpFam ( AlterOpFamilyStmt stmt,
Oid  opfamoid,
List operators,
List procedures 
)

Definition at line 1852 of file event_trigger.c.

References EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::in_extension, lappend(), MemoryContextSwitchTo(), ObjectAddressSet, OperatorFamilyRelationId, CollectedCommand::opfam, palloc(), CollectedCommand::parsetree, SCT_AlterOpFamily, and CollectedCommand::type.

Referenced by AlterOpFamilyAdd(), and AlterOpFamilyDrop().

1854 {
1855  MemoryContext oldcxt;
1856  CollectedCommand *command;
1857 
1858  /* ignore if event trigger context not set, or collection disabled */
1859  if (!currentEventTriggerState ||
1861  return;
1862 
1864 
1865  command = palloc(sizeof(CollectedCommand));
1866  command->type = SCT_AlterOpFamily;
1867  command->in_extension = creating_extension;
1868  ObjectAddressSet(command->d.opfam.address,
1869  OperatorFamilyRelationId, opfamoid);
1870  command->d.opfam.operators = operators;
1871  command->d.opfam.procedures = procedures;
1872  command->parsetree = (Node *) copyObject(stmt);
1873 
1876 
1877  MemoryContextSwitchTo(oldcxt);
1878 }
union CollectedCommand::@102 d
struct CollectedCommand::@102::@106 opfam
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
Definition: nodes.h:509
#define OperatorFamilyRelationId
Definition: pg_opfamily.h:29
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
List * lappend(List *list, void *datum)
Definition: list.c:128
bool creating_extension
Definition: extension.c:67
#define ObjectAddressSet(addr, class_id, object_id)
Definition: objectaddress.h:40
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerCollectAlterTableSubcmd ( Node subcmd,
ObjectAddress  address 
)

Definition at line 1746 of file event_trigger.c.

References CollectedATSubcmd::address, CollectedCommand::alterTable, Assert, EventTriggerQueryState::commandCollectionInhibited, copyObject, EventTriggerQueryState::currentCommand, EventTriggerQueryState::cxt, CollectedCommand::d, IsA, lappend(), MemoryContextSwitchTo(), newsub(), OidIsValid, palloc(), and CollectedATSubcmd::parsetree.

Referenced by ATExecCmd().

1747 {
1748  MemoryContext oldcxt;
1750 
1751  /* ignore if event trigger context not set, or collection disabled */
1752  if (!currentEventTriggerState ||
1754  return;
1755 
1756  Assert(IsA(subcmd, AlterTableCmd));
1758 
1760 
1761  newsub = palloc(sizeof(CollectedATSubcmd));
1762  newsub->address = address;
1763  newsub->parsetree = copyObject(subcmd);
1764 
1767 
1768  MemoryContextSwitchTo(oldcxt);
1769 }
union CollectedCommand::@102 d
#define IsA(nodeptr, _type_)
Definition: nodes.h:560
struct CollectedCommand::@102::@104 alterTable
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
#define OidIsValid(objectId)
Definition: c.h:538
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
CollectedCommand * currentCommand
Definition: event_trigger.c:66
List * lappend(List *list, void *datum)
Definition: list.c:128
#define Assert(condition)
Definition: c.h:675
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
static color newsub(struct colormap *cm, color co)
Definition: regc_color.c:389
ObjectAddress address
void EventTriggerCollectAlterTSConfig ( AlterTSConfigurationStmt stmt,
Oid  cfgId,
Oid dictIds,
int  ndicts 
)

Definition at line 1919 of file event_trigger.c.

References CollectedCommand::atscfg, EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::in_extension, lappend(), MemoryContextSwitchTo(), ObjectAddressSet, palloc(), palloc0(), CollectedCommand::parsetree, SCT_AlterTSConfig, TSConfigRelationId, and CollectedCommand::type.

Referenced by DropConfigurationMapping(), and MakeConfigurationMapping().

1921 {
1922  MemoryContext oldcxt;
1923  CollectedCommand *command;
1924 
1925  /* ignore if event trigger context not set, or collection disabled */
1926  if (!currentEventTriggerState ||
1928  return;
1929 
1931 
1932  command = palloc0(sizeof(CollectedCommand));
1933  command->type = SCT_AlterTSConfig;
1934  command->in_extension = creating_extension;
1935  ObjectAddressSet(command->d.atscfg.address,
1936  TSConfigRelationId, cfgId);
1937  command->d.atscfg.dictIds = palloc(sizeof(Oid) * ndicts);
1938  memcpy(command->d.atscfg.dictIds, dictIds, sizeof(Oid) * ndicts);
1939  command->d.atscfg.ndicts = ndicts;
1940  command->parsetree = (Node *) copyObject(stmt);
1941 
1944 
1945  MemoryContextSwitchTo(oldcxt);
1946 }
union CollectedCommand::@102 d
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
Definition: nodes.h:509
CollectedCommandType type
unsigned int Oid
Definition: postgres_ext.h:31
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
#define TSConfigRelationId
Definition: pg_ts_config.h:31
List * lappend(List *list, void *datum)
Definition: list.c:128
void * palloc0(Size size)
Definition: mcxt.c:878
struct CollectedCommand::@102::@108 atscfg
bool creating_extension
Definition: extension.c:67
#define ObjectAddressSet(addr, class_id, object_id)
Definition: objectaddress.h:40
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerCollectCreateOpClass ( CreateOpClassStmt stmt,
Oid  opcoid,
List operators,
List procedures 
)

Definition at line 1885 of file event_trigger.c.

References EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, CollectedCommand::createopc, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::in_extension, lappend(), MemoryContextSwitchTo(), ObjectAddressSet, OperatorClassRelationId, palloc0(), CollectedCommand::parsetree, SCT_CreateOpClass, and CollectedCommand::type.

Referenced by DefineOpClass().

1887 {
1888  MemoryContext oldcxt;
1889  CollectedCommand *command;
1890 
1891  /* ignore if event trigger context not set, or collection disabled */
1892  if (!currentEventTriggerState ||
1894  return;
1895 
1897 
1898  command = palloc0(sizeof(CollectedCommand));
1899  command->type = SCT_CreateOpClass;
1900  command->in_extension = creating_extension;
1901  ObjectAddressSet(command->d.createopc.address,
1902  OperatorClassRelationId, opcoid);
1903  command->d.createopc.operators = operators;
1904  command->d.createopc.procedures = procedures;
1905  command->parsetree = (Node *) copyObject(stmt);
1906 
1909 
1910  MemoryContextSwitchTo(oldcxt);
1911 }
union CollectedCommand::@102 d
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
#define OperatorClassRelationId
Definition: pg_opclass.h:49
Definition: nodes.h:509
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
List * lappend(List *list, void *datum)
Definition: list.c:128
void * palloc0(Size size)
Definition: mcxt.c:878
bool creating_extension
Definition: extension.c:67
struct CollectedCommand::@102::@107 createopc
#define ObjectAddressSet(addr, class_id, object_id)
Definition: objectaddress.h:40
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerCollectGrant ( InternalGrant istmt)

Definition at line 1808 of file event_trigger.c.

References InternalGrant::col_privs, EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::grant, InternalGrant::grantees, CollectedCommand::in_extension, lappend(), lfirst, list_copy(), MemoryContextSwitchTo(), NIL, NULL, InternalGrant::objects, palloc(), CollectedCommand::parsetree, SCT_Grant, and CollectedCommand::type.

Referenced by ExecGrantStmt_oids().

1809 {
1810  MemoryContext oldcxt;
1811  CollectedCommand *command;
1812  InternalGrant *icopy;
1813  ListCell *cell;
1814 
1815  /* ignore if event trigger context not set, or collection disabled */
1816  if (!currentEventTriggerState ||
1818  return;
1819 
1821 
1822  /*
1823  * This is tedious, but necessary.
1824  */
1825  icopy = palloc(sizeof(InternalGrant));
1826  memcpy(icopy, istmt, sizeof(InternalGrant));
1827  icopy->objects = list_copy(istmt->objects);
1828  icopy->grantees = list_copy(istmt->grantees);
1829  icopy->col_privs = NIL;
1830  foreach(cell, istmt->col_privs)
1831  icopy->col_privs = lappend(icopy->col_privs, copyObject(lfirst(cell)));
1832 
1833  /* Now collect it, using the copied InternalGrant */
1834  command = palloc(sizeof(CollectedCommand));
1835  command->type = SCT_Grant;
1836  command->in_extension = creating_extension;
1837  command->d.grant.istmt = icopy;
1838  command->parsetree = NULL;
1839 
1842 
1843  MemoryContextSwitchTo(oldcxt);
1844 }
union CollectedCommand::@102 d
#define NIL
Definition: pg_list.h:69
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
List * list_copy(const List *oldlist)
Definition: list.c:1160
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
struct CollectedCommand::@102::@105 grant
List * lappend(List *list, void *datum)
Definition: list.c:128
bool creating_extension
Definition: extension.c:67
#define NULL
Definition: c.h:229
#define lfirst(lc)
Definition: pg_list.h:106
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerCollectSimpleCommand ( ObjectAddress  address,
ObjectAddress  secondaryObject,
Node parsetree 
)

Definition at line 1652 of file event_trigger.c.

References EventTriggerQueryState::commandCollectionInhibited, EventTriggerQueryState::commandList, copyObject, creating_extension, EventTriggerQueryState::cxt, CollectedCommand::d, CollectedCommand::in_extension, lappend(), MemoryContextSwitchTo(), palloc(), CollectedCommand::parsetree, SCT_Simple, CollectedCommand::simple, and CollectedCommand::type.

Referenced by AlterPublicationOptions(), CreateSchemaCommand(), ProcessUtilitySlow(), and PublicationAddTables().

1655 {
1656  MemoryContext oldcxt;
1657  CollectedCommand *command;
1658 
1659  /* ignore if event trigger context not set, or collection disabled */
1660  if (!currentEventTriggerState ||
1662  return;
1663 
1665 
1666  command = palloc(sizeof(CollectedCommand));
1667 
1668  command->type = SCT_Simple;
1669  command->in_extension = creating_extension;
1670 
1671  command->d.simple.address = address;
1672  command->d.simple.secondaryObject = secondaryObject;
1673  command->parsetree = copyObject(parsetree);
1674 
1676  command);
1677 
1678  MemoryContextSwitchTo(oldcxt);
1679 }
union CollectedCommand::@102 d
struct CollectedCommand::@102::@103 simple
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
CollectedCommandType type
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
List * lappend(List *list, void *datum)
Definition: list.c:128
bool creating_extension
Definition: extension.c:67
void * palloc(Size size)
Definition: mcxt.c:849
#define copyObject(obj)
Definition: nodes.h:621
void EventTriggerDDLCommandEnd ( Node parsetree)

Definition at line 825 of file event_trigger.c.

References CommandCounterIncrement(), EventTriggerCommonSetup(), EventTriggerInvoke(), EVT_DDLCommandEnd, IsUnderPostmaster, list_free(), and NIL.

Referenced by ProcessUtilitySlow().

826 {
827  List *runlist;
828  EventTriggerData trigdata;
829 
830  /*
831  * See EventTriggerDDLCommandStart for a discussion about why event
832  * triggers are disabled in single user mode.
833  */
834  if (!IsUnderPostmaster)
835  return;
836 
837  runlist = EventTriggerCommonSetup(parsetree,
838  EVT_DDLCommandEnd, "ddl_command_end",
839  &trigdata);
840  if (runlist == NIL)
841  return;
842 
843  /*
844  * Make sure anything the main command did will be visible to the event
845  * triggers.
846  */
848 
849  /* Run the triggers. */
850  EventTriggerInvoke(runlist, &trigdata);
851 
852  /* Cleanup. */
853  list_free(runlist);
854 }
#define NIL
Definition: pg_list.h:69
static void EventTriggerInvoke(List *fn_oid_list, EventTriggerData *trigdata)
static List * EventTriggerCommonSetup(Node *parsetree, EventTriggerEvent event, const char *eventstr, EventTriggerData *trigdata)
bool IsUnderPostmaster
Definition: globals.c:100
void CommandCounterIncrement(void)
Definition: xact.c:922
void list_free(List *list)
Definition: list.c:1133
Definition: pg_list.h:45
void EventTriggerDDLCommandStart ( Node parsetree)

Definition at line 777 of file event_trigger.c.

References CommandCounterIncrement(), EventTriggerCommonSetup(), EventTriggerInvoke(), EVT_DDLCommandStart, IsUnderPostmaster, list_free(), and NIL.

Referenced by ProcessUtilitySlow().

778 {
779  List *runlist;
780  EventTriggerData trigdata;
781 
782  /*
783  * Event Triggers are completely disabled in standalone mode. There are
784  * (at least) two reasons for this:
785  *
786  * 1. A sufficiently broken event trigger might not only render the
787  * database unusable, but prevent disabling itself to fix the situation.
788  * In this scenario, restarting in standalone mode provides an escape
789  * hatch.
790  *
791  * 2. BuildEventTriggerCache relies on systable_beginscan_ordered, and
792  * therefore will malfunction if pg_event_trigger's indexes are damaged.
793  * To allow recovery from a damaged index, we need some operating mode
794  * wherein event triggers are disabled. (Or we could implement
795  * heapscan-and-sort logic for that case, but having disaster recovery
796  * scenarios depend on code that's otherwise untested isn't appetizing.)
797  */
798  if (!IsUnderPostmaster)
799  return;
800 
801  runlist = EventTriggerCommonSetup(parsetree,
803  "ddl_command_start",
804  &trigdata);
805  if (runlist == NIL)
806  return;
807 
808  /* Run the triggers. */
809  EventTriggerInvoke(runlist, &trigdata);
810 
811  /* Cleanup. */
812  list_free(runlist);
813 
814  /*
815  * Make sure anything the event triggers did will be visible to the main
816  * command.
817  */
819 }
#define NIL
Definition: pg_list.h:69
static void EventTriggerInvoke(List *fn_oid_list, EventTriggerData *trigdata)
static List * EventTriggerCommonSetup(Node *parsetree, EventTriggerEvent event, const char *eventstr, EventTriggerData *trigdata)
bool IsUnderPostmaster
Definition: globals.c:100
void CommandCounterIncrement(void)
Definition: xact.c:922
void list_free(List *list)
Definition: list.c:1133
Definition: pg_list.h:45
void EventTriggerEndCompleteQuery ( void  )

Definition at line 1264 of file event_trigger.c.

References EventTriggerQueryState::cxt, MemoryContextDelete(), and EventTriggerQueryState::previous.

Referenced by ProcessUtilitySlow().

1265 {
1266  EventTriggerQueryState *prevstate;
1267 
1268  prevstate = currentEventTriggerState->previous;
1269 
1270  /* this avoids the need for retail pfree of SQLDropList items: */
1272 
1273  currentEventTriggerState = prevstate;
1274 }
void MemoryContextDelete(MemoryContext context)
Definition: mcxt.c:200
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
struct EventTriggerQueryState * previous
Definition: event_trigger.c:69
void EventTriggerInhibitCommandCollection ( void  )

Definition at line 1618 of file event_trigger.c.

References EventTriggerQueryState::commandCollectionInhibited.

Referenced by ProcessUtilitySlow().

1619 {
1621  return;
1622 
1624 }
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
void EventTriggerSQLDrop ( Node parsetree)

Definition at line 860 of file event_trigger.c.

References CommandCounterIncrement(), EventTriggerCommonSetup(), EventTriggerInvoke(), EVT_SQLDrop, EventTriggerQueryState::in_sql_drop, IsUnderPostmaster, list_free(), NIL, PG_CATCH, PG_END_TRY, PG_RE_THROW, PG_TRY, slist_is_empty(), and EventTriggerQueryState::SQLDropList.

Referenced by ProcessUtilitySlow().

861 {
862  List *runlist;
863  EventTriggerData trigdata;
864 
865  /*
866  * See EventTriggerDDLCommandStart for a discussion about why event
867  * triggers are disabled in single user mode.
868  */
869  if (!IsUnderPostmaster)
870  return;
871 
872  /*
873  * Use current state to determine whether this event fires at all. If
874  * there are no triggers for the sql_drop event, then we don't have
875  * anything to do here. Note that dropped object collection is disabled
876  * if this is the case, so even if we were to try to run, the list would
877  * be empty.
878  */
881  return;
882 
883  runlist = EventTriggerCommonSetup(parsetree,
884  EVT_SQLDrop, "sql_drop",
885  &trigdata);
886 
887  /*
888  * Nothing to do if run list is empty. Note this shouldn't happen,
889  * because if there are no sql_drop events, then objects-to-drop wouldn't
890  * have been collected in the first place and we would have quit above.
891  */
892  if (runlist == NIL)
893  return;
894 
895  /*
896  * Make sure anything the main command did will be visible to the event
897  * triggers.
898  */
900 
901  /*
902  * Make sure pg_event_trigger_dropped_objects only works when running
903  * these triggers. Use PG_TRY to ensure in_sql_drop is reset even when
904  * one trigger fails. (This is perhaps not necessary, as the currentState
905  * variable will be removed shortly by our caller, but it seems better to
906  * play safe.)
907  */
909 
910  /* Run the triggers. */
911  PG_TRY();
912  {
913  EventTriggerInvoke(runlist, &trigdata);
914  }
915  PG_CATCH();
916  {
918  PG_RE_THROW();
919  }
920  PG_END_TRY();
922 
923  /* Cleanup. */
924  list_free(runlist);
925 }
#define NIL
Definition: pg_list.h:69
static void EventTriggerInvoke(List *fn_oid_list, EventTriggerData *trigdata)
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
static List * EventTriggerCommonSetup(Node *parsetree, EventTriggerEvent event, const char *eventstr, EventTriggerData *trigdata)
bool IsUnderPostmaster
Definition: globals.c:100
static bool slist_is_empty(slist_head *head)
Definition: ilist.h:563
void CommandCounterIncrement(void)
Definition: xact.c:922
#define PG_CATCH()
Definition: elog.h:293
#define PG_RE_THROW()
Definition: elog.h:314
void list_free(List *list)
Definition: list.c:1133
#define PG_TRY()
Definition: elog.h:284
Definition: pg_list.h:45
#define PG_END_TRY()
Definition: elog.h:300
void EventTriggerSQLDropAddObject ( const ObjectAddress object,
bool  original,
bool  normal 
)

Definition at line 1314 of file event_trigger.c.

References AccessShareLock, SQLDropObject::addrargs, SQLDropObject::address, SQLDropObject::addrnames, Assert, ObjectAddress::classId, EventTriggerQueryState::cxt, DatumGetName, DatumGetObjectId, EventTriggerSupportsObjectClass(), get_catalog_object_by_oid(), get_namespace_name(), get_object_attnum_name(), get_object_attnum_namespace(), get_object_namensp_unique(), getObjectClass(), getObjectIdentityParts(), getObjectTypeDescription(), heap_close, heap_getattr, heap_open(), InvalidAttrNumber, is_objectclass_supported(), isAnyTempNamespace(), SQLDropObject::istemp, isTempNamespace(), MemoryContextSwitchTo(), NamespaceRelationId, NameStr, SQLDropObject::next, SQLDropObject::normal, ObjectAddress::objectId, ObjectAddress::objectSubId, SQLDropObject::objecttype, SQLDropObject::objidentity, SQLDropObject::objname, SQLDropObject::original, palloc0(), pfree(), pstrdup(), RelationGetDescr, SQLDropObject::schemaname, slist_push_head(), and EventTriggerQueryState::SQLDropList.

Referenced by deleteObjectsInList(), and DropSubscription().

1315 {
1316  SQLDropObject *obj;
1317  MemoryContext oldcxt;
1318 
1320  return;
1321 
1323 
1324  /* don't report temp schemas except my own */
1325  if (object->classId == NamespaceRelationId &&
1326  (isAnyTempNamespace(object->objectId) &&
1327  !isTempNamespace(object->objectId)))
1328  return;
1329 
1331 
1332  obj = palloc0(sizeof(SQLDropObject));
1333  obj->address = *object;
1334  obj->original = original;
1335  obj->normal = normal;
1336 
1337  /*
1338  * Obtain schema names from the object's catalog tuple, if one exists;
1339  * this lets us skip objects in temp schemas. We trust that
1340  * ObjectProperty contains all object classes that can be
1341  * schema-qualified.
1342  */
1343  if (is_objectclass_supported(object->classId))
1344  {
1345  Relation catalog;
1346  HeapTuple tuple;
1347 
1348  catalog = heap_open(obj->address.classId, AccessShareLock);
1349  tuple = get_catalog_object_by_oid(catalog, obj->address.objectId);
1350 
1351  if (tuple)
1352  {
1353  AttrNumber attnum;
1354  Datum datum;
1355  bool isnull;
1356 
1358  if (attnum != InvalidAttrNumber)
1359  {
1360  datum = heap_getattr(tuple, attnum,
1361  RelationGetDescr(catalog), &isnull);
1362  if (!isnull)
1363  {
1364  Oid namespaceId;
1365 
1366  namespaceId = DatumGetObjectId(datum);
1367  /* temp objects are only reported if they are my own */
1368  if (isTempNamespace(namespaceId))
1369  {
1370  obj->schemaname = "pg_temp";
1371  obj->istemp = true;
1372  }
1373  else if (isAnyTempNamespace(namespaceId))
1374  {
1375  pfree(obj);
1376  heap_close(catalog, AccessShareLock);
1377  MemoryContextSwitchTo(oldcxt);
1378  return;
1379  }
1380  else
1381  {
1382  obj->schemaname = get_namespace_name(namespaceId);
1383  obj->istemp = false;
1384  }
1385  }
1386  }
1387 
1389  obj->address.objectSubId == 0)
1390  {
1391  attnum = get_object_attnum_name(obj->address.classId);
1392  if (attnum != InvalidAttrNumber)
1393  {
1394  datum = heap_getattr(tuple, attnum,
1395  RelationGetDescr(catalog), &isnull);
1396  if (!isnull)
1397  obj->objname = pstrdup(NameStr(*DatumGetName(datum)));
1398  }
1399  }
1400  }
1401 
1402  heap_close(catalog, AccessShareLock);
1403  }
1404  else
1405  {
1406  if (object->classId == NamespaceRelationId &&
1407  isTempNamespace(object->objectId))
1408  obj->istemp = true;
1409  }
1410 
1411  /* object identity, objname and objargs */
1412  obj->objidentity =
1413  getObjectIdentityParts(&obj->address, &obj->addrnames, &obj->addrargs);
1414 
1415  /* object type */
1417 
1419 
1420  MemoryContextSwitchTo(oldcxt);
1421 }
bool get_object_namensp_unique(Oid class_id)
slist_node next
#define NamespaceRelationId
Definition: pg_namespace.h:34
ObjectAddress address
char * getObjectTypeDescription(const ObjectAddress *object)
#define RelationGetDescr(relation)
Definition: rel.h:429
const char * objname
#define DatumGetObjectId(X)
Definition: postgres.h:506
char * pstrdup(const char *in)
Definition: mcxt.c:1077
char * getObjectIdentityParts(const ObjectAddress *object, List **objname, List **objargs)
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition: palloc.h:109
#define AccessShareLock
Definition: lockdefs.h:36
static void slist_push_head(slist_head *head, slist_node *node)
Definition: ilist.h:574
AttrNumber get_object_attnum_namespace(Oid class_id)
#define heap_close(r, l)
Definition: heapam.h:97
const char * objidentity
unsigned int Oid
Definition: postgres_ext.h:31
ObjectClass getObjectClass(const ObjectAddress *object)
Definition: dependency.c:2325
const char * objecttype
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
#define DatumGetName(X)
Definition: postgres.h:591
void pfree(void *pointer)
Definition: mcxt.c:950
char * get_namespace_name(Oid nspid)
Definition: lsyscache.c:3038
bool isTempNamespace(Oid namespaceId)
Definition: namespace.c:3008
bool EventTriggerSupportsObjectClass(ObjectClass objclass)
const char * schemaname
#define heap_getattr(tup, attnum, tupleDesc, isnull)
Definition: htup_details.h:769
AttrNumber get_object_attnum_name(Oid class_id)
void * palloc0(Size size)
Definition: mcxt.c:878
uintptr_t Datum
Definition: postgres.h:372
Relation heap_open(Oid relationId, LOCKMODE lockmode)
Definition: heapam.c:1284
#define Assert(condition)
Definition: c.h:675
HeapTuple get_catalog_object_by_oid(Relation catalog, Oid objectId)
#define InvalidAttrNumber
Definition: attnum.h:23
#define NameStr(name)
Definition: c.h:499
bool isAnyTempNamespace(Oid namespaceId)
Definition: namespace.c:3046
bool is_objectclass_supported(Oid class_id)
int16 AttrNumber
Definition: attnum.h:21
bool EventTriggerSupportsGrantObjectType ( GrantObjectType  objtype)

Definition at line 1186 of file event_trigger.c.

References ACL_OBJECT_COLUMN, ACL_OBJECT_DATABASE, ACL_OBJECT_DOMAIN, ACL_OBJECT_FDW, ACL_OBJECT_FOREIGN_SERVER, ACL_OBJECT_FUNCTION, ACL_OBJECT_LANGUAGE, ACL_OBJECT_LARGEOBJECT, ACL_OBJECT_NAMESPACE, ACL_OBJECT_RELATION, ACL_OBJECT_SEQUENCE, ACL_OBJECT_TABLESPACE, ACL_OBJECT_TYPE, and Assert.

Referenced by ExecGrantStmt_oids(), and standard_ProcessUtility().

1187 {
1188  switch (objtype)
1189  {
1190  case ACL_OBJECT_DATABASE:
1191  case ACL_OBJECT_TABLESPACE:
1192  /* no support for global objects */
1193  return false;
1194 
1195  case ACL_OBJECT_COLUMN:
1196  case ACL_OBJECT_RELATION:
1197  case ACL_OBJECT_SEQUENCE:
1198  case ACL_OBJECT_DOMAIN:
1199  case ACL_OBJECT_FDW:
1201  case ACL_OBJECT_FUNCTION:
1202  case ACL_OBJECT_LANGUAGE:
1204  case ACL_OBJECT_NAMESPACE:
1205  case ACL_OBJECT_TYPE:
1206  return true;
1207  default:
1208  Assert(false);
1209  return true;
1210  }
1211 }
#define Assert(condition)
Definition: c.h:675
bool EventTriggerSupportsObjectClass ( ObjectClass  objclass)

Definition at line 1133 of file event_trigger.c.

References OCLASS_AM, OCLASS_AMOP, OCLASS_AMPROC, OCLASS_CAST, OCLASS_CLASS, OCLASS_COLLATION, OCLASS_CONSTRAINT, OCLASS_CONVERSION, OCLASS_DATABASE, OCLASS_DEFACL, OCLASS_DEFAULT, OCLASS_EVENT_TRIGGER, OCLASS_EXTENSION, OCLASS_FDW, OCLASS_FOREIGN_SERVER, OCLASS_LANGUAGE, OCLASS_LARGEOBJECT, OCLASS_OPCLASS, OCLASS_OPERATOR, OCLASS_OPFAMILY, OCLASS_POLICY, OCLASS_PROC, OCLASS_PUBLICATION, OCLASS_PUBLICATION_REL, OCLASS_REWRITE, OCLASS_ROLE, OCLASS_SCHEMA, OCLASS_STATISTIC_EXT, OCLASS_SUBSCRIPTION, OCLASS_TBLSPACE, OCLASS_TRANSFORM, OCLASS_TRIGGER, OCLASS_TSCONFIG, OCLASS_TSDICT, OCLASS_TSPARSER, OCLASS_TSTEMPLATE, OCLASS_TYPE, and OCLASS_USER_MAPPING.

Referenced by deleteObjectsInList(), and EventTriggerSQLDropAddObject().

1134 {
1135  switch (objclass)
1136  {
1137  case OCLASS_DATABASE:
1138  case OCLASS_TBLSPACE:
1139  case OCLASS_ROLE:
1140  /* no support for global objects */
1141  return false;
1142  case OCLASS_EVENT_TRIGGER:
1143  /* no support for event triggers on event triggers */
1144  return false;
1145  case OCLASS_CLASS:
1146  case OCLASS_PROC:
1147  case OCLASS_TYPE:
1148  case OCLASS_CAST:
1149  case OCLASS_COLLATION:
1150  case OCLASS_CONSTRAINT:
1151  case OCLASS_CONVERSION:
1152  case OCLASS_DEFAULT:
1153  case OCLASS_LANGUAGE:
1154  case OCLASS_LARGEOBJECT:
1155  case OCLASS_OPERATOR:
1156  case OCLASS_OPCLASS:
1157  case OCLASS_OPFAMILY:
1158  case OCLASS_AMOP:
1159  case OCLASS_AMPROC:
1160  case OCLASS_REWRITE:
1161  case OCLASS_TRIGGER:
1162  case OCLASS_SCHEMA:
1163  case OCLASS_TRANSFORM:
1164  case OCLASS_TSPARSER:
1165  case OCLASS_TSDICT:
1166  case OCLASS_TSTEMPLATE:
1167  case OCLASS_TSCONFIG:
1168  case OCLASS_FDW:
1169  case OCLASS_FOREIGN_SERVER:
1170  case OCLASS_USER_MAPPING:
1171  case OCLASS_DEFACL:
1172  case OCLASS_EXTENSION:
1173  case OCLASS_POLICY:
1174  case OCLASS_AM:
1175  case OCLASS_PUBLICATION:
1177  case OCLASS_SUBSCRIPTION:
1178  case OCLASS_STATISTIC_EXT:
1179  return true;
1180  }
1181 
1182  return true;
1183 }
bool EventTriggerSupportsObjectType ( ObjectType  obtype)

Definition at line 1068 of file event_trigger.c.

References OBJECT_ACCESS_METHOD, OBJECT_AGGREGATE, OBJECT_AMOP, OBJECT_AMPROC, OBJECT_ATTRIBUTE, OBJECT_CAST, OBJECT_COLLATION, OBJECT_COLUMN, OBJECT_CONVERSION, OBJECT_DATABASE, OBJECT_DEFACL, OBJECT_DEFAULT, OBJECT_DOMAIN, OBJECT_DOMCONSTRAINT, OBJECT_EVENT_TRIGGER, OBJECT_EXTENSION, OBJECT_FDW, OBJECT_FOREIGN_SERVER, OBJECT_FOREIGN_TABLE, OBJECT_FUNCTION, OBJECT_INDEX, OBJECT_LANGUAGE, OBJECT_LARGEOBJECT, OBJECT_MATVIEW, OBJECT_OPCLASS, OBJECT_OPERATOR, OBJECT_OPFAMILY, OBJECT_POLICY, OBJECT_PUBLICATION, OBJECT_PUBLICATION_REL, OBJECT_ROLE, OBJECT_RULE, OBJECT_SCHEMA, OBJECT_SEQUENCE, OBJECT_STATISTIC_EXT, OBJECT_SUBSCRIPTION, OBJECT_TABCONSTRAINT, OBJECT_TABLE, OBJECT_TABLESPACE, OBJECT_TRANSFORM, OBJECT_TRIGGER, OBJECT_TSCONFIGURATION, OBJECT_TSDICTIONARY, OBJECT_TSPARSER, OBJECT_TSTEMPLATE, OBJECT_TYPE, OBJECT_USER_MAPPING, and OBJECT_VIEW.

Referenced by standard_ProcessUtility().

1069 {
1070  switch (obtype)
1071  {
1072  case OBJECT_DATABASE:
1073  case OBJECT_TABLESPACE:
1074  case OBJECT_ROLE:
1075  /* no support for global objects */
1076  return false;
1077  case OBJECT_EVENT_TRIGGER:
1078  /* no support for event triggers on event triggers */
1079  return false;
1080  case OBJECT_ACCESS_METHOD:
1081  case OBJECT_AGGREGATE:
1082  case OBJECT_AMOP:
1083  case OBJECT_AMPROC:
1084  case OBJECT_ATTRIBUTE:
1085  case OBJECT_CAST:
1086  case OBJECT_COLUMN:
1087  case OBJECT_COLLATION:
1088  case OBJECT_CONVERSION:
1089  case OBJECT_DEFACL:
1090  case OBJECT_DEFAULT:
1091  case OBJECT_DOMAIN:
1092  case OBJECT_DOMCONSTRAINT:
1093  case OBJECT_EXTENSION:
1094  case OBJECT_FDW:
1095  case OBJECT_FOREIGN_SERVER:
1096  case OBJECT_FOREIGN_TABLE:
1097  case OBJECT_FUNCTION:
1098  case OBJECT_INDEX:
1099  case OBJECT_LANGUAGE:
1100  case OBJECT_LARGEOBJECT:
1101  case OBJECT_MATVIEW:
1102  case OBJECT_OPCLASS:
1103  case OBJECT_OPERATOR:
1104  case OBJECT_OPFAMILY:
1105  case OBJECT_POLICY:
1106  case OBJECT_PUBLICATION:
1108  case OBJECT_RULE:
1109  case OBJECT_SCHEMA:
1110  case OBJECT_SEQUENCE:
1111  case OBJECT_SUBSCRIPTION:
1112  case OBJECT_STATISTIC_EXT:
1113  case OBJECT_TABCONSTRAINT:
1114  case OBJECT_TABLE:
1115  case OBJECT_TRANSFORM:
1116  case OBJECT_TRIGGER:
1118  case OBJECT_TSDICTIONARY:
1119  case OBJECT_TSPARSER:
1120  case OBJECT_TSTEMPLATE:
1121  case OBJECT_TYPE:
1122  case OBJECT_USER_MAPPING:
1123  case OBJECT_VIEW:
1124  return true;
1125  }
1126  return true;
1127 }
void EventTriggerTableRewrite ( Node parsetree,
Oid  tableOid,
int  reason 
)

Definition at line 932 of file event_trigger.c.

References CommandCounterIncrement(), DEBUG1, elog, EventTriggerCommonSetup(), EventTriggerInvoke(), EVT_TableRewrite, InvalidOid, IsUnderPostmaster, list_free(), NIL, PG_CATCH, PG_END_TRY, PG_RE_THROW, PG_TRY, EventTriggerQueryState::table_rewrite_oid, and EventTriggerQueryState::table_rewrite_reason.

Referenced by ATRewriteTables().

933 {
934  List *runlist;
935  EventTriggerData trigdata;
936 
937  elog(DEBUG1, "EventTriggerTableRewrite(%u)", tableOid);
938 
939  /*
940  * Event Triggers are completely disabled in standalone mode. There are
941  * (at least) two reasons for this:
942  *
943  * 1. A sufficiently broken event trigger might not only render the
944  * database unusable, but prevent disabling itself to fix the situation.
945  * In this scenario, restarting in standalone mode provides an escape
946  * hatch.
947  *
948  * 2. BuildEventTriggerCache relies on systable_beginscan_ordered, and
949  * therefore will malfunction if pg_event_trigger's indexes are damaged.
950  * To allow recovery from a damaged index, we need some operating mode
951  * wherein event triggers are disabled. (Or we could implement
952  * heapscan-and-sort logic for that case, but having disaster recovery
953  * scenarios depend on code that's otherwise untested isn't appetizing.)
954  */
955  if (!IsUnderPostmaster)
956  return;
957 
958  runlist = EventTriggerCommonSetup(parsetree,
960  "table_rewrite",
961  &trigdata);
962  if (runlist == NIL)
963  return;
964 
965  /*
966  * Make sure pg_event_trigger_table_rewrite_oid only works when running
967  * these triggers. Use PG_TRY to ensure table_rewrite_oid is reset even
968  * when one trigger fails. (This is perhaps not necessary, as the
969  * currentState variable will be removed shortly by our caller, but it
970  * seems better to play safe.)
971  */
974 
975  /* Run the triggers. */
976  PG_TRY();
977  {
978  EventTriggerInvoke(runlist, &trigdata);
979  }
980  PG_CATCH();
981  {
984  PG_RE_THROW();
985  }
986  PG_END_TRY();
987 
990 
991  /* Cleanup. */
992  list_free(runlist);
993 
994  /*
995  * Make sure anything the event triggers did will be visible to the main
996  * command.
997  */
999 }
#define NIL
Definition: pg_list.h:69
#define DEBUG1
Definition: elog.h:25
static void EventTriggerInvoke(List *fn_oid_list, EventTriggerData *trigdata)
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
static List * EventTriggerCommonSetup(Node *parsetree, EventTriggerEvent event, const char *eventstr, EventTriggerData *trigdata)
bool IsUnderPostmaster
Definition: globals.c:100
void CommandCounterIncrement(void)
Definition: xact.c:922
#define InvalidOid
Definition: postgres_ext.h:36
#define PG_CATCH()
Definition: elog.h:293
#define PG_RE_THROW()
Definition: elog.h:314
void list_free(List *list)
Definition: list.c:1133
#define elog
Definition: elog.h:219
#define PG_TRY()
Definition: elog.h:284
Definition: pg_list.h:45
#define PG_END_TRY()
Definition: elog.h:300
void EventTriggerUndoInhibitCommandCollection ( void  )

Definition at line 1630 of file event_trigger.c.

References EventTriggerQueryState::commandCollectionInhibited.

Referenced by ProcessUtilitySlow().

1631 {
1633  return;
1634 
1636 }
static EventTriggerQueryState * currentEventTriggerState
Definition: event_trigger.c:72
Oid get_event_trigger_oid ( const char *  trigname,
bool  missing_ok 
)

Definition at line 641 of file event_trigger.c.

References CStringGetDatum, ereport, errcode(), errmsg(), ERROR, EVENTTRIGGERNAME, GetSysCacheOid1, and OidIsValid.

Referenced by get_object_address_unqualified().

642 {
643  Oid oid;
644 
646  if (!OidIsValid(oid) && !missing_ok)
647  ereport(ERROR,
648  (errcode(ERRCODE_UNDEFINED_OBJECT),
649  errmsg("event trigger \"%s\" does not exist", trigname)));
650  return oid;
651 }
int errcode(int sqlerrcode)
Definition: elog.c:575
unsigned int Oid
Definition: postgres_ext.h:31
#define OidIsValid(objectId)
Definition: c.h:538
#define GetSysCacheOid1(cacheId, key1)
Definition: syscache.h:179
#define ERROR
Definition: elog.h:43
#define CStringGetDatum(X)
Definition: postgres.h:584
#define ereport(elevel, rest)
Definition: elog.h:122
int errmsg(const char *fmt,...)
Definition: elog.c:797
void RemoveEventTriggerById ( Oid  ctrigOid)

Definition at line 477 of file event_trigger.c.

References CatalogTupleDelete(), elog, ERROR, EVENTTRIGGEROID, EventTriggerRelationId, heap_close, heap_open(), HeapTupleIsValid, ObjectIdGetDatum, ReleaseSysCache(), RowExclusiveLock, SearchSysCache1, and HeapTupleData::t_self.

Referenced by doDeletion().

478 {
479  Relation tgrel;
480  HeapTuple tup;
481 
483 
485  if (!HeapTupleIsValid(tup))
486  elog(ERROR, "cache lookup failed for event trigger %u", trigOid);
487 
488  CatalogTupleDelete(tgrel, &tup->t_self);
489 
490  ReleaseSysCache(tup);
491 
493 }
void CatalogTupleDelete(Relation heapRel, ItemPointer tid)
Definition: indexing.c:255
#define heap_close(r, l)
Definition: heapam.h:97
#define SearchSysCache1(cacheId, key1)
Definition: syscache.h:152
#define ObjectIdGetDatum(X)
Definition: postgres.h:513
#define ERROR
Definition: elog.h:43
ItemPointerData t_self
Definition: htup.h:65
#define RowExclusiveLock
Definition: lockdefs.h:38
void ReleaseSysCache(HeapTuple tuple)
Definition: syscache.c:1116
Relation heap_open(Oid relationId, LOCKMODE lockmode)
Definition: heapam.c:1284
#define HeapTupleIsValid(tuple)
Definition: htup.h:77
#define EventTriggerRelationId
#define elog
Definition: elog.h:219
bool trackDroppedObjectsNeeded ( void  )

Definition at line 1282 of file event_trigger.c.

References EventCacheLookup(), EVT_DDLCommandEnd, EVT_SQLDrop, EVT_TableRewrite, and list_length().

Referenced by deleteObjectsInList(), and EventTriggerBeginCompleteQuery().

1283 {
1284  /*
1285  * true if any sql_drop, table_rewrite, ddl_command_end event trigger
1286  * exists
1287  */
1288  return list_length(EventCacheLookup(EVT_SQLDrop)) > 0 ||
1291 }
static int list_length(const List *l)
Definition: pg_list.h:89
List * EventCacheLookup(EventTriggerEvent event)
Definition: evtcache.c:64