Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
4232c4b4
Commit
4232c4b4
authored
Sep 01, 2011
by
Robert Haas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Userspace access vector cache for contrib/sepgsql.
KaiGai Kohei
parent
3d14bd25
Changes
12
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
661 additions
and
211 deletions
+661
-211
configure
configure
+12
-12
configure.in
configure.in
+2
-2
contrib/sepgsql/Makefile
contrib/sepgsql/Makefile
+1
-1
contrib/sepgsql/dml.c
contrib/sepgsql/dml.c
+26
-33
contrib/sepgsql/hooks.c
contrib/sepgsql/hooks.c
+28
-36
contrib/sepgsql/proc.c
contrib/sepgsql/proc.c
+17
-51
contrib/sepgsql/relation.c
contrib/sepgsql/relation.c
+28
-41
contrib/sepgsql/schema.c
contrib/sepgsql/schema.c
+17
-22
contrib/sepgsql/selinux.c
contrib/sepgsql/selinux.c
+1
-1
contrib/sepgsql/sepgsql.h
contrib/sepgsql/sepgsql.h
+17
-1
contrib/sepgsql/uavc.c
contrib/sepgsql/uavc.c
+511
-0
doc/src/sgml/sepgsql.sgml
doc/src/sgml/sepgsql.sgml
+1
-11
No files found.
configure
View file @
4232c4b4
...
...
@@ -9481,9 +9481,9 @@ fi
# for contrib/sepgsql
if
test
"
$with_selinux
"
=
yes
;
then
{
$as_echo
"
$as_me
:
$LINENO
: checking for selinux_s
epgsql_context_path
in -lselinux"
>
&5
$as_echo_n
"checking for selinux_s
epgsql_context_path
in -lselinux... "
>
&6
;
}
if
test
"
${
ac_cv_lib_selinux_selinux_s
epgsql_context_path
+set
}
"
=
set
;
then
{
$as_echo
"
$as_me
:
$LINENO
: checking for selinux_s
tatus_open
in -lselinux"
>
&5
$as_echo_n
"checking for selinux_s
tatus_open
in -lselinux... "
>
&6
;
}
if
test
"
${
ac_cv_lib_selinux_selinux_s
tatus_open
+set
}
"
=
set
;
then
$as_echo_n
"(cached) "
>
&6
else
ac_check_lib_save_LIBS
=
$LIBS
...
...
@@ -9501,11 +9501,11 @@ cat >>conftest.$ac_ext <<_ACEOF
#ifdef __cplusplus
extern "C"
#endif
char selinux_s
epgsql_context_path
();
char selinux_s
tatus_open
();
int
main ()
{
return selinux_s
epgsql_context_path
();
return selinux_s
tatus_open
();
;
return 0;
}
...
...
@@ -9531,12 +9531,12 @@ $as_echo "$ac_try_echo") >&5
test
"
$cross_compiling
"
=
yes
||
$as_test_x
conftest
$ac_exeext
}
;
then
ac_cv_lib_selinux_selinux_s
epgsql_context_path
=
yes
ac_cv_lib_selinux_selinux_s
tatus_open
=
yes
else
$as_echo
"
$as_me
: failed program was:"
>
&5
sed
's/^/| /'
conftest.
$ac_ext
>
&5
ac_cv_lib_selinux_selinux_s
epgsql_context_path
=
no
ac_cv_lib_selinux_selinux_s
tatus_open
=
no
fi
rm
-rf
conftest.dSYM
...
...
@@ -9544,9 +9544,9 @@ rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
conftest
$ac_exeext
conftest.
$ac_ext
LIBS
=
$ac_check_lib_save_LIBS
fi
{
$as_echo
"
$as_me
:
$LINENO
: result:
$ac_cv_lib_selinux_selinux_s
epgsql_context_path
"
>
&5
$as_echo
"
$ac_cv_lib_selinux_selinux_s
epgsql_context_path
"
>
&6
;
}
if
test
"x
$ac_cv_lib_selinux_selinux_s
epgsql_context_path
"
=
x
""
yes
;
then
{
$as_echo
"
$as_me
:
$LINENO
: result:
$ac_cv_lib_selinux_selinux_s
tatus_open
"
>
&5
$as_echo
"
$ac_cv_lib_selinux_selinux_s
tatus_open
"
>
&6
;
}
if
test
"x
$ac_cv_lib_selinux_selinux_s
tatus_open
"
=
x
""
yes
;
then
cat
>>
confdefs.h
<<
_ACEOF
#define HAVE_LIBSELINUX 1
_ACEOF
...
...
@@ -9554,8 +9554,8 @@ _ACEOF
LIBS
=
"-lselinux
$LIBS
"
else
{
{
$as_echo
"
$as_me
:
$LINENO
: error: library 'libselinux', version 2.0.9
3
or newer, is required for SELinux support"
>
&5
$as_echo
"
$as_me
: error: library 'libselinux', version 2.0.9
3
or newer, is required for SELinux support"
>
&2
;
}
{
{
$as_echo
"
$as_me
:
$LINENO
: error: library 'libselinux', version 2.0.9
9
or newer, is required for SELinux support"
>
&5
$as_echo
"
$as_me
: error: library 'libselinux', version 2.0.9
9
or newer, is required for SELinux support"
>
&2
;
}
{
(
exit
1
)
;
exit
1
;
}
;
}
fi
...
...
configure.in
View file @
4232c4b4
...
...
@@ -964,8 +964,8 @@ fi
# for contrib/sepgsql
if test "$with_selinux" = yes; then
AC_CHECK_LIB(selinux, selinux_s
epgsql_context_path
, [],
[AC_MSG_ERROR([library 'libselinux', version 2.0.9
3
or newer, is required for SELinux support])])
AC_CHECK_LIB(selinux, selinux_s
tatus_open
, [],
[AC_MSG_ERROR([library 'libselinux', version 2.0.9
9
or newer, is required for SELinux support])])
fi
# for contrib/uuid-ossp
...
...
contrib/sepgsql/Makefile
View file @
4232c4b4
# contrib/sepgsql/Makefile
MODULE_big
=
sepgsql
OBJS
=
hooks.o selinux.o label.o dml.o
\
OBJS
=
hooks.o selinux.o
uavc.o
label.o dml.o
\
schema.o relation.o proc.o
DATA_built
=
sepgsql.sql
...
...
contrib/sepgsql/dml.c
View file @
4232c4b4
...
...
@@ -150,12 +150,11 @@ check_relation_privileges(Oid relOid,
uint32
required
,
bool
abort
)
{
char
relkind
=
get_rel_relkind
(
relOid
);
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
ObjectAddress
object
;
char
*
audit_name
;
Bitmapset
*
columns
;
int
index
;
char
relkind
=
get_rel_relkind
(
relOid
);
bool
result
=
true
;
/*
...
...
@@ -184,13 +183,14 @@ check_relation_privileges(Oid relOid,
/*
* Check permissions on the relation
*/
tcontext
=
sepgsql_get_label
(
RelationRelationId
,
relOid
,
0
);
audit_name
=
getObjectDescriptionOids
(
RelationRelationId
,
relOid
);
object
.
classId
=
RelationRelationId
;
object
.
objectId
=
relOid
;
object
.
objectSubId
=
0
;
audit_name
=
getObjectDescription
(
&
object
);
switch
(
relkind
)
{
case
RELKIND_RELATION
:
result
=
sepgsql_check_perms
(
scontext
,
tcontext
,
result
=
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_TABLE
,
required
,
audit_name
,
...
...
@@ -201,8 +201,7 @@ check_relation_privileges(Oid relOid,
Assert
((
required
&
~
SEPG_DB_TABLE__SELECT
)
==
0
);
if
(
required
&
SEPG_DB_TABLE__SELECT
)
result
=
sepgsql_check_perms
(
scontext
,
tcontext
,
result
=
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_SEQUENCE
,
SEPG_DB_SEQUENCE__GET_VALUE
,
audit_name
,
...
...
@@ -210,8 +209,7 @@ check_relation_privileges(Oid relOid,
break
;
case
RELKIND_VIEW
:
result
=
sepgsql_check_perms
(
scontext
,
tcontext
,
result
=
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_VIEW
,
SEPG_DB_VIEW__EXPAND
,
audit_name
,
...
...
@@ -222,7 +220,6 @@ check_relation_privileges(Oid relOid,
/* nothing to be checked */
break
;
}
pfree
(
tcontext
);
pfree
(
audit_name
);
/*
...
...
@@ -242,7 +239,6 @@ check_relation_privileges(Oid relOid,
{
AttrNumber
attnum
;
uint32
column_perms
=
0
;
ObjectAddress
object
;
if
(
bms_is_member
(
index
,
selected
))
column_perms
|=
SEPG_DB_COLUMN__SELECT
;
...
...
@@ -258,20 +254,17 @@ check_relation_privileges(Oid relOid,
/* obtain column's permission */
attnum
=
index
+
FirstLowInvalidHeapAttributeNumber
;
tcontext
=
sepgsql_get_label
(
RelationRelationId
,
relOid
,
attnum
);
object
.
classId
=
RelationRelationId
;
object
.
objectId
=
relOid
;
object
.
objectSubId
=
attnum
;
audit_name
=
getObjectDescription
(
&
object
);
result
=
sepgsql_check_perms
(
scontext
,
tcontext
,
result
=
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_COLUMN
,
column_perms
,
audit_name
,
abort
);
pfree
(
tcontext
);
pfree
(
audit_name
);
if
(
!
result
)
...
...
contrib/sepgsql/hooks.c
View file @
4232c4b4
...
...
@@ -184,9 +184,7 @@ sepgsql_exec_check_perms(List *rangeTabls, bool abort)
static
bool
sepgsql_needs_fmgr_hook
(
Oid
functionId
)
{
char
*
old_label
;
char
*
new_label
;
char
*
function_label
;
ObjectAddress
object
;
if
(
next_needs_fmgr_hook
&&
(
*
next_needs_fmgr_hook
)
(
functionId
))
...
...
@@ -198,14 +196,8 @@ sepgsql_needs_fmgr_hook(Oid functionId)
* functions as trusted-procedure, if the security policy has a rule that
* switches security label of the client on execution.
*/
old_label
=
sepgsql_get_client_label
();
new_label
=
sepgsql_proc_get_domtrans
(
functionId
);
if
(
strcmp
(
old_label
,
new_label
)
!=
0
)
{
pfree
(
new_label
);
if
(
sepgsql_avc_trusted_proc
(
functionId
)
!=
NULL
)
return
true
;
}
pfree
(
new_label
);
/*
* Even if not a trusted-procedure, this function should not be inlined
...
...
@@ -213,17 +205,15 @@ sepgsql_needs_fmgr_hook(Oid functionId)
* that it shall be actually failed later because of same reason with
* ACL_EXECUTE.
*/
function_label
=
sepgsql_get_label
(
ProcedureRelationId
,
functionId
,
0
);
if
(
sepgsql_check_perms
(
sepgsql_get_client_label
(),
function_label
,
object
.
classId
=
ProcedureRelationId
;
object
.
objectId
=
functionId
;
object
.
objectSubId
=
0
;
if
(
!
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_PROCEDURE
,
SEPG_DB_PROCEDURE__EXECUTE
,
NULL
,
false
)
!=
true
)
{
pfree
(
function_label
);
SEPGSQL_AVC_NOAUDIT
,
false
))
return
true
;
}
pfree
(
function_label
);
return
false
;
}
...
...
@@ -251,32 +241,30 @@ sepgsql_fmgr_hook(FmgrHookEventType event,
if
(
!
stack
)
{
MemoryContext
oldcxt
;
const
char
*
cur_label
=
sepgsql_get_client_label
();
oldcxt
=
MemoryContextSwitchTo
(
flinfo
->
fn_mcxt
);
stack
=
palloc
(
sizeof
(
*
stack
));
stack
->
old_label
=
NULL
;
stack
->
new_label
=
sepgsql_
proc_get_domtrans
(
flinfo
->
fn_oid
);
stack
->
new_label
=
sepgsql_
avc_trusted_proc
(
flinfo
->
fn_oid
);
stack
->
next_private
=
0
;
MemoryContextSwitchTo
(
oldcxt
);
if
(
strcmp
(
cur_label
,
stack
->
new_label
)
!=
0
)
{
/*
* process:transition permission between old and new
* label, when user tries to switch security label of the
* client
on execution of trusted procedure.
* process:transition permission between old and new label,
* when user tries to switch security label of the client
*
on execution of trusted procedure.
*/
sepgsql_check_perms
(
cur_label
,
stack
->
new_label
,
if
(
stack
->
new_label
)
sepgsql_avc_check_perms_label
(
stack
->
new_label
,
SEPG_CLASS_PROCESS
,
SEPG_PROCESS__TRANSITION
,
NULL
,
true
);
}
*
private
=
PointerGetDatum
(
stack
);
}
Assert
(
!
stack
->
old_label
);
if
(
stack
->
new_label
)
stack
->
old_label
=
sepgsql_set_client_label
(
stack
->
new_label
);
if
(
next_fmgr_hook
)
...
...
@@ -290,6 +278,7 @@ sepgsql_fmgr_hook(FmgrHookEventType event,
if
(
next_fmgr_hook
)
(
*
next_fmgr_hook
)
(
event
,
flinfo
,
&
stack
->
next_private
);
if
(
stack
->
old_label
)
sepgsql_set_client_label
(
stack
->
old_label
);
stack
->
old_label
=
NULL
;
break
;
...
...
@@ -433,6 +422,9 @@ _PG_init(void)
errmsg
(
"SELinux: failed to get server security label: %m"
)));
sepgsql_set_client_label
(
context
);
/* Initialize userspace access vector cache */
sepgsql_avc_init
();
/* Security label provider hook */
register_label_provider
(
SEPGSQL_LABEL_TAG
,
sepgsql_object_relabel
);
...
...
contrib/sepgsql/proc.c
View file @
4232c4b4
...
...
@@ -96,64 +96,30 @@ sepgsql_proc_post_create(Oid functionId)
void
sepgsql_proc_relabel
(
Oid
functionId
,
const
char
*
seclabel
)
{
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
ObjectAddress
object
;
char
*
audit_name
;
audit_name
=
getObjectDescriptionOids
(
ProcedureRelationId
,
functionId
);
object
.
classId
=
ProcedureRelationId
;
object
.
objectId
=
functionId
;
object
.
objectSubId
=
0
;
audit_name
=
getObjectDescription
(
&
object
);
/*
* check db_procedure:{setattr relabelfrom} permission
*/
tcontext
=
sepgsql_get_label
(
ProcedureRelationId
,
functionId
,
0
);
sepgsql_check_perms
(
scontext
,
tcontext
,
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_PROCEDURE
,
SEPG_DB_PROCEDURE__SETATTR
|
SEPG_DB_PROCEDURE__RELABELFROM
,
audit_name
,
true
);
pfree
(
tcontext
);
/*
* check db_procedure:{relabelto} permission
*/
sepgsql_check_perms
(
scontext
,
seclabel
,
sepgsql_avc_check_perms_label
(
seclabel
,
SEPG_CLASS_DB_PROCEDURE
,
SEPG_DB_PROCEDURE__RELABELTO
,
audit_name
,
true
);
pfree
(
audit_name
);
}
/*
* sepgsql_proc_get_domtrans
*
* It computes security label of the client that shall be applied when
* the current client invokes the supplied function.
* This computed label is either same or different from the current one.
* If security policy informed the function is a trusted-procedure,
* we need to switch security label of the client during execution of
* the function.
*
* Also note that the translated label shall be allocated using palloc().
* So, need to switch memory context, if you want to hold the string in
* someone except for CurrentMemoryContext.
*/
char
*
sepgsql_proc_get_domtrans
(
Oid
functionId
)
{
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
char
*
ncontext
;
tcontext
=
sepgsql_get_label
(
ProcedureRelationId
,
functionId
,
0
);
ncontext
=
sepgsql_compute_create
(
scontext
,
tcontext
,
SEPG_CLASS_PROCESS
);
pfree
(
tcontext
);
return
ncontext
;
}
contrib/sepgsql/relation.c
View file @
4232c4b4
...
...
@@ -79,10 +79,8 @@ void
sepgsql_attribute_relabel
(
Oid
relOid
,
AttrNumber
attnum
,
const
char
*
seclabel
)
{
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
char
*
audit_name
;
ObjectAddress
object
;
char
*
audit_name
;
if
(
get_rel_relkind
(
relOid
)
!=
RELKIND_RELATION
)
ereport
(
ERROR
,
...
...
@@ -97,26 +95,20 @@ sepgsql_attribute_relabel(Oid relOid, AttrNumber attnum,
/*
* check db_column:{setattr relabelfrom} permission
*/
tcontext
=
sepgsql_get_label
(
RelationRelationId
,
relOid
,
attnum
);
sepgsql_check_perms
(
scontext
,
tcontext
,
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_COLUMN
,
SEPG_DB_COLUMN__SETATTR
|
SEPG_DB_COLUMN__RELABELFROM
,
audit_name
,
true
);
/*
* check db_column:{relabelto} permission
*/
sepgsql_check_perms
(
scontext
,
seclabel
,
sepgsql_avc_check_perms_label
(
seclabel
,
SEPG_CLASS_DB_COLUMN
,
SEPG_DB_PROCEDURE__RELABELTO
,
audit_name
,
true
);
pfree
(
tcontext
);
pfree
(
audit_name
);
}
...
...
@@ -227,8 +219,7 @@ out:
void
sepgsql_relation_relabel
(
Oid
relOid
,
const
char
*
seclabel
)
{
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
ObjectAddress
object
;
char
*
audit_name
;
char
relkind
;
uint16_t
tclass
=
0
;
...
...
@@ -246,31 +237,27 @@ sepgsql_relation_relabel(Oid relOid, const char *seclabel)
errmsg
(
"cannot set security labels on relations except "
"for tables, sequences or views"
)));
audit_name
=
getObjectDescriptionOids
(
RelationRelationId
,
relOid
);
object
.
classId
=
RelationRelationId
;
object
.
objectId
=
relOid
;
object
.
objectSubId
=
0
;
audit_name
=
getObjectDescription
(
&
object
);
/*
* check db_xxx:{setattr relabelfrom} permission
*/
tcontext
=
sepgsql_get_label
(
RelationRelationId
,
relOid
,
0
);
sepgsql_check_perms
(
scontext
,
tcontext
,
sepgsql_avc_check_perms
(
&
object
,
tclass
,
SEPG_DB_TABLE__SETATTR
|
SEPG_DB_TABLE__RELABELFROM
,
audit_name
,
true
);
/*
* check db_xxx:{relabelto} permission
*/
sepgsql_check_perms
(
scontext
,
seclabel
,
sepgsql_avc_check_perms_label
(
seclabel
,
tclass
,
SEPG_DB_TABLE__RELABELTO
,
audit_name
,
true
);
pfree
(
tcontext
);
pfree
(
audit_name
);
}
contrib/sepgsql/schema.c
View file @
4232c4b4
...
...
@@ -65,35 +65,30 @@ sepgsql_schema_post_create(Oid namespaceId)
void
sepgsql_schema_relabel
(
Oid
namespaceId
,
const
char
*
seclabel
)
{
char
*
scontext
=
sepgsql_get_client_label
();
char
*
tcontext
;
ObjectAddress
object
;
char
*
audit_name
;
audit_name
=
getObjectDescriptionOids
(
NamespaceRelationId
,
namespaceId
);
object
.
classId
=
NamespaceRelationId
;
object
.
objectId
=
namespaceId
;
object
.
objectSubId
=
0
;
audit_name
=
getObjectDescription
(
&
object
);
/*
* check db_schema:{setattr relabelfrom} permission
*/
tcontext
=
sepgsql_get_label
(
NamespaceRelationId
,
namespaceId
,
0
);
sepgsql_check_perms
(
scontext
,
tcontext
,
sepgsql_avc_check_perms
(
&
object
,
SEPG_CLASS_DB_SCHEMA
,
SEPG_DB_SCHEMA__SETATTR
|
SEPG_DB_SCHEMA__RELABELFROM
,
audit_name
,
true
);
/*
* check db_schema:{relabelto} permission
*/
sepgsql_check_perms
(
scontext
,
seclabel
,
sepgsql_avc_check_perms_label
(
seclabel
,
SEPG_CLASS_DB_SCHEMA
,
SEPG_DB_SCHEMA__RELABELTO
,
audit_name
,
true
);
pfree
(
tcontext
);
pfree
(
audit_name
);
}
contrib/sepgsql/selinux.c
View file @
4232c4b4
...
...
@@ -642,7 +642,7 @@ bool
sepgsql_getenforce
(
void
)
{
if
(
sepgsql_mode
==
SEPGSQL_MODE_DEFAULT
&&
se
curity
_getenforce
()
>
0
)
se
linux_status
_getenforce
()
>
0
)
return
true
;
return
false
;
...
...
contrib/sepgsql/sepgsql.h
View file @
4232c4b4
...
...
@@ -15,6 +15,7 @@
#include "fmgr.h"
#include <selinux/selinux.h>
#include <selinux/avc.h>
/*
* SE-PostgreSQL Label Tag
...
...
@@ -245,6 +246,22 @@ extern bool sepgsql_check_perms(const char *scontext,
uint32
required
,
const
char
*
audit_name
,
bool
abort
);
/*
* uavc.c
*/
#define SEPGSQL_AVC_NOAUDIT ((void *)(-1))
extern
bool
sepgsql_avc_check_perms_label
(
const
char
*
tcontext
,
uint16
tclass
,
uint32
required
,
const
char
*
audit_name
,
bool
abort
);
extern
bool
sepgsql_avc_check_perms
(
const
ObjectAddress
*
tobject
,
uint16
tclass
,
uint32
required
,
const
char
*
audit_name
,
bool
abort
);
extern
char
*
sepgsql_avc_trusted_proc
(
Oid
functionId
);
extern
void
sepgsql_avc_init
(
void
);
/*
* label.c
...
...
@@ -286,6 +303,5 @@ extern void sepgsql_relation_relabel(Oid relOid, const char *seclabel);
*/
extern
void
sepgsql_proc_post_create
(
Oid
functionId
);
extern
void
sepgsql_proc_relabel
(
Oid
functionId
,
const
char
*
seclabel
);
extern
char
*
sepgsql_proc_get_domtrans
(
Oid
functionId
);
#endif
/* SEPGSQL_H */
contrib/sepgsql/uavc.c
0 → 100644
View file @
4232c4b4
This diff is collapsed.
Click to expand it.
doc/src/sgml/sepgsql.sgml
View file @
4232c4b4
...
...
@@ -64,7 +64,7 @@
or higher with <productname>SELinux</productname> enabled. It is not
available on any other platform, and must be explicitly enabled using
<literal>--with-selinux</>. You will also need <productname>libselinux</>
2.0.9
3
or higher and <productname>selinux-policy</> 3.9.13 or higher
2.0.9
9
or higher and <productname>selinux-policy</> 3.9.13 or higher
(some distributions may backport the necessary rules into older policy
versions).
</para>
...
...
@@ -473,16 +473,6 @@ postgres=# SELECT cid, cname, show_credit(cid) FROM customer;
<title>Limitations</title>
<variablelist>
<varlistentry>
<term>Userspace access vector cache</term>
<listitem>
<para>
<productname>sepgsql</> does not yet support an access vector cache.
This would likely improve performance.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term>Data Definition Language (DDL) Permissions</term>
<listitem>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment