pipe_rpc 2.2.3 → 2.3.0
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/pipe_rpc/client.rb +21 -3
- data/lib/pipe_rpc/client_request.rb +1 -1
- data/lib/pipe_rpc/client_request_result.rb +1 -1
- data/lib/pipe_rpc/hub_request.rb +1 -1
- data/lib/pipe_rpc/hub_request_result.rb +1 -1
- data/lib/pipe_rpc/hub_server.rb +23 -4
- data/lib/pipe_rpc/transport_mapper.rb +39 -0
- data/lib/pipe_rpc/version.rb +1 -1
- metadata +3 -3
- data/lib/pipe_rpc/deep_mapper.rb +0 -44
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0358adf8660892a8dcd7f7fa2cdc00fa7aec1e7c
|
4
|
+
data.tar.gz: 260d9f45bd8c159d9a27c5a0f8630da1edc1ad15
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: eeb67540050b3e85b54f21e0c33e2cc0880ef9b77bafe2aaa0c056b4691dc083087a212e015fe44237d4ba5b709c8f493c013c8e676196a3c606a848b3f4b8ae
|
7
|
+
data.tar.gz: 7ee01e84a9ae90ac0c4f86820345a9a7c1ea2aab5a5dd1dcb3426649f5a9283c811b4f9b2cdf79098d20ce18e5fac6c376169c0425cf95a57c4df5a3fb1e6779
|
data/lib/pipe_rpc/client.rb
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
module PipeRpc
|
2
2
|
class Client < BasicInterface
|
3
|
+
TRANSPORT_PREFIX = "__rpc_client__"
|
4
|
+
|
3
5
|
def initialize(server_id = :default, hub)
|
4
|
-
|
6
|
+
Kernel.raise ClientInitializationError.new("server id #{server_id.inspect} no symbol") unless server_id.is_a? Symbol
|
5
7
|
@__rpc_server_id__ = server_id
|
6
8
|
@hub = hub
|
7
9
|
end
|
8
10
|
|
9
|
-
attr_reader :__rpc_server_id__
|
10
|
-
|
11
11
|
def respond_to?(method)
|
12
12
|
super or method_missing(:respond_to?, method)
|
13
13
|
end
|
@@ -16,5 +16,23 @@ module PipeRpc
|
|
16
16
|
request = Client::Request.new(@hub, server: @__rpc_server_id__, method: method, arguments: args)
|
17
17
|
@hub.requests.evaluate(request)
|
18
18
|
end
|
19
|
+
|
20
|
+
def to_rpc_transport(hub = nil)
|
21
|
+
"#{TRANSPORT_PREFIX}#{@__rpc_server_id__}"
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
class << Client
|
26
|
+
def const_missing(name)
|
27
|
+
::Object.const_get(name)
|
28
|
+
end
|
29
|
+
|
30
|
+
def from_rpc_transport?(transport)
|
31
|
+
(transport.is_a? String) and (transport.start_with? Hub::Server::TRANSPORT_PREFIX)
|
32
|
+
end
|
33
|
+
|
34
|
+
def from_rpc_transport(hub, transport)
|
35
|
+
hub.clients[transport.sub(Hub::Server::TRANSPORT_PREFIX, '').to_sym]
|
36
|
+
end
|
19
37
|
end
|
20
38
|
end
|
@@ -4,7 +4,7 @@ module PipeRpc
|
|
4
4
|
class Client::Request < Request
|
5
5
|
def initialize(hub, request)
|
6
6
|
@hub = hub
|
7
|
-
request[:arguments] =
|
7
|
+
request[:arguments] = TransportMapper.to_transport(request[:arguments], hub)
|
8
8
|
super request
|
9
9
|
# discard first three entries mentioning Client::Request#initialize,
|
10
10
|
# Client::Request.new and Client#method_missing in stacktrace
|
@@ -18,7 +18,7 @@ module PipeRpc
|
|
18
18
|
@value.set_backtrace(@value.backtrace.to_a + @request.stacktrace) if @value.respond_to? :set_backtrace
|
19
19
|
raise @value
|
20
20
|
else
|
21
|
-
|
21
|
+
TransportMapper.from_transport(@value, @request.hub)
|
22
22
|
end
|
23
23
|
end
|
24
24
|
end
|
data/lib/pipe_rpc/hub_request.rb
CHANGED
@@ -12,7 +12,7 @@ module PipeRpc
|
|
12
12
|
def handle
|
13
13
|
evaluate_result do
|
14
14
|
# the block is passed for asynchronous evaluation
|
15
|
-
mapped_arguments =
|
15
|
+
mapped_arguments = TransportMapper.from_transport(arguments, @hub)
|
16
16
|
@hub.servers[server].__send__(method, *mapped_arguments, &evaluate_result_proc)
|
17
17
|
end
|
18
18
|
end
|
data/lib/pipe_rpc/hub_server.rb
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
module PipeRpc
|
2
2
|
class Hub::Server < BasicInterface
|
3
|
+
TRANSPORT_PREFIX = "__rpc_server__"
|
4
|
+
|
3
5
|
kernel = ::Kernel.dup
|
4
6
|
kernel.class_eval do
|
5
7
|
alias_method :__rpc_server_class__, :class
|
@@ -8,14 +10,31 @@ module PipeRpc
|
|
8
10
|
end
|
9
11
|
include kernel
|
10
12
|
|
11
|
-
|
13
|
+
def to_rpc_server_id
|
14
|
+
"#{__rpc_server_class__}##{__id__}".to_sym
|
15
|
+
end
|
16
|
+
|
17
|
+
def to_rpc_transport(hub)
|
18
|
+
hub.servers.add(self) unless hub.servers.registered? to_rpc_server_id
|
19
|
+
"#{TRANSPORT_PREFIX}#{to_rpc_server_id}"
|
20
|
+
end
|
21
|
+
end
|
12
22
|
|
13
|
-
|
23
|
+
class << Hub::Server
|
24
|
+
def const_missing(name)
|
14
25
|
::Object.const_get(name)
|
15
26
|
end
|
16
27
|
|
17
|
-
def
|
18
|
-
|
28
|
+
def instance_eval_for(server, *args, &block)
|
29
|
+
Object.instance_method(:instance_eval).bind(server).call(*args, &block)
|
30
|
+
end
|
31
|
+
|
32
|
+
def from_rpc_transport?(transport)
|
33
|
+
(transport.is_a? String) and (transport.start_with? Client::TRANSPORT_PREFIX)
|
34
|
+
end
|
35
|
+
|
36
|
+
def from_rpc_transport(hub, transport)
|
37
|
+
hub.servers[transport.sub(Client::TRANSPORT_PREFIX, '').to_sym]
|
19
38
|
end
|
20
39
|
end
|
21
40
|
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
module PipeRpc
|
2
|
+
class TransportMapper
|
3
|
+
def self.map(object, &mapper)
|
4
|
+
if Client === object
|
5
|
+
# first filter out clients so for them subsequent checks are not sent
|
6
|
+
# through the pipe
|
7
|
+
yield object
|
8
|
+
elsif Hash === object
|
9
|
+
object.map{ |k, v| [k, map(v, &mapper)] }.to_h
|
10
|
+
elsif object.respond_to? :map
|
11
|
+
object.map{ |item| map(item, &mapper) }
|
12
|
+
else
|
13
|
+
yield object
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def self.to_transport(object, hub)
|
18
|
+
map(object) do |value|
|
19
|
+
if value.respond_to? :to_rpc_transport
|
20
|
+
value.to_rpc_transport(hub)
|
21
|
+
else
|
22
|
+
value
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def self.from_transport(object, hub)
|
28
|
+
map(object) do |value|
|
29
|
+
if Hub::Server.from_rpc_transport? value
|
30
|
+
Hub::Server.from_rpc_transport(hub, value)
|
31
|
+
elsif Client.from_rpc_transport? value
|
32
|
+
Client.from_rpc_transport(hub, value)
|
33
|
+
else
|
34
|
+
value
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
data/lib/pipe_rpc/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: pipe_rpc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Christopher Aue
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2016-09-
|
11
|
+
date: 2016-09-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: msgpack
|
@@ -105,7 +105,6 @@ files:
|
|
105
105
|
- lib/pipe_rpc/client_request_response.rb
|
106
106
|
- lib/pipe_rpc/client_request_result.rb
|
107
107
|
- lib/pipe_rpc/client_request_result_response.rb
|
108
|
-
- lib/pipe_rpc/deep_mapper.rb
|
109
108
|
- lib/pipe_rpc/error.rb
|
110
109
|
- lib/pipe_rpc/error_response.rb
|
111
110
|
- lib/pipe_rpc/gateway.rb
|
@@ -123,6 +122,7 @@ files:
|
|
123
122
|
- lib/pipe_rpc/hub_socket.rb
|
124
123
|
- lib/pipe_rpc/request.rb
|
125
124
|
- lib/pipe_rpc/result_response.rb
|
125
|
+
- lib/pipe_rpc/transport_mapper.rb
|
126
126
|
- lib/pipe_rpc/version.rb
|
127
127
|
- pipe_rpc.gemspec
|
128
128
|
homepage: https://github.com/christopheraue/ruby-pipe_rpc
|
data/lib/pipe_rpc/deep_mapper.rb
DELETED
@@ -1,44 +0,0 @@
|
|
1
|
-
module PipeRpc
|
2
|
-
class DeepMapper
|
3
|
-
def self.map(object, &mapper)
|
4
|
-
if object.respond_to? :__rpc_server_id__
|
5
|
-
# first filter out clients so for them subsequent checks are not sent
|
6
|
-
# through the pipe
|
7
|
-
yield object
|
8
|
-
elsif Hash === object
|
9
|
-
object.map{ |k, v| [k, map(v, &mapper)] }.to_h
|
10
|
-
elsif object.respond_to? :map
|
11
|
-
object.map{ |item| map(item, &mapper) }
|
12
|
-
else
|
13
|
-
yield object
|
14
|
-
end
|
15
|
-
end
|
16
|
-
|
17
|
-
def self.to_transport(object, hub)
|
18
|
-
map(object) do |value|
|
19
|
-
if value.respond_to? :__rpc_server_id__
|
20
|
-
# first filter out clients so for them subsequent checks are not sent
|
21
|
-
# through the pipe
|
22
|
-
"__rpc_client__#{value.__rpc_server_id__}"
|
23
|
-
elsif value.respond_to? :to_rpc_server_id
|
24
|
-
hub.servers.add(value) unless hub.servers.registered? value.to_rpc_server_id
|
25
|
-
"__rpc_server__#{value.to_rpc_server_id}"
|
26
|
-
else
|
27
|
-
value
|
28
|
-
end
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
def self.from_transport(object, hub)
|
33
|
-
map(object) do |value|
|
34
|
-
if value.is_a?(String) and value.start_with?('__rpc_client__')
|
35
|
-
hub.servers[value.sub('__rpc_client__', '').to_sym]
|
36
|
-
elsif value.is_a?(String) and value.start_with?('__rpc_server__')
|
37
|
-
Client.new(value.sub('__rpc_server__', '').to_sym, hub)
|
38
|
-
else
|
39
|
-
value
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|