Аутентификация в HTTP-сервисах приложения для неинтерактивных пользователей

Запрос к HTTP-сервису может быть выполнен не конечным пользователем, а внешней системой. Например, запрос доступа к сервису может быть сделан другим приложением или консольной утилитой по расписанию. В этом случае для аутентификации пользователя используются токены доступа. Чтобы предоставить права на ресурсы приложения внешней программе, нужно установить связь между этой программой и пользователем приложения. В большинстве случаев для этого рекомендуется создавать отдельных служебных пользователей для внешних программ.

Настройка доступа внешнего приложения к ресурсу

Пусть в приложении есть HTTP-сервис и пользователь, обладающий правом вызова этого сервиса. Убедиться, что пользователь обладает правом доступа к данному сервису, можно в свойствах этого сервиса или в YAML-файле. Подробнее о контроле прав доступа читайте здесь. Если для вашего приложения не существует соответствующего пользователя, его необходимо создать, подключить к приложению и т. д. (подробнее см. здесь).

Далее, один раз, необходимо в приложении получить ключ доступа для этого пользователя.

После этого при каждом вызове HTTP-сервиса внешняя программа должна отправить запрос на получение токена аутентификации по адресу:

http://serverhost:port/applications/{app}/sys/token

где {app} — это название приложения из HTTP-пути публикации. Например, так может выглядеть соответствующая ссылка для Демонстрационного приложения:

http://localhost:9090/applications/DemonstratsionnoePrilozhenie/sys/token

Получение токена выполняется с проверкой прав работы пользователя в приложении с помощью токенов.

Формат запроса для получения токена:

POST <URL>
Content-Type: application/x-www-form-urlencoded
Authorization: Basic <Base64(ClientId:ClientSecret)>
            
grant_type=CLIENT_CREDENTIALS

Во встроенном языке этот же запрос может выглядеть следующим образом:

метод Скрипт()
   исп Ответ = КлиентHttp.ЗапросPost("http://127.0.0.1:9090/applications/DemonstratsionnoePrilozhenie/sys/token")
   .ДобавитьЗаголовок("Content-Type", "application/x-www-form-urlencoded")
   .ДобавитьЗаголовок("Authorization", "Basic " + Кодировки.Base64.КодироватьВСтроку("YzxctW-0W8dnIQ7q6XMCXV0IwVz3W_kee-c8HByMrjs=:1wEqWtJ7oM0bOuciVOBsJTv_r8v0zkGSf_8lARSHMtA="))
   .УстановитьТело("grant_type=CLIENT_CREDENTIALS")
   .Выполнить()

В случае успешного получения токена внешняя программа получит ответ в формате JSON:

{
   "id_token": "<сериализованный токен аутентификации>",
   "token_type": "Bearer"
}

После того как токен получен, можно вызывать HTTP-сервис из приложения. Для этого в запрос нужно добавить заголовок Authorization:

Authorization: Bearer <токен, полученный от менеджера аутентификации>

Во встроенном языке этот же запрос может выглядеть следующим образом:

   // Прочитать ответ из JSON
   пер ДанныеОтвета = СериализацияJson.ПрочитатьСоответствие(Ответ.Тело)
            
   // Получить токен из JSON
   пер Токен = ДанныеОтвета.Получить("id_token")
            
   исп Статус = КлиентHttp.ЗапросGet("http://127.0.0.1:9090/console/api/v2/applications/1ed76519-66b9-6fcc-9dfa-2f405661fde3")
   .ДобавитьЗаголовок("Authorization", "Bearer " + Токен).Выполнить()

Токен действителен в течение часа. Таким образом, можно сделать сразу несколько вызовов (возможно разных сервисов), используя уже полученный токен, а не получая его заново.

Если токен устарел, то при вызове HTTP-сервиса вернется ответ с кодом 401. Это значит, что нужно снова запросить токен аутентификации.