Commit 0a17fd72 authored by Bruce Momjian's avatar Bruce Momjian

Please find a attached a small patch that adds accessor functions

for "aclitem" so that it is not an opaque datatype.

I needed these functions to browse aclitems from user land. I can load
them when necessary, but it seems to me that these accessors for a
backend type belong to the backend, so I submit them.

Fabien Coelho
parent 9cb7b76e
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/utils/adt/acl.c,v 1.101 2003/11/29 19:51:57 pgsql Exp $ * $PostgreSQL: pgsql/src/backend/utils/adt/acl.c,v 1.102 2004/04/26 15:06:48 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -874,6 +874,43 @@ makeaclitem(PG_FUNCTION_ARGS) ...@@ -874,6 +874,43 @@ makeaclitem(PG_FUNCTION_ARGS)
PG_RETURN_ACLITEM_P(aclitem); PG_RETURN_ACLITEM_P(aclitem);
} }
/* give access to internal data within aclitem
*/
Datum
aclitem_grantee(PG_FUNCTION_ARGS)
{
AclItem * a = PG_GETARG_ACLITEM_P(0);
PG_RETURN_INT32(a->ai_grantee);
}
Datum
aclitem_grantor(PG_FUNCTION_ARGS)
{
AclItem * a = PG_GETARG_ACLITEM_P(0);
PG_RETURN_INT32(a->ai_grantor);
}
Datum
aclitem_idtype(PG_FUNCTION_ARGS)
{
AclItem * a = PG_GETARG_ACLITEM_P(0);
PG_RETURN_INT32(ACLITEM_GET_IDTYPE(*a));
}
Datum
aclitem_privs(PG_FUNCTION_ARGS)
{
AclItem * a = PG_GETARG_ACLITEM_P(0);
PG_RETURN_INT32(ACLITEM_GET_PRIVS(*a));
}
Datum
aclitem_goptions(PG_FUNCTION_ARGS)
{
AclItem * a = PG_GETARG_ACLITEM_P(0);
PG_RETURN_INT32(ACLITEM_GET_GOPTIONS(*a));
}
static AclMode static AclMode
convert_priv_string(text *priv_type_text) convert_priv_string(text *priv_type_text)
{ {
......
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/catalog/catversion.h,v 1.224 2004/04/23 20:32:19 neilc Exp $ * $PostgreSQL: pgsql/src/include/catalog/catversion.h,v 1.225 2004/04/26 15:06:49 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -53,6 +53,6 @@ ...@@ -53,6 +53,6 @@
*/ */
/* yyyymmddN */ /* yyyymmddN */
#define CATALOG_VERSION_NO 200404220 #define CATALOG_VERSION_NO 200404260
#endif #endif
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/catalog/pg_proc.h,v 1.325 2004/04/23 20:32:19 neilc Exp $ * $PostgreSQL: pgsql/src/include/catalog/pg_proc.h,v 1.326 2004/04/26 15:06:49 momjian Exp $
* *
* NOTES * NOTES
* The script catalog/genbki.sh reads this file and generates .bki * The script catalog/genbki.sh reads this file and generates .bki
...@@ -3534,6 +3534,18 @@ DESCR("non-persistent series generator"); ...@@ -3534,6 +3534,18 @@ DESCR("non-persistent series generator");
DATA(insert OID = 1069 ( generate_series PGNSP PGUID 12 f f t t v 2 20 "20 20" _null_ generate_series_int8 - _null_ )); DATA(insert OID = 1069 ( generate_series PGNSP PGUID 12 f f t t v 2 20 "20 20" _null_ generate_series_int8 - _null_ ));
DESCR("non-persistent series generator"); DESCR("non-persistent series generator");
/* aclitem utils */
DATA(insert OID = 2510 ( aclitem_grantor PGNSP PGUID 12 f f t f i 1 23 "1033" _null_ aclitem_grantor - _null_ ));
DESCR("extract user id grantor from aclitem");
DATA(insert OID = 2511 ( aclitem_grantee PGNSP PGUID 12 f f t f i 1 23 "1033" _null_ aclitem_grantee - _null_ ));
DESCR("extract grantee (user or group id) from aclitem");
DATA(insert OID = 2512 ( aclitem_idtype PGNSP PGUID 12 f f t f i 1 23 "1033" _null_ aclitem_idtype - _null_ ));
DESCR("extract id type of grantee (0 public, 1 user, 2 group) from aclitem");
DATA(insert OID = 2513 ( aclitem_privs PGNSP PGUID 12 f f t f i 1 23 "1033" _null_ aclitem_privs - _null_ ));
DESCR("extract privileges from aclitem");
DATA(insert OID = 2514 ( aclitem_goptions PGNSP PGUID 12 f f t f i 1 23 "1033" _null_ aclitem_goptions - _null_ ));
DESCR("extract grant options from aclitem");
/* /*
* Symbolic values for provolatile column: these indicate whether the result * Symbolic values for provolatile column: these indicate whether the result
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/utils/acl.h,v 1.66 2004/01/14 23:01:55 tgl Exp $ * $PostgreSQL: pgsql/src/include/utils/acl.h,v 1.67 2004/04/26 15:06:49 momjian Exp $
* *
* NOTES * NOTES
* An ACL array is simply an array of AclItems, representing the union * An ACL array is simply an array of AclItems, representing the union
...@@ -220,6 +220,11 @@ extern Datum aclcontains(PG_FUNCTION_ARGS); ...@@ -220,6 +220,11 @@ extern Datum aclcontains(PG_FUNCTION_ARGS);
extern Datum makeaclitem(PG_FUNCTION_ARGS); extern Datum makeaclitem(PG_FUNCTION_ARGS);
extern Datum aclitem_eq(PG_FUNCTION_ARGS); extern Datum aclitem_eq(PG_FUNCTION_ARGS);
extern Datum hash_aclitem(PG_FUNCTION_ARGS); extern Datum hash_aclitem(PG_FUNCTION_ARGS);
extern Datum aclitem_grantee(PG_FUNCTION_ARGS);
extern Datum aclitem_grantor(PG_FUNCTION_ARGS);
extern Datum aclitem_idtype(PG_FUNCTION_ARGS);
extern Datum aclitem_privs(PG_FUNCTION_ARGS);
extern Datum aclitem_goptions(PG_FUNCTION_ARGS);
/* /*
* prototypes for functions in aclchk.c * prototypes for functions in aclchk.c
......
...@@ -581,6 +581,20 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION') ...@@ -581,6 +581,20 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION')
t t
(1 row) (1 row)
-- aclitem utils small test
SELECT u1.usename AS u1, u2.usename AS u2,
aclitem_idtype(c.relacl[0]) AS idtype,
aclitem_privs(c.relacl[0]) AS privs,
aclitem_goptions(c.relacl[0]) AS goptions
FROM pg_class AS c, pg_user AS u1, pg_user AS u2
WHERE u1.usesysid = aclitem_grantor(c.relacl[0])
AND u2.usesysid = aclitem_grantee(c.relacl[0])
AND c.relname LIKE 'atest4';
u1 | u2 | idtype | privs | goptions
--------------+--------------+--------+-------+----------
regressuser1 | regressuser1 | 1 | 127 | 127
(1 row)
-- clean up -- clean up
\c regression \c regression
DROP FUNCTION testfunc2(int); DROP FUNCTION testfunc2(int);
......
...@@ -316,6 +316,15 @@ SELECT has_table_privilege('regressuser3', 'atest4', 'SELECT'); -- false ...@@ -316,6 +316,15 @@ SELECT has_table_privilege('regressuser3', 'atest4', 'SELECT'); -- false
SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION'); -- true SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION'); -- true
-- aclitem utils small test
SELECT u1.usename AS u1, u2.usename AS u2,
aclitem_idtype(c.relacl[0]) AS idtype,
aclitem_privs(c.relacl[0]) AS privs,
aclitem_goptions(c.relacl[0]) AS goptions
FROM pg_class AS c, pg_user AS u1, pg_user AS u2
WHERE u1.usesysid = aclitem_grantor(c.relacl[0])
AND u2.usesysid = aclitem_grantee(c.relacl[0])
AND c.relname LIKE 'atest4';
-- clean up -- clean up
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment