anycable 0.6.4 → 1.0.0.rc2
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/CHANGELOG.md +24 -236
- data/MIT-LICENSE +1 -1
- data/README.md +17 -16
- data/lib/anycable.rb +3 -12
- data/lib/anycable/broadcast_adapters.rb +4 -2
- data/lib/anycable/broadcast_adapters/base.rb +29 -0
- data/lib/anycable/broadcast_adapters/http.rb +130 -0
- data/lib/anycable/broadcast_adapters/redis.rb +7 -6
- data/lib/anycable/cli.rb +35 -11
- data/lib/anycable/config.rb +44 -21
- data/lib/anycable/exceptions_handling.rb +5 -7
- data/lib/anycable/health_server.rb +4 -2
- data/lib/anycable/middleware.rb +9 -1
- data/lib/anycable/middleware_chain.rb +2 -2
- data/lib/anycable/middlewares/check_version.rb +24 -0
- data/lib/anycable/rpc.rb +84 -0
- data/lib/anycable/rpc/rpc_pb.rb +57 -39
- data/lib/anycable/rpc/rpc_services_pb.rb +4 -3
- data/lib/anycable/rpc_handler.rb +44 -24
- data/lib/anycable/rspec.rb +6 -0
- data/lib/anycable/rspec/rpc_command_context.rb +20 -0
- data/lib/anycable/rspec/rpc_stub_context.rb +13 -0
- data/lib/anycable/rspec/with_grpc_server.rb +15 -0
- data/lib/anycable/server.rb +6 -62
- data/lib/anycable/socket.rb +48 -6
- data/lib/anycable/version.rb +1 -1
- metadata +21 -41
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.shared_context "anycable:rpc:server" do
|
4
|
+
before(:all) do
|
5
|
+
@server = AnyCable::Server.new(
|
6
|
+
host: AnyCable.config.rpc_host,
|
7
|
+
**AnyCable.config.to_grpc_params,
|
8
|
+
interceptors: AnyCable.middleware.to_a
|
9
|
+
)
|
10
|
+
|
11
|
+
@server.start
|
12
|
+
end
|
13
|
+
|
14
|
+
after(:all) { @server.stop }
|
15
|
+
end
|
data/lib/anycable/server.rb
CHANGED
@@ -21,51 +21,9 @@ module AnyCable
|
|
21
21
|
# # stop server
|
22
22
|
# server.stop
|
23
23
|
class Server
|
24
|
-
class << self
|
25
|
-
# rubocop:disable Metrics/AbcSize, Metrics/MethodLength
|
26
|
-
def start(**options)
|
27
|
-
warn <<~DEPRECATION
|
28
|
-
DEPRECATION WARNING: Using AnyCable::Server.start is deprecated!
|
29
|
-
Please, use anycable CLI instead.
|
30
|
-
|
31
|
-
See https://docs.anycable.io/#upgrade_to_0_6_0
|
32
|
-
DEPRECATION
|
33
|
-
|
34
|
-
AnyCable.server_callbacks.each(&:call)
|
35
|
-
|
36
|
-
server = new(
|
37
|
-
host: AnyCable.config.rpc_host,
|
38
|
-
**AnyCable.config.to_grpc_params,
|
39
|
-
interceptors: AnyCable.middleware.to_a,
|
40
|
-
**options
|
41
|
-
)
|
42
|
-
|
43
|
-
AnyCable.middleware.freeze
|
44
|
-
|
45
|
-
if AnyCable.config.http_health_port_provided?
|
46
|
-
health_server = AnyCable::HealthServer.new(
|
47
|
-
server,
|
48
|
-
**AnyCable.config.to_http_health_params
|
49
|
-
)
|
50
|
-
health_server.start
|
51
|
-
end
|
52
|
-
|
53
|
-
at_exit do
|
54
|
-
server.stop
|
55
|
-
health_server&.stop
|
56
|
-
end
|
57
|
-
|
58
|
-
AnyCable.logger.info "Broadcasting Redis channel: #{AnyCable.config.redis_channel}"
|
59
|
-
|
60
|
-
server.start
|
61
|
-
server.wait_till_terminated
|
62
|
-
end
|
63
|
-
# rubocop:enable Metrics/AbcSize, Metrics/MethodLength
|
64
|
-
end
|
65
|
-
|
66
24
|
attr_reader :grpc_server, :host
|
67
25
|
|
68
|
-
def initialize(host:, logger:
|
26
|
+
def initialize(host:, logger: nil, **options)
|
69
27
|
@logger = logger
|
70
28
|
@host = host
|
71
29
|
@grpc_server = build_server(options)
|
@@ -78,8 +36,6 @@ module AnyCable
|
|
78
36
|
|
79
37
|
raise "Cannot re-start stopped server" if stopped?
|
80
38
|
|
81
|
-
check_default_host
|
82
|
-
|
83
39
|
logger.info "RPC server is starting..."
|
84
40
|
|
85
41
|
@start_thread = Thread.new { grpc_server.run }
|
@@ -114,7 +70,11 @@ module AnyCable
|
|
114
70
|
|
115
71
|
private
|
116
72
|
|
117
|
-
attr_reader :
|
73
|
+
attr_reader :start_thread
|
74
|
+
|
75
|
+
def logger
|
76
|
+
@logger ||= AnyCable.logger
|
77
|
+
end
|
118
78
|
|
119
79
|
def build_server(options)
|
120
80
|
GRPC::RpcServer.new(**options).tap do |server|
|
@@ -132,21 +92,5 @@ module AnyCable
|
|
132
92
|
)
|
133
93
|
health_checker
|
134
94
|
end
|
135
|
-
|
136
|
-
def check_default_host
|
137
|
-
return unless host.is_a?(Anycable::Config::DefaultHostWrapper)
|
138
|
-
|
139
|
-
warn <<~DEPRECATION
|
140
|
-
DEPRECATION WARNING: You're using default rpc_host configuration which starts AnyCable RPC
|
141
|
-
server on all available interfaces including external IPv4 and IPv6.
|
142
|
-
This is about to be changed to loopback interface only in future versions.
|
143
|
-
|
144
|
-
Please, consider switching to the loopback interface or set "[::]:50051"
|
145
|
-
explicitly in your configuration, if you want to continue with the current
|
146
|
-
behavior and supress this message.
|
147
|
-
|
148
|
-
See https://docs.anycable.io/#/configuration
|
149
|
-
DEPRECATION
|
150
|
-
end
|
151
95
|
end
|
152
96
|
end
|
data/lib/anycable/socket.rb
CHANGED
@@ -3,11 +3,46 @@
|
|
3
3
|
module AnyCable
|
4
4
|
# Socket mock to be used with application connection
|
5
5
|
class Socket
|
6
|
-
|
6
|
+
# Represents the per-connection store
|
7
|
+
# (for example, used to keep session beetween RPC calls)
|
8
|
+
class State
|
9
|
+
attr_reader :dirty_keys, :source
|
10
|
+
|
11
|
+
def initialize(from)
|
12
|
+
@source = from
|
13
|
+
@dirty_keys = nil
|
14
|
+
end
|
15
|
+
|
16
|
+
def read(key)
|
17
|
+
source&.[](key)
|
18
|
+
end
|
19
|
+
|
20
|
+
alias [] read
|
21
|
+
|
22
|
+
def write(key, val)
|
23
|
+
return if source&.[](key) == val
|
24
|
+
|
25
|
+
@source ||= {}
|
26
|
+
@dirty_keys ||= []
|
27
|
+
dirty_keys << key
|
28
|
+
source[key] = val
|
29
|
+
end
|
30
|
+
|
31
|
+
alias []= write
|
32
|
+
|
33
|
+
def changed_fields
|
34
|
+
return unless source && dirty_keys
|
35
|
+
source.slice(*dirty_keys)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
attr_reader :transmissions, :env, :cstate, :istate
|
7
40
|
|
8
41
|
def initialize(env: nil)
|
9
42
|
@transmissions = []
|
10
43
|
@env = env
|
44
|
+
@cstate = env["anycable.cstate"] = State.new(env["anycable.raw_cstate"])
|
45
|
+
@istate = env["anycable.istate"] = State.new(env["anycable.raw_istate"])
|
11
46
|
end
|
12
47
|
|
13
48
|
def transmit(websocket_message)
|
@@ -15,11 +50,11 @@ module AnyCable
|
|
15
50
|
end
|
16
51
|
|
17
52
|
def subscribe(_channel, broadcasting)
|
18
|
-
streams << broadcasting
|
53
|
+
streams[:start] << broadcasting
|
19
54
|
end
|
20
55
|
|
21
|
-
def unsubscribe(_channel,
|
22
|
-
|
56
|
+
def unsubscribe(_channel, broadcasting)
|
57
|
+
streams[:stop] << broadcasting
|
23
58
|
end
|
24
59
|
|
25
60
|
def unsubscribe_from_all(_channel)
|
@@ -27,12 +62,11 @@ module AnyCable
|
|
27
62
|
end
|
28
63
|
|
29
64
|
def streams
|
30
|
-
@streams ||= []
|
65
|
+
@streams ||= {start: [], stop: []}
|
31
66
|
end
|
32
67
|
|
33
68
|
def close
|
34
69
|
@closed = true
|
35
|
-
@transmissions.clear
|
36
70
|
@streams&.clear
|
37
71
|
@stop_all_streams = true
|
38
72
|
end
|
@@ -44,5 +78,13 @@ module AnyCable
|
|
44
78
|
def stop_streams?
|
45
79
|
@stop_all_streams == true
|
46
80
|
end
|
81
|
+
|
82
|
+
def session
|
83
|
+
cstate.read(SESSION_KEY)
|
84
|
+
end
|
85
|
+
|
86
|
+
def session=(val)
|
87
|
+
cstate.write(SESSION_KEY, val)
|
88
|
+
end
|
47
89
|
end
|
48
90
|
end
|
data/lib/anycable/version.rb
CHANGED
metadata
CHANGED
@@ -1,27 +1,27 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: anycable
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 1.0.0.rc2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- palkan
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-
|
11
|
+
date: 2020-06-24 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: anyway_config
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- - "
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
19
|
version: 1.4.2
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- - "
|
24
|
+
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: 1.4.2
|
27
27
|
- !ruby/object:Gem::Dependency
|
@@ -72,14 +72,14 @@ dependencies:
|
|
72
72
|
requirements:
|
73
73
|
- - ">="
|
74
74
|
- !ruby/object:Gem::Version
|
75
|
-
version: '
|
75
|
+
version: '13.0'
|
76
76
|
type: :development
|
77
77
|
prerelease: false
|
78
78
|
version_requirements: !ruby/object:Gem::Requirement
|
79
79
|
requirements:
|
80
80
|
- - ">="
|
81
81
|
- !ruby/object:Gem::Version
|
82
|
-
version: '
|
82
|
+
version: '13.0'
|
83
83
|
- !ruby/object:Gem::Dependency
|
84
84
|
name: rack
|
85
85
|
requirement: !ruby/object:Gem::Requirement
|
@@ -109,47 +109,19 @@ dependencies:
|
|
109
109
|
- !ruby/object:Gem::Version
|
110
110
|
version: '3.5'
|
111
111
|
- !ruby/object:Gem::Dependency
|
112
|
-
name:
|
112
|
+
name: webmock
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version:
|
117
|
+
version: '3.8'
|
118
118
|
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version:
|
125
|
-
- !ruby/object:Gem::Dependency
|
126
|
-
name: simplecov
|
127
|
-
requirement: !ruby/object:Gem::Requirement
|
128
|
-
requirements:
|
129
|
-
- - ">="
|
130
|
-
- !ruby/object:Gem::Version
|
131
|
-
version: 0.3.8
|
132
|
-
type: :development
|
133
|
-
prerelease: false
|
134
|
-
version_requirements: !ruby/object:Gem::Requirement
|
135
|
-
requirements:
|
136
|
-
- - ">="
|
137
|
-
- !ruby/object:Gem::Version
|
138
|
-
version: 0.3.8
|
139
|
-
- !ruby/object:Gem::Dependency
|
140
|
-
name: pry-byebug
|
141
|
-
requirement: !ruby/object:Gem::Requirement
|
142
|
-
requirements:
|
143
|
-
- - ">="
|
144
|
-
- !ruby/object:Gem::Version
|
145
|
-
version: '0'
|
146
|
-
type: :development
|
147
|
-
prerelease: false
|
148
|
-
version_requirements: !ruby/object:Gem::Requirement
|
149
|
-
requirements:
|
150
|
-
- - ">="
|
151
|
-
- !ruby/object:Gem::Version
|
152
|
-
version: '0'
|
124
|
+
version: '3.8'
|
153
125
|
description: AnyCable is a polyglot replacement for ActionCable-compatible servers
|
154
126
|
email:
|
155
127
|
- dementiev.vm@gmail.com
|
@@ -168,6 +140,8 @@ files:
|
|
168
140
|
- bin/setup
|
169
141
|
- lib/anycable.rb
|
170
142
|
- lib/anycable/broadcast_adapters.rb
|
143
|
+
- lib/anycable/broadcast_adapters/base.rb
|
144
|
+
- lib/anycable/broadcast_adapters/http.rb
|
171
145
|
- lib/anycable/broadcast_adapters/redis.rb
|
172
146
|
- lib/anycable/cli.rb
|
173
147
|
- lib/anycable/config.rb
|
@@ -175,9 +149,15 @@ files:
|
|
175
149
|
- lib/anycable/health_server.rb
|
176
150
|
- lib/anycable/middleware.rb
|
177
151
|
- lib/anycable/middleware_chain.rb
|
152
|
+
- lib/anycable/middlewares/check_version.rb
|
153
|
+
- lib/anycable/rpc.rb
|
178
154
|
- lib/anycable/rpc/rpc_pb.rb
|
179
155
|
- lib/anycable/rpc/rpc_services_pb.rb
|
180
156
|
- lib/anycable/rpc_handler.rb
|
157
|
+
- lib/anycable/rspec.rb
|
158
|
+
- lib/anycable/rspec/rpc_command_context.rb
|
159
|
+
- lib/anycable/rspec/rpc_stub_context.rb
|
160
|
+
- lib/anycable/rspec/with_grpc_server.rb
|
181
161
|
- lib/anycable/server.rb
|
182
162
|
- lib/anycable/socket.rb
|
183
163
|
- lib/anycable/version.rb
|
@@ -198,14 +178,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
198
178
|
requirements:
|
199
179
|
- - ">="
|
200
180
|
- !ruby/object:Gem::Version
|
201
|
-
version: 2.
|
181
|
+
version: 2.5.0
|
202
182
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
203
183
|
requirements:
|
204
|
-
- - "
|
184
|
+
- - ">"
|
205
185
|
- !ruby/object:Gem::Version
|
206
|
-
version:
|
186
|
+
version: 1.3.1
|
207
187
|
requirements: []
|
208
|
-
rubygems_version: 3.0.
|
188
|
+
rubygems_version: 3.0.6
|
209
189
|
signing_key:
|
210
190
|
specification_version: 4
|
211
191
|
summary: AnyCable is a polyglot replacement for ActionCable-compatible servers
|