Re: Restoring default privileges on objects

Поиск
Список
Период
Сортировка
От Stuart McGraw
Тема Re: Restoring default privileges on objects
Дата
Msg-id e7387e04-0a17-3a77-8e0c-da6794625a30@mtneva.com
обсуждение исходный текст
Ответ на Re: Restoring default privileges on objects  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: Restoring default privileges on objects
Re: Restoring default privileges on objects
Список pgsql-general
On 8/29/23 13:27, Tom Lane wrote:
> Erik Wienhold <ewie@ewie.name> writes:
>> On 29/08/2023 18:43 CEST Stuart McGraw <smcg4191@mtneva.com> wrote:
>>> Shouldn't psql put *something* (like "(default)" or "-") in the
>>> "Access privileges" column to indicate that?  Or conversely,
>>> something (like "(none)"?) in the revoked case?
> 
>> Indeed, that's confusing.  Command \dp always prints null as empty string [1].
>> So \pset null '(null)' has no effect.
> 
> Yeah, perhaps.  The reason it so seldom comes up is that a state of
> zero privileges is extremely rare (because it's useless in practice).
> 
> That being the case, if we were to do something about this, I'd vote
> for changing the display of zero-privileges to "(none)" or something
> along that line, rather than changing the display of NULL, which
> people are accustomed to.
> 
> Fixing \dp to honor "\pset null" for this might be a reasonable
> thing to do too.  I'm actually a bit surprised that that doesn't
> work already.
> 
>             regards, tom lane

That change would still require someone using \dp to realize that
the "Access privileges" value could be either '' or NULL (I guess
that could be pointed out more obviously in the psql doc), and then
do a '\pset null' before doing \dp?  That seems a little inconvenient.

As a possible alternative, in the query that \dp sends, what about
replacing the line:

   select ...,
     pg_catalog.array_to_string(c.relacl, E'\n') as "Access privileges"
     ...

with something like:

     CASE array_length(c.relacl,1) WHEN 0 THEN '(none)' ELSE pg_catalog.array_to_string(c.relacl, E'\n') END as "Access
privileges"

I realize that removes the ability to control with pset what is
displayed, but maybe a little more foolproof for naive users like
myself?




В списке pgsql-general по дате отправления:

Предыдущее
От: Alan Stange
Дата:
Сообщение: Re: [INTERNET] Re: auto vacuum question
Следующее
От: Erik Wienhold
Дата:
Сообщение: createuser unexpectedly creates superuser with createdb and createrole