Предоставление доступа с помощью двух ролей с разными атрибутами пользователя
Теперь представьте ситуацию, в которой вы хотите предоставить пользователю доступ к данным, которые относятся к двум странам и ко всем столицам, указанным в таблице. Для этого необходимо сделать следующее:
Создать несколько атрибутов пользователя для предоставления доступа к странам и столицам.
Создать роли доступа на платформе с использованием этих атрибутов и назначить их пользователю.
Создание нескольких атрибутов пользователя для предоставления доступа к странам и столицам
Откройте Keycloak, введя соответствующий адрес в адресной строке браузера:
<domain>/v3/keycloak
где<domain>
– адрес вашего сервера.Откройте консоль администратора и в боковой панели нажмите Users:
Выберите пользователя, для которого будут создаваться RLS-роли. В нашем примере это пользователь ivanov:
В открывшемся окне перейдите на вкладку Attributes и нажмите Add an attribute, чтобы добавить атрибут:
В поле Key укажите уникальный ключ атрибута, например Countries, а в поле Value укажите его значение. В нашем примере это Россия:
Добавьте еще один атрибут с таким же ключом. Наличие единого ключа позволит обратиться к ним как к массиву при создании правил доступа. В нашем примере мы добавим Франция:
Аналогичным образом создайте еще один атрибут, но уже с другим ключом. Мы назвали его Capital и присвоили ему значение
1
, которое в нашей таблице соответствует столицам:Нажмите Save для сохранения изменений.
Создание роли доступа на платформе и назначение её пользователю
Перейдите в требуемую рабочую область и откройте набор данных, для которого вы хотите создать роли безопасности. В нашем примере это Продажи:
В открывшемся окне нажмите Данные > Роли безопасности:
В появившемся окне нажмите кнопку с крестиком для создания роли:
Переименуйте созданную роль. Мы переименовали её в Россия, Франция:
Для назначения роли пользователю нажмите кнопку справа от названия роли:
В строке поиска начните вводить имя пользователям (в нашем случае ivanov):
Выберите найденного пользователя и нажмите Назначить. Пользователю будет назначена созданная роль, о чём система проинформирует вас:
Кликните название созданной роли в левой стороне диалогового окна. Отобразится список таблиц набора данных, с которым вы работаете:
Выберите таблицу, для которой вы хотите создать правило. В нашем примере это Локация:
В поле справа от списка таблиц введите DAX-выражение фильтрации. В нашем примере мы хотим, чтобы пользователь ivanov мог просматривать только те данные, которые относятся к странам Россия и Франция. Для этого мы введем следующее выражение:
'Локация' [Country] IN USERATTRIBUTEASARRAY ("Countries")
Данный запрос вернёт все строки из таблицы
Локация
, в которых столбецCountry
содержит значения, указанные в атрибутах с ключомCountries
(т.е. Россия и Франция).Нажмите Сохранить DAX в правом нижнем углу.
Аналогичным образом создайте еще одну роль, пройдя все вышеописанные шаги, но только в пункте 4
мы назовем её Столицы, а в пункте 10
введем следующее выражение:
'Локация' [City] IN USERATTRIBUTEASARRAY ("Capital")
После выполнения всех вышеописанных действий, пользователь ivanov получит доступ к данным, которые имеют отношение к двум странам (Россия и Франция) и ко всем столицам, занесённым в таблицу.
Смотрите также
На этой странице
Время чтения: 2 мин.
Нужна дополнительная помощь?