diff options
author | Jeremy Daer <jeremydaer@gmail.com> | 2016-03-23 13:24:44 -0700 |
---|---|---|
committer | Jeremy Daer <jeremydaer@gmail.com> | 2016-03-23 13:24:44 -0700 |
commit | 09e30d9ada55636e3d96b16901d1164a78cec2dd (patch) | |
tree | 414e23db5728be3ccc8fb2ae3380d73ad2da8204 /actioncable/lib | |
parent | baf8f8eb586e4117e89453e1d2ad8eef7d5f163e (diff) | |
parent | 4f8a8e2c065e4db1f4df0df2fd75338154c6be07 (diff) | |
download | rails-09e30d9ada55636e3d96b16901d1164a78cec2dd.tar.gz rails-09e30d9ada55636e3d96b16901d1164a78cec2dd.tar.bz2 rails-09e30d9ada55636e3d96b16901d1164a78cec2dd.zip |
Merge pull request #24259 from jeremy/cable/disconnected-client-errors
Cable: Gracefully handle disconnected clients
Diffstat (limited to 'actioncable/lib')
3 files changed, 4 insertions, 1 deletions
diff --git a/actioncable/lib/action_cable/connection/client_socket.rb b/actioncable/lib/action_cable/connection/client_socket.rb index 9e4dbcd6e6..7d6de78582 100644 --- a/actioncable/lib/action_cable/connection/client_socket.rb +++ b/actioncable/lib/action_cable/connection/client_socket.rb @@ -71,6 +71,8 @@ module ActionCable def write(data) @stream.write(data) + rescue => e + emit_error e.message end def transmit(message) diff --git a/actioncable/lib/action_cable/connection/faye_client_socket.rb b/actioncable/lib/action_cable/connection/faye_client_socket.rb index c9139b6858..47d09a9e14 100644 --- a/actioncable/lib/action_cable/connection/faye_client_socket.rb +++ b/actioncable/lib/action_cable/connection/faye_client_socket.rb @@ -36,6 +36,7 @@ module ActionCable @faye.on(:open) { |event| @event_target.on_open } @faye.on(:message) { |event| @event_target.on_message(event.data) } @faye.on(:close) { |event| @event_target.on_close(event.reason, event.code) } + @faye.on(:error) { |event| @event_target.on_error(event.message) } end end end diff --git a/actioncable/lib/action_cable/connection/stream.rb b/actioncable/lib/action_cable/connection/stream.rb index 2d97b28c09..0cf59091bc 100644 --- a/actioncable/lib/action_cable/connection/stream.rb +++ b/actioncable/lib/action_cable/connection/stream.rb @@ -29,7 +29,7 @@ module ActionCable def write(data) return @rack_hijack_io.write(data) if @rack_hijack_io return @stream_send.call(data) if @stream_send - rescue EOFError + rescue EOFError, Errno::ECONNRESET @socket_object.client_gone end |