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.
@@ -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
@@ -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: AnyCable.logger, **options)
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 :logger, :start_thread
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
@@ -3,11 +3,46 @@
3
3
  module AnyCable
4
4
  # Socket mock to be used with application connection
5
5
  class Socket
6
- attr_reader :transmissions, :env
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, _broadcasting)
22
- raise NotImplementedError
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
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module AnyCable
4
- VERSION = "0.6.4"
4
+ VERSION = "1.0.0.rc2"
5
5
  end
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.6.4
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-01-24 00:00:00.000000000 Z
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: '10.0'
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: '10.0'
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: rubocop
112
+ name: webmock
113
113
  requirement: !ruby/object:Gem::Requirement
114
114
  requirements:
115
115
  - - "~>"
116
116
  - !ruby/object:Gem::Version
117
- version: 0.68.0
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: 0.68.0
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.4.0
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: '0'
186
+ version: 1.3.1
207
187
  requirements: []
208
- rubygems_version: 3.0.3
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