aboutsummaryrefslogtreecommitdiffstats
path: root/lib/assets/javascripts/cable/subscriptions.coffee
diff options
context:
space:
mode:
authorPratik <pratiknaik@gmail.com>2015-11-04 17:43:31 -0600
committerPratik <pratiknaik@gmail.com>2015-11-04 17:43:31 -0600
commitde64aa3440f85b74692b61f7e46a14a1a7003e56 (patch)
tree8ebac494bc23e5248558dbcabff0cc62ba48cc49 /lib/assets/javascripts/cable/subscriptions.coffee
parent7c1631fa48b8862f37d1026b4f0cf1061dd6947a (diff)
parent1ce0e66f090631f5113cb844be32b2b7fe4dc88e (diff)
downloadrails-de64aa3440f85b74692b61f7e46a14a1a7003e56.tar.gz
rails-de64aa3440f85b74692b61f7e46a14a1a7003e56.tar.bz2
rails-de64aa3440f85b74692b61f7e46a14a1a7003e56.zip
Merge pull request #102 from rails/subscription-rejection
Allow rejecting subscriptions from the channel
Diffstat (limited to 'lib/assets/javascripts/cable/subscriptions.coffee')
-rw-r--r--lib/assets/javascripts/cable/subscriptions.coffee21
1 files changed, 15 insertions, 6 deletions
diff --git a/lib/assets/javascripts/cable/subscriptions.coffee b/lib/assets/javascripts/cable/subscriptions.coffee
index 4efb384ee2..13db32eb2c 100644
--- a/lib/assets/javascripts/cable/subscriptions.coffee
+++ b/lib/assets/javascripts/cable/subscriptions.coffee
@@ -23,18 +23,27 @@ class Cable.Subscriptions
@notify(subscription, "initialized")
@sendCommand(subscription, "subscribe")
- reload: ->
- for subscription in @subscriptions
- @sendCommand(subscription, "subscribe")
-
remove: (subscription) ->
- @subscriptions = (s for s in @subscriptions when s isnt subscription)
+ @forget(subscription)
+
unless @findAll(subscription.identifier).length
@sendCommand(subscription, "unsubscribe")
+ reject: (identifier) ->
+ for subscription in @findAll(identifier)
+ @forget(subscription)
+ @notify(subscription, "rejected")
+
+ forget: (subscription) ->
+ @subscriptions = (s for s in @subscriptions when s isnt subscription)
+
findAll: (identifier) ->
s for s in @subscriptions when s.identifier is identifier
+ reload: ->
+ for subscription in @subscriptions
+ @sendCommand(subscription, "subscribe")
+
notifyAll: (callbackName, args...) ->
for subscription in @subscriptions
@notify(subscription, callbackName, args...)
@@ -48,7 +57,7 @@ class Cable.Subscriptions
for subscription in subscriptions
subscription[callbackName]?(args...)
- if callbackName in ["initialized", "connected", "disconnected"]
+ if callbackName in ["initialized", "connected", "disconnected", "rejected"]
{identifier} = subscription
@record(notification: {identifier, callbackName, args})