---
description: Простой способ отправлять сообщения в WhatsApp
---

# Отправка WEASY

::::::{tip}
Для подключения канала обратитесь к вашему менеджеру или в службу поддержки клиентов [sales@i-dgtl.ru](mailto:sales@i-dgtl.ru)
::::::

## Отправка WEASY-сообщений

<mark style="color:green;">`POST`</mark> `https://direct.i-dgtl.ru/api/v1/message`

Метод позволяет отправлять массив одиночных сообщений **(от 1 до 1000)**

#### Headers

| Name                                            | Type   | Description        |
| ----------------------------------------------- | ------ | ------------------ |
| Authorization<mark style="color:red;">\*</mark> | string | `Basic {TOKEN_1}`  |
| Content-Type<mark style="color:red;">\*</mark>  | string | `application/json` |

#### Request Body

| Name                                          | Type    | Description                                                                                                                                                                                                                                                                                              |
| --------------------------------------------- | ------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| channelType<mark style="color:red;">\*</mark> | string  | Канал отправки (`WEASY`)                                                                                                                                                                                                                                                                                 |
| senderName<mark style="color:red;">\*</mark>  | string  | Номер телефона WhatsApp-аккаунта привязанного к Weasy                                                                                                                                                                                                                                                    |
| destination<mark style="color:red;">\*</mark> | string  | Номер абонента                                                                                                                                                                                                                                                                                           |
| content<mark style="color:red;">\*</mark>     | object  | Контент сообщения. Ниже описаны возможные варианты содержимого.                                                                                                                                                                                                                                          |
| tags                                          | array   | Теги сообщения (массив строк). Каждый тег должен соответствовать выражению `^\w+$` (допускаются буквы в любом регистре, цифры и нижнее подчеркивание "\_")                                                                                                                                               |
| useLocalTime                                  | boolean | <p>Флаг, отвечающий за таймзону, в которой будет отправлено сообщение:<br><strong><code>true</code></strong> – отправка в таймзоне абонента<br><strong><code>false</code></strong> – отправка по МСК<br><em>По умолчанию true</em></p>                                                                   |
| localSendTime                                 | string  | <p>Нижняя граница допустимого времени отправки сообщения (с учетом значения<code>useLocalTime</code>)<br>Дата в формате <code>YYYY-MM-DD hh:mm:ss</code> в диапазоне от (текущее время в UTC - 12 часов) до (текущее время в UTC + 7 дней)<br><em>По умолчанию сообщение будет отправлено сразу</em></p> |
| localCompletionTime                           | string  | Верхняя граница допустимого времени отправки сообщения (с учетом `useLocalTime`) в диапазоне от `localSendTime` до (текущее время в UTC + 70 дней)                                                                                                                                                       |
| ttl                                           | integer | <p>Время жизни сообщения в секундах. По истечении ttl сообщению устанавливается финальный статус.<br><code>60 ≤ ttl ≤ 86400</code></p>                                                                                                                                                                   |
| hours                                         | array   | Допустимые часы отправки (массив чисел). В массиве могут быть переданы целые числа от 0 до 23, каждое из которых соответствует разрешенному для отправки интервалу с учетом `useLocalTime`; значения должны быть уникальны.                                                                              |
| days                                          | array   | Допустимые дни отправки (массив чисел). В массиве могут быть переданы целые числа от 1 (пн) до 7 (вс), каждое из которых соответствует разрешенному для отправки дню недели; значения должны быть уникальны.                                                                                             |
| shortUrl                                      | boolean | <p>Флаг, отвечающий за сокращение ссылок в сообщении:<br><code>true</code> - ссылки в тексте сообщения будут сокращены<br>По умолчанию false</p>                                                                                                                                                         |
| callbackUrl                                   | string  | Адрес для отправки callback                                                                                                                                                                                                                                                                              |
| callbackEvents                                | array   | События, по которым будут отправлены callback (массив строк). При наличии `callbackUrl` и отсутствии `callbackEvents` в запросе, будет отправлен callback по событию `delivered`.                                                                                                                        |
| externalMessageId                             | string  | Внутренний id сообщения в вашей системе. До 100 символов                                                                                                                                                                                                                                                 |

::::::{tab-set}

:::::{tab-item} 200

В случае успешного запроса возвращается ответ, в котором перечислены идентификаторы сообщений и коды результата. При значении errors = false гарантируется, что все переданные сообщения успешно созданы.

```
{
  "errors": false,
  "items": [
    {
      "messageUuid": "063474ec-a34f-4558-90c5-984395000004",
      "code": 201
    },
    {
      "messageUuid": "063564ec-a34f-4558-90c5-984395000005",
      "code": 201
    }
  ]
}
```
:::::


:::::{tab-item} 401

Использование невалидного токена / отсутствие заголовка авторизации.

::::{tab-set}

:::{tab-item} 4012

```
{
    "error": {
        "code": 4012,
        "msg": "Bad credentials"
    }
}
```
:::


:::{tab-item} 4010

```
{
    "error": {
        "code": 4010,
        "msg": "Not Authenticated"
    }
}
```
:::

::::

:::::


:::::{tab-item} 403

Использование неподходящего токена.

```
{
    "error": {
        "code": 4030,
        "msg": "Access Denied"
    }
}
```
:::::


:::::{tab-item} 422

Невалидные параметры в теле запроса; ниже приведены несколько примеров ответа.

```
{
    "error": {
        "code": 4220,
        "msg": "Invalid msisdn"
    }
}
-----------------------------------------------------------------------------
{
    "error": {
        "code": 4220,
        "msg": "Invalid text length in weasy content (0)"
    }
}
-----------------------------------------------------------------------------
{
    "error": {
        "code": 4220,
        "msg": "Invalid caption length in weasy content (3)"
    }
}
-----------------------------------------------------------------------------
{
    "error": {
        "code": 4220,
        "msg": "Invalid caption length in weasy content (3)"
    }
}
```
:::::


:::::{tab-item} 402

Payment Required. Недостаточно средств на балансе.

```javascript
{
    "error": {
        "code": 402,
        "msg": "Insufficient funds"
    }
}
```
:::::

::::::


::::::{tip}
Рекомендуемое время ожидания ответа: 70 секунд.\
Как правило, ответ на запрос возвращается не более чем за несколько секунд, но таймаут величиной в 70 секунд позволяет гарантированно получить ответ на запрос, в том числе в ситуациях повышенной нагрузки.
::::::

::::::{tip}
Для использования личного домена в сокращенных ссылках необходимо обратиться в поддержку
::::::

Возможные варианты перечислений:

| Параметр       | Варианты                                                              |
| -------------- | --------------------------------------------------------------------- |
| callbackEvents | [События для отправки callback](../extra/references/#callback-events) |

## Текстовое сообщение <a href="#text" id="text"></a>

Для отправки текстового WEASY-сообщения используется следующий объект `content`:

```
{
  "contentType": "text",
  "text": "текст сообщения"
}
```

| Параметр    | Тип                                   | Описание                                                                                         |
| ----------- | ------------------------------------- | ------------------------------------------------------------------------------------------------ |
| contentType | <p>string</p><p><em>required</em></p> | Тип контента (`text`)                                                                            |
| text        | <p>string</p><p><em>required</em></p> | <p>Текст сообщения; строка в кодировке UTF-8 без Byte Order Mark</p><p>От 1 до 1000 символов</p> |

## Сообщение с изображением <a href="#image" id="image"></a>

Для отправки WEASY-сообщения с изображением используется следующий объект `content`:

```
{
  "contentType": "image",
  "imageUrl": "https://image.png",
  "imageName": "Подпись к изображению"
}
```

| Параметр    | Тип                                   | Описание               |
| ----------- | ------------------------------------- | ---------------------- |
| contentType | <p>string</p><p><em>required</em></p> | Тип контента (`image`) |
| imageUrl    | <p>string</p><p><em>required</em></p> | Ссылка на изображение  |
| imageName   | <p>string<br><em>required</em></p>    | Подпись к изображению  |

## Сообщение с документом <a href="#document" id="document"></a>

Для отправки WEASY-сообщения с документом используется следующий объект `content`:

```
{
  "contentType": "document",
  "documentUrl": "https://document.pdf",
  "documentName": "Документ"
}
```

| Параметр     | Тип                                   | Описание                  |
| ------------ | ------------------------------------- | ------------------------- |
| contentType  | <p>string</p><p><em>required</em></p> | Тип контента (`document`) |
| documentUrl  | <p>string</p><p><em>required</em></p> | Ссылка на документ        |
| documentName | <p>string<br><em>required</em></p>    | Название документа        |

## Пример запроса <a href="#example" id="example"></a>

::::::{tab-set}

:::::{tab-item} JSON

```
POST https://direct.i-dgtl.ru/api/v1/message
Authorization: Basic QWxhZGRpbjpvc...
Content-Type: application/json
[
  {
    "senderName": "SENDER",
    "channelType": "WEASY",
    "content": {
      "contentType": "text",
      "text": "Текст сообщения"
    },
    "destination": "7818242882"
  }
]
```
:::::


:::::{tab-item} cURL

```
curl -X POST 'https://direct.i-dgtl.ru/api/v1/message' \
-H 'Content-Type: application/json' \
-H 'Authorization: Basic QWxhZGRpbjpvc...' \
-d '[{"senderName":"SENDER","channelType":"WEASY","content":{"contentType":"text","text":"Текст сообщения"},"destination":"7818242882"}]'
```
:::::


:::::{tab-item} Python

```
import requests
import json

url = "https://direct.i-dgtl.ru/api/v1/message"

payload = json.dumps([
  {
    "senderName": "SENDER",
    "channelType": "WEASY",
    "destination": "7818242882",
    "content": {
      "contentType": "text",
      "text": "Текст сообщения"
    }
  }
])
headers = {
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

```
:::::


:::::{tab-item} JavaScript

```
const myHeaders = new Headers();
myHeaders.append("Content-Type", "application/json");

const raw = JSON.stringify([
  {
    "senderName": "SENDER",
    "channelType": "WEASY",
    "destination": "7818242882",
    "content": {
      "contentType": "text",
      "text": "Текст сообщения"
    }
  }
]);

const requestOptions = {
  method: "POST",
  headers: myHeaders,
  body: raw,
  redirect: "follow"
};

fetch("https://direct.i-dgtl.ru/api/v1/message", requestOptions)
  .then((response) => response.text())
  .then((result) => console.log(result))
  .catch((error) => console.error(error));
```
:::::


:::::{tab-item} Java

```
OkHttpClient client = new OkHttpClient().newBuilder()
  .build();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "[\n  {\n    \"senderName\": \"SENDER\",\n    \"channelType\": \"WEASY\",\n    \"destination\": \"7818242882\",\n    \"content\": {\n      \"contentType\": \"text\",\n      \"text\": \"Текст сообщения\"\n    }\n  }\n]");
Request request = new Request.Builder()
  .url("https://direct.i-dgtl.ru/api/v1/message")
  .method("POST", body)
  .addHeader("Content-Type", "application/json")
  .build();
Response response = client.newCall(request).execute();
```
:::::


:::::{tab-item} PHP

```
<?php
$client = new Client();
$headers = [
  'Content-Type' => 'application/json'
];
$body = '[
  {
    "senderName": "SENDER",
    "channelType": "WEASY",
    "destination": "7818242882",
    "content": {
      "contentType": "text",
      "text": "Текст сообщения"
    }
  }
]';
$request = new Request('POST', 'https://direct.i-dgtl.ru/api/v1/message', $headers, $body);
$res = $client->sendAsync($request)->wait();
echo $res->getBody();

```
:::::


:::::{tab-item} Go

```
package main

import (
  "fmt"
  "strings"
  "net/http"
  "io"
)

func main() {

  url := "https://direct.i-dgtl.ru/api/v1/message"
  method := "POST"

  payload := strings.NewReader(`[
  {
    "senderName": "SENDER",
    "channelType": "WEASY",
    "destination": "7818242882",
    "content": {
      "contentType": "text",
      "text": "Текст сообщения"
    }
  }
]`)

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, payload)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("Content-Type", "application/json")

  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := io.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}
```
:::::

::::::


::::::{tip}
В примере указан минимальный набор параметров, который позволяет моментально отправить WEASY-сообщение. Вы можете кастомизировать контент, время отправки, настроить коллбэки, добавить теги и внутренний идентификатор, используя опциональные параметры, описанные выше на данной странице.
::::::
