Notification API
1. Introduction
Yellow.ai's Notification API lets you send business-initiated messages from the various supported channels directly from your CRM or internal Systems.
The API supports different channels (SMS, email, and WhatsApp) and makes it easier for developers to integrate it anywhere in less time.
Starting from August 1, 2023, access to Notification APIs has been shifted to an on-demand model. This means that these APIs will no longer be available by default for bots created on or after August 1, 2023.
For a more efficient approach, we strongly recommend adopting Flow campaigns and User Event APIs. Rest assured, bots that were created before August 2023 can still use Notification APIs without any interruptions.
To view Notification API collections for each channel, see
1.1 Features of the Notification API
- Single endpoint for multiple channels
- Enable a range of API services with one-click
- Real-time reports on the YM Platform with the basic features of the BI tool to visualise your data
- Callback Webhook Configuration support to receive delivery updates directly on your system
1.2 IPs Whitelisting
Additionally, our outbound IPs given below must be whitelisted for the reports callback to flow into your system.
- 13.71.52.164
- 13.71.49.46
1.3 Enable Notification API
To use notification APIs, you first need to enable this
To use the Notification API you have to enable it on the platform as explained here:
- Go to the Engage module.
- Navigate to Preferences.
- Click Enable API Access.
If notification API is not enabled for the bot, you will get a 400
error (API access is not enabled).
1.4 Send delivery status to Webhook
You can add your webhook to receive delivery status updates in real time along with the custom payload from yellow.ai.
To enable receiving delivery status updates to your webhook:
Go to the Engage module,
Navigate to Preferences.
Enable Postback URL.
In Send the delivery status to (applicable only for notifications API), enter the Webhook URL to which the delivery updates need to be pushed.
To know what the sample webhook payload looks like, see Sample webhook payload.
Ensure that no authentication is required to push data to the Webhook URL.
1.5 Send notification API reports
You can send reports of notifications sent through API to your preferred users. The report is sent as a CSV file for the chosen duration.
To send Notification API reports to your preferred recipients:
Go to the Engage module,
Navigate to Preferences.
Enable Notification API reports.
In Send notification API reports to, enter the email IDs of each recipient to whom you want to send reports. Press Enter after entering each email ID.
In for time period between, set the duration (Start date and End date)for which you want to send the report.
To also send the report of WhatsApp notification API, enable Whatsapp v1 Notification API.
2. Notification API Details
2.1 Request Information
Base URL
https://cloud.yellow.ai/api/engagements/notifications/v2/push?bot={botId}
Region Code | Region | Host |
---|---|---|
R0 | India | https://cloud.yellow.ai |
R1 | MEA | https://r1.cloud.yellow.ai |
R2 | Jakarta | https://r2.cloud.yellow.ai |
R3 | Singapore | https://r3.cloud.yellow.ai |
R4 | USA | https://r4.cloud.yellow.ai |
R5 | Europe | https://r5.cloud.yellow.ai |
Headers
Header | Description/Value |
---|---|
Content-Type | application/json |
x-api-key | For https://app.yellow.ai platform: Get the API key from the path Configuration > Access Control > Bot API Key. For https://cloud.yellow.ai platform: Click on the Access control icon on top-right > Go to API Keys (you can see this option only if you are a bot admin). > Click +Generate API key**. Click here for detailed help. |
Only users with a Super Admin role can create a Bot API key.
Request Query Parameter
Parameter | Datatype | Description |
---|---|---|
botId* | String | Unique ID of the bot. Login to the Platform and navigate to the bot . You can find the bot ID in the URL Eg: x16387123456 |
Request Body Parameters
Parameter | Type | Required | Description |
---|---|---|---|
userDetails | Object | Yes | Details of the user to be notified. Eg. Phone Number for WhatsApp. |
notification (fields: params ) | Object | Yes | Template details |
media | Object | Optional | Template Media URL, Quick Reply Payload can be passed here |
config fields: (customPayload , postbackUrl ) | Object (Obj, String) | Optional | Configuration details for the API.customPayload - Custom information will be sent back with delivery updates. postbackUrl - Used to receive delivery updates on the client's webhook. To receive delivery updates on the client's webhook, enable Postback URL in Engage > Preferences and enter the Webhook URL. See Send delivery status to webhook. |
userDetails
Object
This object contains all relevant information about the user. It needs to have at least one contactable information and any number of additional parameters. For a WhatsApp notification, the number
field is mandatory.
"userDetails": {
"number": "919090909090", //mandatory for SMS, WhatsApp, Voice //country code to be added without space // if not added default 91
"email": "[email protected]", //mandatory for email channel
"cc": "[email protected]", //applicable only for email // array of string or string
"bcc": "[email protected]", //applicable only for email // array of string or string
}
notification
Object
This contains the message template details that need to be sent as a notification. templateId
is mandatory.
{
"notification": {
"templateId": "template_name",
// The name of the template as defined in the template manager. Mandatory for WhatsApp and SMS (wherever applicable).
"params": {
// Renderable parameters defined in the template.
"emiValue": "15000",
// Variable parameter names as shown in the template manager. Dynamic values can be passed,
"balance": "79999",
"media": [
{
// Applicable for WhatsApp.
"title": "title",
// Optional for document media types.
"mediaLink": "https://URL.com.jpeg",
"quickReplies": [
{
"type": "quick_reply",
"value": "payload 1"
},
{
"type": "quick_reply",
"value": "payload 2"
}
]
}
],
"quickReplies": {
"ctaUrlParam": {
"buttonText": "pricing-ai-chatbot"
// "buttonText" represents the text that will be displayed on the button.
// "pricing-ai-chatbot" represents the extension of the URL after the domain (as configured in the template.
}
}
}
}
}
config
Object
This contains the list of available pre-configuration that will be validated before sending the messages to the user.
"config": {
"customPayload": {
"firstName": "Wasim",
"phone": "91999999999",
"UID" : "Got the details"
},
"postbackUrl": "https://webhook.url"
}
2.2 Sample Webhook Payload
As soon as we receive a callback from the downstream services, we will post that data to the configured Webhook if available. Webhooks will be called with the request body.
{
"event": {
"status": "delivered"
},
"userId": "919999999999",
"source": "whatsapp",
"campaign": "apiNotifications",
"templateId": "video_button1",
"msgId": "3Yp8jdIUj8jNeoFOP1ZLT",
"workflowId": null,
"firstName": "Wasim",
"phone": "91999999999",
"UID": "Got the details"
}
2.3 Postman Collections
To access the entire Postman documentation and run collections, click the following button.
For API details of a specific channel, click the respective channel.
When you raise any support ticket, include msgId
or traceId
in the request.
2.4 Response Codes
On successful queueing of the notification, you will receive a 202 status code with the relevant msgId
. This confirms that the message details have been received by us and will be queued for sending on the relevant channel. The downstream service will pick the queue and will start sending it and updating the delivery status on the webhook, and the reports under Data Explorer on the platform.
HTTP Response Codes
Status code | Description |
---|---|
200 | Indicates general success of an API call. |
201 | Indicates successful resource creation. |
202 | Message queued successfully. You will receive a msgId for acknowledgement and tracking. |
204 | Response payload is empty. |
301 | Should be used to relocate resources. New URI should be used in the Location header of the response. |
400 | Bad request. Request structure is not formed correctly. Please check the message field for more information. |
401 | Unauthorised or invalid access token. Please check your auth token. Only Super Admin Auth tokens are accepted for using API. |
403 | Unauthorized user. |
404 | Resource not found. |
405 | HTTP method not supported for the API. |
406 | Must be used when the requested media type cannot be served by the API. |
415 | Rquest body does not contain content type. |
422 | Invalid inputs. The request structure is evaluated to be correct but the parameter values are not within the expected range. Channel not configured. |
429 | Rate limited. Occurs when there are too many requests sent to the API within a short time. Once a rate limit error is captured, the rate of the API call should be decreased to honour the limits. Default Rate Limit is 2000 requests/min per Bot. |
500 | Internal server error. TraceId will be sent back for tracking. |
503 | Downstream service is temporarily unavailable. Please try again later. |
API Error Codes
Error Code | Description |
---|---|
100 - Parameter is invalid | One or more parameters are invalid. Please check the error message to learn more about how to fix it. |
190 - Access token has expired | Generate a new access token |
1004 - mediaUploadError | Failed to upload media to WhatsApp (wa tier - cloud-api/onprem) |
1400 - authException | If no sub-code is present, the login status or access token has expired, been revoked, or is otherwise invalid. Get a new access token. If a sub-code is present, see the subcode. (wa tier - cloud-api/onprem) |
1401 - apiUnknown | Possibly a temporary issue due to downtime. Wait and retry the operation. If it occurs again, check that you are requesting an existing API. See Authentication and Authorization Errors for debugging information. (wa tier - cloud-api/onprem) |
1402 - apiService | Temporary issue due to downtime. Wait and retry the operation. See Troubleshooting, Error 2 for debugging information. (wa tier - cloud-api/onprem) |
1403 - apiMethod | Capability or permissions issue. Make sure your app has the necessary capability or permissions to make this call. (wa tier - cloud-api/onprem) |
1404 - apiTooManyCalls | Temporary issue due to throttling. Wait and retry the operation, or examine your API request volume. (WA tier - cloud-api/onprem) |
1405 - apiPermissionDenied | Permission is either not granted or has been removed. Handle the missing permissions. (WA tier - cloud-api/onprem) |
1406 - parameterIsInvalid | One or more parameters are invalid (wa tier - cloud-api/onprem) |
1406 - invalidUser | The recipient WhatsApp number is invalid / The user doesn't have a WhatsApp Account (wa tier - cloud-api/onprem) |
1407 - accessTokenExpired | Get a new access token. (WA tier - cloud-api/onprem) |
1408 - contactsError | Client-side rate limit has been hit. Unable to deliver message. Reasons can include: The recipient phone number is not a WhatsApp phone number.
|
1409 - phoneNumberNotAllowed | You are not allowed to onboard this phone number in Cloud API, please contact us for more information (wa tier - cloud-api/onprem) |
1410 - temporaryBlockForPolicyViolations | The WhatsApp Business Account associated with the app has been restricted or disabled for violating a platform policy (wa tier - cloud-api/onprem). |
1411 - duplicatePost | Duplicate posts cannot be published consecutively. Change the content of the post and try again. (wa tier - cloud-api/onprem) |
1412 - platformRateLimit | You hit platform rate limits, please refer to the Rate Limit section for more information. (wa tier - cloud-api/onprem) |
1413 - Media download error | Message failed to send because there were one or more errors related to your payment method. - Payment account is not attached to a WhatsApp Account. - Credit line is over the limit. - Credit line (Payment account) not set or active. - WhatsApp Business Account is deleted. - Account has been suspended by us. - Timezone not set. - Currency not set. - MessagingFor request (On Behalf Of (OBO)) is pending or declined. - Check your payment setup in WhatsApp Manager and try again. (wa tier - cloud-api/onprem) |
1414 - paymentIssues | There is some issue with the payment method of the Account. Please check on WhatsApp Business Manager. |
1415 - Message expired | Message failed to send during its Time To Live (TTL) duration. |
1416 - Rate limit error | Message failed to send because there were too many messages sent from this phone number in a short period of time. Please resend the failed messages. |
1417 - Unsigned certificate | Message failed to send because there was an error related to your certificate. Please contact support to investigate. |
1418 - Reengagement message | Message failed to send because more than 24 hours have passed since the customer last replied to this number. Use a message template to respond. |
1419 - Messaging limit reached | Failed due to WhatsApp 24-Hour Limit restrictions. Please check the link to know more about the restrictions. |
1420 - Generic error | WhatsApp was unable to send the message. Please try again. |
1421 - Unsupported message type | Message type is not supported. Please use the right message type. |
1422 - Message too long | Message length exceeds the limit of 4096 characters. Please shorten the message and try again. |
1423 - Invalid recipient type | - |
1424 - Access denied | Number is already registered on WhatsApp. See Migrating a Phone Number for information on moving a phone number from WhatsApp to the WhatsApp Business API. |
1425 - Resource not found | File or resource is not found. |
1426 - Parameter is missing | Required parameter is missing. |
1427 - parameterTypeError | The value entered for a parameter is of the wrong type or there is another problem. |
1428 - badUser | You will receive this message when you send a message to yourself. To resolve this, please send the message to a number that is not your own. |
1429 - parameterMissing | Number of parameters passed does not match the expected number of variable parameters. |
1432 - parameterTypeError | The format of the parameter does not match with the format in the created template. |
1443 - Template error | Template name does not exist in the translation or would have been paused from Meta’s end. |
1444 - System overloaded | WhatsApp cloud API system is overloaded. |
1500 - messageExpired | The message failed to send due to some issue with the WhatsApp Business Account. It may be down or disconnected for more than 1 day. |
1501 - ttlLimitReached | The message failed to send during its Time To Live (TTL) duration. Please resend the message. |
1503 - userPartOfExperiment | Failed to send message because this user's phone number is part of an experiment. |
1504 - waCompatibility | There could be any of the following reasons:
|
1520 - WA Tier - Cloud-API-Webhook | The WhatsApp message was not delivered by Meta to ensure compliance and maintain a healthy messaging environment. It is due to a limit, avoid immediately resending the template message, as it may result in another error. Instead, retry sending the message at progressively longer intervals until it is successfully delivered. For more details, see refer to the Meta doc for the Error Code 131049 |
14271 - invalidParameter | One or more parameters are invalid. (WA tier - cloud-api/onprem). |
14272 - Invalid user | The recipient WhatsApp number is invalid or the user doesn't have a WhatsApp account. |
When using Notification APIs, you may encounter the following error message if a WhatsApp template receives a low rating.
{
success: false,
message: "Template:<template-name> has reached low quality and cannot be used"
}
4. Reports
You can view data regarding the campaigns you execute through the Insights module.
- Within Insights, select the Data Explorer tab on the left.
- In the Data Explorer section, select Notification Reports under Default Datasets.
- To begin experimenting with Campaign Reports, you can select Filters, and use filters such as BOTID, CAMPAIGNID, and TEMPLATEID individually, or in different combinations to pull data.
- Once you have generated a data set that you find useful, click on Summarise. With this, you can group and summarise this data set in different ways.
5. Examples
5.1 Normal Text Notification
1. CURL request
curl --location --request POST 'https://app.yellowmessenger.com/api/engagements/notifications/v2/push?bot=BOT_ID_HERE' \
--header 'x-auth-token: TOKEN' \
--header 'Content-Type: application/json' \
--header 'Cookie: ym_xid=TOKEN' \
--data-raw '{
"userDetails": {
"number": "USER_PHONE_NUMBER"
},
"notification": {
"type": "whatsapp",
"sender": "SENDER_PHONE_NUMBER",
"templateId": "TEMPLATE_ID",
"params": {
"1": "var1",
"2": "www.yellow.ai"
}
}
}'
2. Sample
5.2 Image Notification
1. CURL request
curl --location --request POST 'https://app.yellowmessenger.com/api/engagements/notifications/v2/push?bot=BOT_ID_HERE' \
--header 'x-auth-token: TOKEN' \
--header 'Content-Type: application/json' \
--header 'Cookie: ym_xid=TOKEN' \
--data-raw '{
"userDetails": {
"number": "USER_PHONE_NUMBER"
},
"notification": {
"type": "whatsapp",
"sender": "SENDER_PHONE_NUMBER",
"templateId": "TEMPLATE_ID",
"params": {
"media": {
"mediaLink": "MEDIA_URL"
},
"1": "var1",
"2": "www.yellow.ai",
"3": "test"
}
}
}'
5.3 File Notification
1. CURL request
curl --location --request POST 'https://app.yellowmessenger.com/api/engagements/notifications/v2/push?bot=BOT_ID_HERE' \
--header 'x-auth-token: TOKEN' \
--header 'Content-Type: application/json' \
--header 'Cookie: ym_xid=TOKEN' \
--data-raw '{
"userDetails": {
"number": "USER_PHONE_NUMBERs"
},
"notification": {
"type": "whatsapp",
"sender": "SENDER_PHONE_NUMBER",
"templateId": "TEMPLATE_ID",
"params": {
"media": {
"mediaLink": "MEDIA_URL"
},
"1": "var1",
"2": "www.yellow.ai",
"3": "test"
}
}
}'