Подскажите, пожалуйста. Есть схема в postgres, например, external. В нее добавляются

таблицы с помощью Spark.
Создал роль - read_only_external, которая умеет только SELECT таблицы в схеме external.
Написал привилегию, если в схеме external появляется новая таблица, то роль read_only_external автоматический может ее читать:
ALTER DEFAULT PRIVILEGES IN SCHEMA external GRANT SELECT ON TABLES TO read_only_external;

Когда Spark создает новую таблицу в схеме external, то дефолтная настройка не отрабатывает. То бишь роль не может читать из новой созданной таблицы.
Если я ручками создаю тестовую таблицу в схеме external, то роль ее видит.

Что за магия вне Хогвартса?

6 ответов

20 просмотров

Может это: You can change default privileges only for objects that will be created by yourself or by roles that you are a member of.

А создают разные юзернэймы?

Nikita-Sysoev Автор вопроса
BadRat
Может это: You can change default privileges only ...

У меня своя роль и у Spark тоже. Но мы оба superuser. Разница в том, что условную схему external я создал, а Спарк туда закидывает таблицы. То есть, из-за того, что я создал схему, то и созданные мной таблицы в этой схеме будут автоматический читаться ролью read_only_external, потому что создана такая привилегия. Спарк никакого отношения к схеме read_only_external не имеет и не состоит в других ролях, то его таблицы созданные в схеме external будут игнорироваться настроенной привилегий для read_only_external? Вообще не очевидное поведение для меня

Nikita Sysoev
У меня своя роль и у Spark тоже. Но мы оба superus...

Кароч эти изменения привязаны к роли всегда. Если ты роль не указываешь то к той под которой делаешь альтер.https://www.postgresql.org/docs/current/sql-alterdefaultprivileges.html

Nikita-Sysoev Автор вопроса
BadRat
Кароч эти изменения привязаны к роли всегда. Если ...

Спасибо. Буду играться сейчас с этим. Если бы даже изначально это прочитал в документации, то не понял, что это относится к моей проблеме

Nikita Sysoev
Спасибо. Буду играться сейчас с этим. Если бы даже...

А сразу в явном виде грант после создания нельзя дать?

Похожие вопросы

Обсуждают сегодня

Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Привет!) Кто как юзает переменные в строках?) Чисто ради интереса Вот так: echo "У меня {$bananasAmount} бананов"; Или вот так: echo "У меня ${bananasAmount} бананов";
Виталий
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
разработчик ботов скидывает портфолио, боты которые он уже создал. А вот как узнать что это именно он их создал?
Gosudar
4
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Карта сайта