Вебхуки
Вебхуки предоставляют возможность получать обновления по интересующим темам, как только они произошли в системе ATI.SU.
Требования к вебхукам
Для того чтобы обеспечить безопасность и стабильную работу, есть несколько требований, которым должен удовлетворять вебхук:
- не является открытым и угадываемым, то есть третьи лица не должны иметь возможности узнать о его существовании;
- если используется DNS-имя, оно должно разрешаться в публичный1 IPv4 адрес;
- если используется IP-адрес, он должен быть публичным1 IPv4 адресом;
- доступен по протоколу HTTPS;
- уникален на каждую подписку;
- реализует механизм аутентификации.
Рекомендации по реализации
1. Время ответа
На ответ вебхуку дается 20 секунд, поэтому рекомендуется реализовывать его таким образом, чтобы ответ означал факт получения сообщения, а не его обработки.
2. Уникальность
Во избежание смешивания данных разных пользователей, рекомендуется для каждой подписки иметь уникальный URL.
3. TLS
Сообщения могут содержать закрытую информацию, поэтому отправка их в незашифрованном виде недопустима. Если у вас нет возможности использовать доверенный сертификат, напишите на почту api@ati.su.
Использование API
Для существования вебхука необходимы два метода по одному URL. Первый (GET) отвечает за управление состоянием, а второй (POST) — за передачу сообщений.
Создание вебхука
Создание вебхука происходит в два этапа: отправка запроса на создание и верификация.
Отправка запроса на создание
Чтобы подписаться на события через вебхуки, необходимо выбрать тему и указать её в параметре topic. Для
тем подписки, которые позволяют подписаться на события по чужим сущностям, необходимо
задать тип подписки complex в параметре subscription_type, а также заполнить параметры фильтра в соответствии с темой и
указать их в параметре subscription запроса на создание вебхука.
Параметр subscription
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
Параметр callback должен содержать URL вебхука. В URL допустимы параметры запроса, которые будут переданы при вызове
вебхука. Параметры запроса можно использовать, например, для привязки вебхука к пользователю:
https://example.org/webhook?userId=00000000 Создать вебхук post /webhooks/v1/create
Запрос создания вебхука
Тип подписки вебхука
normal— Обычнаяcomplex— С возможностью настройки фильтров
Тема
URL
Параметры подписки с возможностью настройки фильтров
Тема
URL
curl 'https://api.ati.su/webhooks/v1/create' \ -X 'POST' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json' \ --data-raw '{"topic":"cargoes.on_boards","callback":"https://example.com/webhook?userId=000000","subscription_type":"complex","subscription":{"channel":"cargoes.on_boards","boards":["644bdc87dbd6fc3747887c7b"]}}'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("POST", "https://api.ati.su", "/webhooks/v1/create", "{""topic"":""cargoes.on_boards"",""callback"":""https://example.com/webhook?userId=000000"",""subscription_type"":""complex"",""subscription"":{""channel"":""cargoes.on_boards"",""boards"":[""644bdc87dbd6fc3747887c7b""]}}"); 202
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Создать вебхук post /gw/oauth2/webhooks/v1/create Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
Запрос создания вебхука
Тип подписки вебхука
normal— Обычнаяcomplex— С возможностью настройки фильтров
Тема
URL
Параметры подписки с возможностью настройки фильтров
Тема
URL
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/create' \ -X 'POST' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json' \ --data-raw '{"topic":"cargoes.on_boards","callback":"https://example.com/webhook?userId=000000","subscription_type":"complex","subscription":{"channel":"cargoes.on_boards","boards":["644bdc87dbd6fc3747887c7b"]}}'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("POST", "https://api.ati.su", "/gw/oauth2/webhooks/v1/create", "{""topic"":""cargoes.on_boards"",""callback"":""https://example.com/webhook?userId=000000"",""subscription_type"":""complex"",""subscription"":{""channel"":""cargoes.on_boards"",""boards"":[""644bdc87dbd6fc3747887c7b""]}}"); 202
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
В ответе содержится заголовок Location с URL GET-метода проверки состояния созданного вебхука.
Верификация
После отправки запроса на создание, вебхук проходит верификацию. Вызывается GET метод по URL вебхука с параметрами
challenge и topic, а также параметрами указанными при создании.
GET /webhook?status=verification&verification_status=progress&topic=orders&challenge=608b672ed0a5aaecc2d42488 HTTP/1.1Host: example.org:443Date: Thu, 01 Jan 1970 00:00:00 GMTDigest: 47DEQpj8HBSa+/TImW+5JCeuQeRkm5NMpJWZG3hSuFU=Accept: application/jsonAuthorization: HMAC-SHA-256 Credential=6447f577905114d5b9b2c618&SignedHeaders=Date;Digest;Host&Signature=IFfS27QZuXLTNV9idpwnUNDSiayHYAJO0IcoJy2pHy8=Вебхук должен ответить в течение 20 секунд на верификационный запрос JSON-строкой с содержимым параметра challenge.
Верификационный запрос, так же как и все остальные, имеет заголовок Authorization, поэтому возможна его
аутентификация. При его поступлении следует получить сгенерированный ключ с помощью метода проверки
состояния вебхука (поле hook.key).
HTTP/1.1 200 OKContent-Type: application/json; charset=utf-8Content-Length: 26
"608b672ed0a5aaecc2d42488"Как только ответ будет получен, отправится оповещение о смене состояния. После
успешной верификации, отключите логику обработки параметра challenge для данного вебхука, чтобы избежать ошибок.
Если верификация провалилась, узнать причину можно с помощью метода проверки состояния вебхука. Вебхук
будет находиться в состоянии verification.
Проверка состояния вебхука
Проверка состояния одного вебхука
Получить состояние вебхука get /webhooks/v1/status/{id}
curl 'https://api.ati.su/webhooks/v1/status/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/webhooks/v1/status/{id}"); 200
Состояние вебхука
Идентификатор состояния вебхука
created— Созданverification— Проверяетсяactive— Активенremoved— Удаленdeactivated— ДеактивированХук деактивируется, если на протяжении нескольких дней ни одна отправка в него не удалась
Деактивированный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата первой проваленной отправки
Активный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата окончания приостановки подписки
Созданный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Проверка вебхука
Идентификатор состояния проверки
progress— Выполнениеfailed— Провалена
Причины провала проверки вебхука
unknown_error— Неизвестная ошибкаОшибка на стороне ATI.SU
tls_error— Ошибка установки защищенного соединенияВозможно используется недоверенный сертификат, или сервер не поддерживает протокол HTTPS
socket_error— Ошибка создания TCP соединенияВозможно указан недоступный IP адрес, DNS-имя, разрешающееся в недоступный IP адрес, или сервер не принимает запросы
request_error— Ошибка запросаПолучен HTTP-код, отличный от 200, или превышено время ожидания ответа
challenge_mismatch— Challenge не совпадаетwrong_response_format— Неправильный формат ответаФормат ответа отличается от JSON-строки
Проверяемый вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Получить состояние вебхука get /gw/oauth2/webhooks/v1/status/{id} Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/status/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/gw/oauth2/webhooks/v1/status/{id}"); 200
Состояние вебхука
Идентификатор состояния вебхука
created— Созданverification— Проверяетсяactive— Активенremoved— Удаленdeactivated— ДеактивированХук деактивируется, если на протяжении нескольких дней ни одна отправка в него не удалась
Деактивированный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата первой проваленной отправки
Активный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата окончания приостановки подписки
Созданный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Проверка вебхука
Идентификатор состояния проверки
progress— Выполнениеfailed— Провалена
Причины провала проверки вебхука
unknown_error— Неизвестная ошибкаОшибка на стороне ATI.SU
tls_error— Ошибка установки защищенного соединенияВозможно используется недоверенный сертификат, или сервер не поддерживает протокол HTTPS
socket_error— Ошибка создания TCP соединенияВозможно указан недоступный IP адрес, DNS-имя, разрешающееся в недоступный IP адрес, или сервер не принимает запросы
request_error— Ошибка запросаПолучен HTTP-код, отличный от 200, или превышено время ожидания ответа
challenge_mismatch— Challenge не совпадаетwrong_response_format— Неправильный формат ответаФормат ответа отличается от JSON-строки
Проверяемый вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Для тем подписки с фильтром также доступно получение параметров фильтра.
Получить параметры фильтра get /webhooks/v1/subscriptions/{id}
curl 'https://api.ati.su/webhooks/v1/subscriptions/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/webhooks/v1/subscriptions/{id}"); 200
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
Получить параметры фильтра get /gw/oauth2/webhooks/v1/subscriptions/{id} Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/subscriptions/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/gw/oauth2/webhooks/v1/subscriptions/{id}"); 200
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
Проверка состояния нескольких вебхуков
Получить состояние нескольких вебхуков get /webhooks/v1/status
curl 'https://api.ati.su/webhooks/v1/status' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/webhooks/v1/status"); 200
Состояние вебхука
Идентификатор состояния вебхука
created— Созданverification— Проверяетсяactive— Активенremoved— Удаленdeactivated— ДеактивированХук деактивируется, если на протяжении нескольких дней ни одна отправка в него не удалась
Деактивированный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата первой проваленной отправки
Активный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата окончания приостановки подписки
Созданный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Проверка вебхука
Идентификатор состояния проверки
progress— Выполнениеfailed— Провалена
Причины провала проверки вебхука
unknown_error— Неизвестная ошибкаОшибка на стороне ATI.SU
tls_error— Ошибка установки защищенного соединенияВозможно используется недоверенный сертификат, или сервер не поддерживает протокол HTTPS
socket_error— Ошибка создания TCP соединенияВозможно указан недоступный IP адрес, DNS-имя, разрешающееся в недоступный IP адрес, или сервер не принимает запросы
request_error— Ошибка запросаПолучен HTTP-код, отличный от 200, или превышено время ожидания ответа
challenge_mismatch— Challenge не совпадаетwrong_response_format— Неправильный формат ответаФормат ответа отличается от JSON-строки
Проверяемый вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Получить состояние нескольких вебхуков get /gw/oauth2/webhooks/v1/status Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/status' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/gw/oauth2/webhooks/v1/status"); 200
Состояние вебхука
Идентификатор состояния вебхука
created— Созданverification— Проверяетсяactive— Активенremoved— Удаленdeactivated— ДеактивированХук деактивируется, если на протяжении нескольких дней ни одна отправка в него не удалась
Деактивированный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата первой проваленной отправки
Активный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Дата окончания приостановки подписки
Созданный вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Проверка вебхука
Идентификатор состояния проверки
progress— Выполнениеfailed— Провалена
Причины провала проверки вебхука
unknown_error— Неизвестная ошибкаОшибка на стороне ATI.SU
tls_error— Ошибка установки защищенного соединенияВозможно используется недоверенный сертификат, или сервер не поддерживает протокол HTTPS
socket_error— Ошибка создания TCP соединенияВозможно указан недоступный IP адрес, DNS-имя, разрешающееся в недоступный IP адрес, или сервер не принимает запросы
request_error— Ошибка запросаПолучен HTTP-код, отличный от 200, или превышено время ожидания ответа
challenge_mismatch— Challenge не совпадаетwrong_response_format— Неправильный формат ответаФормат ответа отличается от JSON-строки
Проверяемый вебхук
Идентификатор
URL
Тема
Идентификатор приложения
Идентификатор контакта
Ключ, используемый для подписывания запросов
Оповещения о смене состояния вебхука
GET-метод по URL вебхука используется также для оповещений о смене его (вебхука) состояния. Во все вызовы передается
параметр topic, обозначающий тему подписки.
| Событие | Параметры | Описание |
|---|---|---|
| Провал верификации | status: verificationverification_status: failed | Проблемы с верификацией. |
| Провал отправки | distribution_status: failedsince: YYYY-MM-DDThh:mm:ss | Проблемы с отправкой сообщения. В параметре since указана дата первой проваленной отправки. |
| Провал повторной отправки | distribution_status: failed_retryfailed_count: число | Проблемы с повторной отправкой сообщений. В параметре failed_count указано количество повторно отправляемых сообщений. |
| Остальные изменения состояния вебхука | status: одно из значений поля status |
Оповещение о смене статуса не ожидает ответа.
Получение сообщений
При возникновении события, вызывается POST метод вебхука с параметром topic. В теле запроса передается одна или
несколько обновленных сущностей (параметр entities[].entity) и другие параметры события.
Соответствие порядка возникновения событий и отправки сообщений не гарантируется. Поэтому, при получении сообщения,
необходимо сравнивать параметр action_date текущего и предыдущего сообщений.
Тело запроса
Запрос с отправляемыми сообщениями
Тема
Сообщения
Идентификатор отправляемой сущности
Дата события
Отправляемая сущность
Является ли отправка повторной
POST /webhook?topic=orders HTTP/1.1Host: example.org:443Date: Thu, 01 Jan 1970 00:00:00 GMTDigest: SypZnuCTiysyLuUz9DOYckaU/vf0zrzdxKL1j/sHemg=Content-Type: application/jsonContent-Length: 208Authorization: HMAC-SHA-256 Credential=6447f577905114d5b9b2c618&SignedHeaders=Date;Digest;Host&Signature=V8CpKji2ysF5h5VVerhcq/GMQGxoHwf0EcGiDIL41e0=
{"topic": "orders", "entities": [{"entity_id": "4ea8c372-9510-4880-a80d-fb9ac19129cf", "action_date": "2021-04-30T05:12:41.687Z", "entity": {"id": "4ea8c372-9510-4880-a80d-fb9ac19129cf"}}], "is_retry": false}Ожидается ответ с кодом 2xx (Successful)2 на протяжении 20 секунд. В ином случае отправка помечается проваленной, и отправляется оповещение об изменении состояния вебхука.
Для временной приостановки получения сообщений, можно использовать ответ 429 (Too Many Requests)3 с заголовком Retry-After4. Приостановка возможна не более чем на 1 день.
Если был получен ответ 410 (Gone)5, вебхук удаляется без возможности восстановления.
Повторные отправки
Как только вебхук успешно примет сообщение, будет предпринята попытка повторно отправить сообщения, отправка которых
провалилась ранее. Отличить повторную отправку от первоначальной можно по значению true в заголовке ATI-Is-Retry
запроса. В случае провала повторной отправки, она будет отложена до успешного получения вебхуком нового сообщения.
Если отправки проваливаются на протяжении 4 дня, вебхук деактивируется. Возобновление его работы возможно только через повторное создание.
До тех пор, пока вебхук не удален, можно получить его проваленные отправки.
Получить проваленные отправки get /webhooks/v1/distributions/failed/{id}
curl 'https://api.ati.su/webhooks/v1/distributions/failed/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/webhooks/v1/distributions/failed/{id}"); 200
Проваленная отправка сообщения
Идентификатор отправляемой сущности
Дата события
Идентификатор состояния отправки
failed— Провалена
Отправляемая сущность
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Получить проваленные отправки get /gw/oauth2/webhooks/v1/distributions/failed/{id} Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/distributions/failed/{id}' \ -X 'GET' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("GET", "https://api.ati.su", "/gw/oauth2/webhooks/v1/distributions/failed/{id}"); 200
Проваленная отправка сообщения
Идентификатор отправляемой сущности
Дата события
Идентификатор состояния отправки
failed— Провалена
Отправляемая сущность
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Редактирование вебхука
Изменение параметров вебхука не предусмотрено, но для тем подписки с фильтром возможно редактирование фильтра с помощью соответствующего метода. Изменение канала подписки невозможно.
Отредактировать параметры фильтра put /webhooks/v1/subscriptions/{id}
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
curl 'https://api.ati.su/webhooks/v1/subscriptions/{id}' \ -X 'PUT' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json' \ --data-raw '{"channel":"cargoes.on_boards","boards":["string"]}'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("PUT", "https://api.ati.su", "/webhooks/v1/subscriptions/{id}", "{""channel"":""cargoes.on_boards"",""boards"":[""string""]}"); 200
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
Отредактировать параметры фильтра put /gw/oauth2/webhooks/v1/subscriptions/{id} Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/subscriptions/{id}' \ -X 'PUT' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json' \ --data-raw '{"channel":"cargoes.on_boards","boards":["string"]}'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("PUT", "https://api.ati.su", "/gw/oauth2/webhooks/v1/subscriptions/{id}", "{""channel"":""cargoes.on_boards"",""boards"":[""string""]}"); 200
Каналы подписки
cargoes.on_boards— Грузы на площадкахauctions.on_boards— Торги на площадках
Удаление вебхука
При удалении вебхука, прекращается отправка сообщений в него, а также удаляются его проваленные отправки.
Удалить вебхук delete /webhooks/v1/delete/{id}
curl 'https://api.ati.su/webhooks/v1/delete/{id}' \ -X 'DELETE' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("DELETE", "https://api.ati.su", "/webhooks/v1/delete/{id}"); 202
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки
Удалить вебхук delete /gw/oauth2/webhooks/v1/delete/{id} Отправка запросов с авторизацией OAuth2.0 v2 временно недоступна
curl 'https://api.ati.su/gw/oauth2/webhooks/v1/delete/{id}' \ -X 'DELETE' \ -H 'Authorization: Bearer {authorizationToken}' \ -H 'Content-Type: application/json'Процедура ВыполнитьHTTPЗапрос(МетодЗапроса, АдресХоста, АдресРесурса, ТекстЗапроса) Экспорт ЗаголовкиHTTP = Новый Соответствие(); ЗаголовкиHTTP.Вставить("Accept", "application/json"); ЗаголовкиHTTP.Вставить("Content-Type", "application/json"); ЗаголовкиHTTP.Вставить("Authorization", "Bearer {authorizationToken}"); HTTPЗапрос = Новый HTTPЗапрос(АдресРесурса, ЗаголовкиHTTP); HTTPЗапрос.УстановитьТелоИзСтроки(ТекстЗапроса, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать); ЗащищенноеСоединениеSSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows, Новый СертификатыУдостоверяющихЦентровWindows);
Соединение = Новый HTTPСоединение(АдресХоста,,,,,, ЗащищенноеСоединениеSSL);
Попытка Ответ = Соединение.ВызватьHTTPМетод(МетодЗапроса, HTTPЗапрос); Сообщить("Код ответа: " + Ответ.КодСостояния); Сообщить("Ответ: " + Ответ.ПолучитьТелоКакСтроку("UTF-8")); Исключение Сообщить("Ошибка выполнения запроса!" + Символы.ПС + ОписаниеОшибки()); КонецПопытки;КонецПроцедуры
ВыполнитьHTTPЗапрос("DELETE", "https://api.ati.su", "/gw/oauth2/webhooks/v1/delete/{id}"); 202
4XX Ошибка запроса. [Подробнее про ошибки API](/documentation/errors/)
Описание ошибки
Код ошибки
Причина ошибки
Дополнительные параметры
Вложенные ошибки