PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Listen Sie Berechtigungen und Berechtigungen für eine materialisierte Ansicht in PostgreSQL auf

In Postgres Systemkatalogen sind der grundlegende Satz vollständiger Informationen über die Installation und die Datenbanken. Systemkataloge sind die zuverlässigste Informationsquelle.Informationsschema als Hilfsfunktion basiert auf Systemkatalogen und wird aus Gründen der Kompatibilität mit anderen RDBMs bereitgestellt:

Materialisierte Ansichten sind keine SQL-Standardobjekte, daher enthält das Informationsschema keine Informationen über sie.

Der Systemkatalog pg_class enthält alle Informationen zu Privilegien in der Spalte relacl .

Wenn die Spalte null ist dann hat der Eigentümer alle Rechte.

Ein leerer String als Benutzername in acl string bedeutet public .

create materialized view test_view as select 1;
grant select on test_view to public;
grant delete on test_view to a_user;

select 
    coalesce(nullif(s[1], ''), 'public') as grantee, 
    s[2] as privileges
from 
    pg_class c
    join pg_namespace n on n.oid = relnamespace
    join pg_roles r on r.oid = relowner,
    unnest(coalesce(relacl::text[], format('{%s=arwdDxt/%s}', rolname, rolname)::text[])) acl, 
    regexp_split_to_array(acl, '=|/') s
where nspname = 'public' and relname = 'test_view';

 grantee  | privileges 
----------+------------
 postgres | arwdDxt
 public   | r
 a_user   | d
(3 rows)

Sie benötigen eine Funktion, um Berechtigungen lesbar anzuzeigen Format:

create or replace function priviliges_from_acl(text)
returns text language sql as $$
    select string_agg(privilege, ', ')
    from (
        select 
            case ch
                when 'r' then 'SELECT'
                when 'w' then 'UPDATE'
                when 'a' then 'INSERT'
                when 'd' then 'DELETE'
                when 'D' then 'TRUNCATE'
                when 'x' then 'REFERENCES'
                when 't' then 'TRIGGER'
            end privilege
        from
            regexp_split_to_table($1, '') ch
    ) s 
$$;

Verwendung:

select 
    coalesce(nullif(s[1], ''), 'public') as grantee, 
    priviliges_from_acl(s[2]) as privileges
from 
    pg_class c
    join pg_namespace n on n.oid = relnamespace
    join pg_roles r on r.oid = relowner,
    unnest(coalesce(relacl::text[], format('{%s=arwdDxt/%s}', rolname, rolname)::text[])) acl, 
    regexp_split_to_array(acl, '=|/') s
where nspname = 'public' and relname = 'test_view';

 grantee  |                          privileges                           
----------+---------------------------------------------------------------
 postgres | INSERT, SELECT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER
 public   | SELECT
 a_user   | DELETE
(3 rows)