Для работы с API платформы необходимо получить токен доступа (access_token). Токен используется для заполнения заголовка авторизации в запросах к API.
Можно получить токен, отправив отдельный запрос (описан ниже). Но предварительно необходимо выполнить настройку на стороне Keycloak (один из компонентов платформы Robin).
Необходимо включить grant_type в кейклоке, для этого
features=token-exchange,admin-fine-grained-authz |
systemctl restart keycloak |











Метод: POST
URL запроса: https://<адрес вашего Keycloak>:8443/realms/robin/protocol/openid-connect/token
Параметры тела POST-запроса:
| Параметр | Значение | Описание |
|---|---|---|
| client_id | ExternalClient | Фиксированное значение |
| client_secret | Секретный ключ клиента. Пример: lN10xJuiK9fnIlUIRxWEaJwSEKvaeckL | Значение можно получить из панели администратора в Keycloak:
Если у вас нет доступа в Keycloak, получить ключ можно от администратора платформы Robin в вашей организации. |
| grant_type | urn:ietf:params:oauth:grant-type:token-exchange | Фиксированное значение |
| tenant_id | Идентификатор тенанта. Пример: f9fdg366-31e5-11ee-be30-0236va230006 | Идентификатор тенанта, в рамках которого будут выполняться запросы к API. Например, при запросе списка машин, система вернет только те машины, которые добавлены в указанный тенант. Скопировать идентификатор тенанта можно на странице модуля "Мониторинг":
|
| user_id | Идентификатор пользователя. Пример: 5g8c3bc4-2ff1-30a1-36ca-7sc274fa86ad | Идентификатор пользователя платформы Robin, под учётной записью которого будут выполняться запросы к API. При выполнении запросов будут учитываться права пользователя в том тенанте, который вы указали в запросе. Например, при запросе списка роботов, система вернет только тех роботов, который доступны указанному пользователю в указанном тенанте. Для получения идентификатора пользователя:
|
POST https://prod.rpa.ru:8443/realms/robin/protocol/openid-connect/token Content-Type: application/x-www-form-urlencoded client_id=ExternalClient&client_secret=lN10xJuiK9fnIlUIRxWEaJwSEKvaeckL&grant_type=urn:ietf:params:oauth:grant-type:token-exchange&tenant_id=f9fdg366-31e5-11ee-be30-0236va230006&user_id=5g8c3bc4-2ff1-30a1-36ca-7sc274fa86ad |
При успешном выполнении запроса будет возвращен ответ с кодом 200
В теле ответа будет указан access_token, который необходим при выполнении запросов к API платформы.
{ "access_token": "ваш_токен_доступа", "expires_in": 3600, "token_type": "Bearer" } |
Authorization: Bearer <ваш_токен_доступа> |