Sending Media
🔒 WhatsApp 24-Hour Session Rule
Before sending media, make sure the WhatsApp session with the user is active.
If the user has not messaged your business within the last 24 hours, WhatsApp requires the first message to be a template message.
After the customer replies, the 24-hour session opens and you may send media messages using this API. For sandbox testing, send your join code to the sandbox number to activate your session. Learn more
POST https://gateway.lipachat.com/api/v1/whatsapp/media
This API enables users to send Images, Videos, or Audio.
Headers
Content-Type
application/json
apiKey
Get apiKey from App portal settings tab https://app.lipachat.com/app/settings
Body
messageId
string
A unique identifier for the message. This will be used to track the message status and for deduplication purposes.
mediaType
string
Pass value as IMAGE, VIDEO, AUDIO, DOCUMENT or STICKER
mediaUrl
string
URL of an image to be sent. Must be a valid URL starting with https://...
caption
string
Media caption. Optional.
filename
string
Optional, applies to Document.
from
string
Sandbox number +254110090747 or your own WABA phone number.
to
string
Receiver phone number. It should start with a country code.
curl --location 'https://gateway.lipachat.com/api/v1/whatsapp/media' \
--header 'apiKey: YOUR_API_KEY' \
--header 'Content-Type: application/json' \
--data '{
"messageId": "5d3f62c3-eb8f-4150-8941-bdceb0f429bb",
"to": "254XXXXX",
"from": "254110090747",
"mediaType": "IMAGE",
"mediaUrl": "https://picsum.photos/id/237/200/300",
"caption": ""
}'// Create an instance of OkHttpClient
OkHttpClient client = new OkHttpClient().newBuilder()
.build();
// Define the media type for the request
MediaType mediaType = MediaType.parse("application/json");
// Create the request body with the necessary JSON payload using a text block
RequestBody body = RequestBody.create(mediaType, """
{
"messageId": "5d3f62c3-eb8f-4150-8941-bdceb0f429bb",
"to": "254XXXXX",
"from": "254110090747",
"mediaType": "IMAGE",
"mediaUrl": "https://picsum.photos/id/237/200/300",
"caption": ""
}
""");
// Build the request with the required headers
Request request = new Request.Builder()
.url("https://gateway.lipachat.com/api/v1/whatsapp/media")
.method("POST", body)
.addHeader("apiKey", "YOUR_API_KEY")
.addHeader("Content-Type", "application/json")
.build();
// Execute the request and get the response
Response response = client.newCall(request).execute();
const axios = require('axios');
let data = JSON.stringify({
"messageId": "5d3f62c3-eb8f-4150-8941-bdceb0f429bb",
"to": "254XXXXX",
"from": "254110090747",
"mediaType": "IMAGE",
"mediaUrl": "https://picsum.photos/id/237/200/300",
"caption": ""
});
let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://gateway.lipachat.com/api/v1/whatsapp/media',
headers: {
'apiKey': 'YOUR_API_KEY',
'Content-Type': 'application/json'
},
data : data
};
axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
Response
{
"timestamp": "2023-08-06T01:27:56.825898971",
"data": {
"messageId": "7addc006-07db-4fae-aac5-b285903b41d4",
"waId": "wamid.HBgMMjU0NzE3NzQ2NTY1FQIAEnRgSRjJGRkMzNkQ0QUVENTIxQ0NBAA==",
"status": "SENT",
"statusDesc": "Media sent successfully"
},
"status": "success",
"message": "",
"errors": null
}{
"timestamp": "2023-08-06T17:50:35.701+00:00",
"status": 400,
"error": "Bad Request",
"path": "/api/v1/whatsapp/message/text"
}{
"timestamp": "2023-08-06T20:49:48.455464058",
"data": null,
"status": "success",
"message": "Invalid credentials",
"errors": null
}Last updated