Receive notifications about channel events
A webhook is a user-defined callback over HTTP. You use webhooks to notify your app or back-end system when certain Voice Calling events occur. Agora Notifications enables you to subscribe to events and receive notifications about them across multiple product lines.
Understand the tech
Using Agora Console you subscribe to specific events for your project and tell Notifications the URL of the webhooks you have configured to receive these events. Notifications sends notifications of your events to your webhooks every time they occur. Your server authenticates the notification and returns 200 Ok
to confirm reception. You use the information in the JSON payload of each notification to give the best user experience to your users.
The following figure illustrates the workflow when Notifications is enabled for the specific events you subscribe to:
- A user commits an action that creates an event. For example, creates a channel.
- Notifications sends an HTTPS POST request to your webhook.
- Your server validates the request signature, then sends a response to Notifications within 10 seconds. The response body must be in JSON.
If Notifications receives 200 OK
within 10 seconds of sending the initial notification, the callback is considered successful. If these conditions are not met, Notifications immediately resends the notification. The interval between notification attempts gradually increases. Notifications stops sending notifications after three retries.
Prerequisites
To set up and use Agora NCS, you must have:
-
A computer with Internet access.
If your network access is restricted by a firewall, call the IP address query API to retrieve the Notifications IP addresses , then configure the firewall to allow these IP addresses.
Handle notifications for specific events
In order to handle notifications for the events you subscribe to you need to:
- Create your webhook
- Enable Notifications
- Verify Notifications signatures
- Implement online user status tracking
- Handle redundant notifications and abnormal user activity
Create your webhook
Once Notifications is enabled, Agora SD-RTN™ sends notification callbacks as HTTPS POST
requests to your webhook when events that you are subscribed to occur. The data format of the requests is JSON, the character encoding is UTF-8
, and the signature algorithm is HMAC/SHA1
or HMAC/SHA256
.
For Notifications, a webhook is an endpoint on an HTTP
server that handles these requests. In a production environment you write this in your web infrastructure, for development purposes best practice is to create a simple local server and use a service such as ngrok to supply a public URL that you register with Agora SD-RTN™ when you enable Notifications.
To do this, take the following steps:
-
Setup a Java project for your server
Your server receives and handles Notifications notifications. The
RootHandler
handles requests sent to the root address of your server and theNcsHandler
handles the Notifications notifications sent to<your server address>/ncsNotify
. To Set up your server, create a new Java project and add the following code to a file namedMain.java
: -
Add a JSON library to your project
The body of an HTTP request that your server receives contains event parameters in JSON format. To read these parameters download the
json-simple-1.1.1.jar
library and add it to your JAVA project. -
Handle Notifications callbacks
To define the
RootHandler
and theNcsHandler
, create a new file namedHandlers.java
in your JAVA project folder. Add the following code to this file: -
Create a public URL for your server
In this example you use ngrok to create a public URL for your server.
-
Download and install ngrok. If you have
Chocolatey
, use the following command: -
Add an
authtoken
to ngrok:To obtain an
authtoken
, sign up with ngrok. -
Start a tunnel to your local server using the following command:
You see a Forwarding URL displayed such as
https:// 1111-123-456-789-99.ap.ngrok.io
. This is the public URL for your local server that you use to enable Notifications.
-
Enable Notifications
To enable Notifications:
-
Log in to Agora Console. On the Project Management tab, locate the project for which you want to enable Notifications and click Config.
-
Select the Service Config tab, locate Notification Center Service, and click Enable.
-
In Notification Center Service Configuration, fill in the following information:
-
Product Name: Select the product for which you wish to enable notifications.
-
Event: Select all the channel events that you want to subscribe to.
If the events that you want to subscribe to generate a high number of queries per second (QPS), such as events
105
and106
, ensure your server has sufficient processing capacity. -
Receive Server Location: Select the region where your server that receives the notifications is located. Agora connects to the nearest Agora node server based on your specified location.
-
Receive Server URL: The
HTTPS
public address of your server that receives the notifications. For example,https://1111-123-456-789-99.ap.ngrok.io/ncsNotify
.-
To enhance security, Agora Notifications no longer supports
HTTP
addresses. -
To reduce the delay in notification delivery, best practice is to activate
HTTP
persistent connection (also calledHTTP
keep-alive) on your server with the following settings:MaxKeepAliveRequests
: 100 or moreKeepAliveTimeout
: 10 seconds or more
-
-
Secret: Copy and save the displayed secret to Add signature verification.
-
Allowed IP List: If your server is behind a firewall, check the box here, and ensure that you call the IP address query API to get the IP addresses of the Agora Notifications server and add them to the firewall's allowed IP list.
-
-
Press Save. Agora performs a health test for your configuration as follows:
-
The Notifications health test generates test events that correspond to your subscribed events, and then sends test event callbacks to your server. In test event callbacks, the channelName is
test_webhook
, and the uid is12121212
. -
After receiving each test event callback, your server must respond within 10 seconds with a status code of
200
. The response body must be in JSON format. -
When the Notifications health test succeeds, read the prompt and press Save Notifications Configuration. After your configuration is approved, the Status of Notification Center Service shows Enabled.
If the Notifications health test fails, follow the prompt on the Agora Console to troubleshoot the error. Common errors include the following:
-
Request timeout (590): Your server does not return the status code 200 within 10 seconds. Check whether your server responds to the request properly. If your server responds to the request properly, contact Agora Technical Support to check if the network connection between the Agora Notifications server and your server is working.
-
Domain name unreachable (591): The domain name is invalid and cannot be resolved to the target IP address. Check whether your server is properly deployed.
-
Certificate error (592): The Agora Notifications server fails to verify the SSL certificates returned by your server. Check if the SSL certificates of your server are valid. If your server is behind a firewall, check whether you have added all IP addresses of the Agora Notifications server to the firewall's allowed IP list.
-
Other response errors: Your server returns a response with a status code other than 200. See the prompt on the Agora Console for the specific status code and error messages.
-
-
Add signature verification
To communicate securely between Notifications and your webhook, Agora SD-RTN™ uses signatures for identity verification.
-
When you configure Notifications in Agora Console, Agora SD-RTN™ generates the secret you use for verification.
-
When sending a notification, Notifications generates two signature values from the secret using
HMAC/SHA1
andHMAC/SHA256
algorithms. These signatures are added asAgora-Signature
andAgora-Signature-V2
to theHTTPS
request header. -
When your server receives a callback, you can verify
Agora-Signature
orAgora-Signature-V2
.- To verify
Agora-Signature
, use the secret, the raw request body, and theHMAC/SHA1
algorithm. - To verify
Agora-Signature-V2
, use the secret, the raw request body, and theHMAC/SHA2
algorithm.
- To verify
To add signature verification to your server, take the following steps:
-
In your JAVA project folder, add a new file named
Signature.java
containing the following code:Make sure you update your Notifications secret in the code. To verify authenticity using
Agora-Signature-V2
, replaceHmacSHA1
withHmacSHA256
in the sample code.
-
To verify data in the Notifications callback, add the following code to your Notifications notification handler:
Implement online user status tracking
This section provides sample Java code to show how to use channel event callbacks to maintain online user status at your app server.
To maintain a user registry, take the following steps:
-
Create a new file in you JAVA project folder named
UserRegistry.java
containing the following code. -
Instantiate the
UserRegistry
classAdd the following code to the
Handlers
class afterpublic class Handlers {
: -
To update the user registry when you receive a Notifications callback, add the following code to the
handle
method in theNcsHandler
class afteros.close();
:
When adopting the solutions recommended by Agora to maintain user online status, you need to recognize the following:
- The solutions only guarantee eventual consistency of user status.
- To improve accuracy, notification callbacks specific to one channel must be handled in a single process.
Handle redundant notifications and abnormal user activity
When using Notifications to maintain the online status of your app users, your server might experience the following issues:
-
Message notifications are redundant. You receive multiple notifications because the Agora Notifications server can send more than one notification callback for each channel event to ensure reliability of the service.
-
Message notifications arrive out of order. Network issues cause callbacks to arrive at your server in a different order than the order of event occurrence.
To accurately maintain the online status of users, your server needs to be able to deal with redundant notifications and handle received notifications in the same order as events occur. The following section shows you how to use channel event callbacks to accomplish this.
Handle redundant or out of order notifications
Agora Notifications sends RTC channel event callbacks to your server. All channel events, except for 101
and 102
events, contain the clientSeq
field (Unit64) in payload
, which represents the sequence number of an event. This field is used to identify the order in which events occur on the app client. For notification callbacks reporting the activities of the same user, the value of the clientSeq
field increases as events happen.
Refer to the following steps to use the clientSeq
field to enable your server to handle redundant messages, and messages arriving out of order:
-
Enable Agora Notifications, and subscribe to RTC channel event callbacks. Best practice is to subscribe to the following event types according to your scenario:
- In the
LIVE_BROADCASTING
profile:103
,104
,105
,106
,111
, and112
. - In the
COMMUNICATION
profile:103
,104
,111
, and112
.
- In the
-
Use the channel event callbacks to get the latest status updates about the following at your server:
- Channel lists
- User lists in each channel
- Data for each user, including the user ID, user role, whether the user is in a channel, and
clientSeq
of channel events
-
When receiving notification callbacks of a user, search for the user in the user lists. If there is no data for the user, create data specific to the user.
-
Compare the value in the
clientSeq
field of the latest notification callback you receive with that of the last notification callback handled by your server:- If the former is greater than the latter, the notification callback needs to be handled.
- If the former is less than the latter, the notification callback should be ignored.
-
When receiving notification callbacks reporting a user leaving a channel, wait for one minute before deleting the user data. If it is deleted immediately, your server cannot handle notifications in the same order as channel events happen when receiving redundant notifications or notifications out of order.
Deal with abnormal user activities
When your server receives a notification callback of event 104
with reason as 999
, it means that the user is considered to have abnormal activities due to frequent login and logout actions. In this case, best practice is that your server calls the Banning user privileges API to remove the user from the current channel one minute after receiving such notification callback; otherwise, the notification callbacks your server receives about the user's events might be redundant or arrive out of order, which makes it hard for you to accurately maintain the online status of this user.
Reference
This section contains in depth information about Notifications
Request Header
The header of notification callbacks contains the following fields:
Field name | Value |
---|---|
Content-Type | application/json |
Agora-Signature | The signature generated by Agora using the Secret and the HMAC/SHA1 algorithm. You need to use the Secret and HMAC/SHA1 algorithm to verify the signature value. For details, see Signature verification. |
Agora-Signature-V2 | The signature generated by Agora using the Secret and the HMAC/SHA256 algorithm. You need to use the Secret and the HMAC/SHA256 algorithm to verify the signature value. For details, see Signature verification. |
Request Body
The request body of notification callbacks contains the following fields:
Field name | Type | Description |
---|---|---|
noticeId | String | The notification ID, identifying the notification callback when the event occurs. |
productId | Number | The product ID. Value 1 means the Realtime Communication (RTC) service. |
eventType | Number | The type of events being notified. For details, see event types. |
notifyMs | Number | The Unix timestamp (ms) when the Agora Notifications server sends a notification callback to your server. This value is updated when the Agora server resends the notification callback. |
payload | JSON Object | The content of the event being notified. The payload varies with event type. For details, see Channel event types. |
Example
Channel events
The Agora Notifications server notifies your server of the following channel event types when you use the RTC service:
eventType | Event name | Description |
---|---|---|
101 | channel create | Initializes the channel. |
102 | channel destroy | Destroys the channel. |
103 | broadcaster join channel | In the live streaming profile, the host joins the channel. |
104 | broadcaster leave channel | In the live streaming profile, the host leaves the channel. |
105 | audience join channel | In the live streaming profile, an audience member joins the channel. |
106 | audience leave channel | In the live streaming profile, an audience member leaves the channel. |
107 | user join channel with communication mode | In the communication profile, a user joins the channel. This events applies to the communication mode in RTC v3.x products only. For the communication profile in RTC v4.x (v4.0.0 and higher versions) products, your server receives the 103 event instead. |
108 | user leave channel with communication mode | In the communication profile, a user leaves the channel. This events applies to the communication profile in RTC v3.x products only. For the communication profile in RTC v4.x products, your server receives the 104 event instead. |
111 | client role change to broadcaster | In the communication profile in RTC v4. x products or in the live streaming profile, an audience member switches their user role to host. |
112 | client role change to audience | In the communication profile in RTC v4. x products or in the live streaming profile, a host switches their user role to audience member. |
101 channel create
This event type indicates that a channel is initialized (when the first user joins the channel). The payload contains the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
102 channel destroy
This event type indicates that the last user in the channel leaves the channel and the channel is destroyed. The payload contains the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
103 broadcaster join channel
This event type indicates that a host joins the channel in the live streaming profile. The payload contains the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the host in the channel. |
platform | Number | The platform type of the host's device:
|
clientType | Number | The type of services used by the host on Linux. Common return values include:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
104 broadcaster leave channel
This event type indicates that a host leaves the channel in the live streaming profile. The payload contains the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the host in the channel. |
platform | Number | The platform type of the host's device:
|
clientType | Number | The type of services used by the host on Linux. Common return values include:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
reason | Number | The reason why the host leaves the channel:
|
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
duration | Number | The length of time (s) that the host stays in the channel. |
Example
105 audience join channel
This event type indicates that an audience member joins the channel in the live streaming profile The payload includes the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the audience member in the channel. |
platform | Number | The platform type of the audience member's device:
|
clientType | Number | The type of services used by the host on Linux. Common return values include:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
106 audience leave channel
This event type indicates that an audience member leaves the channel in the live streaming profile. The payload includes the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the audience member in the channel. |
platform | Number | The platform type of the audience member's device:
|
clientType | Number | The type of services used by the audience member on Linux. Common return values include:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
reason | Number | The reason why the audience member leaves the channel:
|
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
duration | Number | The length of time (s) that the audience member stays in the channel. |
Example
107 user join channel with communication mode
This event type indicates that a user joins the channel in the communication profile. The payload includes the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the user in the channel. |
platform | Number | The platform type of the host's device:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
108 user leave channel with communication mode
This event type indicates that a user leaves the channel in the communication profile. The payload includes the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the user in the channel. |
platform | Number | The platform type of the user's device:
|
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
reason | Number | The reason why a user leaves the channel:
|
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
duration | Number | The length of time (s) that the user stays in the channel. |
Example
111 client role change to broadcaster
This event type indicates that an audience member calls setClientRole to switch their user role to host in the live streaming profile. The payload includes the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the user in the channel. |
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
112 client role change to audience
This event type indicates that a host call setClientRole to switch their user role to audience member in the live streaming profile. The payload contains the following fields:
Field name | Type | Description |
---|---|---|
channelName | String | The name of the channel. |
uid | Number | The user ID of the user in the channel. |
clientSeq | Number | The sequence number, which is used to identify the order in which events occur on the app client. You can use the value of this field to sort the events of a user into chronological order. |
ts | Number | The Unix timestamp (s) when the event occurs on the Agora RTC server. |
Example
IP address query API
If your server that receives notification callbacks is behind a firewall, you need to call the IP address query API to retrieve the IP addresses of Notifications and configure your firewall to trust all these IP addresses.
Agora occasionally adjusts the Notifications IP addresses. Best practice is to call this endpoint at least every 24 hours and automatically update the firewall configuration.
Prototype
- Method:
GET
- Endpoint:
https://api.agora.io/v2/ncs/ip
Request header
Authorization: You must generate a Base64-encoded credential with the Customer ID and Customer Secret provided by Agora, and then pass the credential to the Authorization field in the HTTP request header.
Request body
This API has no body parameters.
Response body
When the request succeeds, the response body looks like the following:
Each primary IP field shows an IP address of Notifications server. When you receive a response, you need to note the primary IP fields and add all these IP addresses to your firewall's allowed IP list.
Considerations
- The Agora Notifications does not guarantee that notification callbacks arrive at your server in the same order as events occur.
- Your server needs to be able to handle messages arriving out of order.
- To improve the reliability of Notifications, there can be more than one notification callback for each event, and your server needs to be able to handle repeated messages.