Отправка TELEGRAM#
{% hint style=»info» %} Для получения возможности отправки TELEGARAM-сообщений необходимо:
Создать TELEGRAM-бота (инструкция)
Добавить TELEGRAM-бота в Личном кабинете i-Digital Direct (инструкция)
Попросить абонентов запустить бота и поделиться с ним номером телефона
После этого вы сможете отправлять TELEGRAM-сообщения всем абонентам, кто поделился номером телефона с вашим ботом. {% endhint %}
Отправка TELEGRAM-сообщений#
POST https://direct.i-dgtl.ru/api/v1/message
Метод позволяет отправлять массив одиночных сообщений (от 1 до 1000)
Headers#
Name |
Type |
Description |
|---|---|---|
Authorization* |
string |
|
Content-Type* |
string |
|
Request Body#
Name |
Type |
Description |
|---|---|---|
channelType* |
string |
Канал отправки ( |
senderName* |
string |
Имя отправителя. Допускаются имена ботов, добавленных в ЛК Direct |
destination* |
string |
Номер абонента |
content* |
object |
Контент сообщения. Ниже описаны возможные варианты содержимого. |
tags |
array |
Теги сообщения (массив строк). Каждый тег должен соответствовать выражению |
useLocalTime |
boolean |
Флаг, отвечающий за таймзону, в которой будет отправлено сообщение: |
localSendTime |
string |
Нижняя граница допустимого времени отправки сообщения (с учетом значения |
localCompletionTime |
string |
Верхняя граница допустимого времени отправки сообщения (с учетом |
ttl |
integer |
Время жизни сообщения в секундах. По истечении ttl сообщению устанавливается финальный статус. |
hours |
array |
Допустимые часы отправки (массив чисел). В массиве могут быть переданы целые числа от 0 до 23, каждое из которых соответствует разрешенному для отправки интервалу с учетом |
days |
array |
Допустимые дни отправки (массив чисел). В массиве могут быть переданы целые числа от 1 (пн) до 7 (вс), каждое из которых соответствует разрешенному для отправки дню недели; значения должны быть уникальны. |
shortUrl |
boolean |
Флаг, отвечающий за сокращение ссылок в сообщении: |
callbackUrl |
string |
Адрес для отправки callback |
callbackEvents |
array |
События, по которым будут отправлены callback (массив строк). При наличии |
externalMessageId |
string |
Внутренний id сообщения в вашей системе. До 100 символов. |
В случае успешного запроса возвращается ответ, в котором перечислены идентификаторы сообщений и коды результата. При значении errors = false гарантируется, что все переданные сообщения успешно созданы.
{
"errors": false,
"items": [
{
"messageUuid": "063474ec-a34f-4558-90c5-984395000004",
"code": 201
},
{
"messageUuid": "063564ec-a34f-4558-90c5-984395000005",
"code": 201
}
]
}
Использование невалидного токена / отсутствие заголовка авторизации.
{
"error": {
"code": 4012,
"msg": "Bad credentials"
}
}
{
"error": {
"code": 4010,
"msg": "Not Authenticated"
}
}
Использование неподходящего токена.
{
"error": {
"code": 4030,
"msg": "Access Denied"
}
}
Невалидные параметры в теле запроса; ниже приведены несколько примеров ответа.
{
"error": {
"code": 4220,
"msg": "Invalid msisdn"
}
}
-----------------------------------------------------------------------------
{
"error": {
"code": 4220,
"msg": "Invalid text length in viber content (0)"
}
}
-----------------------------------------------------------------------------
{
"error": {
"code": 4220,
"msg": "Invalid caption length in viber content (3)"
}
}
-----------------------------------------------------------------------------
{
"error": {
"code": 4220,
"msg": "Invalid caption length in viber content (3)"
}
}
Payment Required. Недостаточно средств на балансе.
{
"error": {
"code": 402,
"msg": "Insufficient funds"
}
}
{% hint style=»warning» %}
Рекомендуемое время ожидания ответа: 70 секунд.
Как правило, ответ на запрос возвращается не более чем за несколько секунд, но таймаут величиной в 70 секунд позволяет гарантированно получить ответ на запрос, в том числе в ситуациях повышенной нагрузки.
{% endhint %}
{% hint style=»info» %} Для использования личного домена в сокращенных ссылках необходимо обратиться в поддержку {% endhint %}
Возможные варианты перечислений:
Параметр |
Варианты |
|---|---|
callbackEvents |
Текстовое сообщение #
Текстовое TELEGRAM-сообщение, помимо текста, может содержать кнопки с ссылками
Для отправки текстового TELEGRAM-сообщения используется следующий объект content:
{
"contentType": "text",
"text": "Текст TELEGRAM-сообщения",
"inlineKeyboard": [
[
{
"text": "текст кнопки 1",
"url": "https://i-dgtl.ru/1"
},
{
"text": "текст кнопки 2",
"url": "https://i-dgtl.ru/2"
}
],
[
{
"text": "текст кнопки 3",
"url": "https://i-dgtl.ru/3"
},
{
"text": "текст кнопки 4",
"url": "https://i-dgtl.ru/4"
}
]
]
}
Параметр |
Тип |
Описание |
|---|---|---|
contentType |
string required |
Тип контента ( |
text |
string required |
Текст сообщения; строка в кодировке UTF-8 без Byte Order Mark От 1 до 4096 символов |
inlineKeyboard |
array (arrays) |
Массив с массивами объектов кнопок |
inlineKeyboard.text |
string |
Текст кнопки; от 1 до 50 символов |
inlineKeyboard.url |
string |
Ссылка, на которую происходит переход при нажатии на кнопку; от 1 до 1000 символов |
{% hint style=»info» %} Вы можете форматировать текст сообщения:
Для полужирного шрифта нужны две звездочки слева и справа от фрагмента. **text** → text
Для курсива понадобятся по два знака нижнего подчеркивания слева и справа. __text__ → text
Чтобы сделать текст моноширинным, оберните его в тройные апострофы. „““text“““→
textДля переноса текста на новую строку используйте символ
\n. {% endhint %}
Сообщение с изображением #
Для отправки TELEGRAM-сообщения с изображением используется следующий объект content:
{
"contentType": "image",
"imageUrl": "https://image.png",
"caption": "Подпись к изображению",
"inlineKeyboard": [
[
{
"text": "текст кнопки 1",
"url": "https://i-dgtl.ru/1"
},
{
"text": "текст кнопки 2",
"url": "https://i-dgtl.ru/2"
}
],
[
{
"text": "текст кнопки 3",
"url": "https://i-dgtl.ru/3"
},
{
"text": "текст кнопки 4",
"url": "https://i-dgtl.ru/4"
}
]
]
}
Параметр |
Тип |
Описание |
|---|---|---|
contentType |
string required |
Тип контента ( |
imageUrl |
string required |
Ссылка на изображение |
caption |
string |
Подпись к изображению; до 1024 символов |
inlineKeyboard |
array (arrays) |
Массив с массивами объектов кнопок |
inlineKeyboard.text |
string |
Текст кнопки; от 1 до 50 символов |
inlineKeyboard.url |
string |
Ссылка, на которую происходит переход при нажатии на кнопку; от 1 до 1000 символов |
Пример запроса #
POST https://direct.i-dgtl.ru/api/v1/message
Authorization: Basic QWxhZGRpbjpvc...
Content-Type: application/json
[
{
"senderName": "i-digital_bot",
"channelType": "TELEGRAM",
"content": {
"contentType": "text",
"text": "Текст TELEGRAM-сообщения"
},
"destination": "79999999999"
}
]
curl -X POST 'https://direct.i-dgtl.ru/api/v1/message' \
-H 'Content-Type: application/json' \
-H 'Authorization: Basic QWxhZGRpbjpvc...' \
-d '[{"senderName":"i-digital_bot","channelType":"TELEGRAM","content":{"contentType":"text","text":"Текст TELEGRAM-сообщения"},"destination":"79999999999"}]'
{% hint style=»info» %} В примере указан минимальный набор параметров, который позволяет моментально отправить TELEGRAM-сообщение. Вы можете кастомизировать контент, время отправки, настроить коллбэки, добавить теги и внутренний идентификатор, используя опциональные параметры, описанные выше на данной странице. {% endhint %}