---
title: NotificationsApi
---
## PureCloud::NotificationsApi
All URIs are relative to *https://api.mypurecloud.com*
Method | Description
------------- | ------------- | -------------
[**delete_notifications_channel_subscriptions**](NotificationsApi.html#delete_notifications_channel_subscriptions) | Remove all subscriptions
[**get_notifications_availabletopics**](NotificationsApi.html#get_notifications_availabletopics) | Get available notification topics.
[**get_notifications_channel_subscriptions**](NotificationsApi.html#get_notifications_channel_subscriptions) | The list of all subscriptions for this channel
[**get_notifications_channels**](NotificationsApi.html#get_notifications_channels) | The list of existing channels
[**post_notifications_channel_subscriptions**](NotificationsApi.html#post_notifications_channel_subscriptions) | Add a list of subscriptions to the existing list of subscriptions
[**post_notifications_channels**](NotificationsApi.html#post_notifications_channels) | Create a new channel
[**put_notifications_channel_subscriptions**](NotificationsApi.html#put_notifications_channel_subscriptions) | Replace the current list of subscriptions with a new list.
{: class="table table-striped"}
## delete_notifications_channel_subscriptions(channel_id)
Remove all subscriptions
Wraps DELETE /api/v2/notifications/channels/{channelId}/subscriptions
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
channel_id = "channel_id_example" # String | Channel ID
begin
#Remove all subscriptions
api_instance.delete_notifications_channel_subscriptions(channel_id)
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->delete_notifications_channel_subscriptions: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**channel_id** | **String**| Channel ID | |
{: class="table table-striped"}
### Return type
nil (empty response body)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**AvailableTopicEntityListing**](AvailableTopicEntityListing.html) get_notifications_availabletopics(opts)
Get available notification topics.
Wraps GET /api/v2/notifications/availabletopics
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
opts = {
expand: ["expand_example"] # Array | Which fields, if any, to expand
}
begin
#Get available notification topics.
result = api_instance.get_notifications_availabletopics(opts)
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->get_notifications_availabletopics: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**expand** | [**Array<String>**](String.html)| Which fields, if any, to expand | [optional]
**Values**: description, requiresPermissions, schema, transports |
{: class="table table-striped"}
### Return type
[**AvailableTopicEntityListing**](AvailableTopicEntityListing.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**ChannelTopicEntityListing**](ChannelTopicEntityListing.html) get_notifications_channel_subscriptions(channel_id)
The list of all subscriptions for this channel
Wraps GET /api/v2/notifications/channels/{channelId}/subscriptions
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
channel_id = "channel_id_example" # String | Channel ID
begin
#The list of all subscriptions for this channel
result = api_instance.get_notifications_channel_subscriptions(channel_id)
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->get_notifications_channel_subscriptions: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**channel_id** | **String**| Channel ID | |
{: class="table table-striped"}
### Return type
[**ChannelTopicEntityListing**](ChannelTopicEntityListing.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**ChannelEntityListing**](ChannelEntityListing.html) get_notifications_channels(opts)
The list of existing channels
Wraps GET /api/v2/notifications/channels
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
opts = {
includechannels: "token" # String | Show user's channels for this specific token or across all tokens for this user and app. Channel Ids for other access tokens will not be shown, but will be presented to show their existence.
}
begin
#The list of existing channels
result = api_instance.get_notifications_channels(opts)
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->get_notifications_channels: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**includechannels** | **String**| Show user's channels for this specific token or across all tokens for this user and app. Channel Ids for other access tokens will not be shown, but will be presented to show their existence. | [optional] [default to token]
**Values**: token, oauthclient |
{: class="table table-striped"}
### Return type
[**ChannelEntityListing**](ChannelEntityListing.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**ChannelTopicEntityListing**](ChannelTopicEntityListing.html) post_notifications_channel_subscriptions(channel_id, body)
Add a list of subscriptions to the existing list of subscriptions
Wraps POST /api/v2/notifications/channels/{channelId}/subscriptions
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
channel_id = "channel_id_example" # String | Channel ID
body = [PureCloud::ChannelTopic.new] # Array | Body
begin
#Add a list of subscriptions to the existing list of subscriptions
result = api_instance.post_notifications_channel_subscriptions(channel_id, body)
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->post_notifications_channel_subscriptions: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**channel_id** | **String**| Channel ID | |
**body** | [**Array<ChannelTopic>**](ChannelTopic.html)| Body | |
{: class="table table-striped"}
### Return type
[**ChannelTopicEntityListing**](ChannelTopicEntityListing.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**Channel**](Channel.html) post_notifications_channels
Create a new channel
There is a limit of 20 channels per user/app combination. Creating a 21st channel will remove the channel with oldest last used date. Channels without an active connection will be removed first.
Wraps POST /api/v2/notifications/channels
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
begin
#Create a new channel
result = api_instance.post_notifications_channels
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->post_notifications_channels: #{e}"
end
```
### Parameters
This endpoint does not need any parameter.
{: class="table table-striped"}
### Return type
[**Channel**](Channel.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json
## [**ChannelTopicEntityListing**](ChannelTopicEntityListing.html) put_notifications_channel_subscriptions(channel_id, body)
Replace the current list of subscriptions with a new list.
Wraps PUT /api/v2/notifications/channels/{channelId}/subscriptions
Requires NO permissions:
### Example
```{"language":"ruby"}
# load the gem
require 'purecloudplatformclientv2'
# setup authorization
@secret = ENV['PURECLOUD_SECRET']
@id = ENV['PURECLOUD_CLIENT_ID']
environment = "mypurecloud.com"
@authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment
PureCloud.configure do |config|
config.access_token = @authToken
end
api_instance = PureCloud::NotificationsApi.new
channel_id = "channel_id_example" # String | Channel ID
body = [PureCloud::ChannelTopic.new] # Array | Body
begin
#Replace the current list of subscriptions with a new list.
result = api_instance.put_notifications_channel_subscriptions(channel_id, body)
p result
rescue PureCloud::ApiError => e
puts "Exception when calling NotificationsApi->put_notifications_channel_subscriptions: #{e}"
end
```
### Parameters
Name | Type | Description | Notes
------------- | ------------- | ------------- | -------------
**channel_id** | **String**| Channel ID | |
**body** | [**Array<ChannelTopic>**](ChannelTopic.html)| Body | |
{: class="table table-striped"}
### Return type
[**ChannelTopicEntityListing**](ChannelTopicEntityListing.html)
### HTTP request headers
- **Content-Type**: application/json
- **Accept**: application/json