В данном разделе описана общая структура API, форматы запросов и ответов
Запросы к API осуществляются через протокол HTTPS, для авторизации используется протокол OAuth2, после получения токена через OAuth2, он передается в каждом API-запросе в заголовке Authorization. (См. Авторизация приложений).
При наличии тела запроса (запросы типа POST и PUT), его содержимое должно быть передано в формате JSON, заголовок Content-Type должен быть установлен в application/json. Исключение составляет закгрузка файлов, например звуковых файлов.
Методы для работы с ресурсами
Название | https запрос | путь | параметры пути |
---|---|---|---|
получение списка ресурсов | GET | /realm/{realm_id}/resource/ |
|
добавление ресурса | POST | /realm/{realm_id}/resource/ | |
получение ресурса по идентификатору | GET | /realm/{realm_id}/resource/{resource_id} | |
изменение ресурса | PUT | /realm/{realm_id}/resource/{resource_id} | |
удаление ресурса по идентификатору | DELETE | /realm/{realm_id}/resource/{resource_id} |
Набор методов не всегда полный и зависит от ресурса.
Получение списка ресурсов
Запросы на получение списка ресурсов осуществляются запросом типа GET. В ответе возвращается JSON-массив, содержащий ресурсы. Если ресурсы отсутствуют или ни один из ресурсов не подходит под условия фильтрации (см. ниже), возвращается пустой массив.
HTTP-код ответа при успешной операции: 200.
Фильтрация
Многие запросы на получение списка ресурсов имеют дополнительные параметры запроса, которые указываются в строке запроса после символа "?". Эти параметры позволяют отфильтровать список, возвращаемый запросом по одному или нескольким полям.
Например, запрос ниже позволяет пользователю типа "клиент" получить список добавочных номеров типа "телефон", которые состоят в группе добавочных с идентификатором 1:
GET https://hostname/api/ver1.0/client/@me/extension/?extension_group_id=1&type=phone
Добавление ресурса
Новые ресурсы добавляются запросом типа POST, тело запроса – JSON-документ, содержащий параметры ресурса. Параметры могут быть обязательными и необязательными. Во втором случае, параметр ресурса примет значение по умолчанию. Некоторые параметры допускают значение null, которое означает отсутствие значения параметра.
HTTP-код ответа при успешной операции: 201. В случае успеха операции возвращается созданный ресурс.
В случае неправильных параметров возвращаемый ответ имеет код 400, а телом ответа является JSON-документ, описывающий причину ошибки в поле message. Если поле message содержит сообщение "Bad Request", то ошибка заключается в формировании JSON-документа.
Получение ресурса
Получение конкретного ресурса по его идентификатору осуществляется запросом типа GET, при этом идентификатор ресурса содержится в URL, например пользователь типа "клиент" может получить данные о ресурсе "extension" с идентификатором "2"
GET https://hostname/api/ver1.0/client/@me/extension/2
HTTP-код ответа при успешной операции: 200. При этом возвращается ресурс в формате JSON-документа. В случае, если ресурс не найден, код ответа будет 404.
Изменение ресурса
Изменение (обновление) ресурса по его идентификатору осуществляется запросом типа PUT, при этом идентификатор ресурса содержится в URL.
Тело запроса, JSON-документ, содержащий параметры, которые требуется изменить. Параметры, не переданные в запросе, не изменяться.
HTTP-код ответа при успешной операции: 200. В случае успеха операции возвращается обновленный ресурс. Если ресурс отсутствует, код ответа будет 404.
В случае неправильных параметров возвращаемый ответ имеет код 400, а телом ответа является JSON-документ, описывающий причину ошибки в поле message.
Удаление ресурса
Получение конкретного ресурса по его идентификатору осуществляется запросом типа DELETE, при этом идентификатор ресурса содержится в URL.
HTTP-код ответа при успешной операции: 204. Если удаляемый ресурс отсутствует, код ответа будет 404.
Структура частей документации, описывающих ресурсы
- краткое описание назначения ресурса
- оглавление
- таблица с описанием параметров ресурса
- формальное описание всех методов ресурса для:
- раздела пользователей типа "клиент"
- раздела пользователей типа "группа добавочных"
- раздела пользователей типа "добавочный"
- примеры использования
- cсылки по теме