Hi

2016-02-29 2:40 GMT+01:00 Joe Conway <m...@joeconway.com>:

> On 01/07/2016 09:08 AM, Joe Conway wrote:
> > On 01/06/2016 10:36 AM, Tom Lane wrote:
> >> I think a design that was actually somewhat robust would require two
> >> hooks, one at check_role and one at assign_role, wherein the first one
> >> would do any potentially-failing work and package all required info into
> >> a blob that could be passed through to the assign hook.
>
> Attached.
>

These patches are pretty trivial, and I can confirm so all regress tests
are passed.

I see following issues:

1. Missing the possibility to pass custom data from SetRoleCheck_hook to
SetRoleAssign_hook. Tom mentioned it in his comment.

2. Missing little bit more comments and an explanation why and when to use
these hooks.

Regards

Pavel




>
> Joe
>
> --
> Crunchy Data - http://crunchydata.com
> PostgreSQL Support for Secure Enterprises
> Consulting, Training, & Open Source Development
>
diff --git a/src/backend/commands/variable.c b/src/backend/commands/variable.c
new file mode 100644
index 903b3a6..7bc0e93
*** a/src/backend/commands/variable.c
--- b/src/backend/commands/variable.c
***************
*** 32,37 ****
--- 32,41 ----
  #include "utils/timestamp.h"
  #include "mb/pg_wchar.h"
  
+ /* Hooks for plugins to get control in check_role() and assign_role() */
+ SetRoleCheck_hook_type SetRoleCheck_hook = NULL;
+ SetRoleAssign_hook_type SetRoleAssign_hook = NULL;
+ 
  /*
   * DATESTYLE
   */
*************** typedef struct
*** 768,773 ****
--- 772,778 ----
        /* This is the "extra" state for both SESSION AUTHORIZATION and ROLE */
        Oid                     roleid;
        bool            is_superuser;
+       void            *data;
  } role_auth_extra;
  
  bool
*************** check_role(char **newval, void **extra,
*** 900,905 ****
--- 905,913 ----
        myextra->is_superuser = is_superuser;
        *extra = (void *) myextra;
  
+       if (SetRoleCheck_hook)
+               (*SetRoleCheck_hook) (GetSessionUserId(), roleid, is_superuser, 
myextra->data);
+ 
        return true;
  }
  
*************** assign_role(const char *newval, void *ex
*** 908,913 ****
--- 916,928 ----
  {
        role_auth_extra *myextra = (role_auth_extra *) extra;
  
+       /*
+        * Any defined hooks must be able to execute in a failed
+        * transaction to restore a prior value of the ROLE GUC variable.
+        */
+       if (SetRoleAssign_hook)
+               (*SetRoleAssign_hook) (myextra->roleid, myextra->is_superuser, 
&myextra->data);
+ 
        SetCurrentRoleId(myextra->roleid, myextra->is_superuser);
  }
  
diff --git a/src/include/commands/variable.h b/src/include/commands/variable.h
new file mode 100644
index 8105951..f229749
*** a/src/include/commands/variable.h
--- b/src/include/commands/variable.h
***************
*** 12,17 ****
--- 12,22 ----
  
  #include "utils/guc.h"
  
+ /* Hooks for plugins to get control in check_role() and assign_role() */
+ typedef void (*SetRoleCheck_hook_type) (Oid, Oid, bool, void**);
+ extern PGDLLIMPORT SetRoleCheck_hook_type SetRoleCheck_hook;
+ typedef void (*SetRoleAssign_hook_type) (Oid, bool, void*);
+ extern PGDLLIMPORT SetRoleAssign_hook_type SetRoleAssign_hook;
  
  extern bool check_datestyle(char **newval, void **extra, GucSource source);
  extern void assign_datestyle(const char *newval, void *extra);
-- 
Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-hackers

Reply via email to