SSO: создание пользователя на лету
Общее описание
Классически, SSO позволяет перейти в систему пользователю, который уже в ней зарегистрирован. Однако, возможен сценарий, когда такого пользователя в Кортеос нет, и его нужно зарегистрировать в момент первого перехода в систему, условно говоря, “на лету”.
Для того, чтобы создать пользователя на лету, необходимо заполнить структуру AccountDetails так, как показано в примере:
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sso="https://sso.corteos.ru/">
<soapenv:Header/>
<soapenv:Body>
<sso:Set>
<!--Optional:-->
<sso:request>
<sso:AccountDetails id_Group="ХХ" GroupSecurityKey="ХХХХХХХХХХХ" Email="themax1@elmotest.ru">
<!--Optional:-->
<sso:PersonToCreate LastName="Админских" FirstName="Максим" MiddleName="Валерьевич"
LastNameLatin="Adminskih" FirstNameLatin="Maksim" MiddleNameLatin="Valerievich" Gender="true" DateBirth="2000-01-02">
<!--Optional:-->
<sso:INN>987987987</sso:INN>
<!--Optional:-->
<sso:KPP>779901001</sso:KPP>
<!--Optional:-->
<sso:CountryAlpha2>RU</sso:CountryAlpha2>
<!--Optional:-->
</sso:PersonToCreate>
<sso:id_Role>1</sso:id_Role>
</sso:AccountDetails>
</sso:request>
</sso:Set>
</soapenv:Body>
</soapenv:Envelope>
В этом случае, если пользователя с Email(в нашем примере - themax1@elmotest.ru - нет в системе, то он будет создан на лету.
Данные для персоны берутся из контейнера PersonToCreate, который имеет тип данных персона. Минимальный набор полей показан в примере, нужно передать:
LastName - фамилия персоны на русском языке, строка
FirstName - имя персоны на русском языке, строка
MiddleName - отчество персоны, если нет - передаем пробельный символ, строка.
LastNameLatin, FirstNameLatin, MiddleNameLatin - все то же самое, но на английском языке, строка. Если у вас в системе эти данные не хранятся, то русский аналог необходимо транслитерировать по ГОСТ 7.79-2000 (система Б)
Gender - true - мужчина, false - женщина
DateBirth - дата рождения, datetime
INN - ИНН организации, в которой работает персона, строка
KPP - КПП организации, в которой работает персона, строка. По полям ИНН и КПП мы привязываем персону к нужной компании
CountryAplha2 - alpha2 код страны, гражданином которой является персона.
id_Role - идентификатор роли пользователя, который будет создан в процессе SSO
Посмотреть идентификаторы, доступные в вашей компании, можно из-под пользователя с правами Тревел-Менеджера в меню “Настройки” - “Роли”:
Идентификаторы ролей показаны в первом столбце:
Дополнительно можно передавать контактные данные, структурные коды, документы по создаваемой персоне, аналогично тому, как мы передаем при передаче пассажира - детально можно посмотреть на SSO портале.
Важные замечания
Нужно ли дублировать данные персоны в пассажирах, если она передана как пользователь?
Данные пользователя и пассажира обрабатываются разными разборщиками, поэтому их необходимо дублировать.
Что будет, если передать детали пользователя, а такой пользователь уже зарегистрирован в системе? Обновятся ли его данные?
Если пользователь уже зарегистрирован, элемент PersonToCreate не обрабатывается в принципе, обновить данные можно только через данные пассажиров.
Нужно ли активировать созданного через SSO пользователя в редакторе договора?
Нет. Пользователь активируется автоматически.