|
|
@ -44,21 +44,21 @@ module GRPC |
|
|
|
|
|
|
|
|
|
|
|
# setup_channel is used by #initialize to constuct a channel from its |
|
|
|
# setup_channel is used by #initialize to constuct a channel from its |
|
|
|
# arguments. |
|
|
|
# arguments. |
|
|
|
def self.setup_channel(alt_chan, host, creds, **kw) |
|
|
|
def self.setup_channel(alt_chan, host, creds, channel_args = {}) |
|
|
|
unless alt_chan.nil? |
|
|
|
unless alt_chan.nil? |
|
|
|
fail(TypeError, '!Channel') unless alt_chan.is_a?(Core::Channel) |
|
|
|
fail(TypeError, '!Channel') unless alt_chan.is_a?(Core::Channel) |
|
|
|
return alt_chan |
|
|
|
return alt_chan |
|
|
|
end |
|
|
|
end |
|
|
|
if kw['grpc.primary_user_agent'].nil? |
|
|
|
if channel_args['grpc.primary_user_agent'].nil? |
|
|
|
kw['grpc.primary_user_agent'] = '' |
|
|
|
channel_args['grpc.primary_user_agent'] = '' |
|
|
|
else |
|
|
|
else |
|
|
|
kw['grpc.primary_user_agent'] += ' ' |
|
|
|
channel_args['grpc.primary_user_agent'] += ' ' |
|
|
|
end |
|
|
|
end |
|
|
|
kw['grpc.primary_user_agent'] += "grpc-ruby/#{VERSION}" |
|
|
|
channel_args['grpc.primary_user_agent'] += "grpc-ruby/#{VERSION}" |
|
|
|
unless creds.is_a?(Core::ChannelCredentials) || creds.is_a?(Symbol) |
|
|
|
unless creds.is_a?(Core::ChannelCredentials) || creds.is_a?(Symbol) |
|
|
|
fail(TypeError, '!ChannelCredentials or Symbol') |
|
|
|
fail(TypeError, '!ChannelCredentials or Symbol') |
|
|
|
end |
|
|
|
end |
|
|
|
Core::Channel.new(host, kw, creds) |
|
|
|
Core::Channel.new(host, channel_args, creds) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
# Allows users of the stub to modify the propagate mask. |
|
|
|
# Allows users of the stub to modify the propagate mask. |
|
|
@ -96,15 +96,16 @@ module GRPC |
|
|
|
# :this_channel_is_insecure |
|
|
|
# :this_channel_is_insecure |
|
|
|
# @param channel_override [Core::Channel] a pre-created channel |
|
|
|
# @param channel_override [Core::Channel] a pre-created channel |
|
|
|
# @param timeout [Number] the default timeout to use in requests |
|
|
|
# @param timeout [Number] the default timeout to use in requests |
|
|
|
# @param kw [KeywordArgs]the channel arguments |
|
|
|
# @param channel_args [Hash] the channel arguments |
|
|
|
def initialize(host, q, creds, |
|
|
|
def initialize(host, q, creds, |
|
|
|
channel_override: nil, |
|
|
|
channel_override: nil, |
|
|
|
timeout: nil, |
|
|
|
timeout: nil, |
|
|
|
propagate_mask: nil, |
|
|
|
propagate_mask: nil, |
|
|
|
**kw) |
|
|
|
channel_args: {}) |
|
|
|
fail(TypeError, '!CompletionQueue') unless q.is_a?(Core::CompletionQueue) |
|
|
|
fail(TypeError, '!CompletionQueue') unless q.is_a?(Core::CompletionQueue) |
|
|
|
@ch = ClientStub.setup_channel(channel_override, host, creds, **kw) |
|
|
|
@ch = ClientStub.setup_channel(channel_override, host, creds, |
|
|
|
alt_host = kw[Core::Channel::SSL_TARGET] |
|
|
|
channel_args) |
|
|
|
|
|
|
|
alt_host = channel_args[Core::Channel::SSL_TARGET] |
|
|
|
@host = alt_host.nil? ? host : alt_host |
|
|
|
@host = alt_host.nil? ? host : alt_host |
|
|
|
@propagate_mask = propagate_mask |
|
|
|
@propagate_mask = propagate_mask |
|
|
|
@timeout = timeout.nil? ? DEFAULT_TIMEOUT : timeout |
|
|
|
@timeout = timeout.nil? ? DEFAULT_TIMEOUT : timeout |
|
|
@ -135,42 +136,35 @@ module GRPC |
|
|
|
# If return_op is true, the call returns an Operation, calling execute |
|
|
|
# If return_op is true, the call returns an Operation, calling execute |
|
|
|
# on the Operation returns the response. |
|
|
|
# on the Operation returns the response. |
|
|
|
# |
|
|
|
# |
|
|
|
# == Keyword Args == |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# Unspecified keyword arguments are treated as metadata to be sent to the |
|
|
|
|
|
|
|
# server. |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# @param method [String] the RPC method to call on the GRPC server |
|
|
|
# @param method [String] the RPC method to call on the GRPC server |
|
|
|
# @param req [Object] the request sent to the server |
|
|
|
# @param req [Object] the request sent to the server |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param timeout [Numeric] (optional) the max completion time in seconds |
|
|
|
|
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
|
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# will be propagated by this one. |
|
|
|
# will be propagated by this one. |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# the call |
|
|
|
# the call |
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
# @param metadata [Hash] metadata to be sent to the server |
|
|
|
# @return [Object] the response received from the server |
|
|
|
# @return [Object] the response received from the server |
|
|
|
def request_response(method, req, marshal, unmarshal, |
|
|
|
def request_response(method, req, marshal, unmarshal, |
|
|
|
deadline: nil, |
|
|
|
deadline: nil, |
|
|
|
timeout: nil, |
|
|
|
|
|
|
|
return_op: false, |
|
|
|
return_op: false, |
|
|
|
parent: nil, |
|
|
|
parent: nil, |
|
|
|
credentials: nil, |
|
|
|
credentials: nil, |
|
|
|
**kw) |
|
|
|
metadata: {}) |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
deadline: deadline, |
|
|
|
deadline: deadline, |
|
|
|
timeout: timeout, |
|
|
|
|
|
|
|
parent: parent, |
|
|
|
parent: parent, |
|
|
|
credentials: credentials) |
|
|
|
credentials: credentials) |
|
|
|
return c.request_response(req, **kw) unless return_op |
|
|
|
return c.request_response(req, metadata: metadata) unless return_op |
|
|
|
|
|
|
|
|
|
|
|
# return the operation view of the active_call; define #execute as a |
|
|
|
# return the operation view of the active_call; define #execute as a |
|
|
|
# new method for this instance that invokes #request_response. |
|
|
|
# new method for this instance that invokes #request_response. |
|
|
|
op = c.operation |
|
|
|
op = c.operation |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
c.request_response(req, **kw) |
|
|
|
c.request_response(req, metadata: metadata) |
|
|
|
end |
|
|
|
end |
|
|
|
op |
|
|
|
op |
|
|
|
end |
|
|
|
end |
|
|
@ -205,42 +199,35 @@ module GRPC |
|
|
|
# |
|
|
|
# |
|
|
|
# If return_op is true, the call returns the response. |
|
|
|
# If return_op is true, the call returns the response. |
|
|
|
# |
|
|
|
# |
|
|
|
# == Keyword Args == |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# Unspecified keyword arguments are treated as metadata to be sent to the |
|
|
|
|
|
|
|
# server. |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# @param method [String] the RPC method to call on the GRPC server |
|
|
|
# @param method [String] the RPC method to call on the GRPC server |
|
|
|
# @param requests [Object] an Enumerable of requests to send |
|
|
|
# @param requests [Object] an Enumerable of requests to send |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param timeout [Numeric] (optional) the max completion time in seconds |
|
|
|
|
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# will be propagated by this one. |
|
|
|
# will be propagated by this one. |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# the call |
|
|
|
# the call |
|
|
|
|
|
|
|
# @param metadata [Hash] metadata to be sent to the server |
|
|
|
# @return [Object|Operation] the response received from the server |
|
|
|
# @return [Object|Operation] the response received from the server |
|
|
|
def client_streamer(method, requests, marshal, unmarshal, |
|
|
|
def client_streamer(method, requests, marshal, unmarshal, |
|
|
|
deadline: nil, |
|
|
|
deadline: nil, |
|
|
|
timeout: nil, |
|
|
|
|
|
|
|
return_op: false, |
|
|
|
return_op: false, |
|
|
|
parent: nil, |
|
|
|
parent: nil, |
|
|
|
credentials: nil, |
|
|
|
credentials: nil, |
|
|
|
**kw) |
|
|
|
metadata: {}) |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
deadline: deadline, |
|
|
|
deadline: deadline, |
|
|
|
timeout: timeout, |
|
|
|
|
|
|
|
parent: parent, |
|
|
|
parent: parent, |
|
|
|
credentials: credentials) |
|
|
|
credentials: credentials) |
|
|
|
return c.client_streamer(requests, **kw) unless return_op |
|
|
|
return c.client_streamer(requests, metadata: metadata) unless return_op |
|
|
|
|
|
|
|
|
|
|
|
# return the operation view of the active_call; define #execute as a |
|
|
|
# return the operation view of the active_call; define #execute as a |
|
|
|
# new method for this instance that invokes #client_streamer. |
|
|
|
# new method for this instance that invokes #client_streamer. |
|
|
|
op = c.operation |
|
|
|
op = c.operation |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
c.client_streamer(requests, **kw) |
|
|
|
c.client_streamer(requests, metadata: metadata) |
|
|
|
end |
|
|
|
end |
|
|
|
op |
|
|
|
op |
|
|
|
end |
|
|
|
end |
|
|
@ -292,35 +279,33 @@ module GRPC |
|
|
|
# @param req [Object] the request sent to the server |
|
|
|
# @param req [Object] the request sent to the server |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param timeout [Numeric] (optional) the max completion time in seconds |
|
|
|
|
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param return_op [true|false]return an Operation if true |
|
|
|
# @param return_op [true|false]return an Operation if true |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# will be propagated by this one. |
|
|
|
# will be propagated by this one. |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# the call |
|
|
|
# the call |
|
|
|
|
|
|
|
# @param metadata [Hash] metadata to be sent to the server |
|
|
|
# @param blk [Block] when provided, is executed for each response |
|
|
|
# @param blk [Block] when provided, is executed for each response |
|
|
|
# @return [Enumerator|Operation|nil] as discussed above |
|
|
|
# @return [Enumerator|Operation|nil] as discussed above |
|
|
|
def server_streamer(method, req, marshal, unmarshal, |
|
|
|
def server_streamer(method, req, marshal, unmarshal, |
|
|
|
deadline: nil, |
|
|
|
deadline: nil, |
|
|
|
timeout: nil, |
|
|
|
|
|
|
|
return_op: false, |
|
|
|
return_op: false, |
|
|
|
parent: nil, |
|
|
|
parent: nil, |
|
|
|
credentials: nil, |
|
|
|
credentials: nil, |
|
|
|
**kw, |
|
|
|
metadata: {}, |
|
|
|
&blk) |
|
|
|
&blk) |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
deadline: deadline, |
|
|
|
deadline: deadline, |
|
|
|
timeout: timeout, |
|
|
|
|
|
|
|
parent: parent, |
|
|
|
parent: parent, |
|
|
|
credentials: credentials) |
|
|
|
credentials: credentials) |
|
|
|
return c.server_streamer(req, **kw, &blk) unless return_op |
|
|
|
return c.server_streamer(req, metadata: metadata, &blk) unless return_op |
|
|
|
|
|
|
|
|
|
|
|
# return the operation view of the active_call; define #execute |
|
|
|
# return the operation view of the active_call; define #execute |
|
|
|
# as a new method for this instance that invokes #server_streamer |
|
|
|
# as a new method for this instance that invokes #server_streamer |
|
|
|
op = c.operation |
|
|
|
op = c.operation |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
c.server_streamer(req, **kw, &blk) |
|
|
|
c.server_streamer(req, metadata: metadata, &blk) |
|
|
|
end |
|
|
|
end |
|
|
|
op |
|
|
|
op |
|
|
|
end |
|
|
|
end |
|
|
@ -391,11 +376,6 @@ module GRPC |
|
|
|
# * the deadline is exceeded |
|
|
|
# * the deadline is exceeded |
|
|
|
# |
|
|
|
# |
|
|
|
# |
|
|
|
# |
|
|
|
# == Keyword Args == |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# Unspecified keyword arguments are treated as metadata to be sent to the |
|
|
|
|
|
|
|
# server. |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# == Return Value == |
|
|
|
# == Return Value == |
|
|
|
# |
|
|
|
# |
|
|
|
# if the return_op is false, the return value is an Enumerator of the |
|
|
|
# if the return_op is false, the return value is an Enumerator of the |
|
|
@ -411,36 +391,35 @@ module GRPC |
|
|
|
# @param requests [Object] an Enumerable of requests to send |
|
|
|
# @param requests [Object] an Enumerable of requests to send |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param marshal [Function] f(obj)->string that marshals requests |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param unmarshal [Function] f(string)->obj that unmarshals responses |
|
|
|
# @param timeout [Numeric] (optional) the max completion time in seconds |
|
|
|
|
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param deadline [Time] (optional) the time the request should complete |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# @param parent [Core::Call] a prior call whose reserved metadata |
|
|
|
# will be propagated by this one. |
|
|
|
# will be propagated by this one. |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# @param credentials [Core::CallCredentials] credentials to use when making |
|
|
|
# the call |
|
|
|
# the call |
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
# @param return_op [true|false] return an Operation if true |
|
|
|
|
|
|
|
# @param metadata [Hash] metadata to be sent to the server |
|
|
|
# @param blk [Block] when provided, is executed for each response |
|
|
|
# @param blk [Block] when provided, is executed for each response |
|
|
|
# @return [Enumerator|nil|Operation] as discussed above |
|
|
|
# @return [Enumerator|nil|Operation] as discussed above |
|
|
|
def bidi_streamer(method, requests, marshal, unmarshal, |
|
|
|
def bidi_streamer(method, requests, marshal, unmarshal, |
|
|
|
deadline: nil, |
|
|
|
deadline: nil, |
|
|
|
timeout: nil, |
|
|
|
|
|
|
|
return_op: false, |
|
|
|
return_op: false, |
|
|
|
parent: nil, |
|
|
|
parent: nil, |
|
|
|
credentials: nil, |
|
|
|
credentials: nil, |
|
|
|
**kw, |
|
|
|
metadata: {}, |
|
|
|
&blk) |
|
|
|
&blk) |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
c = new_active_call(method, marshal, unmarshal, |
|
|
|
deadline: deadline, |
|
|
|
deadline: deadline, |
|
|
|
timeout: timeout, |
|
|
|
|
|
|
|
parent: parent, |
|
|
|
parent: parent, |
|
|
|
credentials: credentials) |
|
|
|
credentials: credentials) |
|
|
|
|
|
|
|
|
|
|
|
return c.bidi_streamer(requests, **kw, &blk) unless return_op |
|
|
|
return c.bidi_streamer(requests, metadata: metadata, |
|
|
|
|
|
|
|
&blk) unless return_op |
|
|
|
|
|
|
|
|
|
|
|
# return the operation view of the active_call; define #execute |
|
|
|
# return the operation view of the active_call; define #execute |
|
|
|
# as a new method for this instance that invokes #bidi_streamer |
|
|
|
# as a new method for this instance that invokes #bidi_streamer |
|
|
|
op = c.operation |
|
|
|
op = c.operation |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
op.define_singleton_method(:execute) do |
|
|
|
c.bidi_streamer(requests, **kw, &blk) |
|
|
|
c.bidi_streamer(requests, metadata: metadata, &blk) |
|
|
|
end |
|
|
|
end |
|
|
|
op |
|
|
|
op |
|
|
|
end |
|
|
|
end |
|
|
@ -457,12 +436,10 @@ module GRPC |
|
|
|
# @param timeout [TimeConst] |
|
|
|
# @param timeout [TimeConst] |
|
|
|
def new_active_call(method, marshal, unmarshal, |
|
|
|
def new_active_call(method, marshal, unmarshal, |
|
|
|
deadline: nil, |
|
|
|
deadline: nil, |
|
|
|
timeout: nil, |
|
|
|
|
|
|
|
parent: nil, |
|
|
|
parent: nil, |
|
|
|
credentials: nil) |
|
|
|
credentials: nil) |
|
|
|
if deadline.nil? |
|
|
|
|
|
|
|
deadline = from_relative_time(timeout.nil? ? @timeout : timeout) |
|
|
|
deadline = from_relative_time(@timeout) if deadline.nil? |
|
|
|
end |
|
|
|
|
|
|
|
# Provide each new client call with its own completion queue |
|
|
|
# Provide each new client call with its own completion queue |
|
|
|
call_queue = Core::CompletionQueue.new |
|
|
|
call_queue = Core::CompletionQueue.new |
|
|
|
call = @ch.create_call(call_queue, |
|
|
|
call = @ch.create_call(call_queue, |
|
|
|