WhatsApp#
WhatsApp Message Sending#
The following WhatsApp messages are supported:
text only;
image only.
Примечание
It is not allowed to send two types of content at the same time (for example, a text and an image).
Request Examples#
To generate a test request with your parameters please
open the request generator.
1{
2 "login":"YOUR_LOGIN",
3 "password":"YOUR_PASSWORD",
4 "useTimeDiff":false,
5 "id":"8770100",
6 "scheduleInfo":
7 {
8 "timeBegin":"10:00",
9 "timeEnd":"20:00",
10 "weekdaysSchedule":"12345"
11 },
12 "destAddr":"Subscriber's_Number",
13 "message":
14 {
15 "type":"WHATSAPP",
16 "data":
17 {
18 "instantContent":
19 {
20 "type":"TEXT",
21 "data":
22 {
23 "text":"hatsApp message text"
24 }
25 },
26 "serviceNumber":"SENDER'S_NAME",
27 "ttl":1440
28 }
29 }
30}
1 {
2 "login":"YOUR_LOGIN",
3 "password":"YOUR_PASSWORD",
4 "useTimeDiff":false,
5 "id":"8770100",
6 "scheduleInfo":
7 {
8 "timeBegin":"10:00",
9 "timeEnd":"20:00",
10 "weekdaysSchedule":"12345"
11 },
12 "destAddr":"Subscriber's_Number",
13 "message":
14 {
15 "type":"WHATSAPP",
16 "data":
17 {
18 "instantContent":
19 {
20 "type":"IMAGE_URL",
21 "data":
22 {
23 "imageURL":"https://example.ru/image"
24 }
25 },
26 "serviceNumber":"SENDER'S_NAME",
27 "ttl":1440
28 }
29 }
30 }
Request Parameters#
The mandatory parameters are highlighted in bold.
Parameter |
Data type |
Description |
---|---|---|
login |
string |
Partner’s name. |
password |
string |
Partner’s password to send messages. |
useTimeDiff |
boolean |
Taking into account the time zone when starting messaging. If true, the message is sent to the subscriber according to the messaging schedule and his time zone. If false, the message is sent according to the messaging initiator schedule UTC+3, regardless of the message recipient time zone. Default value: false. |
shortenLinks |
boolean |
This parameter controls the automatic shortening of long links in a message. Possible values are - true - to shorten links (default value), false - shortening link is not required. If the service is available to the Partner, the URL strings will be shorted by default if the parameter is not received in the request. The ability to use this service is pre-negotiated and configured by the Service Provider. For more details see: Link Shortening Service. |
id |
string |
Partner-side unique ID. This parameter is required to control re-sending and duplication (the control service is enabled separately). The Partner may recall the Service Provider (the request to send a message) with the same ID several times. In this case the message will be sent to the subscriber only once (upon the first request). In response to requests, the Service Provider will return the same message ID in the Service Provider’s system to the Partner (the same as for the first request). The Service Provider optionally returns this ID to the Partner, if available in the message delivery report. |
scheduleInfo |
object |
Messaging schedule. If not specified, it is sent immediately upon receipt of the request. |
scheduleInfo/timeBegin |
string |
Start time, for example, «10:00». |
scheduleInfo/timeEnd |
string |
End time, for example, «21:00». |
scheduleInfo/weekdaysSchedule |
string |
Messaging days. Specified by numbers from 1 (Monday) to 7 (Sunday), for example, «12345». If there are no restrictions on days of the week, this parameter can be empty or not delivered in the request. |
scheduleInfo/deadline |
string |
The end date of the messaging, for example, 2019-05-10T16:29:30+0300. |
destAddr |
string |
Subscriber’s phone number. It contains the country code, operator code and phone number. For the Russian Federation, the code can be „8“, „7“ or „+7“. Examples: 72101234567, +72101234567, 8-210-123-45-67, 82101234567. |
message |
object |
Parameters of a message being sent. |
message/type |
enum |
Message type. The value of WHATSAPP is transmitted. |
message/data/instantContent |
object |
Parameters of the WhatsApp message being sent (images, buttons). |
instantContent/type |
enum |
Type of a message parameter. Possible values are: TEXT (to transmit only text), IMAGE_URL (to transmit only image). |
instantContent/data |
object |
Parameters of the data being sent. Possible values are: text (message text), imageURL (address of the image). |
instantContent/data/text |
string |
Message text. Maximum length is: 1000 characters. |
instantContent/data/imageURL |
string |
URL of an image to be transmitted. 400x400px image with JPG or PNG extension is recommended to be used. |
message/data/serviceNumber |
string |
Sender’s name from which the message is being sent. |
message/data/ttl |
integer |
WhatsApp message lifetime. Possible values in minutes are: 1440, 2880, 4320, 5760, 7200, 8640, 10080. When ttl = 0 or the parameter is absent in the request, the value from the default settings is used, which is set during the integration setup separately for each client. |
message/data/ttlUnit |
enum |
Unit of measurement of the message delivery period. It is transmitted only with ttl. Possible values are: SECONDS; MINUTES (by default); HOURS. |
extraParam |
string |
Additional parameters passed as param1=value1,param2=value2, where param1 and param2 – parameter names, value1 and value2 – values. The comma character cannot be included in the parameter name, but it can be included in its value - in this case it must be doubled. Example: the string place=абзаково,name=гостевой дом-2,coordinates=53.8085896,, 58.6362112,from=23.02.09,to=05.03.09. |
registeredDelivery |
integer |
Requirement of delivery reports. Possible values are: 0 - statuses are not required; 1 - statuses are required (by default); 2 - only «Undelivered» status is required. |
notifyUrl |
string |
Hostname of the incoming api to obtain the delivery report. This parameter is optional in the request, but when sending you need to consider the following: if the parameter is specified, it cannot be empty. The notifyUrl string must be no more than 2048 characters long. If any of the specified conditions are not met, an error will be generated and the request will not be executed. |
cascadeChainLink |
object |
Cascading message parameters. See Cascading Message Sending. |
Response to the Request#
After sending a message the Service Provider returns a response synchronously. In case of successful sending Service Provider returns HTTP-code 200 OK.
Successful Sending#
1 {
2 "mtNum": "107930572",
3 "id": "8770599"
4 }
Parameter |
Data type |
Description |
---|---|---|
mtNum |
string |
Sending chain identifier assigned by the Service Provider platform. |
id |
string |
Partner-side unique ID. Available, if it was included when sending. |
Sending Errors#
For results with errors, a response HTTP code will differ from 200 (see Error Codes).
1 {
2 "error": {
3 "code": 4,
4 "description": "Invalid request"
5 },
6 "extendedDescription": "Message is too long (2024 symbols). WHATSAPP message max length is 1000 symbols."
7 }
Parameter |
Data type |
Description |
---|---|---|
error |
object |
Error information. |
error/code |
int |
Error code. |
error/description |
string |
A brief description of the error. |
extendedDescription |
string |
Detailed description of the error (optional parameter). |
Error Codes#
Code |
Description |
HTTP code |
---|---|---|
1 |
Service is unavailable |
503 |
2 |
Invalid IP-address |
403 |
3 |
Too many connections |
429 |
4 |
Invalid request |
400 |
5 |
Invalid login |
401 |
6 |
Invalid password |
401 |
7 |
serviceNumber is not defined |
400 |
8 |
destAddr is not correct |
406 |
9 |
Message type is not correct |
406 |
10 |
Prohibited sending duplicates |
409 |
11 |
Invalid TTL |
406 |
100 |
100 |
500 |
WhatsApp Messages Delivery Statuses#
To receive WhatsApp message statuses, you need to set up a Delivery Status Service.