Push Notifications - Admin
Push Admin object
This object is accessible through client.push.admin
and provides:
Methods
publish
publish(Object recipient, Object data, callback(ErrorInfo err))
Publishes a push notification directly to a device or group of devices sharing a client identifier. See the push notification direct publishing documentation for more information.
Parameters
- recipient
- an object containing the push recipient details. See the push notification publish REST API documentation for details on the supported recipient fields
- data
- an object containing the push notification data. See the push admin payload structure for details on the supported push payload fields
Push Admin Properties
The push admin object exposes the following public properties:
deviceRegistrations
The returned DeviceRegistrations
object provides functionality for registering, updating, listing and de-registering push devices.
channelSubscriptions
The returned PushChannelSubscriptions
object provides functionality for subscribing, listing and unsubscribing individual devices or groups of identified devices to push notifications published on channels.
DeviceRegistrations object
This object is accessible through client.push.admin.deviceRegistrations
and provides an API to register new push notification devices, update existing devices, deregister old devices, and retrieve or list devices registered to an app.
Methods
get
get(String deviceId, callback(ErrorInfo err, DeviceDetails device))
get(DeviceDetails device, callback(ErrorInfo err, DeviceDetails device))
Obtain the DeviceDetails
for a device registered for receiving push registrations matching the deviceId
argument, or the id
attribute of the provided DeviceDetails
object. Requires push-admin
permission or push-subscribe
permission together with device authentication matching the requested deviceId
.
Parameters
- deviceId
- the unique device ID String for the requested device
- device
- a
DeviceDetails
object containing at a minimum thedeviceId
of the requested device
list
list(Object params, callback(ErrorInfo err, PaginatedResult<DeviceDetails device> resultPage))
Retrieve all devices matching the params filter as a paginated list of DeviceDetails
objects. Requires push-admin
permission.
Parameters
- params
- an object containing the query parameters as key value pairs as specified below.
params
properties
- clientId
- optional filter to restrict to devices associated with that client identifier. Cannot be used with a
deviceId
paramType:String
- deviceId
- optional filter to restrict to devices associated with that device identifier. Cannot be used with a
clientId
paramType:String
- limit
- 100 maximum number of devices per page to retrieve, up to 1,000Type:
Integer
save
save(DeviceDetails device, callback(ErrorInfo err, DeviceDetails device))
Register a new DeviceDetails
object, or update an existing DeviceDetails
object with the Ably service. Requires push-admin
permission or push-subscribe
permission together with device authentication matching the requested deviceId
.
Parameters
- device
- a
DeviceDetails
object
remove
remove(String deviceId, callback(ErrorInfo err))
remove(DeviceDetails device, callback(ErrorInfo err))
Remove a device registered for receiving push registrations that matches the deviceId
argument, or the id
attribute of the provided DeviceDetails
object. Requires push-admin
permission or push-subscribe
permission together with device authentication matching the requested deviceId
.
Parameters
- deviceId
- the unique device ID String for the device
- device
- a
DeviceDetails
object containing at a minimum thedeviceId
of the device
removeWhere
removeWhere(Object params, callback(ErrorInfo err))
Delete all devices matching the params filter. Requires push-admin
permission.
Parameters
- params
- an object containing the filter parameters as key value pairs as specified below.
params
properties
- clientId
- optional filter to restrict to devices associated with that client identifier. Cannot be used with a
deviceId
paramType:String
- deviceId
- optional filter to restrict to devices associated with that device identifier. Cannot be used with a
clientId
paramType:String
PushChannelSubscriptions object
This object is accessible through client.push.admin.channelSubscriptions
and provides an API to subscribe a push notification device to a channel ensuring it receives any push notifications published in the future on that channel. Additionally, this object allows these subscriptions to be retrieved, listed, updated or removed.
Methods
list
list(Object params, callback(ErrorInfo err, PaginatedResult<PushChannelSubscription> resultPage))
Retrieve all push channel subscriptions that match the provided params filter as a paginated list of PushChannelSubscription
objects. Each PushChannelSubscription
represents a device or set of devices sharing the same client identifier registered to a channel to receive push notifications.
Parameters
- params
- an object containing the query parameters as key value pairs as specified below.
params
properties
- channel
- filter to restrict to subscriptions associated with that
channel
- clientId
- optional filter to restrict to devices associated with that client identifier. Cannot be used with a
deviceId
paramType:String
- deviceId
- optional filter to restrict to devices associated with that device identifier. Cannot be used with a
clientId
paramType:String
- limit
- 100 maximum number of channel subscriptions per page to retrieve, up to 1,000Type:
Integer
listChannels
listChannels(Object params, callback(ErrorInfo err, PaginatedResult<String> resultPage))
Retrieve a list of channels with at least one subscribed device as a paginated list of channel name String
objects. Requires push-admin
permission.
Parameters
- params
- an object containing the query parameters as key value pairs as specified below.
params
properties
- limit
- 100 maximum number of channels per page to retrieve, up to 1,000Type:
Integer
save
save(PushChannelSubscription channelSubscription, callback(ErrorInfo err, PushChannelSubscription channelSubscription))
Subscribe a device or group of devices sharing a client identifier for push notifications published on a channel.
Parameters
- channelSubscription
- a
PushChannelSubscription
object
remove
remove(PushChannelSubscription channelSubscription, callback(ErrorInfo err))
Unsubscribe a device or group of devices sharing a client identifier from push notifications on a channel. Requires push-admin
permission or, in the case of a subscription associated with a given deviceId
, push-subscribe
permission together with device authentication matching that deviceId
.
Parameters
- channelSubscription
- a
PushChannelSubscription
object
removeWhere
removeWhere(Object params, callback(ErrorInfo err))
Delete all push channel subscriptions matching the params
filter. Requires push-admin
permission.
Parameters
- params
- an object containing the filter parameters as key value pairs as specified below.
params
properties
- channel
- filter to restrict to subscriptions associated with that
channel
- clientId
- optional filter to restrict to devices associated with that client identifier. Cannot be used with
deviceId
paramType:String
- deviceId
- optional filter to restrict to devices associated with that device identifier. Cannot be used with
clientId
paramType:String
Related types
DeviceDetails
A DeviceDetails
is a type encapsulating attributes of a device registered for push notifications.
Properties
- id
- unique identifier for the device generated by the device itselfType:
String
- clientId
- optional trusted client identifier for the deviceType:
String
- formFactor
- form factor of the push device. Must be one of
phone
,tablet
,desktop
,tv
,watch
,car
orembedded
Type:String
- metadata
- optional metadata object for this device. The metadata for a device may only be set by clients with
push-admin
privilegesType:Object
- platform
- platform of the push device. Must be one of
ios
orandroid
Type:String
- deviceSecret
- Secret value for the device.Type:
String
- push.recipient
- push recipient details for this device. See the REST API push publish documentation for more detailsType:
Object
- push.state
- the current state of the push device being either
Active
,Failing
orFailed
Type:String
- push.errorReason
- when the device’s state is failing or failed, this attribute contains the reason for the most recent failureType:
ErrorInfo
PushChannelSubscription
An PushChannelSubscription
is a type encapsulating the subscription of a device or group of devices sharing a client identifier to a channel in order to receive push notifications.
Properties
- channel
- the channel that this push notification subscription is associated withType:
String
- deviceId
- the device with this identifier is linked to this channel subscription. When present,
clientId
is never presentType:String
- clientId
- devices with this client identifier are included in this channel subscription. When present,
deviceId
is never presentType:String
PushChannelSubscription constructors
PushChannelSubscription.forDevice
PushChannelSubscription.forDevice(String channel, String deviceId) → PushChannelSubscription
A static factory method to create a PushChannelSubscription
object for a channel and single device.
Parameters
- channel
- channel name linked to this push channel subscriptionType:
String
- deviceId
- the device with this identifier will be linked with this push channel subscriptionType:
String
Returns
A PushChannelSubscription
object
PushChannelSubscription.forClient
PushChannelSubscription.forClient(String channel, String clientId) → PushChannelSubscription
A static factory method to create a PushChannelSubscription
object for a channel and group of devices sharing a client identifier.
Parameters
- channel
- channel name linked to this push channel subscriptionType:
String
- clientId
- devices with this client identifier are included in the new push channel subscriptionType:
String
Returns
A PushChannelSubscription
object
PushChannel
PaginatedResult
A PaginatedResult
is a type that represents a page of results for all message and presence history, stats and REST presence requests. The response from a Ably REST API paginated query is accompanied by metadata that indicates the relative queries available to the PaginatedResult
object.
Properties
- items
- contains the current page of results (for example an Array of
Message
orPresenceMessage
objects for a channel history request)Type:Array <Message, Presence, Stats>
Methods
first
first(callback(ErrorInfo err, PaginatedResult resultPage))
Returns a new PaginatedResult
for the first page of results.
hasNext
Boolean hasNext()
Returns true
if there are more pages available by calling next
and returns false
if this page is the last page available.
isLast
Boolean isLast()
Returns true
if this page is the last page and returns false
if there are more pages available by calling next
available.
next
next(callback(ErrorInfo err, PaginatedResult resultPage))
Returns a new PaginatedResult
loaded with the next page of results. If there are no further pages, then null
is returned.
Example
channel.history(function(err, paginatedResult) {
console.log('Page 0 item 0:' + paginatedResult.items[0].data);
paginatedResult.next(function(err, nextPage) {
console.log('Page 1 item 1: ' + nextPage.items[1].data);
console.log('Last page?: ' + nextPage.isLast());
});
});
CopyCopied!