aboutsummaryrefslogtreecommitdiffstats
path: root/actioncable
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2015-12-15 16:38:25 +0100
committerDavid Heinemeier Hansson <david@loudthinking.com>2015-12-15 16:38:25 +0100
commit5b56abb27be4f3524f96d3d04585178f3df459d7 (patch)
tree7045136d0463f870b715fed94b4889661d6dc267 /actioncable
parenta8db0328a5452130b87b568b66fbd125eb10d45d (diff)
parent8625518725575de5524405b264d901b691fce066 (diff)
downloadrails-5b56abb27be4f3524f96d3d04585178f3df459d7.tar.gz
rails-5b56abb27be4f3524f96d3d04585178f3df459d7.tar.bz2
rails-5b56abb27be4f3524f96d3d04585178f3df459d7.zip
Merge pull request #22600 from javan/update-action-cable
Bring latest changes over from actioncable/master
Diffstat (limited to 'actioncable')
-rw-r--r--actioncable/README.md6
-rw-r--r--actioncable/lib/assets/javascripts/cable.coffee.erb13
2 files changed, 15 insertions, 4 deletions
diff --git a/actioncable/README.md b/actioncable/README.md
index 1781e3e82e..aa771f52c0 100644
--- a/actioncable/README.md
+++ b/actioncable/README.md
@@ -91,7 +91,7 @@ The client-side needs to setup a consumer instance of this connection. That's do
#= require cable
@App = {}
-App.cable = Cable.createConsumer "ws://cable.example.com"
+App.cable = Cable.createConsumer("ws://cable.example.com")
```
The ws://cable.example.com address must point to your set of Action Cable servers, and it
@@ -402,7 +402,7 @@ bundle exec puma -p 28080 cable/config.ru
```
The above will start a cable server on port 28080. Remember to point your client-side setup against that using something like:
-`App.cable.createConsumer('ws://basecamp.dev:28080')`.
+`App.cable = Cable.createConsumer("ws://basecamp.dev:28080")`.
### In app
@@ -415,7 +415,7 @@ Example::Application.routes.draw do
end
```
-You can use `App.cable.createConsumer('ws://' + window.location.host + '/websocket')` to connect to the cable server.
+You can use `App.cable = Cable.createConsumer("/websocket")` to connect to the cable server.
For every instance of your server you create and for every worker your server spawns, you will also have a new instance of ActionCable, but the use of Redis keeps messages synced across connections.
diff --git a/actioncable/lib/assets/javascripts/cable.coffee.erb b/actioncable/lib/assets/javascripts/cable.coffee.erb
index 25a9fc79c2..a722f27ac1 100644
--- a/actioncable/lib/assets/javascripts/cable.coffee.erb
+++ b/actioncable/lib/assets/javascripts/cable.coffee.erb
@@ -5,8 +5,19 @@
INTERNAL: <%= ActionCable::INTERNAL.to_json %>
createConsumer: (url = @getConfig("url")) ->
- new Cable.Consumer url
+ new Cable.Consumer @createWebSocketURL(url)
getConfig: (name) ->
element = document.head.querySelector("meta[name='action-cable-#{name}']")
element?.getAttribute("content")
+
+ createWebSocketURL: (url) ->
+ if url and not /^wss?:/i.test(url)
+ a = document.createElement("a")
+ a.href = url
+ # Fix populating Location properties in IE. Otherwise, protocol will be blank.
+ a.href = a.href
+ a.protocol = a.protocol.replace("http", "ws")
+ a.href
+ else
+ url