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