Viber#
Поддерживается отправка следующих типов Viber-сообщений:
только текст;
только изображение;
текст + кнопка для перехода по ссылке;
текст + изображение + кнопка для перехода по ссылке.
Примеры запросов на отправку Viber-сообщений#
Для формирования тестового запроса с вашими параметрами Открыть генератор запросов
1{
2 "login":"ВАШ_ЛОГИН",
3 "password":"ВАШ_ПАРОЛЬ",
4 "useTimeDiff":false,
5 "id":"8770100",
6 "scheduleInfo":
7 {
8 "timeBegin":"10:00",
9 "timeEnd":"20:00",
10 "weekdaysSchedule":"12345"
11 },
12 "destAddr":"Номер_Абонента",
13 "message":
14 {
15 "type":"VIBER",
16 "data":
17 {
18 "instantContent":
19 {
20 "type":"TEXT",
21 "data":
22 {
23 "text":"VIBERMESS"
24 }
25 },
26 "serviceNumber":"НОМЕР_ОТПРАВИТЕЛЯ",
27 "ttl":1
28 }
29 }
30}
1{
2 "login":"ВАШ_ЛОГИН",
3 "password":"ВАШ_ПАРОЛЬ",
4 "id":"8770100",
5 "scheduleInfo":
6 {
7 "timeBegin":"10:00",
8 "timeEnd":"20:00",
9 "weekdaysSchedule":"12345"
10 },
11 "destAddr":"Номер_Абонента",
12 "message":
13 {
14 "type":"VIBER",
15 "data":
16 {
17 "instantContent":
18 {
19 "type":"IMAGE_URL",
20 "data":
21 {
22 "imageURL":"https://example.ru/image"
23 }
24 },
25 "serviceNumber":"НОМЕР_ОТПРАВИТЕЛЯ",
26 "ttl":1
27 }
28 }
29}
1{
2 "login":"ВАШ_ЛОГИН",
3 "password":"ВАШ_ПАРОЛЬ",
4 "useTimeDiff":false,
5 "id":"8770100",
6 "scheduleInfo":
7 {
8 "timeBegin":"10:00",
9 "timeEnd":"20:00",
10 "weekdaysSchedule":"12345"
11 },
12 "destAddr":"Номер_Абонента",
13 "message":
14 {
15 "type":"VIBER",
16 "data":
17 {
18 "instantContent":
19 {
20 "type":"BUTTON",
21 "data":
22 {
23 "text":"VIBERMESS",
24 "imageURL":"https://example.ru/image",
25 "caption":"ПЕРЕЙТИ",
26 "action":"https:// example.ru/image"
27 }
28 },
29 "serviceNumber":"НОМЕР_ОТПРАВИТЕЛЯ",
30 "ttl":1
31 }
32 }
33}
Параметры запросов#
Обязательные параметры выделены жирным шрифтом.
Параметр |
Тип данных |
Описание |
---|---|---|
login |
string |
Имя Партнёра. |
password |
string |
Пароль Партнёра для отправки сообщений. |
useTimeDiff |
boolean |
Учитывание часового пояса при запуске рассылки. Если true, то отправка сообщения осуществляется абоненту согласно расписанию рассылки и его часовому поясу. Если false, то сообщение отправляется согласно расписанию инициатора рассылки UTC+3, не обращая внимание на часовой пояс получателя сообщения. Значение по умолчанию: false. |
id |
string |
Уникальный идентификатор на стороне Партнёра. Данный параметр нужен для контроля повторных отправок и дублирования (сервис контроля включается отдельно). Партнёр может вызывать Сервис-провайдера (запрос на отправку сообщения) с одним и тем же id несколько раз. При этом: отправка сообщения абоненту будет выполнена только один раз (по первому запросу). В ответах на запросы Сервис-провайдер вернет Партнёру один и тот же идентификатор сообщения в системе Сервис-провайдера (тот же, что на первый запрос). Сервис-провайдер опционально возвращает Партнёру данный идентификатор при его наличии в отчёте о доставке сообщения. |
shortenLinks |
boolean |
Параметр управляет включением автоматического сокращения длинных ссылок в сообщении. Возможные значения - true - для сокращения ссылок (значение по умолчанию), false - сокращение ссылки не требуется. Если параметр в запросе не приходит, но, при этом, сервис Партнёру доступен, то ссылки будут сокращаться по умолчанию. Возможность пользоваться данным сервисом предварительно оговаривается и настраивается Сервис-Провайдером. Подробнее: Сервис сокращения ссылок. |
scheduleInfo |
object |
Расписание рассылки. Если не указано, отправляется сразу же, в момент получения запроса. |
scheduleInfo/timeBegin |
string |
Время начала, например, «10:00». |
scheduleInfo/timeEnd |
string |
Время окончания, например, «21:00». |
scheduleInfo/weekdaysSchedule |
string |
Дни рассылки. Задаются цифрами от 1 (понедельник) до 7 (воскресение), например, «12345». Если ограничений по дням недели нет, то данный параметр может быть пустой или не передан в запросе. |
scheduleInfo/deadline |
string |
Дата окончания рассылки, например, 2019-05-10T16:29:30+0300. |
destAddr |
string |
Номер телефона абонента. Содержит код страны, код оператора и номер телефона. Для РФ код может быть „8“, „7“ или „+7“. Примеры: 72101234567, +72101234567, 8-210-123-45-67, 82101234567. |
message |
object |
Параметры отправляемого сообщения. |
message/type |
enum |
Тип сообщения. Передается значение VIBER. |
message/data |
object |
Параметры отправляемых данных. |
message/data/instantContent |
object |
Параметры отправляемого Viber-сообщения (изображения, кнопки). |
instantContent/type |
enum |
Тип параметра сообщения. Допустимые значения: TEXT (для передачи только текста), IMAGE_URL (для передачи только изображения), BUTTON (для передачи текста сообщения, адреса изображения, наименования кнопки и URL для перехода по кнопке, см. instantContent/data). Важно! Для бизнес-аккаунтов, поддерживающих функционал Viber-сессий, доступны сообщения либо TEXT, либо IMAGE_URL. Сообщения с другим типом возвращают ошибку 400 “Invalid request“. |
instantContent/data |
object |
Параметры отправляемых данных при выборе значения BUTTON в instantContent/type. Допустимые значения: text (текст сообщения), imageURL (адрес изображения), caption (наименованием кнопки), action (URL для перехода по кнопке). |
instantContent/data/text |
string |
Текст сообщения. Максимальная длина: 1000 символов. |
instantContent/data/imageURL |
string |
URL изображения для передачи. Рекомендовано использовать изображение размером 400x400px с расширением JPG или PNG. |
instantContent/data/caption |
string |
Текст кнопки в Viber-сообщении. Максимум 30 символов. |
instantContent/data/action |
string |
Ссылка кнопки в Viber-сообщении. Максимум 2048 символов. URL для ссылки должен начинаться с http:// , https:// , viber:// , mailto: , tel: . |
message/data/serviceNumber |
string |
Сервисное имя, от которого осуществляется отправка сообщения. |
message/data/ttl |
integer |
Срок жизни сообщения. Допустимый диапазон, сек: от 30 до 86400. Примечание. При ttl = 0 или отсутствии параметра в запросе берётся значение из настроек по умолчанию, которые задаются при настройке интеграции отдельно для каждого клиента. |
message/data/ttlUnit |
enum |
Единица измерения периода доставки сообщения. Передается только вместе с ttl. Допустимые значения: SECONDS; MINUTES (значение по-умолчанию); HOURS. |
extraParam |
string |
Дополнительные параметры, передаваемые в виде param1=value1,param2=value2, где param1 и param2 – названия параметров, value1 и value2 – значения. Символ запятой в название параметра входить не может, но может входить в его значение - в этом случае он должен удваиваться. Пример: строка место=абзаково,название=гостевой дом-2,координаты=53.8085896,, 58.6362112,c=23.02.09,по=05.03.09. |
registeredDelivery |
integer |
Необходимость отчётов о доставке. Возможные значения: 0 - статусы не нужны; 1 - нужны статусы (по умолчанию); 2 - нужен только статус НЕ ДОСТАВЛЕНО. |
notifyUrl |
string |
Hostname входящего api для получения отчета о доставке. Этот параметр в запросе необязательный, но при его отправке нужно учесть следующее: если парметр указан, он не может быть пустым. Длина строки notifyUrl не должна превышать 2048 символов. При невыполнении любого из указанных условий будет сгенерирована ошибка, запрос не будет выполнен. |
cascadeChainLink |
object |
Параметры каскадных сообщений. См. Каскадная рассылка. |
Ответ на запрос#
После отправки сообщения Сервис-провайдер синхронно возвращает ответ. В случае успешной отправки возвращается HTTP-code 200 OK.
Ответ при успешной отправке Viber-сообщения#
1 {
2 "mtNum": "7390612217"
3 "id": "8770599"
4 }
Параметр |
Тип данных |
Описание |
---|---|---|
mtNum |
string |
Идентификатор цепочки отправки, присваиваемый платформой Сервис-провайдера. |
id |
string |
Уникальный идентификатор на стороне Партнёра. Присутствует, если был передан при отправке. |
Ошибки при отправке Viber-сообщения#
Для ошибочных результатов HTTP-код ответа будет отличный от 200 (см. Коды ошибок отправки).
1 {
2 "error": {
3 "code": 4,
4 "description": "Invalid request"
5 },
6 "extendedDescription": "Capture is absent or length longer 30 characters"
7 }
В данном примере в Viber-сообщении типа BUTTON отсутствует параметр capture, или его длина превышает 30 символов.
Параметр |
Тип данных |
Описание |
---|---|---|
error |
object |
Информация об ошибке. |
error/code |
int |
Код ошибки. |
error/description |
string |
Краткое описание ошибки. |
extendedDescription |
string |
Подробное описание ошибки (необязательный параметр). |
Коды ошибок отправки#
Код |
Описание |
HTTP-код |
---|---|---|
1 |
Service is unavailable |
503 |
2 |
Invalid IP-address |
403 |
3 |
Too many connections |
429 |
4 |
Invalid request |
400 |
5 |
Invalid login |
401 |
6 |
Invalid password |
401 |
7 |
serviceNumber is not defined |
400 |
8 |
destAddr is not correct |
406 |
9 |
Message type is not correct |
406 |
10 |
Prohibited sending duplicates |
409 |
11 |
Invalid TTL |
406 |
100 |
100 |
500 |
Статусы доставки Viber-сообщений#
Для получения статусов Viber-сообщений необходимо настроить Сервис получения статусов доставки сообщений.
Viber-сессия#
Примечание
Функционал Viber-сессий недоступен по умолчанию. Для его подключения следует обратиться к своему курирующему менеджеру.
Подключение функционала сессий#
Важно
Для бизнес-аккаунтов, поддерживающих функционал Viber-сессий, доступны сообщения с типом “только текст“ или “только изображение“ (значение параметра InstantContent.type должно быть либо “TEXT“, либо “IMAGE_URL“).
Особенности работы сессий#
Начало сессии:
сессия может быть инициирована только подписчиком;
сессия начинается, когда подписчик отправляет первое сообщение Партнеру;
сессия не может быть инициирована изображением;
если в рамках переписки присутствует только один отправитель (неважно – подписчик или Партнер), то это не считается сессией, сообщения будут тарифицированы обычным образом.
Лимиты сессии:
продолжительность сессии по умолчанию 24 часа;
Партнер может отправить до 60 сообщений (после превышения данного лимита автоматически стартует новая сессия);
Партнер может отправлять до 10 сообщений без ответа подписчика (после превышения данного лимита сессия автоматически закрывается);
Партнер может отправлять только сообщения с типом “текст“ или “изображение“.
Завершение сессии:
по прошествии 24 часов;
по достижении лимита в 60 сообщений (автоматически стартует новая сессия);
по достижении лимита в 10 безответных сообщений от Партнера.