Exception: Ably::Models::PushChannelSubscription

Inherits:
Exceptions::BaseAblyException show all
Includes:
Ably::Modules::ModelCommon
Defined in:
lib/ably/models/push_channel_subscription.rb

Overview

Contains the subscriptions of a device, or a group of devices sharing the same clientId, has to a channel in order to receive push notifications.

Instance Attribute Summary

Attributes included from Ably::Modules::ModelCommon

#hash

Attributes inherited from Exceptions::BaseAblyException

#code, #message, #request_id, #status

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Ably::Modules::ModelCommon

#==, #[], #as_json, included, #to_json, #to_s

Methods included from Ably::Modules::MessagePack

#to_msgpack

Methods inherited from Exceptions::BaseAblyException

#as_json, #to_s

Constructor Details

#initialize(hash_object = {}) ⇒ PushChannelSubscription

Returns a new instance of PushChannelSubscription.

Parameters:

  • hash_object (Hash, nil) (defaults to: {})

    Device detail attributes



30
31
32
33
34
35
36
37
38
39
40
41
42
43
# File 'lib/ably/models/push_channel_subscription.rb', line 30

def initialize(hash_object = {})
  @raw_hash_object = hash_object || {}
  @hash_object     = IdiomaticRubyWrapper(hash_object)

  if !attributes[:client_id] && !attributes[:device_id]
    raise ArgumentError, 'Either client_id or device_id must be provided'
  end
  if attributes[:client_id] && attributes[:device_id]
    raise ArgumentError, 'client_id and device_id cannot both be provided, they are mutually exclusive'
  end
  if !attributes[:channel]
    raise ArgumentError, 'channel is required'
  end
end

Class Method Details

.for_client_id(channel, client_id) ⇒ PushChannelSubscription

A static factory method to create a PushChannelSubscription object for a channel and group of devices sharing the same clientId.

Parameters:

  • channel (String)

    the realtime pub/sub channel this subscription is registered to

  • client_id (String)

    Client ID that is assigned to one or more registered push devices

Returns:

  • (PushChannelSubscription)

Specification:

  • PSC5



67
68
69
# File 'lib/ably/models/push_channel_subscription.rb', line 67

def self.for_client_id(channel, client_id)
  PushChannelSubscription.new(channel: channel, client_id: client_id)
end

.for_device(channel, device_id) ⇒ PushChannelSubscription

A static factory method to create a PushChannelSubscription object for a channel and single device.

Parameters:

  • channel (String)

    the realtime pub/sub channel this subscription is registered to

  • device_id (String)

    Unique device identifier assigned to the push device

Returns:

  • (PushChannelSubscription)

Specification:

  • PSC5



54
55
56
# File 'lib/ably/models/push_channel_subscription.rb', line 54

def self.for_device(channel, device_id)
  PushChannelSubscription.new(channel: channel, device_id: device_id)
end

Instance Method Details

#attributesObject



110
111
112
# File 'lib/ably/models/push_channel_subscription.rb', line 110

def attributes
  @hash_object
end

#channelString

The channel the push notification subscription is for.

Returns:

  • (String)

Specification:

  • PCS4



77
78
79
# File 'lib/ably/models/push_channel_subscription.rb', line 77

def channel
  attributes[:channel]
end

#client_idString

The ID of the client the device, or devices are associated to.

Returns:

  • (String)

Specification:

  • PCS3, PCS6



87
88
89
# File 'lib/ably/models/push_channel_subscription.rb', line 87

def client_id
  attributes[:client_id]
end

#device_idString

The unique ID of the device.

Returns:

  • (String)

Specification:

  • PCS2, PCS5, PCS6



97
98
99
# File 'lib/ably/models/push_channel_subscription.rb', line 97

def device_id
  attributes[:device_id]
end