mirror of
https://github.com/simtactics/niotso.git
synced 2025-04-01 23:44:02 +00:00
46 lines
1.2 KiB
C
46 lines
1.2 KiB
C
/*
|
|
* objectaccess.h
|
|
*
|
|
* Object access hooks.
|
|
*
|
|
* Portions Copyright (c) 1996-2011, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*/
|
|
|
|
#ifndef OBJECTACCESS_H
|
|
#define OBJECTACCESS_H
|
|
|
|
/*
|
|
* Object access hooks are intended to be called just before or just after
|
|
* performing certain actions on a SQL object. This is intended as
|
|
* infrastructure for security or logging pluggins.
|
|
*
|
|
* OAT_POST_CREATE should be invoked just after the the object is created.
|
|
* Typically, this is done after inserting the primary catalog records and
|
|
* associated dependencies.
|
|
*
|
|
* Other types may be added in the future.
|
|
*/
|
|
typedef enum ObjectAccessType
|
|
{
|
|
OAT_POST_CREATE,
|
|
} ObjectAccessType;
|
|
|
|
/*
|
|
* Hook, and a macro to invoke it.
|
|
*/
|
|
|
|
typedef void (*object_access_hook_type) (ObjectAccessType access,
|
|
Oid classId,
|
|
Oid objectId,
|
|
int subId);
|
|
|
|
extern PGDLLIMPORT object_access_hook_type object_access_hook;
|
|
|
|
#define InvokeObjectAccessHook(access,classId,objectId,subId) \
|
|
do { \
|
|
if (object_access_hook) \
|
|
(*object_access_hook)((access),(classId),(objectId),(subId)); \
|
|
} while(0)
|
|
|
|
#endif /* OBJECTACCESS_H */
|