Device Notification Management via the Console
There will be situations where you want certain operations to be carried out on a device but that device will not be able to support the operation. The failure to carry out such operations will be notified to the EMM administrator and the device owner. There will also be instances where the user will need to be notified of additional information such as the new lock reset pin. This section provides the details of the REST APIs used to manage device notifications.
Sending a device notification
Description | Notify users on device operation failures and other information using this REST API. For more information, see how the notifications function via the console. | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Resource Path | / | ||||||||||||||||||||||||
URL | /mdm-admin/notifications | ||||||||||||||||||||||||
HTTP Method | POST | ||||||||||||||||||||||||
Request/Response Format | application/json | ||||||||||||||||||||||||
cURL command | curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer <EMM_API_TOKEN>" -d @'<JSON_PAYLOAD>' -k -v https://<EMM_HOST>:<EMM_HTTPS_PORT>/mdm-admin/notifications
Example: curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer 33392fb365b3ac693b405b565ddc8a3a" -d @'notification.json' -k -v https://localhost:9443/mdm-admin/notifications | ||||||||||||||||||||||||
Sample output | > POST /mdm-admin/notifications/ HTTP/1.1 > Host: localhost:9443 > User-Agent: curl/7.43.0 > Accept: */* > Content-Type: application/json > Authorization: Bearer 8e6ecc18eeec1c4f161e442aa2033146 > Content-Length: 203 < HTTP/1.1 201 Created < Date: Fri, 11 Mar 2016 10:19:15 GMT < Content-Type: application/json < Content-Length: 77 < Server: WSO2 Carbon Server {"statusCode":201,"messageFromServer":"Notification has added successfully."} | ||||||||||||||||||||||||
Sample JSON Definition | { "notificationId": 4, "deviceIdentifier": { "id": "359298055243973", "type": "android" }, "description": "Alarm operation failed.", "operationId": 5, "status": "NEW" }
|
Updating the device notification status
Description | When a user has read the the device notification the device notification status must change from NEW to CHECKED. Update the device notification status using this REST API. |
---|---|
Resource Path | /{id}/{status} |
URL | /mdm-admin/notifications/{id}/{status} |
HTTP Method | PUT |
Request/Response Format | application/json |
cURL command | curl -X PUT -H "Content-Type: application/json" -H "Authorization: Bearer <EMM_API_TOKEN>" -d @'<JSON_PAYLOAD>' -k -v https://<EMM_HOST>:<EMM_HTTPS_PORT>/mdm-admin/notifications/{id}/{status}
Example: Updating the notification having the notification ID 3 from the unread to the read status. curl -X PUT -H "Content-Type: application/json" -H "Authorization: Bearer 33392fb365b3ac693b405b565ddc8a3a" -k -v https://localhost:9443/mdm-admin/notifications/3/CHECKED |
Sample output | > PUT /mdm-admin/notifications/3/CHECKED HTTP/1.1 > Host: localhost:9443 > User-Agent: curl/7.43.0 > Accept: */* > Content-Type: application/json > Authorization: Bearer c5e2952bd8da8c7d73c68aa92573f3ea > < HTTP/1.1 200 OK < Cache-Control: private < Expires: Thu, 01 Jan 1970 05:30:00 IST < Date: Fri, 11 Mar 2016 11:23:15 GMT < Content-Type: application/json < Content-Length: 82 < Server: WSO2 Carbon Server {"statusCode":200,"messageFromServer":"Notification status updated successfully."} |
Getting all device notification details
Description | Get the details of all notifications that were pushed to the device in WSO2 EMM using this REST API. | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Resource Path | / | ||||||||||||||||||||||||
URL | /mdm-admin/notifications | ||||||||||||||||||||||||
HTTP Method | GET | ||||||||||||||||||||||||
Request/Response Format | application/json | ||||||||||||||||||||||||
cURL command | curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer <EMM_API_TOKEN>" -k -v https://<EMM_HOST>:<EMM_HTTPS_PORT>/mdm-admin/notifications
Example: curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer 33392fb365b3ac693b405b565ddc8a3a" -k -v https://localhost:9443/mdm-admin/notifications | ||||||||||||||||||||||||
Sample output | > GET /mdm-admin/notifications/ HTTP/1.1 > Host: localhost:9443 > User-Agent: curl/7.43.0 > Accept: */* > Content-Type: application/json > Authorization: Bearer 8e6ecc18eeec1c4f161e442aa2033146 > < HTTP/1.1 200 OK < Cache-Control: private < Expires: Thu, 01 Jan 1970 05:30:00 IST < Date: Fri, 11 Mar 2016 10:22:38 GMT < Content-Type: application/json < Content-Length: 288 < Server: WSO2 Carbon Server [{"notificationId":3,"deviceIdentifier":{"id":"359298055243973","type":"android"},"description":"Please update your user password","operationId":4,"status":"NEW"},{"notificationId":4,"deviceIdentifier":{"id":"359298055243973","type":"android"},"description":"Alarm operation failed.","operationId":5,"status":"NEW"}] | ||||||||||||||||||||||||
Sample JSON output Definition | { "notificationId":4, "deviceIdentifier":{ "id":"359298055243973", "type":"android" }, "description":"Alarm operation failed.", "operationId":5, "status":"NEW" }
|
Getting device notifications filtered by the status
Description | Get the details of all the unread notifications or the details of all the read notifications using this REST API. | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Resource Path | /{status} | ||||||||||||||||||||||||
URL | /mdm-admin/notifications/{status} | ||||||||||||||||||||||||
HTTP Method | POST | ||||||||||||||||||||||||
Request/Response Format | application/json | ||||||||||||||||||||||||
cURL command | curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer <EMM_API_TOKEN>" -k -v https://<EMM_HOST>:<EMM_HTTPS_PORT>/mdm-admin/notifications/{status}
Example: curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer 33392fb365b3ac693b405b565ddc8a3a" -k -v https://localhost:9443/mdm-admin/notifications/CHECKED | ||||||||||||||||||||||||
Sample output | > GET /mdm-admin/notifications/CHECKED HTTP/1.1 > Host: localhost:9443 > User-Agent: curl/7.43.0 > Accept: */* > Content-Type: application/json > Authorization: Bearer c5e2952bd8da8c7d73c68aa92573f3ea > < HTTP/1.1 200 OK < Cache-Control: private < Expires: Thu, 01 Jan 1970 05:30:00 IST < Date: Fri, 11 Mar 2016 11:44:24 GMT < Content-Type: application/json < Content-Length: 296 < Server: WSO2 Carbon Server [{"notificationId":3,"deviceIdentifier":{"id":"359298055243973","type":"android"},"description":"Update the user password","operationId":4,"status":"CHECKED"},{"notificationId":6,"deviceIdentifier":{"id":"359298055243973","type":"android"},"description":"Alarm operation failed.","operationId":5,"status":"CHECKED"}] | ||||||||||||||||||||||||
Sample JSON output Definition | { "notificationId":4, "deviceIdentifier":{ "id":"359298055243973", "type":"android" }, "description":"Alarm operation failed.", "operationId":5, "status":"CHECKED" }
|