Commit 6d239ee4 authored by Bruce Momjian's avatar Bruce Momjian

Allow non-super users to set log_duration to true, then false, when the

administrator has not turned it on, and fix other PGC_USERLIMIT
variables.
parent b8245766
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* Written by Peter Eisentraut <peter_e@gmx.net>. * Written by Peter Eisentraut <peter_e@gmx.net>.
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/misc/guc.c,v 1.154 2003/09/03 22:05:08 petere Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/misc/guc.c,v 1.155 2003/09/04 05:11:20 momjian Exp $
* *
*-------------------------------------------------------------------- *--------------------------------------------------------------------
*/ */
...@@ -2556,7 +2556,7 @@ set_config_option(const char *name, const char *value, ...@@ -2556,7 +2556,7 @@ set_config_option(const char *name, const char *value,
/* Limit non-superuser changes */ /* Limit non-superuser changes */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source > PGC_S_UNPRIVILEGED && source > PGC_S_UNPRIVILEGED &&
newval < conf->session_val && newval < conf->reset_val &&
!superuser()) !superuser())
{ {
ereport(elevel, ereport(elevel,
...@@ -2569,8 +2569,8 @@ set_config_option(const char *name, const char *value, ...@@ -2569,8 +2569,8 @@ set_config_option(const char *name, const char *value,
/* Allow admin to override non-superuser setting */ /* Allow admin to override non-superuser setting */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source < PGC_S_UNPRIVILEGED && source < PGC_S_UNPRIVILEGED &&
record->session_source > PGC_S_UNPRIVILEGED && record->reset_source > PGC_S_UNPRIVILEGED &&
newval > conf->session_val && newval > conf->reset_val &&
!superuser()) !superuser())
changeVal = changeVal_orig; changeVal = changeVal_orig;
} }
...@@ -2652,8 +2652,8 @@ set_config_option(const char *name, const char *value, ...@@ -2652,8 +2652,8 @@ set_config_option(const char *name, const char *value,
/* Limit non-superuser changes */ /* Limit non-superuser changes */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source > PGC_S_UNPRIVILEGED && source > PGC_S_UNPRIVILEGED &&
conf->session_val != 0 && conf->reset_val != 0 &&
(newval > conf->session_val || newval == 0) && (newval > conf->reset_val || newval == 0) &&
!superuser()) !superuser())
{ {
ereport(elevel, ereport(elevel,
...@@ -2666,8 +2666,8 @@ set_config_option(const char *name, const char *value, ...@@ -2666,8 +2666,8 @@ set_config_option(const char *name, const char *value,
/* Allow admin to override non-superuser setting */ /* Allow admin to override non-superuser setting */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source < PGC_S_UNPRIVILEGED && source < PGC_S_UNPRIVILEGED &&
record->session_source > PGC_S_UNPRIVILEGED && record->reset_source > PGC_S_UNPRIVILEGED &&
newval < conf->session_val && newval < conf->reset_val &&
!superuser()) !superuser())
changeVal = changeVal_orig; changeVal = changeVal_orig;
} }
...@@ -2749,7 +2749,7 @@ set_config_option(const char *name, const char *value, ...@@ -2749,7 +2749,7 @@ set_config_option(const char *name, const char *value,
/* Limit non-superuser changes */ /* Limit non-superuser changes */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source > PGC_S_UNPRIVILEGED && source > PGC_S_UNPRIVILEGED &&
newval > conf->session_val && newval > conf->reset_val &&
!superuser()) !superuser())
{ {
ereport(elevel, ereport(elevel,
...@@ -2762,8 +2762,8 @@ set_config_option(const char *name, const char *value, ...@@ -2762,8 +2762,8 @@ set_config_option(const char *name, const char *value,
/* Allow admin to override non-superuser setting */ /* Allow admin to override non-superuser setting */
if (record->context == PGC_USERLIMIT && if (record->context == PGC_USERLIMIT &&
source < PGC_S_UNPRIVILEGED && source < PGC_S_UNPRIVILEGED &&
record->session_source > PGC_S_UNPRIVILEGED && record->reset_source > PGC_S_UNPRIVILEGED &&
newval < conf->session_val && newval < conf->reset_val &&
!superuser()) !superuser())
changeVal = changeVal_orig; changeVal = changeVal_orig;
} }
...@@ -2860,8 +2860,8 @@ set_config_option(const char *name, const char *value, ...@@ -2860,8 +2860,8 @@ set_config_option(const char *name, const char *value,
} }
/* Allow admin to override non-superuser setting */ /* Allow admin to override non-superuser setting */
if (source < PGC_S_UNPRIVILEGED && if (source < PGC_S_UNPRIVILEGED &&
record->session_source > PGC_S_UNPRIVILEGED && record->reset_source > PGC_S_UNPRIVILEGED &&
newval < conf->session_val && newval < conf->reset_val &&
!superuser()) !superuser())
changeVal = changeVal_orig; changeVal = changeVal_orig;
} }
......
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