aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Haas <rhaas@postgresql.org>2012-02-15 09:57:56 -0500
committerRobert Haas <rhaas@postgresql.org>2012-02-15 09:57:56 -0500
commitd845fd684a3a386400a42c83c209e70095cadd55 (patch)
tree98b262e001fbbe759698100d604261121f323a9f
parent388c2f93254b90921e207bc1cf52e1c8e0f4bba8 (diff)
downloadpostgresql-d845fd684a3a386400a42c83c209e70095cadd55.tar.gz
postgresql-d845fd684a3a386400a42c83c209e70095cadd55.zip
sepgsql: Reword and fix typo in docs on DML permissions.
Per report from Christoph Berg.
-rw-r--r--doc/src/sgml/sepgsql.sgml43
1 files changed, 18 insertions, 25 deletions
diff --git a/doc/src/sgml/sepgsql.sgml b/doc/src/sgml/sepgsql.sgml
index e45c258ac89..68cc6078af2 100644
--- a/doc/src/sgml/sepgsql.sgml
+++ b/doc/src/sgml/sepgsql.sgml
@@ -345,42 +345,35 @@ $ sudo semodule -r sepgsql-regtest
<para>
For tables, <literal>db_table:select</>, <literal>db_table:insert</>,
- <literal>db_table:update</> or <literal>db_table:delete</> is
+ <literal>db_table:update</> or <literal>db_table:delete</> are
checked for all the referenced target tables depending on the kind of
- statement;
- in addition, <literal>db_table:select</> is also checked for
- all the tables that contain the columns referenced in the
+ statement; in addition, <literal>db_table:select</> is also checked for
+ all the tables that contain columns referenced in the
<literal>WHERE</> or <literal>RETURNING</> clause, as a data source
- of <literal>UPDATE</>, and so on. For example, consider:
-
-<synopsis>
-UPDATE t1 SET x = 2, y = md5sum(y) WHERE z = 100;
-</synopsis>
-
- In this case we must have <literal>db_table:select</> in addition to
- <literal>db_table:update</>, because <literal>t1.a</> is referenced
- within the <literal>WHERE</> clause. Column-level permissions will also be
- checked for each referenced column.
+ for <literal>UPDATE</>, and so on.
</para>
<para>
- For columns, <literal>db_column:select</> is checked on
- not only the columns being read using <literal>SELECT</>, but those being
- referenced in other DML statements.
- Of course, it also checks <literal>db_column:update</> or
- <literal>db_column:insert</> on columns being modified by
- <literal>UPDATE</> or <literal>INSERT</>.
+ Column-level permissions will also be checked for each referenced column.
+ <literal>db_column:select</> is checked on not only the columns being
+ read using <literal>SELECT</>, but those being referenced in other DML
+ statements; <literal>db_column:update</> or <literal>db_column:insert</>
+ will also be checked for columns being modified by <literal>UPDATE</> or
+ <literal>INSERT</>.
</para>
<para>
+ For example, consider:
<synopsis>
UPDATE t1 SET x = 2, y = md5sum(y) WHERE z = 100;
</synopsis>
- In this case, it checks <literal>db_column:update</> on the column
- <literal>t1.x</> being updated, <literal>db_column:{select update}</>
- on the column <literal>t1.y</> being updated and referenced, and
- <literal>db_column:select</> on the column <literal>t1.z</>, since that is
- only referenced in the <literal>WHERE</> clause.
+
+ Here, <literal>db_column:update</> will be checked for
+ <literal>t1.x</>, since it is being updated,
+ <literal>db_column:{select update}</> will be checked for
+ <literal>t1.y</>, since it is both updated and referenced, and
+ <literal>db_column:select</> will be checked for <literal>t1.z</>, since
+ it is only referenced.
<literal>db_table:{select update}</> will also be checked
at the table level.
</para>