grpc 0.11.0 → 0.12.0
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 +4 -4
- data/Makefile +29456 -0
- data/Rakefile +13 -8
- data/etc/roots.pem +5114 -0
- data/include/grpc/byte_buffer.h +120 -0
- data/include/grpc/byte_buffer_reader.h +58 -0
- data/include/grpc/census.h +488 -0
- data/include/grpc/compression.h +106 -0
- data/include/grpc/grpc.h +732 -0
- data/include/grpc/grpc_security.h +374 -0
- data/include/grpc/grpc_zookeeper.h +59 -0
- data/include/grpc/status.h +163 -0
- data/include/grpc/support/alloc.h +72 -0
- data/include/grpc/support/atm.h +92 -0
- data/include/grpc/support/atm_gcc_atomic.h +72 -0
- data/include/grpc/support/atm_gcc_sync.h +87 -0
- data/include/grpc/support/atm_win32.h +125 -0
- data/include/grpc/support/avl.h +91 -0
- data/include/grpc/support/cmdline.h +101 -0
- data/include/grpc/support/cpu.h +57 -0
- data/include/grpc/support/histogram.h +76 -0
- data/include/grpc/support/host_port.h +64 -0
- data/include/grpc/support/log.h +108 -0
- data/include/grpc/support/log_win32.h +51 -0
- data/include/grpc/support/port_platform.h +356 -0
- data/include/grpc/support/slice.h +182 -0
- data/include/grpc/support/slice_buffer.h +102 -0
- data/include/grpc/support/string_util.h +61 -0
- data/include/grpc/support/subprocess.h +57 -0
- data/include/grpc/support/sync.h +315 -0
- data/include/grpc/support/sync_generic.h +55 -0
- data/include/grpc/support/sync_posix.h +47 -0
- data/include/grpc/support/sync_win32.h +49 -0
- data/include/grpc/support/thd.h +91 -0
- data/include/grpc/support/time.h +128 -0
- data/include/grpc/support/tls.h +77 -0
- data/include/grpc/support/tls_gcc.h +56 -0
- data/include/grpc/support/tls_msvc.h +56 -0
- data/include/grpc/support/tls_pthread.h +60 -0
- data/include/grpc/support/useful.h +75 -0
- data/src/core/census/aggregation.h +66 -0
- data/src/core/census/context.c +46 -0
- data/src/core/census/context.h +47 -0
- data/src/core/census/grpc_context.c +53 -0
- data/src/core/census/grpc_filter.c +184 -0
- data/src/core/census/grpc_filter.h +44 -0
- data/src/core/census/initialize.c +57 -0
- data/src/core/census/operation.c +63 -0
- data/src/core/census/rpc_metric_id.h +51 -0
- data/src/core/census/tracing.c +45 -0
- data/src/core/channel/channel_args.c +209 -0
- data/src/core/channel/channel_args.h +88 -0
- data/src/core/channel/channel_stack.c +262 -0
- data/src/core/channel/channel_stack.h +260 -0
- data/src/core/channel/client_channel.c +524 -0
- data/src/core/channel/client_channel.h +63 -0
- data/src/core/channel/client_uchannel.c +243 -0
- data/src/core/channel/client_uchannel.h +60 -0
- data/src/core/channel/compress_filter.c +297 -0
- data/src/core/channel/compress_filter.h +65 -0
- data/src/core/channel/connected_channel.c +167 -0
- data/src/core/channel/connected_channel.h +51 -0
- data/src/core/channel/context.h +49 -0
- data/src/core/channel/http_client_filter.c +248 -0
- data/src/core/channel/http_client_filter.h +44 -0
- data/src/core/channel/http_server_filter.c +233 -0
- data/src/core/channel/http_server_filter.h +42 -0
- data/src/core/channel/subchannel_call_holder.c +259 -0
- data/src/core/channel/subchannel_call_holder.h +98 -0
- data/src/core/client_config/client_config.c +72 -0
- data/src/core/client_config/client_config.h +53 -0
- data/src/core/client_config/connector.c +54 -0
- data/src/core/client_config/connector.h +95 -0
- data/src/core/client_config/default_initial_connect_string.c +39 -0
- data/src/core/client_config/initial_connect_string.c +53 -0
- data/src/core/client_config/initial_connect_string.h +50 -0
- data/src/core/client_config/lb_policies/pick_first.c +398 -0
- data/src/core/client_config/lb_policies/pick_first.h +43 -0
- data/src/core/client_config/lb_policies/round_robin.c +537 -0
- data/src/core/client_config/lb_policies/round_robin.h +46 -0
- data/src/core/client_config/lb_policy.c +134 -0
- data/src/core/client_config/lb_policy.h +143 -0
- data/src/core/client_config/lb_policy_factory.c +48 -0
- data/src/core/client_config/lb_policy_factory.h +73 -0
- data/src/core/client_config/lb_policy_registry.c +88 -0
- data/src/core/client_config/lb_policy_registry.h +54 -0
- data/src/core/client_config/resolver.c +82 -0
- data/src/core/client_config/resolver.h +94 -0
- data/src/core/client_config/resolver_factory.c +55 -0
- data/src/core/client_config/resolver_factory.h +82 -0
- data/src/core/client_config/resolver_registry.c +137 -0
- data/src/core/client_config/resolver_registry.h +65 -0
- data/src/core/client_config/resolvers/dns_resolver.c +257 -0
- data/src/core/client_config/resolvers/dns_resolver.h +42 -0
- data/src/core/client_config/resolvers/sockaddr_resolver.c +391 -0
- data/src/core/client_config/resolvers/sockaddr_resolver.h +50 -0
- data/src/core/client_config/subchannel.c +697 -0
- data/src/core/client_config/subchannel.h +165 -0
- data/src/core/client_config/subchannel_factory.c +49 -0
- data/src/core/client_config/subchannel_factory.h +66 -0
- data/src/core/client_config/uri_parser.c +242 -0
- data/src/core/client_config/uri_parser.h +51 -0
- data/src/core/compression/algorithm.c +166 -0
- data/src/core/compression/algorithm_metadata.h +53 -0
- data/src/core/compression/message_compress.c +198 -0
- data/src/core/compression/message_compress.h +52 -0
- data/src/core/debug/trace.c +136 -0
- data/src/core/debug/trace.h +43 -0
- data/src/core/httpcli/format_request.c +120 -0
- data/src/core/httpcli/format_request.h +45 -0
- data/src/core/httpcli/httpcli.c +286 -0
- data/src/core/httpcli/httpcli.h +162 -0
- data/src/core/httpcli/httpcli_security_connector.c +189 -0
- data/src/core/httpcli/parser.c +211 -0
- data/src/core/httpcli/parser.h +64 -0
- data/src/core/iomgr/closure.c +98 -0
- data/src/core/iomgr/closure.h +97 -0
- data/src/core/iomgr/endpoint.c +67 -0
- data/src/core/iomgr/endpoint.h +102 -0
- data/src/core/iomgr/endpoint_pair.h +47 -0
- data/src/core/iomgr/endpoint_pair_posix.c +82 -0
- data/src/core/iomgr/endpoint_pair_windows.c +97 -0
- data/src/core/iomgr/exec_ctx.c +72 -0
- data/src/core/iomgr/exec_ctx.h +78 -0
- data/src/core/iomgr/executor.c +143 -0
- data/src/core/iomgr/executor.h +53 -0
- data/src/core/iomgr/fd_posix.c +438 -0
- data/src/core/iomgr/fd_posix.h +189 -0
- data/src/core/iomgr/iocp_windows.c +206 -0
- data/src/core/iomgr/iocp_windows.h +56 -0
- data/src/core/iomgr/iomgr.c +156 -0
- data/src/core/iomgr/iomgr.h +43 -0
- data/src/core/iomgr/iomgr_internal.h +58 -0
- data/src/core/iomgr/iomgr_posix.c +52 -0
- data/src/core/iomgr/iomgr_posix.h +39 -0
- data/src/core/iomgr/iomgr_windows.c +73 -0
- data/src/core/iomgr/pollset.h +95 -0
- data/src/core/iomgr/pollset_multipoller_with_epoll.c +258 -0
- data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +227 -0
- data/src/core/iomgr/pollset_posix.c +638 -0
- data/src/core/iomgr/pollset_posix.h +147 -0
- data/src/core/iomgr/pollset_set.h +67 -0
- data/src/core/iomgr/pollset_set_posix.c +182 -0
- data/src/core/iomgr/pollset_set_posix.h +61 -0
- data/src/core/iomgr/pollset_set_windows.c +60 -0
- data/src/core/iomgr/pollset_set_windows.h +39 -0
- data/src/core/iomgr/pollset_windows.c +248 -0
- data/src/core/iomgr/pollset_windows.h +79 -0
- data/src/core/iomgr/resolve_address.h +72 -0
- data/src/core/iomgr/resolve_address_posix.c +183 -0
- data/src/core/iomgr/resolve_address_windows.c +166 -0
- data/src/core/iomgr/sockaddr.h +47 -0
- data/src/core/iomgr/sockaddr_posix.h +44 -0
- data/src/core/iomgr/sockaddr_utils.c +234 -0
- data/src/core/iomgr/sockaddr_utils.h +89 -0
- data/src/core/iomgr/sockaddr_win32.h +46 -0
- data/src/core/iomgr/socket_utils_common_posix.c +208 -0
- data/src/core/iomgr/socket_utils_linux.c +51 -0
- data/src/core/iomgr/socket_utils_posix.c +70 -0
- data/src/core/iomgr/socket_utils_posix.h +113 -0
- data/src/core/iomgr/socket_windows.c +98 -0
- data/src/core/iomgr/socket_windows.h +111 -0
- data/src/core/iomgr/tcp_client.h +53 -0
- data/src/core/iomgr/tcp_client_posix.c +304 -0
- data/src/core/iomgr/tcp_client_windows.c +221 -0
- data/src/core/iomgr/tcp_posix.c +485 -0
- data/src/core/iomgr/tcp_posix.h +65 -0
- data/src/core/iomgr/tcp_server.h +83 -0
- data/src/core/iomgr/tcp_server_posix.c +562 -0
- data/src/core/iomgr/tcp_server_windows.c +509 -0
- data/src/core/iomgr/tcp_windows.c +406 -0
- data/src/core/iomgr/tcp_windows.h +57 -0
- data/src/core/iomgr/time_averaged_stats.c +77 -0
- data/src/core/iomgr/time_averaged_stats.h +88 -0
- data/src/core/iomgr/timer.c +345 -0
- data/src/core/iomgr/timer.h +89 -0
- data/src/core/iomgr/timer_heap.c +148 -0
- data/src/core/iomgr/timer_heap.h +57 -0
- data/src/core/iomgr/timer_internal.h +61 -0
- data/src/core/iomgr/udp_server.c +439 -0
- data/src/core/iomgr/udp_server.h +83 -0
- data/src/core/iomgr/wakeup_fd_eventfd.c +85 -0
- data/src/core/iomgr/wakeup_fd_nospecial.c +51 -0
- data/src/core/iomgr/wakeup_fd_pipe.c +97 -0
- data/src/core/iomgr/wakeup_fd_pipe.h +41 -0
- data/src/core/iomgr/wakeup_fd_posix.c +72 -0
- data/src/core/iomgr/wakeup_fd_posix.h +101 -0
- data/src/core/iomgr/workqueue.h +85 -0
- data/src/core/iomgr/workqueue_posix.c +143 -0
- data/src/core/iomgr/workqueue_posix.h +51 -0
- data/src/core/iomgr/workqueue_windows.c +40 -0
- data/src/core/iomgr/workqueue_windows.h +37 -0
- data/src/core/json/json.c +64 -0
- data/src/core/json/json.h +88 -0
- data/src/core/json/json_common.h +49 -0
- data/src/core/json/json_reader.c +660 -0
- data/src/core/json/json_reader.h +160 -0
- data/src/core/json/json_string.c +379 -0
- data/src/core/json/json_writer.c +260 -0
- data/src/core/json/json_writer.h +97 -0
- data/src/core/profiling/basic_timers.c +274 -0
- data/src/core/profiling/stap_timers.c +65 -0
- data/src/core/profiling/timers.h +119 -0
- data/src/core/security/auth_filters.h +42 -0
- data/src/core/security/base64.c +233 -0
- data/src/core/security/base64.h +52 -0
- data/src/core/security/client_auth_filter.c +337 -0
- data/src/core/security/credentials.c +1273 -0
- data/src/core/security/credentials.h +376 -0
- data/src/core/security/credentials_metadata.c +101 -0
- data/src/core/security/credentials_posix.c +61 -0
- data/src/core/security/credentials_win32.c +61 -0
- data/src/core/security/google_default_credentials.c +260 -0
- data/src/core/security/handshake.c +327 -0
- data/src/core/security/handshake.h +50 -0
- data/src/core/security/json_token.c +405 -0
- data/src/core/security/json_token.h +118 -0
- data/src/core/security/jwt_verifier.c +842 -0
- data/src/core/security/jwt_verifier.h +136 -0
- data/src/core/security/secure_endpoint.c +383 -0
- data/src/core/security/secure_endpoint.h +49 -0
- data/src/core/security/security_connector.c +756 -0
- data/src/core/security/security_connector.h +246 -0
- data/src/core/security/security_context.c +342 -0
- data/src/core/security/security_context.h +114 -0
- data/src/core/security/server_auth_filter.c +264 -0
- data/src/core/security/server_secure_chttp2.c +268 -0
- data/src/core/statistics/census_interface.h +76 -0
- data/src/core/statistics/census_rpc_stats.h +101 -0
- data/src/core/support/alloc.c +90 -0
- data/src/core/support/avl.c +288 -0
- data/src/core/support/block_annotate.h +48 -0
- data/src/core/support/cmdline.c +347 -0
- data/src/core/support/cpu_iphone.c +49 -0
- data/src/core/support/cpu_linux.c +78 -0
- data/src/core/support/cpu_posix.c +77 -0
- data/src/core/support/cpu_windows.c +47 -0
- data/src/core/support/env.h +60 -0
- data/src/core/support/env_linux.c +62 -0
- data/src/core/support/env_posix.c +57 -0
- data/src/core/support/env_win32.c +65 -0
- data/src/core/support/file.c +91 -0
- data/src/core/support/file.h +63 -0
- data/src/core/support/file_posix.c +85 -0
- data/src/core/support/file_win32.c +84 -0
- data/src/core/support/histogram.c +244 -0
- data/src/core/support/host_port.c +110 -0
- data/src/core/support/log.c +66 -0
- data/src/core/support/log_android.c +87 -0
- data/src/core/support/log_linux.c +105 -0
- data/src/core/support/log_posix.c +102 -0
- data/src/core/support/log_win32.c +125 -0
- data/src/core/support/murmur_hash.c +96 -0
- data/src/core/support/murmur_hash.h +44 -0
- data/src/core/support/slice.c +343 -0
- data/src/core/support/slice_buffer.c +282 -0
- data/src/core/support/stack_lockfree.c +175 -0
- data/src/core/support/stack_lockfree.h +53 -0
- data/src/core/support/string.c +296 -0
- data/src/core/support/string.h +121 -0
- data/src/core/support/string_posix.c +86 -0
- data/src/core/support/string_win32.c +109 -0
- data/src/core/support/string_win32.h +47 -0
- data/src/core/support/subprocess_posix.c +112 -0
- data/src/core/support/sync.c +122 -0
- data/src/core/support/sync_posix.c +104 -0
- data/src/core/support/sync_win32.c +128 -0
- data/src/core/support/thd.c +64 -0
- data/src/core/support/thd_internal.h +39 -0
- data/src/core/support/thd_posix.c +94 -0
- data/src/core/support/thd_win32.c +117 -0
- data/src/core/support/time.c +304 -0
- data/src/core/support/time_posix.c +161 -0
- data/src/core/support/time_precise.c +89 -0
- data/src/core/support/time_precise.h +42 -0
- data/src/core/support/time_win32.c +101 -0
- data/src/core/support/tls_pthread.c +45 -0
- data/src/core/surface/api_trace.c +36 -0
- data/src/core/surface/api_trace.h +65 -0
- data/src/core/surface/byte_buffer.c +97 -0
- data/src/core/surface/byte_buffer_reader.c +123 -0
- data/src/core/surface/call.c +1424 -0
- data/src/core/surface/call.h +109 -0
- data/src/core/surface/call_details.c +50 -0
- data/src/core/surface/call_log_batch.c +118 -0
- data/src/core/surface/call_test_only.h +64 -0
- data/src/core/surface/channel.c +327 -0
- data/src/core/surface/channel.h +74 -0
- data/src/core/surface/channel_connectivity.c +220 -0
- data/src/core/surface/channel_create.c +235 -0
- data/src/core/surface/channel_ping.c +79 -0
- data/src/core/surface/completion_queue.c +481 -0
- data/src/core/surface/completion_queue.h +91 -0
- data/src/core/surface/event_string.c +81 -0
- data/src/core/surface/event_string.h +42 -0
- data/src/core/surface/init.c +168 -0
- data/src/core/surface/init.h +40 -0
- data/src/core/surface/init_secure.c +42 -0
- data/src/core/surface/lame_client.c +149 -0
- data/src/core/surface/metadata_array.c +49 -0
- data/src/core/surface/secure_channel_create.c +336 -0
- data/src/core/surface/server.c +1343 -0
- data/src/core/surface/server.h +67 -0
- data/src/core/surface/server_chttp2.c +149 -0
- data/src/core/surface/server_create.c +51 -0
- data/src/core/surface/surface_trace.h +48 -0
- data/src/core/surface/validate_metadata.c +73 -0
- data/src/core/surface/version.c +39 -0
- data/src/core/transport/byte_stream.c +76 -0
- data/src/core/transport/byte_stream.h +88 -0
- data/src/core/transport/chttp2/alpn.c +56 -0
- data/src/core/transport/chttp2/alpn.h +49 -0
- data/src/core/transport/chttp2/bin_encoder.c +285 -0
- data/src/core/transport/chttp2/bin_encoder.h +54 -0
- data/src/core/transport/chttp2/frame.h +69 -0
- data/src/core/transport/chttp2/frame_data.c +245 -0
- data/src/core/transport/chttp2/frame_data.h +101 -0
- data/src/core/transport/chttp2/frame_goaway.c +193 -0
- data/src/core/transport/chttp2/frame_goaway.h +77 -0
- data/src/core/transport/chttp2/frame_ping.c +97 -0
- data/src/core/transport/chttp2/frame_ping.h +56 -0
- data/src/core/transport/chttp2/frame_rst_stream.c +100 -0
- data/src/core/transport/chttp2/frame_rst_stream.h +55 -0
- data/src/core/transport/chttp2/frame_settings.c +259 -0
- data/src/core/transport/chttp2/frame_settings.h +103 -0
- data/src/core/transport/chttp2/frame_window_update.c +114 -0
- data/src/core/transport/chttp2/frame_window_update.h +58 -0
- data/src/core/transport/chttp2/hpack_encoder.c +572 -0
- data/src/core/transport/chttp2/hpack_encoder.h +95 -0
- data/src/core/transport/chttp2/hpack_parser.c +1449 -0
- data/src/core/transport/chttp2/hpack_parser.h +116 -0
- data/src/core/transport/chttp2/hpack_table.c +361 -0
- data/src/core/transport/chttp2/hpack_table.h +108 -0
- data/src/core/transport/chttp2/http2_errors.h +56 -0
- data/src/core/transport/chttp2/huffsyms.c +297 -0
- data/src/core/transport/chttp2/huffsyms.h +48 -0
- data/src/core/transport/chttp2/incoming_metadata.c +96 -0
- data/src/core/transport/chttp2/incoming_metadata.h +60 -0
- data/src/core/transport/chttp2/internal.h +757 -0
- data/src/core/transport/chttp2/parsing.c +866 -0
- data/src/core/transport/chttp2/status_conversion.c +109 -0
- data/src/core/transport/chttp2/status_conversion.h +50 -0
- data/src/core/transport/chttp2/stream_lists.c +401 -0
- data/src/core/transport/chttp2/stream_map.c +198 -0
- data/src/core/transport/chttp2/stream_map.h +85 -0
- data/src/core/transport/chttp2/timeout_encoding.c +185 -0
- data/src/core/transport/chttp2/timeout_encoding.h +47 -0
- data/src/core/transport/chttp2/varint.c +66 -0
- data/src/core/transport/chttp2/varint.h +76 -0
- data/src/core/transport/chttp2/writing.c +356 -0
- data/src/core/transport/chttp2_transport.c +1692 -0
- data/src/core/transport/chttp2_transport.h +51 -0
- data/src/core/transport/connectivity_state.c +164 -0
- data/src/core/transport/connectivity_state.h +85 -0
- data/src/core/transport/metadata.c +690 -0
- data/src/core/transport/metadata.h +156 -0
- data/src/core/transport/metadata_batch.c +194 -0
- data/src/core/transport/metadata_batch.h +125 -0
- data/src/core/transport/static_metadata.c +90 -0
- data/src/core/transport/static_metadata.h +408 -0
- data/src/core/transport/transport.c +183 -0
- data/src/core/transport/transport.h +222 -0
- data/src/core/transport/transport_impl.h +78 -0
- data/src/core/transport/transport_op_string.c +140 -0
- data/src/core/tsi/fake_transport_security.c +525 -0
- data/src/core/tsi/fake_transport_security.h +61 -0
- data/src/core/tsi/ssl_transport_security.c +1467 -0
- data/src/core/tsi/ssl_transport_security.h +173 -0
- data/src/core/tsi/transport_security.c +284 -0
- data/src/core/tsi/transport_security.h +111 -0
- data/src/core/tsi/transport_security_interface.h +344 -0
- data/{bin → src/ruby/bin}/apis/google/protobuf/empty.rb +0 -0
- data/{bin → src/ruby/bin}/apis/pubsub_demo.rb +7 -15
- data/{bin → src/ruby/bin}/apis/tech/pubsub/proto/pubsub.rb +0 -0
- data/{bin → src/ruby/bin}/apis/tech/pubsub/proto/pubsub_services.rb +0 -0
- data/{bin → src/ruby/bin}/grpc_ruby_interop_client +0 -0
- data/{bin → src/ruby/bin}/grpc_ruby_interop_server +0 -0
- data/{bin → src/ruby/bin}/interop/interop_client.rb +0 -0
- data/{bin → src/ruby/bin}/interop/interop_server.rb +0 -0
- data/src/ruby/bin/math.rb +32 -0
- data/{bin → src/ruby/bin}/math_client.rb +1 -1
- data/{bin → src/ruby/bin}/math_server.rb +1 -1
- data/src/ruby/bin/math_services.rb +27 -0
- data/{bin → src/ruby/bin}/noproto_client.rb +1 -1
- data/{bin → src/ruby/bin}/noproto_server.rb +1 -1
- data/{ext → src/ruby/ext}/grpc/extconf.rb +24 -40
- data/{ext → src/ruby/ext}/grpc/rb_byte_buffer.c +0 -0
- data/{ext → src/ruby/ext}/grpc/rb_byte_buffer.h +0 -0
- data/{ext → src/ruby/ext}/grpc/rb_call.c +80 -18
- data/{ext → src/ruby/ext}/grpc/rb_call.h +6 -0
- data/src/ruby/ext/grpc/rb_call_credentials.c +315 -0
- data/src/ruby/ext/grpc/rb_call_credentials.h +46 -0
- data/{ext → src/ruby/ext}/grpc/rb_channel.c +19 -7
- data/{ext → src/ruby/ext}/grpc/rb_channel.h +0 -0
- data/{ext → src/ruby/ext}/grpc/rb_channel_args.c +2 -0
- data/{ext → src/ruby/ext}/grpc/rb_channel_args.h +0 -0
- data/src/ruby/ext/grpc/rb_channel_credentials.c +266 -0
- data/{ext/grpc/rb_credentials.h → src/ruby/ext/grpc/rb_channel_credentials.h} +3 -3
- data/{ext → src/ruby/ext}/grpc/rb_completion_queue.c +3 -1
- data/{ext → src/ruby/ext}/grpc/rb_completion_queue.h +0 -0
- data/src/ruby/ext/grpc/rb_event_thread.c +153 -0
- data/src/ruby/ext/grpc/rb_event_thread.h +37 -0
- data/{ext → src/ruby/ext}/grpc/rb_grpc.c +25 -5
- data/{ext → src/ruby/ext}/grpc/rb_grpc.h +0 -0
- data/{ext → src/ruby/ext}/grpc/rb_server.c +4 -1
- data/{ext → src/ruby/ext}/grpc/rb_server.h +0 -0
- data/{ext → src/ruby/ext}/grpc/rb_server_credentials.c +2 -0
- data/{ext → src/ruby/ext}/grpc/rb_server_credentials.h +0 -0
- data/{lib → src/ruby/lib}/grpc.rb +6 -1
- data/{lib → src/ruby/lib}/grpc/core/time_consts.rb +0 -0
- data/{lib → src/ruby/lib}/grpc/errors.rb +0 -0
- data/{lib → src/ruby/lib}/grpc/generic/active_call.rb +4 -6
- data/{lib → src/ruby/lib}/grpc/generic/bidi_call.rb +16 -4
- data/{lib → src/ruby/lib}/grpc/generic/client_stub.rb +42 -52
- data/{lib → src/ruby/lib}/grpc/generic/rpc_desc.rb +0 -0
- data/{lib → src/ruby/lib}/grpc/generic/rpc_server.rb +15 -8
- data/{lib → src/ruby/lib}/grpc/generic/service.rb +4 -2
- data/src/ruby/lib/grpc/grpc.so +0 -0
- data/{lib → src/ruby/lib}/grpc/logconfig.rb +0 -0
- data/{lib → src/ruby/lib}/grpc/notifier.rb +0 -0
- data/{lib → src/ruby/lib}/grpc/version.rb +2 -2
- data/src/ruby/pb/README.md +42 -0
- data/src/ruby/pb/generate_proto_ruby.sh +51 -0
- data/src/ruby/pb/grpc/health/checker.rb +75 -0
- data/src/ruby/pb/grpc/health/v1alpha/health.rb +29 -0
- data/src/ruby/pb/grpc/health/v1alpha/health_services.rb +28 -0
- data/src/ruby/pb/test/client.rb +469 -0
- data/src/ruby/pb/test/proto/empty.rb +15 -0
- data/src/ruby/pb/test/proto/messages.rb +80 -0
- data/src/ruby/pb/test/proto/test.rb +14 -0
- data/src/ruby/pb/test/proto/test_services.rb +64 -0
- data/src/ruby/pb/test/server.rb +253 -0
- data/{bin/math_services.rb → src/ruby/spec/call_credentials_spec.rb} +19 -18
- data/{spec → src/ruby/spec}/call_spec.rb +10 -1
- data/{spec/credentials_spec.rb → src/ruby/spec/channel_credentials_spec.rb} +38 -12
- data/{spec → src/ruby/spec}/channel_spec.rb +14 -9
- data/{spec → src/ruby/spec}/client_server_spec.rb +31 -2
- data/{spec → src/ruby/spec}/completion_queue_spec.rb +0 -0
- data/{spec → src/ruby/spec}/generic/active_call_spec.rb +2 -1
- data/{spec → src/ruby/spec}/generic/client_stub_spec.rb +27 -67
- data/{spec → src/ruby/spec}/generic/rpc_desc_spec.rb +0 -0
- data/{spec → src/ruby/spec}/generic/rpc_server_pool_spec.rb +0 -0
- data/{spec → src/ruby/spec}/generic/rpc_server_spec.rb +12 -46
- data/{spec → src/ruby/spec}/generic/service_spec.rb +6 -3
- data/{spec → src/ruby/spec}/pb/health/checker_spec.rb +8 -8
- data/{spec → src/ruby/spec}/server_credentials_spec.rb +0 -0
- data/{spec → src/ruby/spec}/server_spec.rb +0 -0
- data/{spec → src/ruby/spec}/spec_helper.rb +0 -0
- data/{spec → src/ruby/spec}/testdata/README +0 -0
- data/{spec → src/ruby/spec}/testdata/ca.pem +0 -0
- data/{spec → src/ruby/spec}/testdata/server1.key +0 -0
- data/src/ruby/spec/testdata/server1.pem +16 -0
- data/{spec → src/ruby/spec}/time_consts_spec.rb +0 -0
- metadata +496 -97
- data/bin/math.proto +0 -80
- data/bin/math.rb +0 -61
- data/ext/grpc/rb_credentials.c +0 -294
- data/lib/grpc/grpc.so +0 -0
- data/spec/testdata/server1.pem +0 -16
@@ -0,0 +1,54 @@
|
|
1
|
+
/*
|
2
|
+
*
|
3
|
+
* Copyright 2015-2016, Google Inc.
|
4
|
+
* All rights reserved.
|
5
|
+
*
|
6
|
+
* Redistribution and use in source and binary forms, with or without
|
7
|
+
* modification, are permitted provided that the following conditions are
|
8
|
+
* met:
|
9
|
+
*
|
10
|
+
* * Redistributions of source code must retain the above copyright
|
11
|
+
* notice, this list of conditions and the following disclaimer.
|
12
|
+
* * Redistributions in binary form must reproduce the above
|
13
|
+
* copyright notice, this list of conditions and the following disclaimer
|
14
|
+
* in the documentation and/or other materials provided with the
|
15
|
+
* distribution.
|
16
|
+
* * Neither the name of Google Inc. nor the names of its
|
17
|
+
* contributors may be used to endorse or promote products derived from
|
18
|
+
* this software without specific prior written permission.
|
19
|
+
*
|
20
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
21
|
+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
22
|
+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
23
|
+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
24
|
+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
25
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
26
|
+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
27
|
+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
28
|
+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
29
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
30
|
+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
*
|
32
|
+
*/
|
33
|
+
|
34
|
+
#ifndef GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_BIN_ENCODER_H
|
35
|
+
#define GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_BIN_ENCODER_H
|
36
|
+
|
37
|
+
#include <grpc/support/slice.h>
|
38
|
+
|
39
|
+
/* base64 encode a slice. Returns a new slice, does not take ownership of the
|
40
|
+
input */
|
41
|
+
gpr_slice grpc_chttp2_base64_encode(gpr_slice input);
|
42
|
+
|
43
|
+
/* Compress a slice with the static huffman encoder detailed in the hpack
|
44
|
+
standard. Returns a new slice, does not take ownership of the input */
|
45
|
+
gpr_slice grpc_chttp2_huffman_compress(gpr_slice input);
|
46
|
+
|
47
|
+
/* equivalent to:
|
48
|
+
gpr_slice x = grpc_chttp2_base64_encode(input);
|
49
|
+
gpr_slice y = grpc_chttp2_huffman_compress(x);
|
50
|
+
gpr_slice_unref(x);
|
51
|
+
return y; */
|
52
|
+
gpr_slice grpc_chttp2_base64_encode_and_huffman_compress(gpr_slice input);
|
53
|
+
|
54
|
+
#endif /* GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_BIN_ENCODER_H */
|
@@ -0,0 +1,69 @@
|
|
1
|
+
/*
|
2
|
+
*
|
3
|
+
* Copyright 2015, Google Inc.
|
4
|
+
* All rights reserved.
|
5
|
+
*
|
6
|
+
* Redistribution and use in source and binary forms, with or without
|
7
|
+
* modification, are permitted provided that the following conditions are
|
8
|
+
* met:
|
9
|
+
*
|
10
|
+
* * Redistributions of source code must retain the above copyright
|
11
|
+
* notice, this list of conditions and the following disclaimer.
|
12
|
+
* * Redistributions in binary form must reproduce the above
|
13
|
+
* copyright notice, this list of conditions and the following disclaimer
|
14
|
+
* in the documentation and/or other materials provided with the
|
15
|
+
* distribution.
|
16
|
+
* * Neither the name of Google Inc. nor the names of its
|
17
|
+
* contributors may be used to endorse or promote products derived from
|
18
|
+
* this software without specific prior written permission.
|
19
|
+
*
|
20
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
21
|
+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
22
|
+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
23
|
+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
24
|
+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
25
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
26
|
+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
27
|
+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
28
|
+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
29
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
30
|
+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
*
|
32
|
+
*/
|
33
|
+
|
34
|
+
#ifndef GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_H
|
35
|
+
#define GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_H
|
36
|
+
|
37
|
+
#include <grpc/support/port_platform.h>
|
38
|
+
#include <grpc/support/slice.h>
|
39
|
+
|
40
|
+
/* Common definitions for frame handling in the chttp2 transport */
|
41
|
+
|
42
|
+
typedef enum {
|
43
|
+
GRPC_CHTTP2_PARSE_OK,
|
44
|
+
GRPC_CHTTP2_STREAM_ERROR,
|
45
|
+
GRPC_CHTTP2_CONNECTION_ERROR
|
46
|
+
} grpc_chttp2_parse_error;
|
47
|
+
|
48
|
+
/* defined in internal.h */
|
49
|
+
typedef struct grpc_chttp2_stream_parsing grpc_chttp2_stream_parsing;
|
50
|
+
typedef struct grpc_chttp2_transport_parsing grpc_chttp2_transport_parsing;
|
51
|
+
|
52
|
+
#define GRPC_CHTTP2_FRAME_DATA 0
|
53
|
+
#define GRPC_CHTTP2_FRAME_HEADER 1
|
54
|
+
#define GRPC_CHTTP2_FRAME_CONTINUATION 9
|
55
|
+
#define GRPC_CHTTP2_FRAME_RST_STREAM 3
|
56
|
+
#define GRPC_CHTTP2_FRAME_SETTINGS 4
|
57
|
+
#define GRPC_CHTTP2_FRAME_PING 6
|
58
|
+
#define GRPC_CHTTP2_FRAME_GOAWAY 7
|
59
|
+
#define GRPC_CHTTP2_FRAME_WINDOW_UPDATE 8
|
60
|
+
|
61
|
+
#define GRPC_CHTTP2_MAX_PAYLOAD_LENGTH ((1 << 14) - 1)
|
62
|
+
|
63
|
+
#define GRPC_CHTTP2_DATA_FLAG_END_STREAM 1
|
64
|
+
#define GRPC_CHTTP2_FLAG_ACK 1
|
65
|
+
#define GRPC_CHTTP2_DATA_FLAG_END_HEADERS 4
|
66
|
+
#define GRPC_CHTTP2_DATA_FLAG_PADDED 8
|
67
|
+
#define GRPC_CHTTP2_FLAG_HAS_PRIORITY 0x20
|
68
|
+
|
69
|
+
#endif /* GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_H */
|
@@ -0,0 +1,245 @@
|
|
1
|
+
/*
|
2
|
+
*
|
3
|
+
* Copyright 2015, Google Inc.
|
4
|
+
* All rights reserved.
|
5
|
+
*
|
6
|
+
* Redistribution and use in source and binary forms, with or without
|
7
|
+
* modification, are permitted provided that the following conditions are
|
8
|
+
* met:
|
9
|
+
*
|
10
|
+
* * Redistributions of source code must retain the above copyright
|
11
|
+
* notice, this list of conditions and the following disclaimer.
|
12
|
+
* * Redistributions in binary form must reproduce the above
|
13
|
+
* copyright notice, this list of conditions and the following disclaimer
|
14
|
+
* in the documentation and/or other materials provided with the
|
15
|
+
* distribution.
|
16
|
+
* * Neither the name of Google Inc. nor the names of its
|
17
|
+
* contributors may be used to endorse or promote products derived from
|
18
|
+
* this software without specific prior written permission.
|
19
|
+
*
|
20
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
21
|
+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
22
|
+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
23
|
+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
24
|
+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
25
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
26
|
+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
27
|
+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
28
|
+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
29
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
30
|
+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
*
|
32
|
+
*/
|
33
|
+
|
34
|
+
#include "src/core/transport/chttp2/frame_data.h"
|
35
|
+
|
36
|
+
#include <string.h>
|
37
|
+
|
38
|
+
#include "src/core/transport/chttp2/internal.h"
|
39
|
+
#include "src/core/support/string.h"
|
40
|
+
#include <grpc/support/alloc.h>
|
41
|
+
#include <grpc/support/log.h>
|
42
|
+
#include <grpc/support/useful.h>
|
43
|
+
#include "src/core/transport/transport.h"
|
44
|
+
|
45
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_init(
|
46
|
+
grpc_chttp2_data_parser *parser) {
|
47
|
+
parser->state = GRPC_CHTTP2_DATA_FH_0;
|
48
|
+
parser->parsing_frame = NULL;
|
49
|
+
return GRPC_CHTTP2_PARSE_OK;
|
50
|
+
}
|
51
|
+
|
52
|
+
void grpc_chttp2_data_parser_destroy(grpc_exec_ctx *exec_ctx,
|
53
|
+
grpc_chttp2_data_parser *parser) {
|
54
|
+
grpc_byte_stream *bs;
|
55
|
+
if (parser->parsing_frame) {
|
56
|
+
grpc_chttp2_incoming_byte_stream_finished(exec_ctx, parser->parsing_frame);
|
57
|
+
}
|
58
|
+
while (
|
59
|
+
(bs = grpc_chttp2_incoming_frame_queue_pop(&parser->incoming_frames))) {
|
60
|
+
grpc_byte_stream_destroy(bs);
|
61
|
+
}
|
62
|
+
}
|
63
|
+
|
64
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_begin_frame(
|
65
|
+
grpc_chttp2_data_parser *parser, gpr_uint8 flags) {
|
66
|
+
if (flags & ~GRPC_CHTTP2_DATA_FLAG_END_STREAM) {
|
67
|
+
gpr_log(GPR_ERROR, "unsupported data flags: 0x%02x", flags);
|
68
|
+
return GRPC_CHTTP2_STREAM_ERROR;
|
69
|
+
}
|
70
|
+
|
71
|
+
if (flags & GRPC_CHTTP2_DATA_FLAG_END_STREAM) {
|
72
|
+
parser->is_last_frame = 1;
|
73
|
+
} else {
|
74
|
+
parser->is_last_frame = 0;
|
75
|
+
}
|
76
|
+
|
77
|
+
return GRPC_CHTTP2_PARSE_OK;
|
78
|
+
}
|
79
|
+
|
80
|
+
void grpc_chttp2_incoming_frame_queue_merge(
|
81
|
+
grpc_chttp2_incoming_frame_queue *head_dst,
|
82
|
+
grpc_chttp2_incoming_frame_queue *tail_src) {
|
83
|
+
if (tail_src->head == NULL) {
|
84
|
+
return;
|
85
|
+
}
|
86
|
+
|
87
|
+
if (head_dst->head == NULL) {
|
88
|
+
*head_dst = *tail_src;
|
89
|
+
memset(tail_src, 0, sizeof(*tail_src));
|
90
|
+
return;
|
91
|
+
}
|
92
|
+
|
93
|
+
head_dst->tail->next_message = tail_src->head;
|
94
|
+
head_dst->tail = tail_src->tail;
|
95
|
+
memset(tail_src, 0, sizeof(*tail_src));
|
96
|
+
}
|
97
|
+
|
98
|
+
grpc_byte_stream *grpc_chttp2_incoming_frame_queue_pop(
|
99
|
+
grpc_chttp2_incoming_frame_queue *q) {
|
100
|
+
grpc_byte_stream *out;
|
101
|
+
if (q->head == NULL) {
|
102
|
+
return NULL;
|
103
|
+
}
|
104
|
+
out = &q->head->base;
|
105
|
+
if (q->head == q->tail) {
|
106
|
+
memset(q, 0, sizeof(*q));
|
107
|
+
} else {
|
108
|
+
q->head = q->head->next_message;
|
109
|
+
}
|
110
|
+
return out;
|
111
|
+
}
|
112
|
+
|
113
|
+
void grpc_chttp2_encode_data(gpr_uint32 id, gpr_slice_buffer *inbuf,
|
114
|
+
gpr_uint32 write_bytes, int is_eof,
|
115
|
+
gpr_slice_buffer *outbuf) {
|
116
|
+
gpr_slice hdr;
|
117
|
+
gpr_uint8 *p;
|
118
|
+
|
119
|
+
hdr = gpr_slice_malloc(9);
|
120
|
+
p = GPR_SLICE_START_PTR(hdr);
|
121
|
+
GPR_ASSERT(write_bytes < (1 << 24));
|
122
|
+
*p++ = (gpr_uint8)(write_bytes >> 16);
|
123
|
+
*p++ = (gpr_uint8)(write_bytes >> 8);
|
124
|
+
*p++ = (gpr_uint8)(write_bytes);
|
125
|
+
*p++ = GRPC_CHTTP2_FRAME_DATA;
|
126
|
+
*p++ = is_eof ? GRPC_CHTTP2_DATA_FLAG_END_STREAM : 0;
|
127
|
+
*p++ = (gpr_uint8)(id >> 24);
|
128
|
+
*p++ = (gpr_uint8)(id >> 16);
|
129
|
+
*p++ = (gpr_uint8)(id >> 8);
|
130
|
+
*p++ = (gpr_uint8)(id);
|
131
|
+
gpr_slice_buffer_add(outbuf, hdr);
|
132
|
+
|
133
|
+
gpr_slice_buffer_move_first(inbuf, write_bytes, outbuf);
|
134
|
+
}
|
135
|
+
|
136
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_parse(
|
137
|
+
grpc_exec_ctx *exec_ctx, void *parser,
|
138
|
+
grpc_chttp2_transport_parsing *transport_parsing,
|
139
|
+
grpc_chttp2_stream_parsing *stream_parsing, gpr_slice slice, int is_last) {
|
140
|
+
gpr_uint8 *const beg = GPR_SLICE_START_PTR(slice);
|
141
|
+
gpr_uint8 *const end = GPR_SLICE_END_PTR(slice);
|
142
|
+
gpr_uint8 *cur = beg;
|
143
|
+
grpc_chttp2_data_parser *p = parser;
|
144
|
+
gpr_uint32 message_flags;
|
145
|
+
grpc_chttp2_incoming_byte_stream *incoming_byte_stream;
|
146
|
+
|
147
|
+
if (is_last && p->is_last_frame) {
|
148
|
+
stream_parsing->received_close = 1;
|
149
|
+
}
|
150
|
+
|
151
|
+
if (cur == end) {
|
152
|
+
return GRPC_CHTTP2_PARSE_OK;
|
153
|
+
}
|
154
|
+
|
155
|
+
switch (p->state) {
|
156
|
+
fh_0:
|
157
|
+
case GRPC_CHTTP2_DATA_FH_0:
|
158
|
+
p->frame_type = *cur;
|
159
|
+
switch (p->frame_type) {
|
160
|
+
case 0:
|
161
|
+
p->is_frame_compressed = 0; /* GPR_FALSE */
|
162
|
+
break;
|
163
|
+
case 1:
|
164
|
+
p->is_frame_compressed = 1; /* GPR_TRUE */
|
165
|
+
break;
|
166
|
+
default:
|
167
|
+
gpr_log(GPR_ERROR, "Bad GRPC frame type 0x%02x", p->frame_type);
|
168
|
+
return GRPC_CHTTP2_STREAM_ERROR;
|
169
|
+
}
|
170
|
+
if (++cur == end) {
|
171
|
+
p->state = GRPC_CHTTP2_DATA_FH_1;
|
172
|
+
return GRPC_CHTTP2_PARSE_OK;
|
173
|
+
}
|
174
|
+
/* fallthrough */
|
175
|
+
case GRPC_CHTTP2_DATA_FH_1:
|
176
|
+
p->frame_size = ((gpr_uint32)*cur) << 24;
|
177
|
+
if (++cur == end) {
|
178
|
+
p->state = GRPC_CHTTP2_DATA_FH_2;
|
179
|
+
return GRPC_CHTTP2_PARSE_OK;
|
180
|
+
}
|
181
|
+
/* fallthrough */
|
182
|
+
case GRPC_CHTTP2_DATA_FH_2:
|
183
|
+
p->frame_size |= ((gpr_uint32)*cur) << 16;
|
184
|
+
if (++cur == end) {
|
185
|
+
p->state = GRPC_CHTTP2_DATA_FH_3;
|
186
|
+
return GRPC_CHTTP2_PARSE_OK;
|
187
|
+
}
|
188
|
+
/* fallthrough */
|
189
|
+
case GRPC_CHTTP2_DATA_FH_3:
|
190
|
+
p->frame_size |= ((gpr_uint32)*cur) << 8;
|
191
|
+
if (++cur == end) {
|
192
|
+
p->state = GRPC_CHTTP2_DATA_FH_4;
|
193
|
+
return GRPC_CHTTP2_PARSE_OK;
|
194
|
+
}
|
195
|
+
/* fallthrough */
|
196
|
+
case GRPC_CHTTP2_DATA_FH_4:
|
197
|
+
p->frame_size |= ((gpr_uint32)*cur);
|
198
|
+
p->state = GRPC_CHTTP2_DATA_FRAME;
|
199
|
+
++cur;
|
200
|
+
message_flags = 0;
|
201
|
+
if (p->is_frame_compressed) {
|
202
|
+
message_flags |= GRPC_WRITE_INTERNAL_COMPRESS;
|
203
|
+
}
|
204
|
+
p->parsing_frame = incoming_byte_stream =
|
205
|
+
grpc_chttp2_incoming_byte_stream_create(
|
206
|
+
exec_ctx, transport_parsing, stream_parsing, p->frame_size,
|
207
|
+
message_flags, &p->incoming_frames);
|
208
|
+
/* fallthrough */
|
209
|
+
case GRPC_CHTTP2_DATA_FRAME:
|
210
|
+
if (cur == end) {
|
211
|
+
grpc_chttp2_list_add_parsing_seen_stream(transport_parsing,
|
212
|
+
stream_parsing);
|
213
|
+
return GRPC_CHTTP2_PARSE_OK;
|
214
|
+
}
|
215
|
+
grpc_chttp2_list_add_parsing_seen_stream(transport_parsing,
|
216
|
+
stream_parsing);
|
217
|
+
if ((gpr_uint32)(end - cur) == p->frame_size) {
|
218
|
+
grpc_chttp2_incoming_byte_stream_push(
|
219
|
+
exec_ctx, p->parsing_frame,
|
220
|
+
gpr_slice_sub(slice, (size_t)(cur - beg), (size_t)(end - beg)));
|
221
|
+
grpc_chttp2_incoming_byte_stream_finished(exec_ctx, p->parsing_frame);
|
222
|
+
p->parsing_frame = NULL;
|
223
|
+
p->state = GRPC_CHTTP2_DATA_FH_0;
|
224
|
+
return GRPC_CHTTP2_PARSE_OK;
|
225
|
+
} else if ((gpr_uint32)(end - cur) > p->frame_size) {
|
226
|
+
grpc_chttp2_incoming_byte_stream_push(
|
227
|
+
exec_ctx, p->parsing_frame,
|
228
|
+
gpr_slice_sub(slice, (size_t)(cur - beg),
|
229
|
+
(size_t)(cur + p->frame_size - beg)));
|
230
|
+
grpc_chttp2_incoming_byte_stream_finished(exec_ctx, p->parsing_frame);
|
231
|
+
p->parsing_frame = NULL;
|
232
|
+
cur += p->frame_size;
|
233
|
+
goto fh_0; /* loop */
|
234
|
+
} else {
|
235
|
+
grpc_chttp2_incoming_byte_stream_push(
|
236
|
+
exec_ctx, p->parsing_frame,
|
237
|
+
gpr_slice_sub(slice, (size_t)(cur - beg), (size_t)(end - beg)));
|
238
|
+
GPR_ASSERT((size_t)(end - cur) <= p->frame_size);
|
239
|
+
p->frame_size -= (gpr_uint32)(end - cur);
|
240
|
+
return GRPC_CHTTP2_PARSE_OK;
|
241
|
+
}
|
242
|
+
}
|
243
|
+
|
244
|
+
GPR_UNREACHABLE_CODE(return GRPC_CHTTP2_CONNECTION_ERROR);
|
245
|
+
}
|
@@ -0,0 +1,101 @@
|
|
1
|
+
/*
|
2
|
+
*
|
3
|
+
* Copyright 2015, Google Inc.
|
4
|
+
* All rights reserved.
|
5
|
+
*
|
6
|
+
* Redistribution and use in source and binary forms, with or without
|
7
|
+
* modification, are permitted provided that the following conditions are
|
8
|
+
* met:
|
9
|
+
*
|
10
|
+
* * Redistributions of source code must retain the above copyright
|
11
|
+
* notice, this list of conditions and the following disclaimer.
|
12
|
+
* * Redistributions in binary form must reproduce the above
|
13
|
+
* copyright notice, this list of conditions and the following disclaimer
|
14
|
+
* in the documentation and/or other materials provided with the
|
15
|
+
* distribution.
|
16
|
+
* * Neither the name of Google Inc. nor the names of its
|
17
|
+
* contributors may be used to endorse or promote products derived from
|
18
|
+
* this software without specific prior written permission.
|
19
|
+
*
|
20
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
21
|
+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
22
|
+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
23
|
+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
24
|
+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
25
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
26
|
+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
27
|
+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
28
|
+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
29
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
30
|
+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
*
|
32
|
+
*/
|
33
|
+
|
34
|
+
#ifndef GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_DATA_H
|
35
|
+
#define GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_DATA_H
|
36
|
+
|
37
|
+
/* Parser for GRPC streams embedded in DATA frames */
|
38
|
+
|
39
|
+
#include "src/core/iomgr/exec_ctx.h"
|
40
|
+
#include <grpc/support/slice.h>
|
41
|
+
#include <grpc/support/slice_buffer.h>
|
42
|
+
#include "src/core/transport/byte_stream.h"
|
43
|
+
#include "src/core/transport/chttp2/frame.h"
|
44
|
+
|
45
|
+
typedef enum {
|
46
|
+
GRPC_CHTTP2_DATA_FH_0,
|
47
|
+
GRPC_CHTTP2_DATA_FH_1,
|
48
|
+
GRPC_CHTTP2_DATA_FH_2,
|
49
|
+
GRPC_CHTTP2_DATA_FH_3,
|
50
|
+
GRPC_CHTTP2_DATA_FH_4,
|
51
|
+
GRPC_CHTTP2_DATA_FRAME
|
52
|
+
} grpc_chttp2_stream_state;
|
53
|
+
|
54
|
+
typedef struct grpc_chttp2_incoming_byte_stream
|
55
|
+
grpc_chttp2_incoming_byte_stream;
|
56
|
+
|
57
|
+
typedef struct grpc_chttp2_incoming_frame_queue {
|
58
|
+
grpc_chttp2_incoming_byte_stream *head;
|
59
|
+
grpc_chttp2_incoming_byte_stream *tail;
|
60
|
+
} grpc_chttp2_incoming_frame_queue;
|
61
|
+
|
62
|
+
typedef struct {
|
63
|
+
grpc_chttp2_stream_state state;
|
64
|
+
gpr_uint8 is_last_frame;
|
65
|
+
gpr_uint8 frame_type;
|
66
|
+
gpr_uint32 frame_size;
|
67
|
+
|
68
|
+
int is_frame_compressed;
|
69
|
+
grpc_chttp2_incoming_frame_queue incoming_frames;
|
70
|
+
grpc_chttp2_incoming_byte_stream *parsing_frame;
|
71
|
+
} grpc_chttp2_data_parser;
|
72
|
+
|
73
|
+
void grpc_chttp2_incoming_frame_queue_merge(
|
74
|
+
grpc_chttp2_incoming_frame_queue *head_dst,
|
75
|
+
grpc_chttp2_incoming_frame_queue *tail_src);
|
76
|
+
grpc_byte_stream *grpc_chttp2_incoming_frame_queue_pop(
|
77
|
+
grpc_chttp2_incoming_frame_queue *q);
|
78
|
+
|
79
|
+
/* initialize per-stream state for data frame parsing */
|
80
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_init(
|
81
|
+
grpc_chttp2_data_parser *parser);
|
82
|
+
|
83
|
+
void grpc_chttp2_data_parser_destroy(grpc_exec_ctx *exec_ctx,
|
84
|
+
grpc_chttp2_data_parser *parser);
|
85
|
+
|
86
|
+
/* start processing a new data frame */
|
87
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_begin_frame(
|
88
|
+
grpc_chttp2_data_parser *parser, gpr_uint8 flags);
|
89
|
+
|
90
|
+
/* handle a slice of a data frame - is_last indicates the last slice of a
|
91
|
+
frame */
|
92
|
+
grpc_chttp2_parse_error grpc_chttp2_data_parser_parse(
|
93
|
+
grpc_exec_ctx *exec_ctx, void *parser,
|
94
|
+
grpc_chttp2_transport_parsing *transport_parsing,
|
95
|
+
grpc_chttp2_stream_parsing *stream_parsing, gpr_slice slice, int is_last);
|
96
|
+
|
97
|
+
void grpc_chttp2_encode_data(gpr_uint32 id, gpr_slice_buffer *inbuf,
|
98
|
+
gpr_uint32 write_bytes, int is_eof,
|
99
|
+
gpr_slice_buffer *outbuf);
|
100
|
+
|
101
|
+
#endif /* GRPC_INTERNAL_CORE_TRANSPORT_CHTTP2_FRAME_DATA_H */
|