Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
84ed1397
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
84ed1397
编写于
6月 25, 2015
作者:
J
Javan Makhmali
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Cable.Consumer
上级
fa0281ae
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
36 addition
and
31 deletion
+36
-31
lib/assets/javascripts/cable.js.coffee
lib/assets/javascripts/cable.js.coffee
+5
-16
lib/assets/javascripts/cable/connection.js.coffee
lib/assets/javascripts/cable/connection.js.coffee
+6
-6
lib/assets/javascripts/cable/connection_monitor.js.coffee
lib/assets/javascripts/cable/connection_monitor.js.coffee
+3
-3
lib/assets/javascripts/cable/consumer.js.coffee
lib/assets/javascripts/cable/consumer.js.coffee
+16
-0
lib/assets/javascripts/cable/subscriber_manager.js.coffee
lib/assets/javascripts/cable/subscriber_manager.js.coffee
+2
-2
lib/assets/javascripts/cable/subscription.js.coffee
lib/assets/javascripts/cable/subscription.js.coffee
+4
-4
未找到文件。
lib/assets/javascripts/cable.js.coffee
浏览文件 @
84ed1397
#= require_self
#= require cable/subscriber_manager
#= require cable/connection
#= require cable/subscription
#= require cable/consumer
class
@
Cable
@
PING_IDENTIFIER
:
"_ping"
@
Cable
=
PING_IDENTIFIER
:
"_ping"
constructor
:
(
@
url
)
->
@
subscribers
=
new
Cable
.
SubscriberManager
this
@
connection
=
new
Cable
.
Connection
this
createSubscription
:
(
channelName
,
mixin
)
->
channel
=
channelName
params
=
if
typeof
channel
is
"object"
then
channel
else
{
channel
}
new
Cable
.
Subscription
this
,
params
,
mixin
send
:
(
data
)
->
@
connection
.
send
(
data
)
createConsumer
:
(
url
)
->
new
Cable
.
Consumer
url
lib/assets/javascripts/cable/connection.js.coffee
浏览文件 @
84ed1397
#= require cable/connection_monitor
class
Cable
.
Connection
constructor
:
(
@
c
able
)
->
new
Cable
.
ConnectionMonitor
@
c
able
constructor
:
(
@
c
onsumer
)
->
new
Cable
.
ConnectionMonitor
@
c
onsumer
@
connect
()
send
:
(
data
)
->
...
...
@@ -17,7 +17,7 @@ class Cable.Connection
@
createWebSocket
()
createWebSocket
:
->
@
websocket
=
new
WebSocket
(
@
c
able
.
url
)
@
websocket
=
new
WebSocket
(
@
c
onsumer
.
url
)
@
websocket
.
onmessage
=
@
onMessage
@
websocket
.
onopen
=
@
onConnect
@
websocket
.
onclose
=
@
onClose
...
...
@@ -33,10 +33,10 @@ class Cable.Connection
onMessage
:
(
message
)
=>
data
=
JSON
.
parse
message
.
data
@
c
able
.
subscribers
.
notify
(
data
.
identifier
,
"received"
,
data
.
message
)
@
c
onsumer
.
subscribers
.
notify
(
data
.
identifier
,
"received"
,
data
.
message
)
onConnect
:
=>
@
c
able
.
subscribers
.
reload
()
@
c
onsumer
.
subscribers
.
reload
()
onClose
:
=>
@
disconnect
()
...
...
@@ -48,5 +48,5 @@ class Cable.Connection
@
websocket
?
.
readyState
is
1
disconnect
:
->
@
c
able
.
subscribers
.
notifyAll
(
"disconnected"
)
@
c
onsumer
.
subscribers
.
notifyAll
(
"disconnected"
)
@
removeWebsocket
()
lib/assets/javascripts/cable/connection_monitor.js.coffee
浏览文件 @
84ed1397
...
...
@@ -4,9 +4,9 @@ class Cable.ConnectionMonitor
identifier
:
Cable
.
PING_IDENTIFIER
constructor
:
(
@
c
able
)
->
constructor
:
(
@
c
onsumer
)
->
@
reset
()
@
c
able
.
subscribers
.
add
(
this
)
@
c
onsumer
.
subscribers
.
add
(
this
)
@
pollConnection
()
connected
:
->
...
...
@@ -35,7 +35,7 @@ class Cable.ConnectionMonitor
reconnect
:
->
console
.
log
"Ping took too long to arrive. Reconnecting.."
@
connectionAttempts
+=
1
@
c
able
.
connection
.
connect
()
@
c
onsumer
.
connection
.
connect
()
now
=
->
new
Date
().
getTime
()
lib/assets/javascripts/cable/consumer.js.coffee
0 → 100644
浏览文件 @
84ed1397
#= require cable/connection
#= require cable/subscription
#= require cable/subscriber_manager
class
Cable
.
Consumer
constructor
:
(
@
url
)
->
@
subscribers
=
new
Cable
.
SubscriberManager
this
@
connection
=
new
Cable
.
Connection
this
createSubscription
:
(
channelName
,
mixin
)
->
channel
=
channelName
params
=
if
typeof
channel
is
"object"
then
channel
else
{
channel
}
new
Cable
.
Subscription
this
,
params
,
mixin
send
:
(
data
)
->
@
connection
.
send
(
data
)
lib/assets/javascripts/cable/subscriber_manager.js.coffee
浏览文件 @
84ed1397
class
Cable
.
SubscriberManager
constructor
:
(
@
c
able
)
->
constructor
:
(
@
c
onsumer
)
->
@
subscribers
=
[]
add
:
(
subscriber
)
->
...
...
@@ -33,4 +33,4 @@ class Cable.SubscriberManager
sendCommand
:
(
subscriber
,
command
)
->
{
identifier
}
=
subscriber
return
true
if
identifier
is
Cable
.
PING_IDENTIFIER
@
c
able
.
send
({
command
,
identifier
})
@
c
onsumer
.
send
({
command
,
identifier
})
lib/assets/javascripts/cable/subscription.js.coffee
浏览文件 @
84ed1397
class
Cable
.
Subscription
constructor
:
(
@
c
able
,
params
=
{},
mixin
)
->
constructor
:
(
@
c
onsumer
,
params
=
{},
mixin
)
->
@
identifier
=
JSON
.
stringify
(
params
)
extend
(
this
,
mixin
)
@
c
able
.
subscribers
.
add
(
this
)
@
c
onsumer
.
subscribers
.
add
(
this
)
# Perform a channel action with the optional data passed as an attribute
perform
:
(
action
,
data
=
{})
->
...
...
@@ -10,10 +10,10 @@ class Cable.Subscription
@
send
(
data
)
send
:
(
data
)
->
@
c
able
.
send
(
command
:
"message"
,
identifier
:
@
identifier
,
data
:
JSON
.
stringify
(
data
))
@
c
onsumer
.
send
(
command
:
"message"
,
identifier
:
@
identifier
,
data
:
JSON
.
stringify
(
data
))
unsubscribe
:
->
@
c
able
.
subscribers
.
remove
(
this
)
@
c
onsumer
.
subscribers
.
remove
(
this
)
extend
=
(
object
,
properties
)
->
if
properties
?
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录