Автоматическая идентификация пользователя по свойствам сессии#
Blitz Identity Provider может выполнять автоматическую идентификацию пользователя и предоставление доступа по предварительно вычисленным свойствам сессии. Поддерживаются любые свойства сессии, которые могут быть определены средствами Заказчика и предоставлены в Blitz Identity Provider.
Совет
Частным случаем использования метода является вход пользователя по номеру мобильного телефона, автоматически определенного по его IP-адресу Заказчиком-оператором сотовой связи.
Внимание
Автоматическая идентификация возможна только для первого фактора.
Для использования данного метода аутентификации выполните описанную ниже последовательность действий.
Шаг 1. Добавление метода в blitz.conf#
Для того чтобы метод автоматической идентификации отображался на вкладке Аутентификация -> Первый фактор, выполните следующие действия:
Откройте файл конфигурации
/usr/share/identityblitz/blitz-config/blitz.conf
.sudo vim /usr/share/identityblitz/blitz-config/blitz.conf
Добавьте метод в список доступных методов первого фактора блока
blitz.prod.local.idp.login.factors
по аналогии с примером ниже. Методы первого фактора задаются в первой секции блока. Название метода должно состоять из префиксаsprop_
и идентификатора: например, у методаsprop_msisdn
из примера идентификаторmsisdn
.Примечание
Можно добавить несколько методов.
"login" : { "factors" : [ [ { "enabled" : false, "method" : "sprop_msisdn" }, … ], [ … ] ], … }
Перезагрузите сервисы.
sudo systemctl restart blitz-idp blitz-console
Шаг 2. Настройка метода в консоли#
Конфигурация метода в консоли управления выполняется следующим образом:
В консоли управления перейдите Аутентификация -> Первый фактор -> настройки метода Автоматическая идентификация.
Выполните маппинг атрибута, хранящегося в источнике данных Blitz Identity Provider, на свойство сессии, получаемое от сервиса Заказчика при выполнении процедуры входа. После получения свойства сессии Blitz Identity Provider выполнит поиск его значения среди значений указанного атрибута и в случае успеха разрешит вход по соответствующей учетной записи. Например, маппинг
phone_number=${p_msisdn}
означает, что свойство сессииp_msisdn
будет сравниваться с атрибутомphone_number
в хранилище данных.Совет
Вы можете добавить несколько условий для поиска среди атрибутов, которые должны выполниться одновременно, чтобы пользователь был идентифицирован, а также ввести альтернативное правило.
По умолчанию после автоматической идентификации пользователя на его экране отображается его идентификатор и запрос на подтверждение входа. Задайте правило для формирования идентификатора пользователя из его атрибутов в виде строки подстановки. Это может быть замаскированный номер телефона, имя пользователя и др.
Для того чтобы деактивировать подтверждение входа, поставьте флажок Не показывать пользователю экран с подтверждением входа.
Нажмите Сохранить.
По умолчанию поиск пользователей для аутентификации происходит во всех активных хранилищах. В блоке Правила выбора хранилища атрибутов можно настроить правила, при выполнении которых поиск пользователя будет осуществляться в определенном хранилище. Можно задать несколько альтернативных правил выбора хранилища. Это позволит аутентифицировать одних пользователей по одному хранилищу, других – по другому.
Для создания правила используйте следующие компоненты:
флажок
not
: признак инвертирования условия;первый столбец: проверяемое выражение, например, атрибут учетной записи, идентификатора приложения и пр.;
второй столбец: условие выбора в виде регулярного выражения, например, значение атрибута пользователя, значение идентификатора приложения и пр.
Например, для того чтобы аутентифицировать всех пользователей, номер телефона которых содержит код
980
, в указанном хранилище, создайте правило, как показано на рисунке ниже.Нажмите Сохранить.
Шаг 3. Создание процедуры входа#
Для использования автоматической идентификации необходимо создать процедуру входа, выполняемую до прохождения первого фактора аутентификации, которая будет запрашивать свойства сессии от сервиса Заказчика. Например, в частном случае при входе по автоматически определенному номеру телефона процедура должна выполнять следующие действия:
Определение IP-адреса пользователя. В случае если IP-адрес лежит в установленном диапазоне, производится вызов сервиса Заказчика-оператора сотовой связи для определения номера мобильного телефона.
После получения номера телефона процедура запрашивает у Blitz Identity Provider вход методом автоматической идентификации.
Пример кода, запускающего вход методом автоматической идентификации (sprop_msisdn
), если свойство сессии p_msisdn
имеет значение +79161234567
:
//Свойство сессии и его значение, при которых будет выполнен вход
String propName = "p_msisdn";
String propValue = "+79161234567";
String propMethod = "sprop_msisdn";
// Добавление свойства сессии в контект
Props sProps = ctx.sessionProps().addStringProp(propName, propValue);
return StrategyState
.MORE_BUILDER()
//Запуск входа по свойству сессии (метод с идентификатором sprop_msisdn), альтернативные методы - вход по паролю и SMS.
.addMethods(new String[] {propMethod, "password", "sms"})
//Установка свойств сессии из контекста
.setSessionProps(sProps)
//Запуск метода sprop_msisdn (при условии, что он включен и сконфигурирован), поиск пользователя с номером +79161234567, аутентификация, если пользователь найден.
.build();
Шаг 4. Кастомизация текстов#
Если вы используете несколько методов автоматической идентификации, следует провести кастомизацию текстов интерфейса для каждого из них, руководствуясь алгоритмом.
В идентификатор текстовой строки понадобится включить имя метода или идентификатор метода. Имя метода определено в файле конфигурации /usr/share/identityblitz/blitz-config/blitz.conf
и состоит из префикса sprop_
и идентификатора метода: например, у метода sprop_msisdn
идентификатор msisdn
.
Для кастомизации используются следующие способы и строки:
Форма входа
Кастомизация с помощью имени метода <sprop_id>
:
login.methods.sprop.head.title.<sprop_id>=Подтверждение входа по номеру телефона
login.methods.sprop.info.<sprop_id>=Ваш номер<br><strong>{0}</strong>.
login.methods.sprop.btn.consent.<sprop_id>=Войти
login.methods.sprop.btn.refuse.<sprop_id>=Войти под другим номером
Отображение метода в списке доступных методов при аутентификации
Кастомизация с помощью идентификатора метода <id>
:
login.methods.switcher.title.sprop.<id>=Автовход по номеру телефона
login.methods.switcher.label.sprop.<id>=Автовход по номеру телефона
Отображение метода в списке методов в консоли управления
Кастомизация с помощью имени метода <sprop_id>
:
page.authn.<sprop_id>.title=Автовход по номеру телефона
page.authn.<sprop_id>.info=Для идентификации пользователя используется свойство сессии p_msisdn, которое вычисляется и сохраняется при старте процедуры входа.
Форма настройки метода в консоли
Кастомизация с помощью имени метода <sprop_id>
:
page.method.sprop.title.<sprop_id>=Автовход по номеру телефона
page.method.sprop.info.<sprop_id>=<p>Для корректной работы автовхода укажите, какие свойствам текущей сессии соответствуют каким атрибутам в источнике данных. Вы можете создать несколько альтернативных правил. </p>Например, правило <code>phone_number=$'{p_msisdn}'</code> означает, что свойство сессии <code>p_msisdn</code>, будет сравниваться с атрибутом <code>phone_number</code> в хранилище данных.</p>
Результат выполнения метода на вкладке События консоли управления
Успешный вход: добавьте строку
audit.method.<sprop_id>
.Вход не выполнен: добавьте строку
console.audit.type.auth_failed.<sprop_id>
.
audit.method.<sprop_id>=Автовход по номеру телефона
console.audit.type.auth_failed.sprop_msisdn=Ошибка автовхода по номеру телефона
Отображение события неуспешного входа в Личном кабинете
Для отображения неуспешного входа в Личном кабинете пользователя добавьте строку profile.audit.type.auth_failed.<sprop_id>
.
profile.audit.type.auth_failed.<sprop_id>=Ошибка автовхода по номеру телефона