grpc 1.49.0.pre1-x64-mingw-ucrt
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of grpc might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/etc/roots.pem +4337 -0
- data/grpc_c.32-msvcrt.ruby +0 -0
- data/grpc_c.64-msvcrt.ruby +0 -0
- data/grpc_c.64-ucrt.ruby +0 -0
- data/src/ruby/bin/math_client.rb +140 -0
- data/src/ruby/bin/math_pb.rb +34 -0
- data/src/ruby/bin/math_server.rb +191 -0
- data/src/ruby/bin/math_services_pb.rb +51 -0
- data/src/ruby/bin/noproto_client.rb +93 -0
- data/src/ruby/bin/noproto_server.rb +97 -0
- data/src/ruby/ext/grpc/ext-export-truffleruby.clang +2 -0
- data/src/ruby/ext/grpc/ext-export-truffleruby.gcc +7 -0
- data/src/ruby/ext/grpc/ext-export.clang +2 -0
- data/src/ruby/ext/grpc/ext-export.gcc +7 -0
- data/src/ruby/ext/grpc/extconf.rb +163 -0
- data/src/ruby/ext/grpc/rb_byte_buffer.c +65 -0
- data/src/ruby/ext/grpc/rb_byte_buffer.h +35 -0
- data/src/ruby/ext/grpc/rb_call.c +1051 -0
- data/src/ruby/ext/grpc/rb_call.h +57 -0
- data/src/ruby/ext/grpc/rb_call_credentials.c +341 -0
- data/src/ruby/ext/grpc/rb_call_credentials.h +31 -0
- data/src/ruby/ext/grpc/rb_channel.c +849 -0
- data/src/ruby/ext/grpc/rb_channel.h +34 -0
- data/src/ruby/ext/grpc/rb_channel_args.c +155 -0
- data/src/ruby/ext/grpc/rb_channel_args.h +38 -0
- data/src/ruby/ext/grpc/rb_channel_credentials.c +286 -0
- data/src/ruby/ext/grpc/rb_channel_credentials.h +37 -0
- data/src/ruby/ext/grpc/rb_completion_queue.c +101 -0
- data/src/ruby/ext/grpc/rb_completion_queue.h +36 -0
- data/src/ruby/ext/grpc/rb_compression_options.c +471 -0
- data/src/ruby/ext/grpc/rb_compression_options.h +29 -0
- data/src/ruby/ext/grpc/rb_enable_cpp.cc +22 -0
- data/src/ruby/ext/grpc/rb_event_thread.c +145 -0
- data/src/ruby/ext/grpc/rb_event_thread.h +21 -0
- data/src/ruby/ext/grpc/rb_grpc.c +333 -0
- data/src/ruby/ext/grpc/rb_grpc.h +77 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +597 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +901 -0
- data/src/ruby/ext/grpc/rb_loader.c +61 -0
- data/src/ruby/ext/grpc/rb_loader.h +25 -0
- data/src/ruby/ext/grpc/rb_server.c +388 -0
- data/src/ruby/ext/grpc/rb_server.h +32 -0
- data/src/ruby/ext/grpc/rb_server_credentials.c +259 -0
- data/src/ruby/ext/grpc/rb_server_credentials.h +37 -0
- data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +218 -0
- data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +37 -0
- data/src/ruby/ext/grpc/rb_xds_server_credentials.c +170 -0
- data/src/ruby/ext/grpc/rb_xds_server_credentials.h +37 -0
- data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
- data/src/ruby/lib/grpc/core/status_codes.rb +135 -0
- data/src/ruby/lib/grpc/core/time_consts.rb +56 -0
- data/src/ruby/lib/grpc/errors.rb +277 -0
- data/src/ruby/lib/grpc/generic/active_call.rb +675 -0
- data/src/ruby/lib/grpc/generic/bidi_call.rb +233 -0
- data/src/ruby/lib/grpc/generic/client_stub.rb +503 -0
- data/src/ruby/lib/grpc/generic/interceptor_registry.rb +53 -0
- data/src/ruby/lib/grpc/generic/interceptors.rb +186 -0
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +204 -0
- data/src/ruby/lib/grpc/generic/rpc_server.rb +551 -0
- data/src/ruby/lib/grpc/generic/service.rb +211 -0
- data/src/ruby/lib/grpc/google_rpc_status_utils.rb +40 -0
- data/src/ruby/lib/grpc/grpc.rb +24 -0
- data/src/ruby/lib/grpc/logconfig.rb +44 -0
- data/src/ruby/lib/grpc/notifier.rb +45 -0
- data/src/ruby/lib/grpc/structs.rb +15 -0
- data/src/ruby/lib/grpc/version.rb +18 -0
- data/src/ruby/lib/grpc.rb +37 -0
- data/src/ruby/pb/README.md +42 -0
- data/src/ruby/pb/generate_proto_ruby.sh +52 -0
- data/src/ruby/pb/grpc/health/checker.rb +75 -0
- data/src/ruby/pb/grpc/health/v1/health_pb.rb +31 -0
- data/src/ruby/pb/grpc/health/v1/health_services_pb.rb +62 -0
- data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +44 -0
- data/src/ruby/pb/grpc/testing/metrics_pb.rb +28 -0
- data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +49 -0
- data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +17 -0
- data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +149 -0
- data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +17 -0
- data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +152 -0
- data/src/ruby/pb/test/client.rb +769 -0
- data/src/ruby/pb/test/server.rb +252 -0
- data/src/ruby/pb/test/xds_client.rb +415 -0
- data/src/ruby/spec/call_credentials_spec.rb +42 -0
- data/src/ruby/spec/call_spec.rb +180 -0
- data/src/ruby/spec/channel_connection_spec.rb +126 -0
- data/src/ruby/spec/channel_credentials_spec.rb +124 -0
- data/src/ruby/spec/channel_spec.rb +245 -0
- data/src/ruby/spec/client_auth_spec.rb +152 -0
- data/src/ruby/spec/client_server_spec.rb +664 -0
- data/src/ruby/spec/compression_options_spec.rb +149 -0
- data/src/ruby/spec/debug_message_spec.rb +134 -0
- data/src/ruby/spec/error_sanity_spec.rb +49 -0
- data/src/ruby/spec/errors_spec.rb +142 -0
- data/src/ruby/spec/generic/active_call_spec.rb +683 -0
- data/src/ruby/spec/generic/client_interceptors_spec.rb +153 -0
- data/src/ruby/spec/generic/client_stub_spec.rb +1083 -0
- data/src/ruby/spec/generic/interceptor_registry_spec.rb +65 -0
- data/src/ruby/spec/generic/rpc_desc_spec.rb +374 -0
- data/src/ruby/spec/generic/rpc_server_pool_spec.rb +127 -0
- data/src/ruby/spec/generic/rpc_server_spec.rb +748 -0
- data/src/ruby/spec/generic/server_interceptors_spec.rb +218 -0
- data/src/ruby/spec/generic/service_spec.rb +263 -0
- data/src/ruby/spec/google_rpc_status_utils_spec.rb +282 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/package_options.proto +28 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/package_options_import.proto +22 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/package_options_import2.proto +23 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/package_options_ruby_style.proto +41 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/same_package_service_name.proto +27 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/same_ruby_package_service_name.proto +29 -0
- data/src/ruby/spec/pb/codegen/package_option_spec.rb +98 -0
- data/src/ruby/spec/pb/duplicate/codegen_spec.rb +57 -0
- data/src/ruby/spec/pb/health/checker_spec.rb +236 -0
- data/src/ruby/spec/server_credentials_spec.rb +104 -0
- data/src/ruby/spec/server_spec.rb +231 -0
- data/src/ruby/spec/spec_helper.rb +61 -0
- data/src/ruby/spec/support/helpers.rb +107 -0
- data/src/ruby/spec/support/services.rb +160 -0
- data/src/ruby/spec/testdata/README +1 -0
- data/src/ruby/spec/testdata/ca.pem +20 -0
- data/src/ruby/spec/testdata/client.key +28 -0
- data/src/ruby/spec/testdata/client.pem +20 -0
- data/src/ruby/spec/testdata/server1.key +28 -0
- data/src/ruby/spec/testdata/server1.pem +22 -0
- data/src/ruby/spec/time_consts_spec.rb +74 -0
- data/src/ruby/spec/user_agent_spec.rb +74 -0
- metadata +406 -0
File without changes
|
File without changes
|
data/grpc_c.64-ucrt.ruby
ADDED
Binary file
|
@@ -0,0 +1,140 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
# Copyright 2015 gRPC authors.
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
|
17
|
+
# Sample app that accesses a Calc service running on a Ruby gRPC server and
|
18
|
+
# helps validate RpcServer as a gRPC server using proto2 serialization.
|
19
|
+
#
|
20
|
+
# Usage: $ path/to/math_client.rb
|
21
|
+
|
22
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
23
|
+
lib_dir = File.join(File.dirname(this_dir), 'lib')
|
24
|
+
$LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir)
|
25
|
+
$LOAD_PATH.unshift(this_dir) unless $LOAD_PATH.include?(this_dir)
|
26
|
+
|
27
|
+
require 'grpc'
|
28
|
+
require 'math_services_pb'
|
29
|
+
require 'optparse'
|
30
|
+
require 'logger'
|
31
|
+
|
32
|
+
include GRPC::Core::TimeConsts
|
33
|
+
|
34
|
+
module StdoutLogger
|
35
|
+
def logger
|
36
|
+
LOGGER
|
37
|
+
end
|
38
|
+
|
39
|
+
LOGGER = Logger.new(STDOUT)
|
40
|
+
end
|
41
|
+
|
42
|
+
GRPC.extend(StdoutLogger)
|
43
|
+
|
44
|
+
def do_div(stub)
|
45
|
+
GRPC.logger.info('request_response')
|
46
|
+
GRPC.logger.info('----------------')
|
47
|
+
req = Math::DivArgs.new(dividend: 7, divisor: 3)
|
48
|
+
GRPC.logger.info("div(7/3): req=#{req.inspect}")
|
49
|
+
resp = stub.div(req)
|
50
|
+
GRPC.logger.info("Answer: #{resp.inspect}")
|
51
|
+
GRPC.logger.info('----------------')
|
52
|
+
end
|
53
|
+
|
54
|
+
def do_sum(stub)
|
55
|
+
# to make client streaming requests, pass an enumerable of the inputs
|
56
|
+
GRPC.logger.info('client_streamer')
|
57
|
+
GRPC.logger.info('---------------')
|
58
|
+
reqs = [1, 2, 3, 4, 5].map { |x| Math::Num.new(num: x) }
|
59
|
+
GRPC.logger.info("sum(1, 2, 3, 4, 5): reqs=#{reqs.inspect}")
|
60
|
+
resp = stub.sum(reqs) # reqs.is_a?(Enumerable)
|
61
|
+
GRPC.logger.info("Answer: #{resp.inspect}")
|
62
|
+
GRPC.logger.info('---------------')
|
63
|
+
end
|
64
|
+
|
65
|
+
def do_fib(stub)
|
66
|
+
GRPC.logger.info('server_streamer')
|
67
|
+
GRPC.logger.info('----------------')
|
68
|
+
req = Math::FibArgs.new(limit: 11)
|
69
|
+
GRPC.logger.info("fib(11): req=#{req.inspect}")
|
70
|
+
resp = stub.fib(req)
|
71
|
+
resp.each do |r|
|
72
|
+
GRPC.logger.info("Answer: #{r.inspect}")
|
73
|
+
end
|
74
|
+
GRPC.logger.info('----------------')
|
75
|
+
end
|
76
|
+
|
77
|
+
def do_div_many(stub)
|
78
|
+
GRPC.logger.info('bidi_streamer')
|
79
|
+
GRPC.logger.info('-------------')
|
80
|
+
reqs = []
|
81
|
+
reqs << Math::DivArgs.new(dividend: 7, divisor: 3)
|
82
|
+
reqs << Math::DivArgs.new(dividend: 5, divisor: 2)
|
83
|
+
reqs << Math::DivArgs.new(dividend: 7, divisor: 2)
|
84
|
+
GRPC.logger.info("div(7/3), div(5/2), div(7/2): reqs=#{reqs.inspect}")
|
85
|
+
resp = stub.div_many(reqs)
|
86
|
+
resp.each do |r|
|
87
|
+
GRPC.logger.info("Answer: #{r.inspect}")
|
88
|
+
end
|
89
|
+
GRPC.logger.info('----------------')
|
90
|
+
end
|
91
|
+
|
92
|
+
def load_test_certs
|
93
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
94
|
+
data_dir = File.join(File.dirname(this_dir), 'spec/testdata')
|
95
|
+
files = ['ca.pem', 'server1.key', 'server1.pem']
|
96
|
+
files.map { |f| File.open(File.join(data_dir, f)).read }
|
97
|
+
end
|
98
|
+
|
99
|
+
def test_creds
|
100
|
+
certs = load_test_certs
|
101
|
+
GRPC::Core::ChannelCredentials.new(certs[0])
|
102
|
+
end
|
103
|
+
|
104
|
+
def main
|
105
|
+
options = {
|
106
|
+
'host' => 'localhost:7071',
|
107
|
+
'secure' => false
|
108
|
+
}
|
109
|
+
OptionParser.new do |opts|
|
110
|
+
opts.banner = 'Usage: [--host <hostname>:<port>] [--secure|-s]'
|
111
|
+
opts.on('--host HOST', '<hostname>:<port>') do |v|
|
112
|
+
options['host'] = v
|
113
|
+
end
|
114
|
+
opts.on('-s', '--secure', 'access using test creds') do |v|
|
115
|
+
options['secure'] = v
|
116
|
+
end
|
117
|
+
end.parse!
|
118
|
+
|
119
|
+
# The Math::Math:: module occurs because the service has the same name as its
|
120
|
+
# package. That practice should be avoided by defining real services.
|
121
|
+
if options['secure']
|
122
|
+
stub_opts = {
|
123
|
+
:creds => test_creds,
|
124
|
+
GRPC::Core::Channel::SSL_TARGET => 'foo.test.google.fr',
|
125
|
+
timeout: INFINITE_FUTURE,
|
126
|
+
}
|
127
|
+
stub = Math::Math::Stub.new(options['host'], **stub_opts)
|
128
|
+
GRPC.logger.info("... connecting securely on #{options['host']}")
|
129
|
+
else
|
130
|
+
stub = Math::Math::Stub.new(options['host'], :this_channel_is_insecure, timeout: INFINITE_FUTURE)
|
131
|
+
GRPC.logger.info("... connecting insecurely on #{options['host']}")
|
132
|
+
end
|
133
|
+
|
134
|
+
do_div(stub)
|
135
|
+
do_sum(stub)
|
136
|
+
do_fib(stub)
|
137
|
+
do_div_many(stub)
|
138
|
+
end
|
139
|
+
|
140
|
+
main
|
@@ -0,0 +1,34 @@
|
|
1
|
+
# Generated by the protocol buffer compiler. DO NOT EDIT!
|
2
|
+
# source: math.proto
|
3
|
+
|
4
|
+
require 'google/protobuf'
|
5
|
+
|
6
|
+
Google::Protobuf::DescriptorPool.generated_pool.build do
|
7
|
+
add_file("math.proto", :syntax => :proto3) do
|
8
|
+
add_message "math.DivArgs" do
|
9
|
+
optional :dividend, :int64, 1
|
10
|
+
optional :divisor, :int64, 2
|
11
|
+
end
|
12
|
+
add_message "math.DivReply" do
|
13
|
+
optional :quotient, :int64, 1
|
14
|
+
optional :remainder, :int64, 2
|
15
|
+
end
|
16
|
+
add_message "math.FibArgs" do
|
17
|
+
optional :limit, :int64, 1
|
18
|
+
end
|
19
|
+
add_message "math.Num" do
|
20
|
+
optional :num, :int64, 1
|
21
|
+
end
|
22
|
+
add_message "math.FibReply" do
|
23
|
+
optional :count, :int64, 1
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
module Math
|
29
|
+
DivArgs = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("math.DivArgs").msgclass
|
30
|
+
DivReply = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("math.DivReply").msgclass
|
31
|
+
FibArgs = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("math.FibArgs").msgclass
|
32
|
+
Num = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("math.Num").msgclass
|
33
|
+
FibReply = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("math.FibReply").msgclass
|
34
|
+
end
|
@@ -0,0 +1,191 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
# Copyright 2015 gRPC authors.
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
|
17
|
+
# Sample gRPC Ruby server that implements the Math::Calc service and helps
|
18
|
+
# validate GRPC::RpcServer as GRPC implementation using proto2 serialization.
|
19
|
+
#
|
20
|
+
# Usage: $ path/to/math_server.rb
|
21
|
+
|
22
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
23
|
+
lib_dir = File.join(File.dirname(this_dir), 'lib')
|
24
|
+
$LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir)
|
25
|
+
$LOAD_PATH.unshift(this_dir) unless $LOAD_PATH.include?(this_dir)
|
26
|
+
|
27
|
+
require 'forwardable'
|
28
|
+
require 'grpc'
|
29
|
+
require 'logger'
|
30
|
+
require 'math_services_pb'
|
31
|
+
require 'optparse'
|
32
|
+
|
33
|
+
# RubyLogger defines a logger for gRPC based on the standard ruby logger.
|
34
|
+
module RubyLogger
|
35
|
+
def logger
|
36
|
+
LOGGER
|
37
|
+
end
|
38
|
+
|
39
|
+
LOGGER = Logger.new(STDOUT)
|
40
|
+
end
|
41
|
+
|
42
|
+
# GRPC is the general RPC module
|
43
|
+
module GRPC
|
44
|
+
# Inject the noop #logger if no module-level logger method has been injected.
|
45
|
+
extend RubyLogger
|
46
|
+
end
|
47
|
+
|
48
|
+
# Holds state for a fibonacci series
|
49
|
+
class Fibber
|
50
|
+
def initialize(limit)
|
51
|
+
fail "bad limit: got #{limit}, want limit > 0" if limit < 1
|
52
|
+
@limit = limit
|
53
|
+
end
|
54
|
+
|
55
|
+
def generator
|
56
|
+
return enum_for(:generator) unless block_given?
|
57
|
+
idx, current, previous = 0, 1, 1
|
58
|
+
until idx == @limit
|
59
|
+
if idx.zero? || idx == 1
|
60
|
+
yield Math::Num.new(num: 1)
|
61
|
+
idx += 1
|
62
|
+
next
|
63
|
+
end
|
64
|
+
tmp = current
|
65
|
+
current = previous + current
|
66
|
+
previous = tmp
|
67
|
+
yield Math::Num.new(num: current)
|
68
|
+
idx += 1
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
# A EnumeratorQueue wraps a Queue to yield the items added to it.
|
74
|
+
class EnumeratorQueue
|
75
|
+
extend Forwardable
|
76
|
+
def_delegators :@q, :push
|
77
|
+
|
78
|
+
def initialize(sentinel)
|
79
|
+
@q = Queue.new
|
80
|
+
@sentinel = sentinel
|
81
|
+
end
|
82
|
+
|
83
|
+
def each_item
|
84
|
+
return enum_for(:each_item) unless block_given?
|
85
|
+
loop do
|
86
|
+
r = @q.pop
|
87
|
+
break if r.equal?(@sentinel)
|
88
|
+
fail r if r.is_a? Exception
|
89
|
+
yield r
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
# The Math::Math:: module occurs because the service has the same name as its
|
95
|
+
# package. That practice should be avoided by defining real services.
|
96
|
+
class Calculator < Math::Math::Service
|
97
|
+
def div(div_args, _call)
|
98
|
+
if div_args.divisor.zero?
|
99
|
+
# To send non-OK status handlers raise a StatusError with the code and
|
100
|
+
# and detail they want sent as a Status.
|
101
|
+
fail GRPC::StatusError.new(GRPC::Status::INVALID_ARGUMENT,
|
102
|
+
'divisor cannot be 0')
|
103
|
+
end
|
104
|
+
|
105
|
+
Math::DivReply.new(quotient: div_args.dividend / div_args.divisor,
|
106
|
+
remainder: div_args.dividend % div_args.divisor)
|
107
|
+
end
|
108
|
+
|
109
|
+
def sum(call)
|
110
|
+
# the requests are accesible as the Enumerator call#each_request
|
111
|
+
nums = call.each_remote_read.collect(&:num)
|
112
|
+
sum = nums.inject { |s, x| s + x }
|
113
|
+
Math::Num.new(num: sum)
|
114
|
+
end
|
115
|
+
|
116
|
+
def fib(fib_args, _call)
|
117
|
+
if fib_args.limit < 1
|
118
|
+
fail StatusError.new(Status::INVALID_ARGUMENT, 'limit must be >= 0')
|
119
|
+
end
|
120
|
+
|
121
|
+
# return an Enumerator of Nums
|
122
|
+
Fibber.new(fib_args.limit).generator
|
123
|
+
# just return the generator, GRPC::GenericServer sends each actual response
|
124
|
+
end
|
125
|
+
|
126
|
+
def div_many(requests)
|
127
|
+
# requests is an lazy Enumerator of the requests sent by the client.
|
128
|
+
q = EnumeratorQueue.new(self)
|
129
|
+
t = Thread.new do
|
130
|
+
begin
|
131
|
+
requests.each do |req|
|
132
|
+
GRPC.logger.info("read #{req.inspect}")
|
133
|
+
resp = Math::DivReply.new(quotient: req.dividend / req.divisor,
|
134
|
+
remainder: req.dividend % req.divisor)
|
135
|
+
q.push(resp)
|
136
|
+
Thread.pass # let the internal Bidi threads run
|
137
|
+
end
|
138
|
+
GRPC.logger.info('finished reads')
|
139
|
+
q.push(self)
|
140
|
+
rescue StandardError => e
|
141
|
+
q.push(e) # share the exception with the enumerator
|
142
|
+
raise e
|
143
|
+
end
|
144
|
+
end
|
145
|
+
t.priority = -2 # hint that the div_many thread should not be favoured
|
146
|
+
q.each_item
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
def load_test_certs
|
151
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
152
|
+
data_dir = File.join(File.dirname(this_dir), 'spec/testdata')
|
153
|
+
files = ['ca.pem', 'server1.key', 'server1.pem']
|
154
|
+
files.map { |f| File.open(File.join(data_dir, f)).read }
|
155
|
+
end
|
156
|
+
|
157
|
+
def test_server_creds
|
158
|
+
certs = load_test_certs
|
159
|
+
GRPC::Core::ServerCredentials.new(
|
160
|
+
nil, [{ private_key: certs[1], cert_chain: certs[2] }], false)
|
161
|
+
end
|
162
|
+
|
163
|
+
def main
|
164
|
+
options = {
|
165
|
+
'host' => 'localhost:7071',
|
166
|
+
'secure' => false
|
167
|
+
}
|
168
|
+
OptionParser.new do |opts|
|
169
|
+
opts.banner = 'Usage: [--host <hostname>:<port>] [--secure|-s]'
|
170
|
+
opts.on('--host HOST', '<hostname>:<port>') do |v|
|
171
|
+
options['host'] = v
|
172
|
+
end
|
173
|
+
opts.on('-s', '--secure', 'access using test creds') do |v|
|
174
|
+
options['secure'] = v
|
175
|
+
end
|
176
|
+
end.parse!
|
177
|
+
|
178
|
+
s = GRPC::RpcServer.new
|
179
|
+
if options['secure']
|
180
|
+
s.add_http2_port(options['host'], test_server_creds)
|
181
|
+
GRPC.logger.info("... running securely on #{options['host']}")
|
182
|
+
else
|
183
|
+
s.add_http2_port(options['host'], :this_port_is_insecure)
|
184
|
+
GRPC.logger.info("... running insecurely on #{options['host']}")
|
185
|
+
end
|
186
|
+
|
187
|
+
s.handle(Calculator)
|
188
|
+
s.run_till_terminated
|
189
|
+
end
|
190
|
+
|
191
|
+
main
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# Generated by the protocol buffer compiler. DO NOT EDIT!
|
2
|
+
# Source: math.proto for package 'math'
|
3
|
+
# Original file comments:
|
4
|
+
# Copyright 2015 gRPC authors.
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'grpc'
|
20
|
+
require 'math_pb'
|
21
|
+
|
22
|
+
module Math
|
23
|
+
module Math
|
24
|
+
class Service
|
25
|
+
|
26
|
+
include ::GRPC::GenericService
|
27
|
+
|
28
|
+
self.marshal_class_method = :encode
|
29
|
+
self.unmarshal_class_method = :decode
|
30
|
+
self.service_name = 'math.Math'
|
31
|
+
|
32
|
+
# Div divides DivArgs.dividend by DivArgs.divisor and returns the quotient
|
33
|
+
# and remainder.
|
34
|
+
rpc :Div, ::Math::DivArgs, ::Math::DivReply
|
35
|
+
# DivMany accepts an arbitrary number of division args from the client stream
|
36
|
+
# and sends back the results in the reply stream. The stream continues until
|
37
|
+
# the client closes its end; the server does the same after sending all the
|
38
|
+
# replies. The stream ends immediately if either end aborts.
|
39
|
+
rpc :DivMany, stream(::Math::DivArgs), stream(::Math::DivReply)
|
40
|
+
# Fib generates numbers in the Fibonacci sequence. If FibArgs.limit > 0, Fib
|
41
|
+
# generates up to limit numbers; otherwise it continues until the call is
|
42
|
+
# canceled. Unlike Fib above, Fib has no final FibReply.
|
43
|
+
rpc :Fib, ::Math::FibArgs, stream(::Math::Num)
|
44
|
+
# Sum sums a stream of numbers, returning the final result once the stream
|
45
|
+
# is closed.
|
46
|
+
rpc :Sum, stream(::Math::Num), ::Math::Num
|
47
|
+
end
|
48
|
+
|
49
|
+
Stub = Service.rpc_stub_class
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
# Copyright 2015 gRPC authors.
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
|
17
|
+
# Sample app that helps validate RpcServer without protobuf serialization.
|
18
|
+
#
|
19
|
+
# Usage: $ ruby -S path/to/noproto_client.rb
|
20
|
+
|
21
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
22
|
+
lib_dir = File.join(File.dirname(this_dir), 'lib')
|
23
|
+
$LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir)
|
24
|
+
|
25
|
+
require 'grpc'
|
26
|
+
require 'optparse'
|
27
|
+
|
28
|
+
# a simple non-protobuf message class.
|
29
|
+
class NoProtoMsg
|
30
|
+
def self.marshal(_o)
|
31
|
+
''
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.unmarshal(_o)
|
35
|
+
NoProtoMsg.new
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
# service the uses the non-protobuf message class.
|
40
|
+
class NoProtoService
|
41
|
+
include GRPC::GenericService
|
42
|
+
rpc :AnRPC, NoProtoMsg, NoProtoMsg
|
43
|
+
end
|
44
|
+
|
45
|
+
NoProtoStub = NoProtoService.rpc_stub_class
|
46
|
+
|
47
|
+
def load_test_certs
|
48
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
49
|
+
data_dir = File.join(File.dirname(this_dir), 'spec/testdata')
|
50
|
+
files = ['ca.pem', 'server1.key', 'server1.pem']
|
51
|
+
files.map { |f| File.open(File.join(data_dir, f)).read }
|
52
|
+
end
|
53
|
+
|
54
|
+
def test_creds
|
55
|
+
certs = load_test_certs
|
56
|
+
GRPC::Core::ChannelCredentials.new(certs[0])
|
57
|
+
end
|
58
|
+
|
59
|
+
def main
|
60
|
+
options = {
|
61
|
+
'host' => 'localhost:7071',
|
62
|
+
'secure' => false
|
63
|
+
}
|
64
|
+
OptionParser.new do |opts|
|
65
|
+
opts.banner = 'Usage: [--host <hostname>:<port>] [--secure|-s]'
|
66
|
+
opts.on('--host HOST', '<hostname>:<port>') do |v|
|
67
|
+
options['host'] = v
|
68
|
+
end
|
69
|
+
opts.on('-s', '--secure', 'access using test creds') do |v|
|
70
|
+
options['secure'] = v
|
71
|
+
end
|
72
|
+
end.parse!
|
73
|
+
|
74
|
+
if options['secure']
|
75
|
+
stub_opts = {
|
76
|
+
:creds => test_creds,
|
77
|
+
GRPC::Core::Channel::SSL_TARGET => 'foo.test.google.fr'
|
78
|
+
}
|
79
|
+
p stub_opts
|
80
|
+
p options['host']
|
81
|
+
stub = NoProtoStub.new(options['host'], **stub_opts)
|
82
|
+
GRPC.logger.info("... connecting securely on #{options['host']}")
|
83
|
+
else
|
84
|
+
stub = NoProtoStub.new(options['host'])
|
85
|
+
GRPC.logger.info("... connecting insecurely on #{options['host']}")
|
86
|
+
end
|
87
|
+
|
88
|
+
GRPC.logger.info('sending a NoProto rpc')
|
89
|
+
resp = stub.an_rpc(NoProtoMsg.new)
|
90
|
+
GRPC.logger.info("got a response: #{resp}")
|
91
|
+
end
|
92
|
+
|
93
|
+
main
|
@@ -0,0 +1,97 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
# Copyright 2015 gRPC authors.
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
|
17
|
+
# Sample app that helps validate RpcServer without protobuf serialization.
|
18
|
+
#
|
19
|
+
# Usage: $ path/to/noproto_server.rb
|
20
|
+
|
21
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
22
|
+
lib_dir = File.join(File.dirname(this_dir), 'lib')
|
23
|
+
$LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir)
|
24
|
+
|
25
|
+
require 'grpc'
|
26
|
+
require 'optparse'
|
27
|
+
|
28
|
+
# a simple non-protobuf message class.
|
29
|
+
class NoProtoMsg
|
30
|
+
def self.marshal(_o)
|
31
|
+
''
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.unmarshal(_o)
|
35
|
+
NoProtoMsg.new
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
# service the uses the non-protobuf message class.
|
40
|
+
class NoProtoService
|
41
|
+
include GRPC::GenericService
|
42
|
+
rpc :AnRPC, NoProtoMsg, NoProtoMsg
|
43
|
+
end
|
44
|
+
|
45
|
+
# an implementation of the non-protobuf service.
|
46
|
+
class NoProto < NoProtoService
|
47
|
+
def initialize(_default_var = 'ignored')
|
48
|
+
end
|
49
|
+
|
50
|
+
def an_rpc(req, _call)
|
51
|
+
GRPC.logger.info('echo service received a request')
|
52
|
+
req
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
def load_test_certs
|
57
|
+
this_dir = File.expand_path(File.dirname(__FILE__))
|
58
|
+
data_dir = File.join(File.dirname(this_dir), 'spec/testdata')
|
59
|
+
files = ['ca.pem', 'server1.key', 'server1.pem']
|
60
|
+
files.map { |f| File.open(File.join(data_dir, f)).read }
|
61
|
+
end
|
62
|
+
|
63
|
+
def test_server_creds
|
64
|
+
certs = load_test_certs
|
65
|
+
GRPC::Core::ServerCredentials.new(
|
66
|
+
nil, [{ private_key: certs[1], cert_chain: certs[2] }], false)
|
67
|
+
end
|
68
|
+
|
69
|
+
def main
|
70
|
+
options = {
|
71
|
+
'host' => 'localhost:9090',
|
72
|
+
'secure' => false
|
73
|
+
}
|
74
|
+
OptionParser.new do |opts|
|
75
|
+
opts.banner = 'Usage: [--host <hostname>:<port>] [--secure|-s]'
|
76
|
+
opts.on('--host HOST', '<hostname>:<port>') do |v|
|
77
|
+
options['host'] = v
|
78
|
+
end
|
79
|
+
opts.on('-s', '--secure', 'access using test creds') do |v|
|
80
|
+
options['secure'] = v
|
81
|
+
end
|
82
|
+
end.parse!
|
83
|
+
|
84
|
+
s = GRPC::RpcServer.new
|
85
|
+
if options['secure']
|
86
|
+
s.add_http2_port(options['host'], test_server_creds)
|
87
|
+
GRPC.logger.info("... running securely on #{options['host']}")
|
88
|
+
else
|
89
|
+
s.add_http2_port(options['host'], :this_port_is_insecure)
|
90
|
+
GRPC.logger.info("... running insecurely on #{options['host']}")
|
91
|
+
end
|
92
|
+
|
93
|
+
s.handle(NoProto)
|
94
|
+
s.run_till_terminated
|
95
|
+
end
|
96
|
+
|
97
|
+
main
|