Re: prevent users from SELECT-ing from pg_roles/pg_database

Поиск
Список
Период
Сортировка
От Muhammad Salahuddin Manzoor
Тема Re: prevent users from SELECT-ing from pg_roles/pg_database
Дата
Msg-id CAKD7CDkcRu8S6i=q8S06VoGyt9jfN5iS_2WvncAALrWwP3XyNg@mail.gmail.com
обсуждение исходный текст
Ответ на Re: prevent users from SELECT-ing from pg_roles/pg_database  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-general
Greetings,

Yes, you are correct. And

For applications/systems/scripts relying  on this information may require sgnificent modifications to handle the restricted access.

Alternative approches can be.

Auditing and monitoring.
You can use pgaudit extension for auditing and minitoring.

Use SE-PostgeSQL extension that give fine grained access control other than PG standard permissions.

Try RLS row level security. May involve careful planning and may not cover all use cases.

Regards,
Salahuddin.


On Fri, 24 May 2024, 22:02 Tom Lane, <tgl@sss.pgh.pa.us> wrote:
Andreas Joseph Krogh <andreas@visena.com> writes:
> Hi, is there a way to prevent a user/role from SELECT-ing from certain
> system-tables?
> I'd like the contents of pg_{user,roles,database} to not be visible to all
> users.

As noted, you can in principle revoke the public SELECT grant from
those views/catalogs.  However, the system is not designed to hide
such information, which means you'll have (at least) two kinds of
issues to worry about:

1. Queries or tools breaking that you didn't expect to break.
It's hardly uncommon for instance for queries on pg_class to
join to pg_roles to get the owner names for tables.

2. Information leaks.  For example, mapping role OID to role name
is trivial with either regrole or pg_get_userbyid(), so it
wouldn't take long to scan the plausible range of role OIDs and
get all their names, even without SQL access to the underlying
catalog.

                        regards, tom lane


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

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: prevent users from SELECT-ing from pg_roles/pg_database
Следующее
От: Peter
Дата:
Сообщение: Autovacuum endless loop in heap_page_prune()?