Re: Security Definer functions no longer works in PG14+

Поиск
Список
Период
Сортировка
От Jobin Augustine
Тема Re: Security Definer functions no longer works in PG14+
Дата
Msg-id CAEpZXffY9xs+nJ3bn2AKySjcrYMhvk=QH_LKa1ystbZ=EU4oXg@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Security Definer functions no longer works in PG14+  (Jan Katins <jasc@gmx.net>)
Ответы Re: Security Definer functions no longer works in PG14+  (Amit Kapila <amit.kapila16@gmail.com>)
Список pgsql-bugs
Thanks, Jan,
Usage of dblink is a good workaround. Thanks for that.

On Fri, May 6, 2022 at 12:02 AM Jan Katins <jasc@gmx.net> wrote:
Hi,

The aiven-extras repo has a workaround for that, using dblink: https://github.com/aiven/aiven-extras/commit/eb8c1107ca91a7da5ecb0c8127c94ce42762881d

Jan

On Thu, 5 May 2022, 17:49 Jobin Augustine, <jobinau@gmail.com> wrote:
Hello Community and Hackers,

A function like:

CREATE OR REPLACE  FUNCTION fn_sql_refresh() RETURNS void AS $$
    ALTER SUBSCRIPTION sub REFRESH PUBLICATION;
$$ LANGUAGE SQL SECURITY DEFINER;

Works with PostgreSQL 13 and older versions.
But gives error on PostgreSQL 14 as follows:

postgres=> select fn_sql_refresh();
ERROR:  ALTER SUBSCRIPTION ... REFRESH cannot be executed from a function
CONTEXT:  SQL function "fn_sql_refresh" statement 1


But it is hurting good operational use cases of logical replication.

Regards,
Jobin.


--
Thanks and Regards,
Jobin Augustine
PostgreSQL Escalation Specialist

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

Предыдущее
От: Masahiko Sawada
Дата:
Сообщение: Re: Implicitly created operator family not listed by pg_event_trigger_ddl_commands
Следующее
От: Andrew Borodin
Дата:
Сообщение: Re: Security Definer functions no longer works in PG14+