Войти

Документация Max

Документация WhatsApp

Управление инстансами

Описание

Данный метод используется для выполнения авторизации инстанса.

В ходе процедуры авторизации на указанный номер телефона будет отправлен SMS-код подтверждения. Полученный код необходимо передать через метод /sendCode, чтобы завершить авторизацию.

Перед началом убедитесь, что на указанном номере уже зарегистрирован аккаунт мессенджера MAX в мобильном приложении.

URL ресурса:
https://app.api-messenger.com/max-v1/start

Входные данные

Параметр Обязателен Значение
phone Да Номер телефона, необходимый для выполнения авторизации в MAX
Например 79000000000

Выходные данные

Структура выходных данных приведена ниже.

   {
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Текстовое описание возникшей ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$array = array(
            'phone' => '79999999999'
        );

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/start?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    echo 'OK';
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Данный метод завершает процесс авторизации инстанса. Введите SMS-код, отправленный после выполнения метода /start.

URL ресурса:
https://app.api-messenger.com/max-v1/sendcode

Входные данные

Параметр Обязателен Значение
code Да Проверочный код из SMS
Например 000000

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Текстовое описание возникшей ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$array = array(
            'code' => '000000'
        );

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/sendcode?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив

if ($data['status'] == 'OK') {
    echo 'OK';
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Метод позволяет получить статус инстанса.

URL ресурса:
https://app.api-messenger.com/max-v1/status

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "account": "{string}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
account Статус инстанса.

Возможные значения:

  • auth — авторизация пройдена, подключен.

  • reboot — перезагружается

  • launched — инстанс запущен, ожидание ввода проверочного кода из смс.

  • no_auth — инстанс закрыт. нет авторизации

Параметр выводится только при status=OK
message Текстовое описание возникшей ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/status?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    echo 'Status: ' . $data['account'];
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Метод позволяет перезапустить инстанс из статуса Подключен.

URL ресурса:
https://app.api-messenger.com/max-v1/reboot

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Текстовое описание возникшей ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/reboot?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
echo $result;

Описание

Метод позволяет закрыть текущий инстанс.

URL ресурса:
https://app.api-messenger.com/max-v1/exit

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Текстовое описание возникшей ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/exit?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'];

Отправка и приём сообщений

Описание

Метод позволяет ставить тестовые сообщения в очередь на отправку.
Сообщение на отправку хранится 24 часа в очереди.
Проверка авторизации инстанса не выполняется.

URL ресурса:
https://app.api-messenger.com/max-v1/sendmessage

Входные данные

Структура тела POST-запроса:

    [
        {
            "chatId": "{string}",
            "message": "{string}"
        },
        ...
    ]

В теле POST-запроса передаются следующие параметры:

Параметр Обязателен Значение
chatId Да Получатель сообщения в формате:
00000000 - идентификатор индивидуального чата
-10000000000000 - идентификатора группового чата
message Да Текстовое сообщение

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "internalId": [
            "{string}",
            ...
            ]
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Сообщение, содержащее описание ошибки, или, в случае успеха, количество добавленных сообщений в формате Successfully added 10
internalId Массив внутренних идентификаторов ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при status=OK

Ограничения

В одном запросе можно передать не более чем 100 сообщений.

Примеры


$token = '1xmrd7YHjff5';

    $array = array(
        array(
            'chatId' => '00000000', // chatId можно получить в webhook или методом /checkNumber
            'message' => 'Hello!', // Сообщение
        )
);

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/sendmessage?token=' . $token);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'] . ': ' . $data['message'];

Описание

Метод позволяет ставить сообщение с локацией в очередь на отправку.
Сообщение на отправку хранится 24 часа в очереди.
Проверка авторизации инстанса не выполняется.

URL ресурса:
https://app.api-messenger.com/max-v1/sendlocation

Входные данные

Структура тела POST-запроса:

   {
        "chatId": "{string}",
        "latitude": "{string}",
        "longitude": "{string}"
    }

В теле POST-запроса передаются следующие параметры:

Параметр Обязателен Значение
chatId Да Получатель сообщения в формате:
00000000 - идентификатор индивидуального чата
-10000000000000 - идентификатора группового чата
latitude Да Широта
longitude Да Долгота

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "internalId": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Сообщение, содержащее описание ошибки, либо, в случае успешного выполнения, уведомление о том, что сообщение добавлено в очередь.
internalId Внутренний идентификатор ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при status=OK

Примеры


$token = '1xmrd7YHjff5';

$array = array(
        'chatId' => '00000000', // chatId можно получить в webhook или методом /checkNumber
        'latitude' => '37.422', 
        'longitude' => '-122.084'
    );

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/sendlocation?token=' . $token);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'];

Описание

Метод позволяет поставить в очередь на отправку файл.
Файл хранится 24 часа в очереди.
Проверка авторизации инстанса не выполняется.

URL ресурса:
https://app.api-messenger.com/max-v1/sendfile

Входные данные

Структура тела POST-запроса:

{
        "chatId": "{string}",
        "body": "{string}",
        "filename": "{string}",
        "caption": "{string}"
    }

В теле POST-запроса передаются следующие параметры:

Параметр Обязателен Значение
chatId Да Получатель сообщения в формате:
00000000 - идентификатор индивидуального чата
-10000000000000 - идентификатора группового чата
body Да Строка в формате base64
filename Да Название файла с расширением.
caption Нет Подпись к файлу, которую увидит получатель.

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "internalId": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Сообщение, содержащее описание ошибки, либо, в случае успешного выполнения, уведомление о том, что файл добавлен в очередь.
internalId Внутренний идентификатор ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при status=OK

Примеры


$token = '1xmrd7YHjff5';

$array = array(
        'body' => '',
        'filename' => 'filename_1.jpg',
        'caption' => 'подпись',
        'chatId' => '00000000', // chatId можно получить в webhook или методом /checkNumber);

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/sendfile?token=' . $token);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'] . ': ' . $data['message'];

Описание

Метод позволяет поставить в очередь на отправку файл по URL.
Файл хранится 24 часа в очереди.
Проверка авторизации инстанса не выполняется.

URL ресурса:
https://app.api-messenger.com/max-v1/sendfileurl

Входные данные

Структура тела POST-запроса:

   {
        "chatId": "{string}",
        "url": "{string}",
        "filename": "{string}",
        "caption": "{string}"
    }

В теле POST-запроса передаются следующие параметры:

Параметр Обязателен Значение
chatId Да Получатель сообщения в формате:
00000000 - идентификатор индивидуального чата
-10000000000000 - идентификатора группового чата
url Да Ссылка на файл
filename Да Название файла с расширением.
caption Нет Подпись к файлу, которую увидит получатель.

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "internalId": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Сообщение, содержащее описание ошибки, либо, в случае успешного выполнения, уведомление о том, что файл добавлен в очередь.
internalId Внутренний идентификатор ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при status=OK

Примеры


$token = '1xmrd7YHjff5';

$array = array(
        'url' => 'https://img1.goodfon.ru/wallpaper/nbig/a/69/kartinka-3d-dikaya-koshka.jpg',
        'filename' => 'filename_1.jpg',
        'caption' => 'caption',
        'chatId' => '00000000', // chatId можно получить в webhook или методом /checkNumber
);

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/sendfileurl?token=' . $token);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'];

Описание

Метод позволяет получить все сообщения за последние 30 дней.

URL ресурса:
https://app.api-messenger.com/max-v1/messages

Входные данные

Параметр Обязателен Значение
api Нет Получить сообщения отправленные через API. Принимает значение true
from Нет Получить сообщения начиная с (>=). Фильтрация происходит по параметру timestamp
to Нет Получить сообщения до (<=). Фильтрация происходит по параметру timestamp
page Нет Номер страницы результатов, которую необходимо показать в ответе.

Если указан номер страницы, превышающий общее количество найденных страниц, выдается ошибка.

Значение по умолчанию: 1.

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "pager":
            {
                "currentPage": {int32},
                "pagesCount": {int32},
                "pageSize": {int32},
                "totalsMessage": {int32}
            },
        "messages":
            [
                {
                    "id": "{string}",
                    "body": "{string}",
                    "chatId": "{int32}",
                    "formattedTitle": "{string}",
                    "fromMe": {boolean},
                    "imgURL": "{string}",
                    "notifyName": "{string}",
                    "sender": "{int32}",
                    "timestamp": {int64},
                    "api": {boolean},
                    "forwarded": {boolean},
                    "ack": "{int32}",
                    "internalId": "{string}",
                    "type": "{enum}"
                    "quotedMessage": {object},
                    "location": {object},
                    "contact": {object},
                    "files": {array},
                },
                ...
            ]
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
pager Сводка по результатам поиска.
messages Список сообщений, удовлетворяющих условиям поиска.
Параметры, вложенные в pager
currentPage Номер выводимой страницы результатов.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска, не найдено, параметр не выводится.
pagesCount Количество страниц с результатами.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска, не найдено, параметр не выводится.
pageSize Количество выводимых на странице сообщений.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска, не найдено, параметр не выводится.
totalsMessage Общее количество найденных сообщений.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска, не найдено, значение параметра: 0.
Параметры, вложенные в messages
id Индивидуальный идентификатор сообщения в системе Max
body Текстовое сообщение
chatId Индивидуальный идентификатор чата
formattedTitle Название чата/группы
fromMe Возможные значения:

  • true — исходящее сообщение.

  • false — входящее сообщение.
imgURL URL на аватар пользователя

Параметр выводится только при fromMe=false
notifyName Имя пользователя в Max

Параметр выводится только при fromMe=false
sender Идентификатор автора сообщения
timestamp Метка времени UNIX в секундах
api Флаг отправки через API. Принимает значения true / false
forwarded Флаг, указывающий, переслано ли сообщение. Принимает значения true / false
ack Статус доставки сообщения.

Возможные значения:

  • 1 — отправлено.

  • 2 — прочитано.

Параметр выводится только при fromMe=true
internalId Внутренний идентификатор ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при api=true
type Тип сообщения.

Основные возможные значения:

  • chat — текстовое сообщение.

  • location — местоположение.

  • contact — карточка контакта.

  • document — документ.

  • video — видео.

  • photo — изображение.

  • sticker — стикер.

  • audio — аудио запись.

  • removed — сообщение удалено.

  • edited — сообщение отредактировано.

Параметры, вложенные в quotedMessage (выводится при forwarded=true)
id Индивидуальный идентификатор сообщения в системе Max
sender Идентификатор автора сообщения
Параметры, вложенные в location (выводится при type=location)
latitude Широта
longitude Долгота
Параметры, вложенные в contact (выводится при type=contact)
name Имя контакта
phone Телефон контакта
Параметры, вложенные в files (выводится при type=document, video, photo, sticker, audio)
url URL на скачивание файла. Файл хранится в нашей системе 1 час после получения.
name Название файла. Работает корректно только для type=document, для остальных типов файлов имя формируется системой.
mime Классификация файла согласно Media Types
quickVideo Возможные значения:

  • true — видеосообщение в формате “кружка”.

  • false — стандартное видео.

Параметр выводится только при type=video

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/messages?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    if ($data['pager']['totalsMessage'] > 0) {
        foreach ($data['messages'] as $v) {
            echo '

Отправитель: ' . (int) $v['sender'] . '
Сообщение: ' . $v['body'] . '

'; } } else echo 'no messages'; } else echo $data['status'] . ': ' . $data['message'];

Управление очередями

Описание

Метод позволяет получить все сообщения которые стоят в очереди на отправку.

URL ресурса:
https://app.api-messenger.com/max-v1/messagesqueue

Входные данные

Параметр Обязателен Значение
filter Нет Фильтр по типу сообщения. Пример: filter=message,file,contact,fileurl,location
page Нет Номер страницы результатов, которую необходимо показать в ответе.

Если указан номер страницы, превышающий общее количество найденных страниц, выдается ошибка.

Значение по умолчанию: 1.

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "pager":
            {
                "currentPage": {int32},
                "pagesCount": {int32},
                "pageSize": {int32},
                "totalsMessage": {int32}
            },
        "messages":
            [
                {
                    "type": "{enum}",
                    "chatId": "{int32}",
                    ... // Параметры в соответствие с отправляемым методом
                },
                ...
            ]
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
pager Сводка по результатам поиска.
messages Список сообщений, удовлетворяющих условиям поиска.
Параметры, вложенные в pager
currentPage Номер выводимой страницы результатов.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска не найдено, параметр не выводится.
pagesCount Количество страниц с результатами.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска не найдено, параметр не выводится.
pageSize Количество выводимых на странице сообщений.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска не найдено, параметр не выводится.
totalsMessage Общее количество найденных сообщений.

Если сообщений, удовлетворяющих заданным в запросе условиям поиска, не найдено, значение параметра: 0.
Параметры, вложенные в messages
type Тип сообщения.

Возможные значения:

  • file — файл.

  • contact — контакт.

  • message — текстовое сообщение.

  • fileurl — файл отправленный по URL.

  • location — местоположение.

chatId Индивидуальный идентификатор чата

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/messagesqueue?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    if ($data['pager']['totalsMessage'] > 0) {
        foreach ($data['messages'] as $v) {
            echo '

Recipient: ' . (int) $v['chatId'] . '
Message: ' . $v['message'] . '

'; } } else echo 'no messages'; } else echo $data['status'] . ': ' . $data['message'];

Описание

Метод позволяет очистить все сообщения стоящие в очереди на отправку.

URL ресурса:
https://app.api-messenger.com/max-v1/clearmessagesqueue

Входные данные

Параметр Обязателен Значение
filter Нет Удалить только определенные типы сообщений. Пример: filter=message,file,contact,fileurl,location

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Сообщение, содержащее описание ошибки.

Параметр выводится только при status=ERROR

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/clearmessagesqueue?files=true&token=' . $token);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'] . ': ' . $data['message'];

Дополнительно

Описание

Метод позволяет проверить сущестование в Max пользователя с указанным номером телефона.

URL ресурса:
https://app.api-messenger.com/max-v1/checknumber

Входные данные

Параметр Обязателен Значение
phone Да Номер телефона в формате 71111111111

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "result": {
            "numberExists": "{boolean}",
            "chatId": "{int32}",
            "img": "{string}"
        }
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
result Результат запроса.

Параметр выводится только при status=OK
message Сообщение, содержащее описание ошибки.

Параметр выводится только при status=ERROR
Параметры, вложенные в result
numberExists Существование номера в Max

Возможные значения:

  • true — номер зарегистрирован в Max.
  • false — номер не зарегистрирован в Max.
chatId Индивидуальный идентификатор чата.

Параметр выводится только при numberExists=true
img URL на аватар контакта в Max

Параметр выводится только при numberExists=true и если у контакта установлен аватар и его отображение разрешено настройками приватности.

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/checknumber?phone=79999999999&token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
print_r($data);

Webhook

Описание

Метод позволяет получить установленный Webhook.

URL ресурса:
https://app.api-messenger.com/max-v1/webhook

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}",
        "webhook": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
webhook Установленный Webhook либо его отсутствие.

Примеры


$token = '1xmrd7YHjff5';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/webhook?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
        echo !empty($data['webhook']) ? $data['webhook'] : 'no webhook';
} else
    echo $data['status'];

Описание

Метод позволяет установить URL для получения webhook.

URL ресурса:
https://app.api-messenger.com/max-v1/setwebhook

Входные данные

Структура тела POST-запроса:

    {
        "webhook": "{string}"
    }

В теле POST-запроса передаются следующие параметры:

Параметр Обязателен Значение
webhook Да URL адрес для получения webhook

Выходные данные

Структура выходных данных приведена ниже.

    { 
        "status": "{enum}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.

Примеры


$token = '1xmrd7YHjff5';

$array = array(
    'webhook' => 'http://your.site/incoming_message.php'
);

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/max-v1/setwebhook?token=' . $token);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($array));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
echo $data['status'];

Система умеет отправлять уведомления о событиях (входящие сообщения, статус отправленных сообщений, изменения состояния инстанса). Для отправки уведомлений во внешние системы в личном кабинете должен быть настроен HTTP адрес. Порядок получения уведомлений на стороне внешней системы не определен. Необходимо учитывать это при обработке событий опираясь на метку времени в поле timestamp.

Формат запроса type=stateInstance

    { 
        "type": "stateInstance",
        "instance": "max",                
        "status": "{enum}",
        "token": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус инстанса.

Возможные значения:

  • launched — инстанс запущен, ожидание ввода проверочного кода из смс.

  • no_auth — инстанс закрыт. нет авторизации
token Токен

Формат запроса type=messageOrAsk

    { 
        "type": "messageOrAsk",
        "instance": "max",                
        "messages":
            [
                {
                    "id": "{string}",
                    "body": "{string}",
                    "chatId": "{int32}",
                    "formattedTitle": "{string}",
                    "fromMe": {boolean},
                    "imgURL": "{string}",
                    "notifyName": "{string}",
                    "sender": "{int32}",
                    "timestamp": {int64},
                    "api": {boolean},
                    "forwarded": {boolean},
                    "ack": "{int32}",
                    "internalId": "{string}",
                    "type": "{enum}"
                    "quotedMessage": {object},
                    "location": {object},
                    "contact": {object},
                    "files": {array},
                },
                ...
            ],
        "ask":
            [
                {
                    "status": "{int}",
                    "chatId": "{int32}",
                    "message": {object}
                },
                ...
            ]
    }

Описание параметров:

Параметр Значение
Параметры, вложенные в messages
id Индивидуальный идентификатор сообщения в системе Max
body Текстовое сообщение
chatId Индивидуальный идентификатор чата
formattedTitle Название чата/группы
fromMe Возможные значения:

  • true — исходящее сообщение.

  • false — входящее сообщение.
imgURL URL на аватар пользователя

Параметр выводится только при fromMe=false
notifyName Имя пользователя в Max

Параметр выводится только при fromMe=false
sender Идентификатор автора сообщения
timestamp Метка времени UNIX в секундах
api Флаг отправки через API. Принимает значения true / false
forwarded Флаг, указывающий, переслано ли сообщение. Принимает значения true / false
ack Статус доставки сообщения.

Возможные значения:

  • 1 — отправлено.

  • 2 — прочитано.

Параметр выводится только при fromMe=true
internalId Внутренний идентификатор ввида 18627b48-1ff2-4e33-9747-9d0abea583b3

Параметр выводится только при api=true
type Тип сообщения.

Основные возможные значения:

  • chat — текстовое сообщение.

  • location — местоположение.

  • contact — карточка контакта.

  • document — документ.

  • video — видео.

  • photo — изображение.

  • sticker — стикер.

  • audio — аудио запись.

  • removed — сообщение удалено.

  • edited — сообщение отредактировано.

Параметры, вложенные в quotedMessage (выводится при forwarded=true)
id Индивидуальный идентификатор сообщения в системе Max
sender Идентификатор автора сообщения
Параметры, вложенные в location (выводится при type=location)
latitude Широта
longitude Долгота
Параметры, вложенные в contact (выводится при type=contact)
name Имя контакта
phone Телефон контакта
Параметры, вложенные в files (выводится при type=document, video, photo, sticker, audio)
url URL на скачивание файла. Файл хранится в нашей системе 1 час после получения.
name Название файла. Работает корректно только для type=document, для остальных типов файлов имя формируется системой.
mime Классификация файла согласно Media Types
quickVideo Возможные значения:

  • true — видеосообщение в формате “кружка”.

  • false — стандартное видео.

Параметр выводится только при type=video
Параметры, вложенные в ask
status Статус доставки сообщения.

Возможные значения:

  • -1 — ошибка, сообщение не отправлено.

  • 1 — отправлено.

  • 2 — прочитано.

chatId Индивидуальный идентификатор чата
message Объект сообщения. Если status=-1 содержит только параметр internalId

Примеры


// Сначала установите webhook согласно 
// документации например на http://ваш.сайт/incoming_message.php

// Декодируем пришедший по webhook JSON
$data = json_decode(file_get_contents('php://input'), true);
foreach($data['messages'] as $message){ // Распечатаем каждое сообщение
    // Здесь уже обработайте каждое сообщение:
    // Добавьте в базу данных или сразу ответьте    
}

Для партнеров

Описание

Добавляет новый инстанс в кабинет пользователя (деньги списываются с баланса за месяц в соответствии с тарифной сеткой)

URL ресурса:
https://app.api-messenger.com/account/add

Входные данные

Параметр Обязателен Значение
key Да Ключ для работы с партнерским API.
Получить в данный момент возможно только через тех.поддержку.
Для тестирования используйте ключ demo
name Нет Название инстанса

Выходные данные

Структура выходных данных приведена ниже.

   {
        "status": "{enum}",
        "token": "{string}",
        "before": "{string}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
token Токен для дальнейшей работы с инстансом
before Крайняя дата до которой инстанс (токен) будет работать. Инстанс автоматически продлевается за 3 дня до даты если есть денежные средства на балансе. В формате YYYY-mm-dd
message Параметр выводится только в случае ошибки

Примеры


$key = 'demo';
$name = 'Custom name';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/account/add?key=' . $key.'&name='.$name);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    echo $data['token'];
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Удаление инстанса из кабинета пользователя (происходит возврат денежных средств на баланс за неиспользованные дни)

URL ресурса:
https://app.api-messenger.com/account/delete

Входные данные

Параметр Обязателен Значение
key Да Ключ для работы с партнерским API.
Получить в данный момент возможно только через тех.поддержку.
Для тестирования используйте ключ demo
token Да Токен инстанса который необходимо удалить

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}"
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Параметр выводится только в случае ошибки

Примеры


$key = 'demo';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/account/delete?token=ttttt&key=' . $key);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    echo 'OK';
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Получение всех инстансов из кабинета пользователя

URL ресурса:
https://app.api-messenger.com/account/list

Входные данные

Параметр Обязателен Значение
key Да Ключ для работы с партнерским API.
Получить в данный момент возможно только через тех.поддержку.
Для тестирования используйте ключ demo

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "result": [
                {
                    "name": "{string}",
                    "token": "{string}",
                    "before": "{string}",
                },
            ]
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Параметр выводится только в случае ошибки
Параметры, вложенные в result
name Название инстанса указанный в кабинете
token Токен инстанса
before Крайняя дата до которой инстанс (токен) будет работать. Инстанс автоматически продлевается за 3 дня до даты если есть денежные средства на балансе. В формате YYYY-mm-dd

Примеры


$key = 'demo';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/account/list?key=' . $key);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    foreach ($data['result'] as $v) {
        echo 'Name: ' . $v['name'] . ', Token: ' . $v['token'] . ', Before: '. $v['before'];
    }
} else {
    echo 'ERROR: ' . $data['message'];
}

Описание

Получение общего баланса аккаунта. Пополнение происходит через тех.поддержку при получении ключа для работы с партнерским API.

URL ресурса:
https://app.api-messenger.com/account/balance

Входные данные

Параметр Обязателен Значение
key Да Ключ для работы с партнерским API.
Получить в данный момент возможно только через тех.поддержку.
Для тестирования используйте ключ demo

Выходные данные

Структура выходных данных приведена ниже.

    {
        "status": "{enum}",
        "message": "{string}",
        "balance": "{int32}",
    }

Описание параметров:

Параметр Значение
status Статус ответа.

Возможные значения:

  • ERROR — произошла ошибка.

  • OK — запрос выполнен успешно.
message Параметр выводится только в случае ошибки
balance Баланс аккаунта

Примеры


$key = 'demo';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://app.api-messenger.com/account/balance?key=' . $key);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json; charset=utf-8'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
$result = curl_exec($ch); // Отправим запрос
curl_close($ch);
$data = json_decode($result, true); // Разберем полученный JSON в массив
if ($data['status'] == 'OK') {
    echo 'Balance:' . $data['balance'];
} else {
    echo 'ERROR: ' . $data['message'];
}
whatsapp business api,подключение whatsapp business api,whatsapp business api цена,whatsapp business api стоимость,whatsapp business api как подключить,whatsapp бизнес api,facebook whatsapp api,whatsapp бот api,twilio whatsapp api,сколько стоит whatsapp business api,whatsapp cloud api,whatsapp business api рассылка,интеграция whatsapp business api,whatsapp business api waba,официальный whatsapp business api,whatsapp api интеграция,green api whatsapp,whatsapp business api получить,business account whatsapp api,whatsapp business api скачать на андроид,whatsapp business cloud api,green api whatsapp proxy,green api whatsapp отзывы,meta api whatsapp,meta whatsapp cloud api,как получить доступ к api whatsapp bisnes,сервис whatsapp business api