LCOV - code coverage report
Current view: top level - src/backend/catalog - objectaccess.c (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 28 56 50.0 %
Date: 2025-01-18 03:14:54 Functions: 5 12 41.7 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /* -------------------------------------------------------------------------
       2             :  *
       3             :  * objectaccess.c
       4             :  *      functions for object_access_hook on various events
       5             :  *
       6             :  * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
       7             :  * Portions Copyright (c) 1994, Regents of the University of California
       8             :  *
       9             :  * -------------------------------------------------------------------------
      10             :  */
      11             : #include "postgres.h"
      12             : 
      13             : #include "catalog/objectaccess.h"
      14             : #include "catalog/pg_class.h"
      15             : #include "catalog/pg_namespace.h"
      16             : #include "catalog/pg_proc.h"
      17             : 
      18             : /*
      19             :  * Hook on object accesses.  This is intended as infrastructure for security
      20             :  * and logging plugins.
      21             :  */
      22             : object_access_hook_type object_access_hook = NULL;
      23             : object_access_hook_type_str object_access_hook_str = NULL;
      24             : 
      25             : 
      26             : /*
      27             :  * RunObjectPostCreateHook
      28             :  *
      29             :  * OAT_POST_CREATE object ID based event hook entrypoint
      30             :  */
      31             : void
      32          34 : RunObjectPostCreateHook(Oid classId, Oid objectId, int subId,
      33             :                         bool is_internal)
      34             : {
      35             :     ObjectAccessPostCreate pc_arg;
      36             : 
      37             :     /* caller should check, but just in case... */
      38             :     Assert(object_access_hook != NULL);
      39             : 
      40          34 :     memset(&pc_arg, 0, sizeof(ObjectAccessPostCreate));
      41          34 :     pc_arg.is_internal = is_internal;
      42             : 
      43          34 :     (*object_access_hook) (OAT_POST_CREATE,
      44             :                            classId, objectId, subId,
      45             :                            &pc_arg);
      46          34 : }
      47             : 
      48             : /*
      49             :  * RunObjectDropHook
      50             :  *
      51             :  * OAT_DROP object ID based event hook entrypoint
      52             :  */
      53             : void
      54          24 : RunObjectDropHook(Oid classId, Oid objectId, int subId,
      55             :                   int dropflags)
      56             : {
      57             :     ObjectAccessDrop drop_arg;
      58             : 
      59             :     /* caller should check, but just in case... */
      60             :     Assert(object_access_hook != NULL);
      61             : 
      62          24 :     memset(&drop_arg, 0, sizeof(ObjectAccessDrop));
      63          24 :     drop_arg.dropflags = dropflags;
      64             : 
      65          24 :     (*object_access_hook) (OAT_DROP,
      66             :                            classId, objectId, subId,
      67             :                            &drop_arg);
      68          24 : }
      69             : 
      70             : /*
      71             :  * RunObjectTruncateHook
      72             :  *
      73             :  * OAT_TRUNCATE object ID based event hook entrypoint
      74             :  */
      75             : void
      76           0 : RunObjectTruncateHook(Oid objectId)
      77             : {
      78             :     /* caller should check, but just in case... */
      79             :     Assert(object_access_hook != NULL);
      80             : 
      81           0 :     (*object_access_hook) (OAT_TRUNCATE,
      82             :                            RelationRelationId, objectId, 0,
      83             :                            NULL);
      84           0 : }
      85             : 
      86             : /*
      87             :  * RunObjectPostAlterHook
      88             :  *
      89             :  * OAT_POST_ALTER object ID based event hook entrypoint
      90             :  */
      91             : void
      92          24 : RunObjectPostAlterHook(Oid classId, Oid objectId, int subId,
      93             :                        Oid auxiliaryId, bool is_internal)
      94             : {
      95             :     ObjectAccessPostAlter pa_arg;
      96             : 
      97             :     /* caller should check, but just in case... */
      98             :     Assert(object_access_hook != NULL);
      99             : 
     100          24 :     memset(&pa_arg, 0, sizeof(ObjectAccessPostAlter));
     101          24 :     pa_arg.auxiliary_id = auxiliaryId;
     102          24 :     pa_arg.is_internal = is_internal;
     103             : 
     104          24 :     (*object_access_hook) (OAT_POST_ALTER,
     105             :                            classId, objectId, subId,
     106             :                            &pa_arg);
     107          24 : }
     108             : 
     109             : /*
     110             :  * RunNamespaceSearchHook
     111             :  *
     112             :  * OAT_NAMESPACE_SEARCH object ID based event hook entrypoint
     113             :  */
     114             : bool
     115          44 : RunNamespaceSearchHook(Oid objectId, bool ereport_on_violation)
     116             : {
     117             :     ObjectAccessNamespaceSearch ns_arg;
     118             : 
     119             :     /* caller should check, but just in case... */
     120             :     Assert(object_access_hook != NULL);
     121             : 
     122          44 :     memset(&ns_arg, 0, sizeof(ObjectAccessNamespaceSearch));
     123          44 :     ns_arg.ereport_on_violation = ereport_on_violation;
     124          44 :     ns_arg.result = true;
     125             : 
     126          44 :     (*object_access_hook) (OAT_NAMESPACE_SEARCH,
     127             :                            NamespaceRelationId, objectId, 0,
     128             :                            &ns_arg);
     129             : 
     130          44 :     return ns_arg.result;
     131             : }
     132             : 
     133             : /*
     134             :  * RunFunctionExecuteHook
     135             :  *
     136             :  * OAT_FUNCTION_EXECUTE object ID based event hook entrypoint
     137             :  */
     138             : void
     139           0 : RunFunctionExecuteHook(Oid objectId)
     140             : {
     141             :     /* caller should check, but just in case... */
     142             :     Assert(object_access_hook != NULL);
     143             : 
     144           0 :     (*object_access_hook) (OAT_FUNCTION_EXECUTE,
     145             :                            ProcedureRelationId, objectId, 0,
     146             :                            NULL);
     147           0 : }
     148             : 
     149             : /* String versions */
     150             : 
     151             : 
     152             : /*
     153             :  * RunObjectPostCreateHookStr
     154             :  *
     155             :  * OAT_POST_CREATE object name based event hook entrypoint
     156             :  */
     157             : void
     158           0 : RunObjectPostCreateHookStr(Oid classId, const char *objectName, int subId,
     159             :                            bool is_internal)
     160             : {
     161             :     ObjectAccessPostCreate pc_arg;
     162             : 
     163             :     /* caller should check, but just in case... */
     164             :     Assert(object_access_hook_str != NULL);
     165             : 
     166           0 :     memset(&pc_arg, 0, sizeof(ObjectAccessPostCreate));
     167           0 :     pc_arg.is_internal = is_internal;
     168             : 
     169           0 :     (*object_access_hook_str) (OAT_POST_CREATE,
     170             :                                classId, objectName, subId,
     171             :                                &pc_arg);
     172           0 : }
     173             : 
     174             : /*
     175             :  * RunObjectDropHookStr
     176             :  *
     177             :  * OAT_DROP object name based event hook entrypoint
     178             :  */
     179             : void
     180           0 : RunObjectDropHookStr(Oid classId, const char *objectName, int subId,
     181             :                      int dropflags)
     182             : {
     183             :     ObjectAccessDrop drop_arg;
     184             : 
     185             :     /* caller should check, but just in case... */
     186             :     Assert(object_access_hook_str != NULL);
     187             : 
     188           0 :     memset(&drop_arg, 0, sizeof(ObjectAccessDrop));
     189           0 :     drop_arg.dropflags = dropflags;
     190             : 
     191           0 :     (*object_access_hook_str) (OAT_DROP,
     192             :                                classId, objectName, subId,
     193             :                                &drop_arg);
     194           0 : }
     195             : 
     196             : /*
     197             :  * RunObjectTruncateHookStr
     198             :  *
     199             :  * OAT_TRUNCATE object name based event hook entrypoint
     200             :  */
     201             : void
     202           0 : RunObjectTruncateHookStr(const char *objectName)
     203             : {
     204             :     /* caller should check, but just in case... */
     205             :     Assert(object_access_hook_str != NULL);
     206             : 
     207           0 :     (*object_access_hook_str) (OAT_TRUNCATE,
     208             :                                RelationRelationId, objectName, 0,
     209             :                                NULL);
     210           0 : }
     211             : 
     212             : /*
     213             :  * RunObjectPostAlterHookStr
     214             :  *
     215             :  * OAT_POST_ALTER object name based event hook entrypoint
     216             :  */
     217             : void
     218          48 : RunObjectPostAlterHookStr(Oid classId, const char *objectName, int subId,
     219             :                           Oid auxiliaryId, bool is_internal)
     220             : {
     221             :     ObjectAccessPostAlter pa_arg;
     222             : 
     223             :     /* caller should check, but just in case... */
     224             :     Assert(object_access_hook_str != NULL);
     225             : 
     226          48 :     memset(&pa_arg, 0, sizeof(ObjectAccessPostAlter));
     227          48 :     pa_arg.auxiliary_id = auxiliaryId;
     228          48 :     pa_arg.is_internal = is_internal;
     229             : 
     230          48 :     (*object_access_hook_str) (OAT_POST_ALTER,
     231             :                                classId, objectName, subId,
     232             :                                &pa_arg);
     233          46 : }
     234             : 
     235             : /*
     236             :  * RunNamespaceSearchHookStr
     237             :  *
     238             :  * OAT_NAMESPACE_SEARCH object name based event hook entrypoint
     239             :  */
     240             : bool
     241           0 : RunNamespaceSearchHookStr(const char *objectName, bool ereport_on_violation)
     242             : {
     243             :     ObjectAccessNamespaceSearch ns_arg;
     244             : 
     245             :     /* caller should check, but just in case... */
     246             :     Assert(object_access_hook_str != NULL);
     247             : 
     248           0 :     memset(&ns_arg, 0, sizeof(ObjectAccessNamespaceSearch));
     249           0 :     ns_arg.ereport_on_violation = ereport_on_violation;
     250           0 :     ns_arg.result = true;
     251             : 
     252           0 :     (*object_access_hook_str) (OAT_NAMESPACE_SEARCH,
     253             :                                NamespaceRelationId, objectName, 0,
     254             :                                &ns_arg);
     255             : 
     256           0 :     return ns_arg.result;
     257             : }
     258             : 
     259             : /*
     260             :  * RunFunctionExecuteHookStr
     261             :  *
     262             :  * OAT_FUNCTION_EXECUTE object name based event hook entrypoint
     263             :  */
     264             : void
     265           0 : RunFunctionExecuteHookStr(const char *objectName)
     266             : {
     267             :     /* caller should check, but just in case... */
     268             :     Assert(object_access_hook_str != NULL);
     269             : 
     270           0 :     (*object_access_hook_str) (OAT_FUNCTION_EXECUTE,
     271             :                                ProcedureRelationId, objectName, 0,
     272             :                                NULL);
     273           0 : }

Generated by: LCOV version 1.14