Перейти к основному содержимому

Создать процесс

Это точка входа для каждой интеграции Web & SDK. Ваш бэкенд вызывает его для создания процесса; ваш фронтенд использует возвращённые токены для отображения iFrame, перенаправления пользователя или инициализации нативного SDK.

Подробнее о полном потоке интеграции см. в разделе Web & SDK Overview.

Endpoint

ОкружениеURL
ProductionPOST https://api.idcloud.unico.app/client/v1/process
SandboxPOST https://api.idcloud.uat.unico.app/client/v1/process

Запрос

Заголовки
ЗаголовокЗначение
AuthorizationBearer <access_token> (см. Authentication)
Content-Typeapplication/json
Параметры тела запроса
ПолеТипОбязательноеОписание
callbackUristringдаURL, на который перенаправляется пользователь после завершения сессии. Используйте / для нативных SDK, где обратный вызов обрабатывается в приложении.
flowstringдаИдентификатор потока — определяет, какие возможности выполняются. Примеры: idunicodocs, idunicosign, idchecktrust, idtoken, idsmart. См. Доступные потоки.
purposestringдаБизнес-цель. Допустимые значения: creditprocess, biometryonboarding, carpurchase, ageverification.
person.duiTypeenumдаТип документа. Допустимые значения: DUI_TYPE_BR_CPF, DUI_TYPE_MX_CURP, DUI_TYPE_US_SSN, DUI_TYPE_BR_PASSPORT, DUI_TYPE_AR_PASSPORT, DUI_TYPE_AR_DNI, DUI_TYPE_NG_NIN, DUI_TYPE_CL_RUN, DUI_TYPE_EC_NI, DUI_TYPE_US_PASSPORT, DUI_TYPE_GT_CUI, DUI_TYPE_UY_CI, DUI_TYPE_ZZ_EMAIL, DUI_TYPE_ID_NIK, DUI_TYPE_ZZ_PHONE_NUMBER, DUI_TYPE_US_DRIVER_LICENSE, DUI_TYPE_NG_BVN.
person.duiValuestringдаНомер документа без форматирования.
person.friendlyNamestringнетОтображаемое имя пользователя в интерфейсе сессии. Максимум 50 символов.
person.phonestringнетНомер телефона в формате DDI + DDD + номер, без разделителей. Обязателен при отправке уведомлений через SMS или WhatsApp.
person.emailstringнетАдрес электронной почты. Обязателен для потоков с электронной подписью.
person.notificationsarrayнетКаналы уведомлений для отправки ссылки на сессию. Каждый элемент содержит notificationChannel: NOTIFICATION_CHANNEL_WHATSAPP, NOTIFICATION_CHANNEL_SMS или NOTIFICATION_CHANNEL_EMAIL.
bioTokenIdstring (UUID)условноеУстарело. Используйте references. Идентификатор ссылочного биометрического процесса. Обязателен для потоков валидации 1:1 (idtoken, idtokentrust, idtokensign) и Умной ревалидации (idsmart).
referencesarrayусловноеСсылочные данные для потоков валидации 1:1 и Умной ревалидации, заменяющие bioTokenId. Каждый элемент содержит referenceType (REFERENCE_TYPE_IMAGE_BASE64 или REFERENCE_TYPE_PROCESS_ID) и referenceContent (изображение в формате base64 или UUID процесса).
useCasestringусловноеСценарий использования Умной ревалидации. Обязателен для idsmart. Примеры: USE_CASE_LOGIN, USE_CASE_IDENTITY_REVALIDATION_7_DAYS, USE_CASE_FIN_TRANSACTIONS.
clientReferencestringнетВаш внутренний идентификатор для данного процесса (внешний ключ для перекрёстных ссылок на портале).
companyBranchIdstring (UUID)нетИдентификатор филиала. Обязателен только в случае, если с сервисным аккаунтом связан более чем один филиал.
expiresInstringнетСрок действия процесса с момента создания. Формат: "3600s". По умолчанию — 7 дней, если не указано.
flow_configobjectнетПереопределение конфигурации для конкретного потока.
flow_config.biometry_capture.enabled_back_camerabooleanнетИспользовать заднюю камеру устройства. Несовместимо с потоками захвата документов или электронной подписи.
contextualizationobjectнетКонтекст транзакции, отображаемый пользователю во время сессии для объяснения процесса захвата.
contextualization.currencystringнетКод валюты, отображаемый пользователю. Допустимые значения: BRL, MXN, USD.
contextualization.pricenumberнетСумма транзакции, отображаемая пользователю.
contextualization.localeobjectнетЛокализованный текст причины. Ключи: ptBr, enUs, esMx — каждый со строкой reason, отображаемой во время сессии.

Пример

curl -X POST https://api.idcloud.unico.app/client/v1/process \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{
"callbackUri": "https://app.client.com/callback",
"flow": "idunicodocs",
"purpose": "biometryonboarding",
"person": {
"duiType": "DUI_TYPE_BR_CPF",
"duiValue": "12345678909",
"friendlyName": "Luke Skywalker",
"phone": "5511912345678",
"email": "[email protected]"
}
}'

Ответы

200 OK
{
"process": {
"id": "53060f52-f146-4c12-a234-5bb5031f6f5b",
"state": "PROCESS_STATE_CREATED",
"flow": "idunicosign",
"purpose": "biometryonboarding",
"callbackUri": "https://app.client.com/callback",
"clientReference": "your-internal-id-123",
"companyBranchId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
"userRedirectUrl": "https://cadastro.unico.app/process/53060f52-f146-4c12-a234-5bb5031f6f5b",
"token": "eyJhbGciOiJSUzI1NiIs...",
"webAppToken": "eyJhbGciOiJSUzI1NiIs...",
"createdAt": "2023-10-09T09:15:25.417105Z",
"expiresAt": "2023-10-09T16:15:25.417105Z",
"capacities": [],
"authenticationInfo": {},
"person": {
"duiType": "DUI_TYPE_BR_CPF",
"duiValue": "12345678909",
"friendlyName": "Luke Skywalker",
"phone": "5511912345678",
"email": "[email protected]",
"notifications": []
},
"companyData": {
"branchId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
"countryCode": "BR"
}
}
}
ПолеТипОписание
process.idstring (UUID)Идентификатор процесса. Используйте его для получения результата через Get Process.
process.stateenumPROCESS_STATE_CREATED — процесс создан, сессия ещё не начата. PROCESS_STATE_FAILED — создание процесса завершилось ошибкой.
process.flowstringИдентификатор потока, переданный при создании.
process.purposestringБизнес-цель, переданная при создании.
process.callbackUristringURI обратного вызова, переданный при создании.
process.clientReferencestringВаш внутренний идентификатор, переданный при создании. Присутствует только если был указан в запросе.
process.companyBranchIdstring (UUID)Идентификатор филиала. Присутствует только если был указан в запросе.
process.userRedirectUrlstringURL для перенаправления пользователя (интеграции Web Redirect и iFrame). Не изменяйте этот URL.
process.tokenstringJWT для инициализации Web SDK iFrame.
process.webAppTokenstringJWT для инициализации нативных SDK (Android, iOS, Flutter).
process.createdAtstring (date-time)Временная метка создания процесса.
process.expiresAtstring (date-time)Временная метка, после которой процесс истекает и не может быть завершён.
process.capacitiesarrayВозможности, настроенные для данного процесса.
process.authenticationInfoobjectИнформация об аутентификации процесса (пустая на момент создания).
process.personobjectОтражение объекта person, переданного при создании.
process.companyData.branchIdstring (UUID)Идентификатор филиала, связанного с процессом.
process.companyData.countryCodestringКод страны, связанный с филиалом (например, BR, MX).
400 Bad Request

Возвращается, когда тело запроса некорректно, обязательные поля отсутствуют или значение flow неизвестно.

401 Unauthorized

Bearer-токен отсутствует, истёк или недействителен. См. Authentication.

429 Too Many Requests

Достигнут лимит запросов. Повторите попытку через интервал, указанный в заголовках ответа.

Коды ошибок

КодСообщениеОписание
3invalid flowКогда указанный поток не существует.
3invalid person: friendly name exceeds 50 characters.Когда отображаемое имя превышает 50 символов.
3invalid purposeКогда указанная бизнес-цель недействительна.
3invalid callbackUri: unable to parse callbackUri: parse "": empty url, invalid callbackUri: url:Когда указанный callbackUri недействителен.
3invalid person: email required for notification channel NOTIFICATION_CHANNEL_EMAIL, invalid email address for notification channel NOTIFICATION_CHANNEL_EMAILКогда указанный адрес электронной почты недействителен и настроено уведомление по электронной почте.
3invalid person: phone number required for notification channel NOTIFICATION_CHANNEL_WHATSAPP, phone number does not contain 13 chars for notification channel NOTIFICATION_CHANNEL_WHATSAPPКогда указанный номер телефона недействителен и настроено уведомление через SMS или WhatsApp.
3idnsv2/GetPublicID request error: rpc error: code = InvalidArgument desc = invalid dui valueКогда указанный идентификатор (duiValue) недействителен.
3invalid expiresIn argumentКогда значение expiresIn недействительно.
9XX ID Apikeys are not setКогда API Key настроен неправильно.

Что дальше

  • После того как пользователь завершит сессию, вызовите Get Process для получения результата или дождитесь webhook.