solid_cable 3.0.10 → 3.0.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/action_cable/subscription_adapter/solid_cable.rb +23 -6
- data/lib/solid_cable/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2bb120f549ab39af171e93f67350d0ca6b44d2d43e42e23d538c74f894a8e4d4
|
4
|
+
data.tar.gz: 13404708ae736ed703e80623b0b8496bbaca984cee263a97818951abb94fe35c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5fc3825837aa2ee2ff4e805e40a45a2c19471576f91d0f9a0603fdb679542e2a473dd2797cd2a0bf795785ea65d713b01c2c3d0f2ef3bdcdba100608a3cf6115
|
7
|
+
data.tar.gz: 1b9474761a35f8aa38063128b6c4fb3a9c30ae94b995e80d1f17eb590cf47ff84f684f557328448d8cc4aa2a26ba509b9b6c32f7ad179d140f9cc23cccca94e9
|
@@ -52,6 +52,9 @@ module ActionCable
|
|
52
52
|
@critical = Concurrent::Semaphore.new(0)
|
53
53
|
|
54
54
|
@thread = Thread.new do
|
55
|
+
Thread.current.name = "solid_cable_listener"
|
56
|
+
Thread.current.report_on_exception = true
|
57
|
+
|
55
58
|
listen
|
56
59
|
end
|
57
60
|
end
|
@@ -103,23 +106,37 @@ module ActionCable
|
|
103
106
|
|
104
107
|
private
|
105
108
|
attr_reader :event_loop, :thread
|
109
|
+
attr_writer :last_id
|
110
|
+
|
111
|
+
def last_id
|
112
|
+
@last_id ||= last_message_id
|
113
|
+
end
|
106
114
|
|
107
115
|
def last_message_id
|
108
116
|
::SolidCable::Message.maximum(:id) || 0
|
109
117
|
end
|
110
118
|
|
111
119
|
def channels
|
112
|
-
@channels ||= Concurrent::
|
120
|
+
@channels ||= Concurrent::Map.new
|
113
121
|
end
|
114
122
|
|
115
123
|
def broadcast_messages
|
116
|
-
|
124
|
+
current_channels = channels.dup
|
125
|
+
|
126
|
+
::SolidCable::Message.
|
127
|
+
broadcastable(current_channels.keys, last_id).
|
117
128
|
each do |message|
|
118
|
-
|
119
|
-
|
120
|
-
|
129
|
+
should_broadcast_message = false
|
130
|
+
channels.compute_if_present(message.channel) do |channel_last_id|
|
131
|
+
break if channel_last_id >= message.id
|
132
|
+
|
133
|
+
should_broadcast_message = true
|
134
|
+
message.id
|
135
|
+
end
|
136
|
+
|
137
|
+
broadcast(message.channel, message.payload) if should_broadcast_message
|
138
|
+
self.last_id = message.id
|
121
139
|
end
|
122
|
-
end
|
123
140
|
end
|
124
141
|
|
125
142
|
def with_polling_volume
|
data/lib/solid_cable/version.rb
CHANGED