This method is used to complete instance authorization.
During the authorization process, an SMS confirmation code will be sent to the specified phone number. The received code must be passed via the /sendCode method to complete authorization.
Before starting, make sure that the specified number already has a MAX messenger account registered in the mobile app.
https://app.api-messenger.com/max-v1/start
| Parameter | Required | Value |
|---|---|---|
| phone | Yes | The phone number required to complete authorization in MAX For example, 79000000000 |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | A text description of the error that occurred. The parameter is displayed only if 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo 'OK';
} else {
echo 'ERROR: ' . $data['message'];
}
This method completes the instance authorization process. Enter the SMS code sent after executing the /start method.
https://app.api-messenger.com/max-v1/sendcode
| Parameter | Required | Value |
|---|---|---|
| code | Yes | Verification code from the SMS. For example 000000 |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | Text description of the error that occurred. The parameter is displayed only if 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo 'OK';
} else {
echo 'ERROR: ' . $data['message'];
}
This method allows you to get the instance status.
Resource URL:https://app.api-messenger.com/max-v1/status
The output data structure is shown below.
{
"status": "{enum}",
"account": "{string}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| account | Instance status. Possible values:
The parameter is displayed only if status=OK
|
| message | Text description of the error that occurred. The parameter is displayed only if 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo 'Status: ' . $data['account'];
} else {
echo 'ERROR: ' . $data['message'];
}
This method allows you to restart an instance from the Connected state.
Resource URL:https://app.api-messenger.com/max-v1/reboot
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | Text description of the error that occurred. The parameter is displayed only if 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); // Send a request
curl_close($ch);
echo $result;
This method allows you to close the current instance.
Resource URL:https://app.api-messenger.com/max-v1/exit
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | Text description of the error that occurred. The parameter is displayed only if 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'];
This method allows you to queue test messages for sending.
The message is kept in the queue for 24 hours.
Instance authorization is not checked.
https://app.api-messenger.com/max-v1/sendmessage
POST request body structure:
[
{
"chatId": "{string}",
"message": "{string}"
},
...
]
The following parameters are passed in the POST request body:
| Parameter | Required | Value |
|---|---|---|
| chatId | Yes | Message recipient in the following format:00000000 - individual chat ID-10000000000000 - group chat ID |
| message | Yes | Text message |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"internalId": [
"{string}",
...
]
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | Message containing an error description or, if successful, the number of messages added in the following format Successfully added 10 |
| internalId | Array of internal view identifiers 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if status=OK |
$token = '1xmrd7YHjff5';
$array = array(
array(
'chatId' => '00000000', // The chatId can be obtained in a webhook or using the /checkNumber method
'message' => 'Hello!', // Message
)
);
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'] . ': ' . $data['message'];
This method allows you to queue a message with a location for sending.
The message is kept in the queue for 24 hours.
Instance authorization is not checked.
https://app.api-messenger.com/max-v1/sendlocation
POST request body structure:
{
"chatId": "{string}",
"latitude": "{string}",
"longitude": "{string}"
}
The following parameters are passed in the POST request body:
| Parameter | Required | Value |
|---|---|---|
| chatId | Yes | Message recipient in the following format:00000000 - individual chat ID-10000000000000 - group chat ID |
| latitude | Yes | Latitude |
| longitude | Yes | Longitude |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"internalId": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | A message containing a description of the error or, if successful, a notification that the message has been added to the queue. |
| internalId | Internal view identifier 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if status=OK |
$token = '1xmrd7YHjff5';
$array = array(
'chatId' => '00000000', // The chatId can be obtained in a webhook or using the /checkNumber method
'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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'];
This method allows you to queue a file for sending.
The file is stored in the queue for 24 hours.
Instance authorization is not checked.
https://app.api-messenger.com/max-v1/sendfile
POST request body structure:
{
"chatId": "{string}",
"body": "{string}",
"filename": "{string}",
"caption": "{string}"
}
The following parameters are passed in the POST request body:
| Parameter | Required | Value |
|---|---|---|
| chatId | Yes | The recipient of the message in the format:00000000 - the ID of the individual chat-10000000000000 - group chat ID |
| body | Yes | A base64-encoded string |
| filename | Yes | The file name with extension. |
| caption | No | The file caption that the recipient will see. |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"internalId": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | A message containing a description of the error, or, if successful, a notification that the file has been added to the queue. |
| internalId | Internal identifier of the view 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if status=OK |
$token = '1xmrd7YHjff5';
$array = array(
'body' => '',
'filename' => 'filename_1.jpg',
'caption' => 'подпись',
'chatId' => '00000000', // The chatId can be obtained in a webhook or using the /checkNumber method);
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'] . ': ' . $data['message'];
This method allows you to queue a file for sending by URL.
The file is stored in the queue for 24 hours.
Instance authorization is not checked.
https://app.api-messenger.com/max-v1/sendfileurl
POST request body structure:
{
"chatId": "{string}",
"url": "{string}",
"filename": "{string}",
"caption": "{string}"
}
The following parameters are passed in the POST request body:
| Parameter | Required | Value |
|---|---|---|
| chatId | Yes | Message recipient in the following format:00000000 - individual chat ID-10000000000000 - group chat ID |
| url | Yes | Link to the file |
| filename | Yes | File name with extension. |
| caption | No | The caption for the file that will be seen recipient. |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"internalId": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | A message containing a description of the error or, if successful, a notification that the file has been added to the queue. |
| internalId | Internal identifier of the view 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if 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', // The chatId can be obtained in a webhook or using the /checkNumber method
);
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'];
This method retrieves all messages for the last 30 days.
Resource URL:https://app.api-messenger.com/max-v1/messages
| Parameter | Required | Value |
|---|---|---|
| api | No | Get messages sent via the API. Evaluates to true |
| from | No | Get messages starting with (>=). Filtering is performed by the timestamp parameter |
| to | No | Get messages up to (<=). Filtering is performed by the timestamp parameter |
| page | No | The page number of the results to display in the response. If the specified page number exceeds the total number of pages found, an error is returned. Default value: 1. |
The output data structure is shown below.
{
"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},
},
...
]
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| pager | Summary of search results. |
| messages | List of messages matching the search criteria. |
Parameters nested in pager
| |
| currentPage | The number of the results page to display. If no messages matching the search criteria specified in the query are found, the parameter is not displayed. |
| pagesCount | Number of pages with results. If no messages matching the search criteria specified in the query are found, the parameter is not displayed. |
| pageSize | The number of messages displayed per page. If no messages matching the search criteria are found, this parameter is not displayed. |
| totalsMessage | The total number of messages found. If no messages matching the search criteria are found, this parameter value is: 0. |
Parameters nested in messages
| |
| id | Individual message identifier in the Max system |
| body | Text message |
| chatId | Individual chat identifier |
| formattedTitle | Chat/group name |
| fromMe | Possible values:
|
| imgURL | URL to the users avatar This parameter is only displayed when fromMe=false |
| notifyName | Username in Max This parameter is only displayed when fromMe=false |
| sender | Message author ID |
| timestamp | UNIX timestamp in seconds |
| api | API sending flag. Accepts values true / false |
| forwarded | Flag indicating whether the message has been forwarded. Accepts values true / false |
| ack | Message delivery status. Possible values:
The parameter is displayed only if fromMe=true
|
| internalId | Views internal ID 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if api=true |
| type | Message type. Main possible values:
|
Parameters nested in quotedMessage (выводится при forwarded=true)
| |
| id | Individual message identifier in the Max system |
| sender | Message author ID |
Parameters nested in location (выводится при type=location)
| |
| latitude | Latitude. |
| longitude | Longitude. |
Parameters nested in contact (выводится при type=contact)
| |
| name | Contact name |
| phone | Contact phone number |
Parameters nested in files (выводится при type=document, video, photo, sticker, audio)
| |
| url | URL for file download. The file is stored in our system for 1 hour after receiving. |
| name | File name. Works correctly only for type=document; for other file types, the name is generated by the system. |
| mime | File classification according to Media Types |
| quickVideo | Possible values:
The parameter is displayed only if 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
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'];
This method allows you to get all messages queued for sending.
Resource URL:https://app.api-messenger.com/max-v1/messagesqueue
| Parameter | Required | Value |
|---|---|---|
| filter | No | Filter by message type. Example: filter=message,file,contact,fileurl,location |
| page | No | The page number of the results to display in the response. If the specified page number is greater than the total number of pages found, an error is returned. Default value: 1. |
The output data structure is shown below.
{
"status": "{enum}",
"pager":
{
"currentPage": {int32},
"pagesCount": {int32},
"pageSize": {int32},
"totalsMessage": {int32}
},
"messages":
[
{
"type": "{enum}",
"chatId": "{int32}",
... // Parameters according to the sending method
},
...
]
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| pager | Summary of search results. |
| messages | List of messages that match the search criteria. |
Parameters nested in pager
| |
| currentPage | The number of the results page to display. If no messages matching the search criteria specified in the query were found, the parameter is not displayed. |
| pagesCount | Number of pages with results. If no messages matching the search criteria specified in the query were found, found, parameter is not displayed. |
| pageSize | Number of messages displayed per page. If no messages matching the search criteria are found, the parameter is not displayed. |
| totalsMessage | Total number of messages found. If no messages matching the search criteria are found, the parameter value is: 0. |
Parameters nested in messages
| |
| type | Message type. Possible values:
|
| chatId | Individual chat ID |
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
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'];
This method clears all messages in the message queue for sending.
Resource URL:https://app.api-messenger.com/max-v1/clearmessagesqueue
| Parameter | Required | Value |
|---|---|---|
| filter | No | Delete only certain message types. Example: filter=message,file,contact,fileurl,location |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | A message containing a description of the error. This parameter is only displayed when 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'] . ': ' . $data['message'];
This method checks the existence of a user with the specified phone number in Max.
Resource URL:https://app.api-messenger.com/max-v1/checknumber
| Parameter | Required | Value |
|---|---|---|
| phone | Yes | Phone number in the format 71111111111 |
The output data structure is shown below.
{
"status": "{enum}",
"result": {
"numberExists": "{boolean}",
"chatId": "{int32}",
"img": "{string}"
}
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| result | Query result. This parameter is only displayed if status=OK |
| message | A message containing a description of the error. The parameter is displayed only if status=ERROR |
Parameters nested in result |
|
| numberExists | The number exists in Max. Possible values:
|
| chatId | The individual chat ID. This parameter is only displayed if numberExists=true |
| img | URL to a contacts avatar in Max This parameter is only displayed if numberExists=true and if the contact has an avatar set and its display is allowed by privacy settings. |
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
print_r($data);
This method allows you to get an installed webhook.
Resource URL:https://app.api-messenger.com/max-v1/webhook
The output data structure is shown below.
{
"status": "{enum}",
"webhook": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| webhook | An installed webhook or its absence. |
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo !empty($data['webhook']) ? $data['webhook'] : 'no webhook';
} else
echo $data['status'];
This method allows you to set a URL for receiving webhook.
Resource URL:https://app.api-messenger.com/max-v1/setwebhook
POST request body structure:
{
"webhook": "{string}"
}
The following parameters are passed in the POST request body:
| Parameter | Required | Value |
|---|---|---|
| webhook | Yes | URL for receiving webhook |
The output data structure is shown below.
{
"status": "{enum}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
echo $data['status'];
The system can send event notifications (incoming messages, status of sent messages, instance state changes). To send notifications to external systems, an HTTP address must be configured in the user account. The order in which notifications are received by the external system is not defined. This must be taken into account when processing events based on the timestamp in the timestamp field.
type=stateInstance {
"type": "stateInstance",
"instance": "max",
"status": "{enum}",
"token": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Instance status. Possible values:
|
| token | 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}
},
...
]
}
Parameter description:
| Parameter | Value |
|---|---|
Parameters attached to messages
| |
| id | Individual message identifier in the Max system |
| body | Text message |
| chatId | Individual chat identifier |
| formattedTitle | Chat/group name |
| fromMe | Possible values:
|
| imgURL | URL to the users avatar This parameter is only displayed when fromMe=false |
| notifyName | Username in Max This parameter is only displayed when fromMe=false |
| sender | Message author ID |
| timestamp | UNIX timestamp in seconds |
| api | API sending flag. Accepts values true / false |
| forwarded | Flag indicating whether the message has been forwarded. Accepts values true / false |
| ack | Message delivery status. Possible values:
The parameter is displayed only if fromMe=true
|
| internalId | Views internal ID 18627b48-1ff2-4e33-9747-9d0abea583b3The parameter is displayed only if api=true |
| type | Message type. Main possible values:
|
Parameters nested in quotedMessage (выводится при forwarded=true)
| |
| id | Individual message identifier in the Max system |
| sender | Message author ID |
Parameters nested in location (выводится при type=location)
| |
| latitude | Latitude. |
| longitude | Longitude. |
Parameters nested in contact (выводится при type=contact)
| |
| name | Contact name |
| phone | Contact phone number |
Parameters nested in files (выводится при type=document, video, photo, sticker, audio)
| |
| url | URL for file download. The file is stored in our system for 1 hour after receiving. |
| name | File name. Works correctly only for type=document; for other file types, the name is generated by the system. |
| mime | File classification according to Media Types |
| quickVideo | Possible values:
The parameter is displayed only if type=video
|
Parameters attached to ask
| |
| status | Message delivery status. Possible values:
|
| chatId | Individual chat ID |
| message | Message object. If status=-1 only contains the internalId parameter |
// First, set up a webhook according to the documentation
// e.g., http://yoursite/incoming_message.php
// Decode the JSON received via webhook
$data = json_decode(file_get_contents('php://input'), true);
foreach($data['messages'] as $message){ // Print each message
// Process each message here:
// Add to the database or reply immediately
}
Adds a new instance to the user account (money is debited from the monthly balance according to the pricing schedule)
Resource URL:https://app.api-messenger.com/account/add
| Parameter | Required | Value |
|---|---|---|
| key | Yes | A key for using the partner API. Currently only available through technical support. Use the key for testing demo |
| name | No | Instance name |
The output data structure is shown below.
{
"status": "{enum}",
"token": "{string}",
"before": "{string}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| token | A token for further use of the instance |
| before | The last date until which the instance (token) will be active. The instance is automatically renewed three days before the expiration date if there are sufficient funds in the balance. In the format YYYY-mm-dd |
| message | The parameter is displayed only in case of an error |
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo $data['token'];
} else {
echo 'ERROR: ' . $data['message'];
}
Deletes an instance from the user account (funds for unused days are refunded to the balance)
Resource URL:https://app.api-messenger.com/account/delete
| Parameter | Required | Value |
|---|---|---|
| key | Yes | Key for working with the partner API. Currently, it can only be obtained through technical support. For testing, use the key demo |
| token | Yes | Token of the instance to be deleted |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}"
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | The parameter is displayed only in case of an error |
$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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo 'OK';
} else {
echo 'ERROR: ' . $data['message'];
}
Get all instances from the user account
Resource URL:https://app.api-messenger.com/account/list
| Parameter | Required | Value |
|---|---|---|
| key | Yes | Key for Working with the partner API. Currently, this information can only be obtained through technical support. For testing, use the key demo |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"result": [
{
"name": "{string}",
"token": "{string}",
"before": "{string}",
},
]
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | The parameter is displayed only in case of an error |
Parameters attached to result
| |
| name | Instance name specified in the dashboard |
| token | Instance token |
| before | The last date until which the instance (token) will be active. The instance is automatically renewed 3 days before the date if there are funds in the balance. In the format 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
foreach ($data['result'] as $v) {
echo 'Name: ' . $v['name'] . ', Token: ' . $v['token'] . ', Before: '. $v['before'];
}
} else {
echo 'ERROR: ' . $data['message'];
}
Get the total account balance. Replenishment occurs through technical support upon receipt of a key for working with the partner API.
Resource URL:https://app.api-messenger.com/account/balance
| Parameter | Required | Value |
|---|---|---|
| key | Yes | Key for working with the partner API. Currently, it can only be obtained through technical support. Use the key for testing. demo |
The output data structure is shown below.
{
"status": "{enum}",
"message": "{string}",
"balance": "{int32}",
}
Parameter description:
| Parameter | Value |
|---|---|
| status | Response status. Possible values:
|
| message | The parameter is displayed only in case of an error. |
| balance | Account 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); // Send a request
curl_close($ch);
$data = json_decode($result, true); // Parse the received JSON into an array
if ($data['status'] == 'OK') {
echo 'Balance:' . $data['balance'];
} else {
echo 'ERROR: ' . $data['message'];
}